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) >>>
父主题: 线性代数函数