2014-11-25 3 views
6

Я знаю, как решить AX = B по методу наименьших квадратов с помощью питона:Как использовать наименьшие квадраты с весовой матрицей в python?

Пример:

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] 

Но что о решении этого же уравнения с матрицей веса не является Идентичность:

A.X = B (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] 

Thanks by adva сть,

+1

Вы просматривали эту ссылку: http://stackoverflow.com/questions/19624997/understanding-scipys-least-square-function-with-irls – xnx

+0

Да; Я попытался: B = numpy.dot (B, W) до решения, но у меня есть сообщение: numpy.linalg.linalg.LinAlgError: 0-мерный массив. Массив должен быть двумерным –

+2

Если вы возьмете точечный продукт двух одномерных массивов, вы получите скаляр. Возможно, вы имеете в виду просто умножить элементы B на W? Лучше использовать здесь массивы numpy, а не списки Python. – xnx

ответ

4

Я нашел другой подход (с использованием 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) 

Те же ценности и те же результаты.

+1

матричный продукт дороже, чем элементный продукт предложения @ xnx – DomTomCat

+1

может быть более дорогостоящим, но это более понятно для чтения. +1 для ясности кода с линейной алгеброй –

5

Я не знаю, как вы определили свои веса, но вы могли бы попробовать это в случае необходимости:

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) 
+1

Спасибо. Я не очень хорошо знаю, и должен понимать, что W [:, np.newaxis] (или W [:, None]) дает диагональную матрицу. То есть массив ([[1], [2], [3], [4], [5]]) означает диагональную матрицу 5x5 с этими значениями на диагонали. –

+1

(Это результат? Aw - массив 5x4, так что это единственное объяснение) –

+1

Извините, меня смутил оператор * (я не использовался для массивов). Это не матричный продукт, а термин термин. –

Смежные вопросы