シュミットの直交化を自分で書く

626 ワード

import numpy as np
A = np.array([[1,1,0],[0,1,1],[1,0,1]],dtype=float)
Q = np.zeros_like(A)
m = shape(Q)[0]
n = shape(Q)[1]
cnt = 0
for a in A.T:
    u = np.copy(a)
    for i in range(0, cnt):
        u -= np.dot(np.dot(Q[:, i].T, a), Q[:, i]) #                
    e = u / np.linalg.norm(u)  #    
    Q[:, cnt] = e
    cnt += 1
print Q
以上は自分で書いたもので、scipyを呼び出すこともできます
from scipy import linalg
A = np.array([[1,1,0],[0,1,1],[1,0,1]])
a = linalg.orth(A)
print array(linalg.orth(A),dtype=float)
print dot(A,A.T)-1
シュミットの直交化の原理はここで言うまでもなく、自分でネット上でいくつかの線形代数の教材を探して見て、自分でやってみると、理解できます.