Я пытаюсь сделать простую линейную функцию регрессии, но по-прежнему сталкиваются с существующей функцииЛинейная регрессия с Python Numpy
numpy.linalg.linalg.LinAlgError: Singular matrix error
(отладочные отпечатками):
def makeLLS(inputData, targetData):
print "In makeLLS:"
print " Shape inputData:",inputData.shape
print " Shape targetData:",targetData.shape
term1 = np.dot(inputData.T, inputData)
term2 = np.dot(inputData.T, targetData)
print " Shape term1:",term1.shape
print " Shape term2:",term2.shape
#print term1
#print term2
result = np.linalg.solve(term1, term2)
return result
Выходной сигнал на консоль с моими тестовыми данными:
In makeLLS:
Shape trainInput1: (773, 10)
Shape trainTargetData: (773, 1)
Shape term1: (10, 10)
Shape term2: (10, 1)
Тогда это ошибки на линии linalg.solve. Это функция линейной регрессии учебника, и я не могу понять, почему она терпит неудачу.
Что такое сингулярная матричная ошибка?
Вы также можете использовать 'np.polyfit (x, y, 1)'. – naught101