QR decomposition: Difference between revisions

m
Line 1,478:
implicit none
integer, parameter :: n = 4
real(8) :: durer(n, n) = reshape(dble([16d0, 5d0, 9d0, 4d0, &
16, 5, 3d09, 10d0, 6d0, 15d04, &
2d03, 11d010, 7d06, 14d015, &
13d0, 8d02, 12d011, 1d0]7, [n14, n])&
13, 8, 12, 1 &
]), [n, n])
real(8) :: q(n, n), r(n, n), qr(n, n), id(n, n), tau(n)
integer, parameter :: lwork = 1024
real(8) :: work(lwork)
integer :: info, i, j
q = durer
call dgeqrf(n, n, q, n, tau, work, lwork, info)
r = 0d0
forall (i = 1:n, j = 1:n, j >= i) r(i, j) = q(i, j)
call dorgqr(n, n, n, q, n, tau, work, lwork, info)
qr = matmul(q, r)
id = matmul(q, transpose(q))
 
call show(4, durer, "A")
call show(4, q, "Q")
Line 1,508 ⟶ 1,510:
integer :: n, i
real(8) :: a(n, n)
 
print *, s
do i = 1, n
print 1, a(i, :)
1 format (*(F12f12.6,:,' '))
end do
end subroutine
175

edits