Eri*_* H. 7 python numpy matrix least-squares
我知道如何使用python通过最小二乘法解决AX = B:
例:
A=[[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,0,0]]
B=[1,1,1,1,1]
X=numpy.linalg.lstsq(A, B)
print X[0]
# [ 5.00000000e-01 5.00000000e-01 -1.66533454e-16 -1.11022302e-16]
Run Code Online (Sandbox Code Playgroud)
但是如果用权重矩阵不是身份来解决这个相同的等式呢:
A.X = B (W)
Run Code Online (Sandbox Code Playgroud)
例:
A=[[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,0,0]]
B=[1,1,1,1,1]
W=[1,2,3,4,5]
Run Code Online (Sandbox Code Playgroud)
谢谢提前,
我不知道你如何定义你的体重,但你可以尝试这个,如果合适的话:
import numpy as np
A=np.array([[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,0,0]])
B = np.array([1,1,1,1,1])
W = np.array([1,2,3,4,5])
Aw = A * np.sqrt(W[:,np.newaxis])
Bw = B * np.sqrt(W)
X = np.linalg.lstsq(Aw, Bw)
Run Code Online (Sandbox Code Playgroud)
我发现了另一种方法(使用W作为对角矩阵和矩阵乘积):
A=[[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,0,0]]
B = [1,1,1,1,1]
W = [1,2,3,4,5]
W = np.sqrt(np.diag(W))
Aw = np.dot(W,A)
Bw = np.dot(B,W)
X = np.linalg.lstsq(Aw, Bw)
Run Code Online (Sandbox Code Playgroud)
相同的值和相同的结果。