版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C语言实现PID算法#includestruct_pidintpv;/*integerthatcontainstheprocessvalue*/intsp;/*integerthatcontainsthesetpoint*/floatintegral;floatpgain;floatigain;floatdgain;intdeadband;intlast_error;struct_pidwarm,*pid;intprocess_point,set_point,dead_band;floatp_gain,i_gain,d_gain,integral_val,new_integ;/*pid_ini
2、tDESCRIPTIONThisfunctioninitializesthepointersinthe_pidstructuretotheprocessvariableandthesetpoint.*pvand*spareintegerpointers.*/voidpid_init(struct_pid*warm,intprocess_point,intset_point)struct_pid*pid;pid=warm;pid-pv=process_point;pid-sp=set_point;/*pid_tuneDESCRIPTIONSetstheproportionalgain(p_gai
3、n),integralgain(i_gain),derivitivegain(d_gain),andthedeadband(dead_band)ofapidcontrolstructure_pid.*/voidpid_tune(struct_pid*pid,floatp_gain,floati_gain,floatd_gain,intdead_band)pid-pgain=p_gain;pid-igain=i_gain;pid-dgain=d_gain;pid-deadband=dead_band;pid-integral=integral_val;pid-last_error=0;/*pid
4、_setintegDESCRIPTIONSetanewvaluefortheintegraltermofthepidequation.Thisisusefulforsettingtheinitialoutputofthepidcontrolleratstartup.*/voidpid_setinteg(struct_pid*pid,floatnew_integ)pid-integral=new_integ;pid-last_error=0;/*pid_bumplessDESCRIPTIONBumplesstransferalgorithim.Whensuddenlychangingsetpoi
5、nts,orwhenrestartingthePIDequationafteranextendedpause,thederivativeoftheequationcancauseabumpinthecontrolleroutput.Thisfunctionwillhelpsmoothoutthatbump.Theprocessvaluein*pvshouldbetheupdatedjustbeforethisfunctionisused.*/voidpid_bumpless(struct_pid*pid)pid-last_error=(pid-sp)-(pid-pv);/*pid_calcDE
6、SCRIPTIONPerformsPIDcalculationsforthe_pidstructure*a.Thisfunctionusesthepositionalformofthepidequation,andincorporatesanintegralwinduppreventionalgorithim.Rectangularintegrationisused,sothisfunctionmustberepeatedonaconsistenttimebasisforaccuratecontrol.RETURNVALUEThenewoutputvalueforthepidloop.USAG
7、E#includecontrol.h*/floatpid_calc(struct_pid*pid)interr;floatpterm,dterm,result,ferror;err=(pid-sp)-(pid-pv);if(abs(err)pid-deadband)ferror=(float)err;/*dointegertofloatconversiononlyonce*/pterm=pid-pgain*ferror;if(pterm100|ptermintegral=0.0;elsepid-integral+=pid-igain*ferror;if(pid-integral100.0)pi
8、d-integral=100.0;elseif(pid-integralintegral=0.0;dterm=(float)(err-pid-last_error)*pid-dgain;result=pterm+pid-integral+dterm;elseresult=pid-integral;pid-last_error=err;return(result);voidmain(void)floatdisplay_value;intcount=0;pid=&warm;/printf(EnterthevaluesofProcesspoint,Setpoint,Pgain,Igain,Dgain
9、n);/scanf(%d%d%f%f%f,&process_point,&set_point,&p_gain,&i_gain,&d_gain);process_point=30;set_point=40;p_gain=(float)(5.2);i_gain=(float)(0.77);d_gain=(float)(0.18);dead_band=2;integral_val=(float)(0.01);printf(ThevaluesofProcesspoint,Setpoint,Pgain,Igain,Dgainn);printf(%6d%6d%4f%4f%4fn,process_point
10、,set_point,p_gain,i_gain,d_gain);printf(EnterthevaluesofProcesspointn);while(count4095000)PID_UK=4095000;elseif(PID_UKSetPoint-NextPoint;/偏差pp-SumError+=Error;/积分dError=pp-LastError-pp-PrevError;/当前微分pp-PrevError=pp-LastError;pp-LastError=Error;return(pp-Proportion*Error/比例项+pp-Integral*pp-SumError/
11、积分项+pp-Derivative*dError/微分项);/*=InitializePIDStructure=*/voidPIDInit(PID*pp)memset(pp,0,sizeof(PID);/*=MainProgram=*doublesensor(void)/DummySensorFunctionreturn100.0;voidactuator(doublerDelta)/DummyActuatorFunctionvoidmain(void)PIDsPID;/PIDControlStructuredoublerOut;/PIDResponse(Output)doublerIn;/PIDFeedback(Input)PIDInit(&sPID);/InitializeStructuresPID.Proportion=0.5;/SetPIDCoefficientssPID.Integral=0.5;sPID.De
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 14类外贸常用单证模板记得收藏(2024版)
- 2024合法的公司借款合同范本
- 2024年度企业间服务购买与提供合同3篇
- 2024年度云计算服务托管与运维合同
- 2024年广告位租赁协议
- 2024年度品牌宣传服务协议样式版B版
- 2024年个性化托管服务安全管理协议版B版
- 2024专业项目承包协议模板集版B版
- 2024年工程技术服务经典合同范本版B版
- 2024年定制高强度纸箱订购协议版B版
- GMP认证药厂固体车间及中药材提取车间平面图
- 海尔售后服务承诺
- 2020-2021学年高二物理粤教版选修3-1课时分层作业17 研究洛伦兹力 Word版含解析
- 国华太仓电厂600MW超临界直流炉控制策略
- 网络安全教育ppt课件
- 阀门基础知识_
- 退房通知书模板
- 生物质能发电厂原料收集存在的问题及其对策
- 海螺牌水泥质量检验报告天报告加章
- 设备保温管理制度
- 四年级奥数-追及问题
评论
0/150
提交评论