版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上基于51单片机的直流电机控制一、 试验器件选择1、 控制芯片的作用主要是与L289相连接驱动直流电机,以及与八位数码管相连显示。(1)、AT89C51是一种带4K自己FLASH存储器的低压、高性能CMOS8为微处理器。单片机的可擦除只读存储器可以反复擦除1000次。该器件采用ATMEL高密度非易失真存储制造技术制造,与工业标准的MCS-51指令集和输出关键相兼容。由于将多功能8位CPU和闪存组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器。AT89C51单片机为很多嵌入式控制系统提供了一种灵活性奥高且廉价的方案。(2)、AT89C51引脚图如下:2、电机
2、驱动芯片(1)、电机驱动芯片选择L298。其主要功能是作为单片机与直流电机中间的过度链接,单片机输出的信号通过L298加载到直流电机上驱动直流电机运行。其引脚图如下:(2)、主要工作原理:1、15脚分别是两个H桥的电流反馈脚,不用时可以直接接地;2、3为一对输出端口,13、14为一对输出端口;4为驱动电压输入,最小值必须比输入的低电平高2;5、7一对输入端口,10、12一对输入端口,TTL电平兼容6、11使能端,低电平禁止输出;8、9分别为接地和逻辑电源3、直流电机。在protues中选择motor-encoder直流电机,引脚图如下:上方左右的两个引脚在点击运转时输出频率相同的方波,但是在相
3、位上相差90 ,而且在正转和反转是相反,因此可以根据这两个引脚的输出情况判断点击的转向。上方中间的引脚每当电机转一圈就输出一个正脉冲,可以据此册数点击的转速。左右两个引脚是电机的电压输入端。4、 74HC74。当D触发器的D和CLK输入端分别接电机上方的左右两个输出端口时可以根据D触发器的输出情况判断点击的转速。5、 八位数码管。用以显示。二、系统硬件设计连接1、 系统的器件连接图如下:2、单片机与数码管通过P0口和P2口相连,其中P2口选择点亮哪一个数码管,P0口则控制被点亮的数码管显示的数据。3、单片通过P10和P11和L298的第一对输入端IN1和IN2相连,然后又L298的第一对输出端
4、OUT1和OUT2与直流电机相连,已达到控制直流电机的目的。4、从P14到P17分别接一个Button按钮来实现PID控制,P36和P37分别接Button按钮实现对电机的加速与减速控制。5、双刀双掷开关SW1课实现点击的正转与反转,单刀双掷开关SW2可实现点击的开启与停止。三、 系统程序设计及功能实现1、 程序流程图:开始输入一个值,点击Enter按钮,通过PID算法,改变PWM波输出让电机运行循环通过按钮加减改变当前值,Enter键确定判断新的输入值与当前值的差值,将差值加到原值上,通过PID算法改变PWM波输出控制电机运行2、 各部分实现程序:专心-专注-专业(1)、普通延时:#incl
5、ude <delay.h>void delayms(unsigned char x) unsigned char i ; while(x-) for(i = 0 ; i < 120 ; i+) ;(2)、数码管显示:#include <reg51.h>#include <display.h>#include <delay.h>void display_lilun(double num) char code table = 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, /07对应数码 0x7f
6、, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71; /8F对应数码long int n=num; P0 = 0; P2 =0x7f; P0 = tablen % 1000/100; delayms(2);/百位加小数点 P0 = 0; P2 =0xbf; P0 = tablen % 100 / 10; delayms(2);/十位 P0 = 0; P2 =0xdf; P0 = tablen % 10; delayms(2);/个位 P0 = 0; /关闭显示器void display(double num,int dir) char code table =
7、 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, /07对应数码 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71; /8F对应数码long int n=num*10; P0 = 0; P2 =0xf7; P0 = tablen / 1000; delayms(2); /百位加小数点 P0 = 0; P2 =0xfb; P0 = tablen % 1000/100; delayms(2); /百位加小数点 P0 = 0; P2 =0xfd; P0 = tablen % 100 / 10+128; del
8、ayms(2);/十位 P0 = 0; P2 =0xfe; P0 = tablen % 10; delayms(2);/个位 P0 = 0; /关闭显示器if(dir=1)P0=0;P2=0xef;P0=0x40;delayms(2);(3)、按键扫描:#include <reg51.h>sbit jiashi=P13; /对各个按钮进行位定义sbit jianshi=P14;sbit jia=P15;sbit jian=P16;sbit enter=P17;extern int num_key5; /定义全局变量void keyscan()if(jiashi=0)while(!j
9、iashi);num_key0+;if(jianshi=0)while(!jianshi);num_key1+;if(jia=0)while(!jia);num_key2+;if(jian=0)while(!jian);num_key3+;if(enter=0)while(!enter);num_key4+;(4)、PWM波输出:#include <reg51.h>#include <delay.h>#include <PWM.h>extern int PWM ; /赋初值extern int start,sudu_lilun;extern double d
10、is_count;sbit S2 =P36 ; /PWM值减少键sbit S3 =P37 ; /PWM值增加键void PWM_duty() if(start>=1) PWM=sudu_lilun;doif(PWM!=0xff) PWM+ ;delayms(10); while(S3=0);doif(PWM>=0x02)PWM- ;delayms(10); while(S2=0);(5)、中断服务程序:#include <reg51.h>extern int PWM,count,count1,dir,count20ms_flag;extern double dis_co
11、unt;sbit PWM_OUT1=P11;sbit PWM_OUT2=P10;void timer0() interrupt 1 long int i; TR1=0 ;dir=0; TL0=0x00;TH0=0xd8; /10msTL0=0xf0; TH1=PWM ; TR1=1 ;PWM_OUT1=0 ; /启动输出PWM_OUT2=0;if(i+=492)count20ms_flag=1;i=0;dis_count=(double)(count+count1)/2;count=0;count1=0;void timer1() interrupt 3 TR1=0 ;if(dir=0)PWM
12、_OUT1=1 ; /结束输出PWM_OUT2=0;elsePWM_OUT1=0;PWM_OUT2=1;void EIRQ0(void) interrupt 0EX0=0;count+;EX0=1;void EIRQ1(void) interrupt 2EX1=0;count1+;EX1=1;(6)、PID控制:#include <PID.h>#include <PWM.h>int P,I,D;extern int sudu_lilun;typedef struct PID /定义结构体int SetPoint; /目标long SumError; /误差double
13、Proportion; /比例系数double Integral; /积分系数 double Derivative; /微分系数int LastError; int PrevError; PID;static PID sPID;static PID *sptr = &sPID;void IncPIDInit()sptr->SumError = 0;sptr->LastError =0; /Error-1sptr->PrevError =0; /Error-2sptr->Proportion =0.5; /比例系数sptr->Integral =0.3; /
14、积分系数sptr->Derivative = 0.3; /微分系数sptr->SetPoint =sudu_lilun;int IncPIDCalc(int NextPoint)register int iError, iIncpid; /当前的误差值iError = sptr->SetPoint - NextPoint; /计算增加量iIncpid = sptr->Proportion * iError /Ek项- sptr->Integral * sptr->LastError /Ek1项+ sptr->Derivative * sptr->
15、PrevError; /Ek2项/存储当前误差以便后面计算sptr->PrevError = sptr->LastError;sptr->LastError = iError;/返回增量值return(iIncpid);(7)、main函数:#include <reg51.h>#include <intrins.h>#include <key.h>#include <delay.h>#include <display.h>#include <PWM.h>#include <PID.h>sbit
16、 P10=P12; /确定电机转向int num_key5;int PWM,PWM1,count,count1,dir,sudu_lilun,start,count20ms_flag;double dis_count;int PWM_PID;void init();void main() init(); while(1) PWM_duty();if(P10=1)dir=0;elsedir=1; keyscan();sudu_lilun=num_key0*10-num_key1*10+num_key2-num_key3;display_lilun(sudu_lilun);if(num_key4=1)start=1;display(dis_count,dir
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业财务分析与决策支持实施手册(标准版)
- 自行车产业政策解读
- 客户服务人员服务规范指南(标准版)
- 企业内部信息安全宣传资料手册
- 建筑节能技术与施工规范
- 电力系统调度与运行管理实施指南
- 旅游酒店餐饮服务与管理手册(标准版)
- 金融理财咨询服务流程与规范
- 电力营销服务规范与客户满意度提升
- 食品安全卫生操作手册
- 2026年山东中医药高等专科学校高职单招职业适应性考试模拟试题含答案解析
- (正式版)DB51∕T 3322-2025 《水利工程建设质量检测管理规范》
- 2025昆士兰临床指南:产程延长和难产(v1)解读课件
- 《制氢现场氢安全管理规范》
- 2025版压力性损伤预防和治疗的新指南解读
- 2025年智能家居安防摄像头市场调研报告市场规模与消费者需求可行性研究报告
- 消控证考试题库及答案中级
- 河南职业技术学院单招职业技能测试参考试题库(含答案)
- 部编版八年级语文下册文言文汇编(原文注释)
- 体内植入物在电外科的使用
- 2025护理实践指南术中低体温预防与护理
评论
0/150
提交评论