Sub Ex_Dgelqf()
Const M = 3, N = 3, K = N
Dim A(M - 1, N - 1) As Double, Tau(N - 1) As Double, Info As Long
A(0, 0) = 0.2: A(0, 1) = -0.11: A(0, 2) = -0.93
A(1, 0) = -0.32: A(1, 1) = 0.81: A(1, 2) = 0.37
A(2, 0) = -0.8: A(2, 1) = -0.92: A(2, 2) = -0.29
'-- Compute LQ factorization of A
Call
Dgelqf(M, N, A(), Tau(), Info)
Debug.Print "L ="
Debug.Print A(0, 0)
Debug.Print A(1, 0), A(1, 1)
Debug.Print A(2, 0), A(2, 1), A(2, 2)
Debug.Print "Info =", Info
'-- Compute Q
Call
Dorglq(M, N, K, A(), Tau(), Info)
Debug.Print "Q ="
Debug.Print A(0, 0), A(0, 1), A(0, 2)
Debug.Print A(1, 0), A(1, 1), A(1, 2)
Debug.Print A(2, 0), A(2, 1), A(2, 2)
Debug.Print "Info =", Info
End Sub
Sub Dgelqf(M As Long, N As Long, A() As Double, Tau() As Double, Info As Long)
LQ factorization
Sub Dorglq(M As Long, N As Long, K As Long, A() As Double, Tau() As Double, Info As Long)
Generates matrix Q of LQ factorization