IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 基于stm32的最小二乘法N次多项式拟合函数 -> 正文阅读

[数据结构与算法]基于stm32的最小二乘法N次多项式拟合函数

最小二乘法实现N次多项式函数拟合

最近都在全力准备电赛,无奈由于郑州的疫情,整个河南赛区和其他一起赛区推迟了全国电子设计大赛,于是,闲暇之中和大家分享一下,使用最小二乘法来实现N次多项式的拟合函数。

一、最小二乘法的思想

最小二乘法主要用于函数拟合或函数极值,思想主要是通过将预测值与理论值的差值的平方和达到最小。

二、代码分析

1、变量定义

extern float cun[100];//外部用来存取数据的数组,这里限制到了100个数据,理论上可以无限多组数据
extern u8 number;//存取数据的个数	
float	matrix[50][50];//正规方程式数组,这里限制在了50 
extern float a[50];//外部变量 用于存储曲线内部计算多项式系数

2、函数功能分析

void ercheng(int degree)//degree为多项式阶数
{	
	u32 		x[2*degree];//x数组变量
	float 	y[degree];//y数组变量
	int 	k;//计数循环变量
	int 	n;//矩阵轮询变量
	int 	c;
	float t=0;//循环增加变量
	float m;//倍数变量
	
//赋值x[]
	for(n=0;n<=(2*degree);n++)
	{
		x[n]=0;
	}//x数组变量清零
	for(n=0;n<=(2*degree);n++)
	{	
		for(k=1;k<=number;k++)
		{
			t=pow(k,n);//k的n次方
			x[n]=t+x[n];
		}	
	}

//赋值y[]
	for(n=0;n<=(degree);n++)
	{
		y[n]=0;
	}//y数组变量清零
	for(n=0;n<=(degree);n++)
	{	
		for(k=1;k<=number;k++)
		{
			t=pow(k,n);//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];
	}	
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-07 21:48:54  更:2021-08-07 21:49:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 19:52:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码