Householder Reflection QR=A
Afficher commentaires plus anciens
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
le 28 Avr 2023
it doesent work
Réponses (1)
Monisha Nalluru
le 18 Sep 2020
0 votes
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 Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!