版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于51单片机的直流电机控制一、 试验器件选择1、 控制芯片的作用主要是与L289相连接驱动直流电机,以及与八位数码管相连显示。(1)、AT89C51是一种带4K自己FLASH存储器的低压、高性能CMOS8为微处理器。单片机的可擦除只读存储器可以反复擦除1000次。该器件采用ATMEL高密度非易失真存储制造技术制造,与工业标准的MCS-51指令集和输出关键相兼容。由于将多功能8位CPU和闪存组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器。AT89C51单片机为很多嵌入式控制系统提供了一种灵活性奥高且廉价的方案。(2)、AT89C51引脚图如下:2、电机驱动芯片(1)、电机驱动芯
2、片选择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直流电机,引脚图如下:上方左右的两个引脚在点击运转时输出频率相同的方波,但是在相位上相差90 ,而且在正转
3、和反转是相反,因此可以根据这两个引脚的输出情况判断点击的转向。上方中间的引脚每当电机转一圈就输出一个正脉冲,可以据此册数点击的转速。左右两个引脚是电机的电压输入端。4、 74HC74。当D触发器的D和CLK输入端分别接电机上方的左右两个输出端口时可以根据D触发器的输出情况判断点击的转速。5、 八位数码管。用以显示。二、系统硬件设计连接1、 系统的器件连接图如下:2、单片机与数码管通过P0口和P2口相连,其中P2口选择点亮哪一个数码管,P0口则控制被点亮的数码管显示的数据。3、单片通过P10和P11和L298的第一对输入端IN1和IN2相连,然后又L298的第一对输出端OUT1和OUT2与直流电
4、机相连,已达到控制直流电机的目的。4、从P14到P17分别接一个Button按钮来实现PID控制,P36和P37分别接Button按钮实现对电机的加速与减速控制。5、双刀双掷开关SW1课实现点击的正转与反转,单刀双掷开关SW2可实现点击的开启与停止。三、 系统程序设计及功能实现1、 程序流程图:开始输入一个值,点击Enter按钮,通过PID算法,改变PWM波输出让电机运行循环通过按钮加减改变当前值,Enter键确定判断新的输入值与当前值的差值,将差值加到原值上,通过PID算法改变PWM波输出控制电机运行2、 各部分实现程序:(1)、普通延时:#include <delay.h>vo
5、id 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, 0x6f, 0x77, 0x7c, 0
6、x39, 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 = 0x3f, 0x06, 0x5b, 0x
7、4f, 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; delayms(2);/十位 P0 = 0; P
8、2 =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(!jiashi);num_key0+;if(j
9、ianshi=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 dis_count;sbit S2 =P36
10、 ; /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_count;sbit PWM_OUT1=P11
11、;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_OUT1=1 ; /结束输出PWM_OU
12、T2=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 Proportion; /比例系数doub
13、le 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; /积分系数sptr->Derivati
14、ve = 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->PrevError; /Ek2项/存储当前
15、误差以便后面计算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 P10=P12; /确定电机转向int
16、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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年非全日制用工协议模板解析
- 2024网络通信设备买卖协议指导
- 2024年新款高强度围墙护栏销售协议
- 2024银行股权质押借款协议模板
- 2024年化围栏施工协议范例
- 2024年门面房使用权转租协议样式
- DB11∕T 1708-2019 施工工地扬尘视频监控和数据传输技术规范
- 2024年度酒店早餐外判协议示例
- 2024城区鼠害防治协议范本
- 2024年企业员工劳动协议条款细则
- 嵌入式课程设计实训
- 第三单元综合卷-2024-2025学年统编版语文五年级上册
- 土方开挖和回填专项施工方案
- 中型直升机交易协议(2024年)版
- 专题08 向量的运算(上海中考特色题型)30题(解析版)
- 2024市场营销知识竞赛题库(试题及答案169题)
- 四级劳动关系协调员题库+答案
- 2024年银行外汇业务知识理论考试题库及答案(含各题型)
- 2022年高考数学试卷(上海)(春考)(解析卷)
- 古代小说戏曲专题-形考任务4-国开-参考资料
- 2-1、职业生涯规划概述
评论
0/150
提交评论