最小二乘法实现N次多项式函数拟合
最近都在全力准备电赛,无奈由于郑州的疫情,整个河南赛区和其他一起赛区推迟了全国电子设计大赛,于是,闲暇之中和大家分享一下,使用最小二乘法来实现N次多项式的拟合函数。
一、最小二乘法的思想
最小二乘法主要用于函数拟合或函数极值,思想主要是通过将预测值与理论值的差值的平方和达到最小。
二、代码分析
1、变量定义
extern float cun[100];
extern u8 number;
float matrix[50][50];
extern float a[50];
2、函数功能分析
void ercheng(int degree)
{
u32 x[2*degree];
float y[degree];
int k;
int n;
int c;
float t=0;
float m;
for(n=0;n<=(2*degree);n++)
{
x[n]=0;
}
for(n=0;n<=(2*degree);n++)
{
for(k=1;k<=number;k++)
{
t=pow(k,n);
x[n]=t+x[n];
}
}
for(n=0;n<=(degree);n++)
{
y[n]=0;
}
for(n=0;n<=(degree);n++)
{
for(k=1;k<=number;k++)
{
t=pow(k,n);
y[n]=t*cun[k-1]+y[n];
}
}
for(n=0;n<=degree;n++)
{
matrix[n][degree+1]=y[n];
for(k=0;k<=degree;k++)
{
matrix[n][k]=x[n+k];
}
}
for(n=0;n<degree;n++)
{
for(c=n+1;c<=degree;c++)
{
m=-matrix[c][n]/matrix[n][n];
for(k=n;k<=(degree+1);k++)
{
matrix[c][k]=matrix[c][k]+m*matrix[n][k];
}
}
}
a[degree]=matrix[degree][degree+1]/matrix[degree][degree];
for(n=(degree-1);n>=0;n--)
{
m=0;
for(k=(n+1);k<(degree+1);k++)
{
m=a[k]*matrix[n][k]+m;
}
a[n]=(matrix[n][degree+1]-m)/matrix[n][n];
}
}
|