中文
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助

linalg.lstsq

功能描述

返回线性矩阵方程的最小二乘解。

该方程可能未确定、良好或过度确定(即a的线性独立行数可以小于、等于或大于其线性独立列数)。如果a是平方且为全秩,则x(但对于舍入误差)是等式的“精确”解。否则,x最小化欧几里得2范数。如果有多个最小化解,则返回具有最小2范数的解。

必选输入参数

参数名

类型

说明

a

(M, N) array_like

系数矩阵。

b

{(M,), (M, K)} array_like

纵轴或因变量值。如果b是二维的,则为b的每个K列计算最小二乘解。

可选输入参数

参数名

类型

默认值

说明

rcond

float

None

a小奇异值的截止比。为了确定秩的目的,如果奇异值小于rcond乘以a的最大奇异值,则将其视为零。

返回数据

名称

类型

说明

x

{(N,),(N,K)} ndarray

最小二乘解。如果b是二维的,则解在x的K列中。

residuals

{(1,), (K,), (0,)} ndarray

平方残差之和:b中每列的平方欧几里得2范数-a @ x。如果a的秩是<N或M <= N,这是一个空数组。如果b是一维的,这是一个(1,)形状数组。否则形状是(K,)。

rank

int

矩阵a的秩。

s

(min(M, N),) ndarray

a的奇异值。

示例

>>> import numpy as np
>>> # y = mx + c
>>> x = np.array([0,1,2,3])
>>> y = np.array([-1,0.2,0.9,2.1])
>>> 
>>> # 令 y = Ap, 其中 A = [[x1]], p = [[m], [c]]
>>> A = np.vstack([x, np.ones(len(x))]).T
>>> A
array([[0., 1.],
       [1., 1.],
       [2., 1.],
       [3., 1.]])
>>> 
>>> m, c = np.linalg.lstsq(A, y, rcond=None)[0]
>>> m, c
(1.0000000000000002, -0.9499999999999996)
>>>