PID控制步进电机转速仿真及c程序
更新时间:2024-01-18 07:21:01 阅读量: 教育文库 文档下载
PID控制步进电机转速仿真及c程序
#include
sfr T2MOD = 0x0c9;
#define uchar unsigned char #define uint unsigned int
sbit Q0 = P2^4; sbit Q1 = P2^5; sbit Q2 = P2^6; sbit Q3 = P2^7;
sbit PWM = P1^7; sbit UP = P1^0; sbit DOWM = P1^1; sbit GORB = P2^3; //换相 sbit ADDSPEED = P1^2; sbit SUBSPEED = P1^3;
uinttuint = 65535;
uinttpwm = 1; //pwm周期为10000us tpwm变量表示pwm高电平时间,也相当于占空比 (仿真时,频率高时,电机反应慢。在实物上要加大频率) uchar t1_flag = 0;
uint pulse = 0; uint t0_flag = 0; uchar t2_flag = 0; bit t2_over = 0; bitJust_Get = 1;
#define ZZ { Q0 = 0;Q1 = 0;Q2 = 1;Q3 = 1;} //正转 #define FZ { Q0 = 1;Q1 = 1;Q2 = 0;Q3 = 0;} //反转 #define STOP { Q0 = 1;Q1 = 0;Q2 = 1;Q3 = 0;} //停止 //禁止出现 Q0 = 0;Q1 = 1;Q2 = 0;Q3 = 1; 不然会烧掉mos管
//************************ PID ************************************* float now = 0,bef = 0,bbef = 0; //本次采样值,上次采样值,上上次采样值 float err_now,err_bef,err_bbef; //当前偏差,上次偏差,上上次偏差 float error_add = 0; //所有偏差之和 float set = 25; //设定值
floatkp = 25; floatki = 25; floatkd = 0;
//*****************************************************************
void delayms(uintms)//延时?个ms {
uchara,b,c; while(ms--) { for(c=1;c>0;c--) for(b=142;b>0;b--) for(a=2;a>0;a--); } }
voidtimer_init() { EA = 1; ET0 = 1; ET1 = 1; ET2 = 1; TMOD = 0x15; //定时器0 计数模式定时器1模式1
T2MOD = 0x01; TH0 = TL0 = 255; TH2 = 0x3C; TL2 = 0xB0; //50MS }
void timer1() interrupt 3 { if(t1_flag == 0) { t1_flag = 1; PWM = 1; TH1 = (tuint - tpwm + 1)/256; TL1 = (tuint - tpwm + 1)%6; } else { t1_flag = 0; PWM = 0; TH1 = (tuint - 10000 + tpwm + 1)/256; TL1 = (tuint - 10000 + tpwm + 1)%6; } }
void timer0() interrupt 1 { TH0 = TL0 = 255; t0_flag++; }
void timer2() interrupt 5 { TF2 = 0; TH2 = 0x3C; TL2 = 0xB0; //50MS t2_flag++; if(t2_flag == 2) { TR0 = 0; TR2 = 0; t2_flag = 0;
t2_over = 1; //表示100ms时间到 } }
voidGetPulse() { t0_flag = 0; t2_flag = 0; TH0 = TL0 = 255; TH2 = 0x3C; TL2 = 0xB0; //50MS TR0 = 1; TR2 = 1; }
int PID() //增量式PID { int change; err_now = set - now; err_bef = set - bef; err_bbef = set - bbef; change = kp*(err_now - err_bef) + ki*err_now + kd*(err_now - 2*err_bef + err_bbef); /* if(set >= now) { if(set - now > 1) change = kp*(err_now - err_bef) + ki*err_now + kd*(err_now - 2*err_bef + err_bbef); else change = 0.2*kp*(err_now - err_bef) + 0.5*ki*err_now + kd*(err_now - 2*err_bef + err_bbef); } else if(now > set) { if(now - set > 1) change = kp*(err_now - err_bef) + ki*err_now + kd*(err_now - 2*err_bef + err_bbef); else change = 0.2*kp*(err_now - err_bef) + 0.5*ki*err_now + kd*(err_now - 2*err_bef + err_bbef);
*/ }
}
//change = (kp + ki + kd)*(set - now) + (-kp - 2*kd)*(set - bef) + kd*(set - bbef); //change = kp*(set - now) + ki*(set - bef) + kd*(set - bbef); if(change > 0) { printchar(1,10,'+'); printuint(1,11,4,change); }
else if(change < 0) { printchar(1,10,'-'); printuint(1,11,4,-change); }
else if(change == 0) { printchar(1,10,' '); printword(1,11,\ \}
return(change);
int PID2() //位置式PID { intnum = 0; staticnum_bef = 0; err_now = set - now; err_bef = set - bef; error_add = error_add + err_now; //误差累加。一旦误差为0则error_add的值不变,PID输出值不变 num = kp*err_now + ki*error_add + kd*(err_now - err_bef); /* if(set - now >= 0) {
if(set - now > 1) num = kp*err_now + ki*error_add + kd*(err_now - err_bef); else num = 0.1*kp*err_now + ki*error_add + kd*(err_now - err_bef); } else { if(now - set > 1) num = kp*err_now + ki*error_add + kd*(err_now - err_bef); else num = 0.1*kp*err_now + ki*error_add + kd*(err_now - err_bef); } */ if(num>num_bef) { printchar(1,10,'+'); printuint(1,11,4,num - num_bef); } else if(num void main() { lcd_init(); timer_init(); TH1 = TL1 = 255; printword(0,0,\ //比例系数 printword(0,5,\ //设定值 printword(1,0,\ //当前占空比 printword(0,10,\ //当前电机反馈的每秒脉冲数 while(1) { if(GORB == 1) { ZZ; } else { FZ; } if(ADDSPEED == 0) set++; if(SUBSPEED == 0) set--; if(Just_Get == 1) { Just_Get = 0; GetPulse(); } else if(t2_over == 1) { t2_over = 0; Just_Get = 1; pulse = t0_flag; bbef = bef; bef = now; now = t0_flag; if(set != 0) { TR1 = 1; } else { TR1 = 0; PWM = 0; } // tpwm = tpwm + PID(); tpwm = PID2(); } //增量式PID //位置式PID } } if(UP == 0) kp = kp + 1; if(DOWM == 0) kp = kp - 1; printuint(0,2,3,kp); printuint(0,7,3,set); printuint(1,5,4,tpwm); printuint(0,13,5,pulse);
正在阅读:
PID控制步进电机转速仿真及c程序01-18
小学生信息素养培养探微04-03
机电总承包合同范本03-24
山东省2015年高水平运动员测试合格名单07-04
WCDMA室内分布建设规划原则V1.001-20
东江湖景区导游词03-13
9种网络安全末日大灾难06-12
初中体育优秀教案 - 图文05-23
小火箭冲上了云霄作文500字06-27
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 步进电机
- 转速
- 仿真
- 控制
- 程序
- PID
- 杭州拱墅区2009五年级上册语文试卷
- 宪法案例分析
- 汉字文化 - -拆字文化
- 计算机控制实验一AD与DA转换 - 图文
- 《应用写作》模拟题答案借鉴
- 财务会计案例
- 前厅客房服务与管理试题
- 矿山储量动态管理要求163号
- 齿轮箱项目可行性研究报告
- 钻井井控实施细则-2014(修改培训版) - 图文
- 各省编办《公路工程基本建设项目概算预算编制办法》
- 北京市人民政府办公厅印发关于进一步加强城管综合行政执法工作意见的通知
- 2010年十二五人才发展规划(舟山20101026)(2)
- 信号与线性系统分析试题及答案(10套)
- Oracle - 11GR2 - RAC - to - RAC - DATAGUARD - 配置方案
- 河南省中原名校豫南九校2018届高三10月高考预测联考金卷试题(word附答案解析版)
- 工厂灭火和应急疏散演习方案
- 公共关系学作业1、2答案
- 乙二醇螺杆制冷机组
- 一些天线基本知识