0

我以前在这方面的主题。

Octave中求解算法多项式回归,最小二乘法的问题

我决定不改变主要问题,而是为每个问题创建一个新问题。

这一次,问题如下。我在多项式回归中使用最小二乘法。

将该函数相对于参数 b 的向量微分并将导数设为零,我们得到方程组(以矩阵形式)。这个公式。

(X^{T}X)b=X^{T}y。

也就是说,如果我想从这里表达b,我需要做我所做的。

b=X^{T}y/(X^{T}X)=> b=X'*y1/(X'*X)

代码:

#Generating random values ​​of experimental data
x=0:0.1:5;
y=3*x+2;
y1=y+randn(size(y));
k=5;#Polynomial degree
X=[x' ones(length(x),1)];
b=X'*y1/(X'*X); Error: operator *: nonconformant arguments (op1 is 2x51, op2 is 1x51)\

是的,数组的尺寸Xy1不重合。随附的屏幕截图将显示所有内容。在此屏幕截图中,变量 X、y1 和 X'(转置)。

在此处输入图像描述

然后我决定从数组中选择 1 列X并将其乘以y1.

在此处输入图像描述

如果您查看屏幕截图,您会看到现在转置X'的尺寸与尺寸相匹配y1。也就是说,应该没有错误,但它仍然存在。

4

1 回答 1

2

你数学错了。在进行矩阵运算时,您不能只是随机划分您想要的位置。

最小二乘解是

b=(X'*X)^-1 * X' * y

另外你的定义y是错误的,或者你的尺码不合适。

x=0:0.1:5;
y=(3*x+2)'; %transpose!
y1=y+randn(size(y));
X=[x' ones(length(x),1)];

矩阵的逆是你永远不应该用数字计算的东西。幸运的是,有一种称为 Moore-Penrose 伪逆的东西,它确保在使用时,您将获得原始问题的最小二乘解。所以让我们使用它。

b=pinv(X'*X)*X'*y;
b_with_noise=pinv(X'*X)*X'*y1;

请注意,以下对于数值精度基本上为零,这意味着它是正确的。

sum(X*b-y)

ans =

  -5.8176e-14

现在,在 MATLAB/octave 中,您可以更轻松地执行以下操作:

b=X\y;
b_with_noise=X\y1;

MATLAB 将找到计算最小二乘解的最佳算法。mldivide有更多信息(octave 文档有点缺乏,但应该以相同的方式工作)。

于 2021-05-06T11:55:23.553 回答