Effacer les filtres
Effacer les filtres

Householder Reflection QR=A

11 vues (au cours des 30 derniers jours)
Ismail Güclü
Ismail Güclü le 26 Août 2020
Commenté : VIERI le 28 Avr 2023
function [Q,R] = househ(A)
%QR-Zerlegung mit Householder
[m,n]=size(A);
Q = eye(m);
D = eye(m);
p = min(m-1,n);
for k=1:p
%untermatrix erstellen / define sub-matrix
x = A(:,k);
if k == 1
x = A(:,k);
elseif k <= p
for i = 1:(k-1)
x(i) = 0;
end
else
continue
end
%Formeln aus dem Buch / equation of the book
a = -sign(A(k,k))*norm(x);
v = x - a*D(:,k);
H = D-2*(v*v')/(v'*v);
% ---------------------------------
if k == 1
Q=H;
else
Q = Q*H;
end
A=H*A;
end
A(find(A==-0))=0; % unnecessary
R=A;
Q=Q';
end
Here u can see my Householder transformation. The Code under the hyphens is wrong but I don´t know why ... can someone help me.
  1 commentaire
VIERI
VIERI le 28 Avr 2023
it doesent work

Connectez-vous pour commenter.

Réponses (1)

Monisha Nalluru
Monisha Nalluru le 18 Sep 2020
Refer to this blog post which explains on Household Refelection and Household QR factorization with sample code for understanding.

Catégories

En savoir plus sur MATLAB dans Help Center et File Exchange

Produits


Version

R2020a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by