シュミットの直交化を自分で書く
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
シュミットの直交化の原理はここで言うまでもなく、自分でネット上でいくつかの線形代数の教材を探して見て、自分でやってみると、理解できます.