下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
这段代码实现的功能:输入量可以测量获得到,而且输入量是连续变化的,并且变化比较快,现在要求输出量始终跟随输入量的大小。首先网上找到PID算法的原理跟简介,然后套用公式编写下面代码(VS2010软件、C#语言的控制台应用程序)。为了验证PID算法控制输出量的跟随性,鄙人产生50个(-5,5)的随机数作为输入量,运行输出输入量的50个值,输出50个PID算法计算出的50个输出值,并计算输出误差值,最后输出PID算法总共用了/多少ms计算得到结果。下面代码直接复制粘贴到VS软件的应用控制台里运行即可实现。若有问题可联系我cbscb@usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.IO;namespacekeshana{class_pid〃采用的是增量PID算法类的定义{publicfloatSetSpeed;//定义设定值publicfloatActualSpeed;//定义实际值publicfloaterr;//定义偏差值publicfloaterr_next;//定义上一个偏差值publicfloaterr_last;//定义最上前的偏差值publicfloatKp,Ki,Kd;//定义比例、积分、微分系数///<summary>IIIPID算法初始化///</summary>publicvoidPID_init(){SetSpeed=0;ActualSpeed=0;err=0;err_last=0;err_next=0;}III<summary>III增量PID算法实现的方法III<Isummary>III<paramname="a"><Iparam>IIIvreturnsx/returns>返回值为最终的输出值
publicdoublePID_realize(floata)//这里的参数a是设定值,即你要输出量为//多大{Kp=0.4f;〃比例系数Ki=0.53f;〃积分系数Kd=0.1f;//微分系数SetSpeed=a;err=SetSpeed-ActualSpeed;floatincrementSpeed;incrementSpeed=Kp*(err-err_next+Ki*err+Kd*(err-2*err_next+err_last));//这是增量PID算法的公式ActualSpeed=ActualSpeed+incrementSpeed;err_last=err_next;err_next=err;returnActualSpeed;}}classProgram{staticinti=O,k=O;〃循环用的中间变量constintt=50;//产生随机数的个数staticint[]num=newint[t];〃用来存储产生的随机数staticvoidMain(string[]args){_pidpid=new_pid();floatspeed;//这个变量用来存储逼近设定值的值//intcount=0;pid.PID_init();Randomr=newRandom();for(i=0;i<t;i++){num[i]=r.Next(-5,5);Console.Write(num[i]+"\t");if((i%10)==0){Console.Write("");"****************************上面是产生的随"****************************上面是产生的随Console.WriteLine(机数作为输入量*********************");Console.WriteLine();Console.WriteLine("****************************下面是输出值11A*************************************");DateTimebegintime=DateTime.Now;//用PID算法开始时记下时间do{speed=(float)pid.PID_realize(num[k]);if(System.Math.Abs(pid.err)>0.0001)continue;k++;Console.Write(speed+"\t");if((k%10)==0){Console.Write("");}}while(k<t);TimeSpants=begintime.Subtract(DateTime.Now);//计算PID算法总共花了多少时间//File.WriteAllText(@"C:\a.txt",speed,System.Text.Encoding.UTF8);Console.WriteLine();Console.WriteLine("**************************PID算法总共花的时间********************************");Console.W
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2023六年级数学上册 六 百分数第7课时 用方程解百分数问题 2列方程解决稍复杂的百分数实际问题(2)教学实录 苏教版
- 文明礼仪演讲稿模板集合5篇
- 物理教研组工作计划三篇
- 五年级体育下册 第十七课 游戏课:踏石过河、攻关教学实录
- 第6课 拉拉手交朋友 一年级道德与法治上册(2024版)教学实录
- 第3单元第11课《赶赴火场-“系统时间”检测模块的应用》教学实录2023-2024学年清华大学版(2012)初中信息技术九年级下册
- 邀请活动的邀请函合集七篇
- 圣诞节活动总结范文5篇
- -转正述职报告
- 后勤年终工作总结15篇
- 人教版小学劳动教育五年级上册教学计划-
- 人教部编版语文小学初中高中必背142篇古诗词39
- 食材配送服务方案(技术方案)
- 医疗废物运送人员培训课件
- 可行性研究报告
- 课件:《中华民族共同体概论》第一讲 中华民族共同体基础理论
- 2024-2025学年安徽省合肥市蜀山区数学四年级第一学期期末质量检测试题含解析
- 2024FA财务顾问合同
- 2024年档案知识竞赛考试题库300题(含答案)
- 2024国家开放大学电大专科《兽医基础》期末试题及答案试卷号2776
- 人教部编版六年级语文上册1-8单元习作作文范文
评论
0/150
提交评论