运动控制系统课程设计学号:姓名:日期:2016/6/30M法、T法、M/T法测速单片机程序设计摘要数字测速具有测速精度高、分辨能力强、受器件影响小等优点,被广泛应用于调速高,调速范围大的调速系统和伺服系统。
本设计的数字转速测量是以单片机AT89C52为控制芯片,利用单片机三个定时器的特点,可以使用按键输入来调等参数以及测速方法的选择,以此来增强本设计的适整M法、T法测速法中Z、TC应性,运用转速测量M法、T法、M/T法,通过对光电编码盘输出的脉冲信号测量,获得电动机转速测量,有精度高,范围宽等特点。
测量结果将会显示在LCD1602液晶显示屏上。
关键词:数字测速,单片机,LCD1602,转速,测速法目录第1章绪论 (5)1.1 数字测速方法的原理与应用 (5)1.1.1 M法测速 (5)1.1.2 T法测速 (6)1.1.3 M/T法测速 (6)第2章系统总体设计 (8)第3章硬件设计 (9)3.1 硬件选型 (9)3.1.1 CPU主控模块的选型 (9)3.1.2显示器的选型 (10)3.2 硬件电路设计 (10)3.2.1时钟电路的设计 (10)3.2.2显示电路 (10)3.2.3速度检测电路 (11)3.2.4按键输入电路 (11)3.2.5复位电路 (12)第4章软件设计 (13)4.1 系统流程 (13)4.1.1 主程序流程设计 (13)4.1.2 M法测速程序设计 (14)4.1.3 T法测速程序设计 (15)4.1.4 M/T法测速程序设计 (15)第5章仿真结果 (17)5.1 测速功能仿真测试 (17)5.1.1 建立仿真文件 (17)5.1.2 测速功能测试 (18)5.2 仿真结果分析 (19)结论 (20)参考文献 (21)附录 (22)第1章 绪论1.1 数字测速方法的原理与应用1.1.1 M 法测速在一定时间T C 内测取旋转编码器输出的脉冲个数M 1用以计算这段时间内的转速,称作M 法测速。
把M 1除以T C 就可得到旋转编码器输出脉冲的频率f 1=M 1/T C ,所以又称为频率法。
M 法是测量单位时间内的脉数换算成频率,因存在测量时间内首尾的半个脉冲问题,可能会有2个脉的误差。
速度较低时,因测量时间内的脉冲数变少,误差所占的比例会变大,所以M 法宜测量高速。
如要降低测量的速度下限,可以提高编码器线数或加大测量的单位时间,使用一次采集的脉冲数尽可能多。
计算公式为:c160ZT M n =时钟Z = 倍频系数 x 编码器光栅数。
M 法测速的分辨率: c c 1c 16060)1(60ZT ZT M ZT M Q =-+=M 法测速误差率:%1001%10060 )1(60 601c 1c 1c 1max⨯=⨯-=M ZT M ZT M ZT M δ 在上式中,Z 和T C 均为常值,因此转速 n 正比于脉冲个数。
高速时M 1大,量化误差较小,随着转速的降低误差增大。
所以,M 法测速只适用于高速段。
1.1.2 T 法测速T 法测速是测出旋转编码器两个输出脉冲之间的间隔时间来计算转速,它又成为周期法测速。
T 法是测量两个脉冲之间的时间换算成周期,从而得到频率。
因存在半个时间单位的问题,可能会有1个时间单位的误差。
速度较高时,测得的周期较小,误差所占的比例变大,所以T 法宜测量低速。
如要增加速度测量的上限,可以减小编码器的脉冲数,或使用更小更精确的计时单位,使一次测量的时间值尽可能大。
计算公式为:2060ZM f n =T 法测速的分辨率: )1(6060)1(602202020-=--=M ZM f ZM f M Z f Q T法测速误差率: %10011%10060 60 )1(602202020max ⨯-=⨯-=M ZM f ZM f M Z f δ 低速时,编码器相邻脉冲间隔时间长,测得的高频时钟脉冲个数M 2多,所以误差率小,测速精度高,故T 法测速适用于低速段。
1.1.3 M/T 法测速在M 法测速中,随着电动机的转速的降低,计数值M 1减少,测速装置的分辨能力变差,测速误差增大。
如果速度过低,M 1将小于1,测速装置便不能正常工作。
T 法测速正好相反,随着电动机转速的增加,计算值M 2减小,测速装置的分辨能力越来越差。
综合这两种测速方法的特点,产生了M/T 法测速。
它无论在高速还是在低速时都具有较高的分辨力和检测精度。
M/T 法采用三个定时/计数器,同时对输入脉冲、高频脉冲、及预设的定时时间进行定时和计数,M 1反映转角,M 2反映测速的准却时间,通过计算可得转速值n。
该法在高速及低速时都具有相对较高的精度。
测速时间T d由脉冲发生器脉冲来同步,即T d等于M1个脉冲周期。
由图1-1可见,从a点开始,计数器对M1和M2计数,到达b点,预定的测速时间时,单片机发出停止计数指令,因为T C不一定正好等于整数个脉冲发生器脉冲周期,所以,计数器仍然对高频脉冲继续计数,到达C点时,脉冲发生器脉冲的上升沿使计数器停止,这样M2就代表了M1个脉冲在周期时间。
转速角可表示为:检测周期可写成:综合二式可求出被测得转速为:n—转速值,单位:(转/分);f0—晶体震荡频率,单位:HZ;M1—输入脉冲数,反映转角;M2—时基脉冲数。
图1-1 M/T法定时/计数测量第2章系统总体设计设计一个基于51单片机的光电编码器测测速。
设计一个电路来实现光电编码器测量;利用单片机内部精确到微妙的定时计数器来实现一个周期的时间来统计脉冲数;P0和P2口控制1602液晶显示转速;利用复位按键功能来实现复位操作。
由于定时器工作模式2是八位,可装入的值太小,每进行一个周期的脉冲统计需要进入5000次定时器中断,由于进入中断的次数太多,所以很容易出现在低八位装满本应触发而程序还在中断子程序中运行,而无法触发中断的情况,所以不采用工作模式2。
工作模式0只需要进入定时中断1000次就可以进行一个周期的脉冲统计,所以选择功能模式0。
用纯软件计数虽然电路简单,但是计数速度慢,难以满足实时性要求,而且容易出错。
我们可以用单片机内部的计数器来实现加减计数。
单片机片内有两个16位定时计数器都可以用来脉冲计数,用两个外部中断来检测正反转,避免了每一个脉冲都要进行高低电平检测的步骤。
转速测量系统的总体设计框图如图2-1所示。
图2-1总体设计框图第3章硬件设计3.1 硬件选型3.1.1 CPU主控模块的选型AT89C52是一种低功耗、高性能CMOS8位微控制器,具有 8K 在系统可编程Flash 存储器。
在单芯片上,拥有灵巧的8 位CPU 和在系统可编程Flash,使得AT89C52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。
具有以下标准功能: 8k字节Flash,512字节RAM, 32 位I/O 口线,看门狗定时器,内置4KB EEPROM,MAX810复位电路,2个16 位定时器/计数器,一个6向量2级中断结构,全双工串行口。
另外可降至0Hz 静态逻辑操作,支持2种软件可选择节电模式。
空闲模式下,CPU 停止工作,允许RAM、定时器/计数器、串口、中断继续工作。
掉电保护方式下,RAM内容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或硬件复位为止。
最高运作频率35MHz,6T/12T可选。
AT89C52RC-40C-PQFP图3-1单片机原理图3.1.2显示器的选型本设计的显示部分使用的是液晶显示器LCD1602,该显示器只能显示英文字母和数字,所以参数的说明都用英语意思或是符号代替。
屏幕上会显示参数、模式以及计算后的速度。
3.2 硬件电路设计3.2.1时钟电路的设计STC89C52内部有一个用于构成振荡器的高增益反相放大器,引脚RXD 和TXD分别是此放大器的输入端和输出端。
时钟可以由内部方式产生或外部方式产生。
在RXD和TXD引脚上外接定时元件,内部振荡器就产生自激振荡。
定时元件通常采用石英晶体和电容组成的并联谐振回路。
晶体振荡频率可以在1.2~12MHz之间选择,电容值在5~30pF之间选择,电容值的大小可对频率起微调的作用。
其电路图3-2如下所示:图3-2时钟电路图3.2.2显示电路显示电路原理图如图3-3所示。
图3-3显示电路原理图3.2.3速度检测电路光电编码器是开漏输出,所以在和单片机连接时需要加上拉电阻。
编码器输出端连接到51单片机外部中断0引脚上所以就可以在每次接收到脉冲时就能触发外部中断,电路如图3-4所示。
图3-4 速度检测电路原理图3.2.4按键输入电路按键输入负责调整测速模式和改变参数的值,一个按键是“确认”按键,一个是“加”按键,在模式选择时为T法选择键;另一个是“减”按键, 在模式选择时为M法选择键。
在调整参数的时候,也是根据“减”“加”调整参数。
其电路图如图3-5所示图3-5按键输入电路图3.2.5复位电路复位电路是指单片机的初始化操作。
单片机启动运行时都需要先复位,其作用是使CPU和系统中其他的部件处于一个确定的初始状态,并从这个状态开始工作。
因而,复位是个很重要的操作方式。
但单片机本身不能自动进行复位的,必须配合相应的外部电路才能实现复位功能。
复位电路的基本功能是:系统上电时提供复位信号,直至系统电源稳定后,撤销复位信号。
为可靠期间,电源稳定后还需经历一定延时才撤销复位信号,以防电源开关或电源插头分—合过程中引起抖动而影响复位。
复位电路如图3-6所示:图3-6复位电路第4章软件设计4.1 系统流程4.1.1 主程序流程设计本设计程序运行时,通过按键输入首先来选择测速方法,然后设定测速法中T和Z等参数。
主程序流程图如图4-1所示。
图4-1 主程序流程图4.1.2 M法测速程序设计选择M法测速模式后,打开外部中断0,同时开启定时器0开始一定时间的定时,外部中断开始计数脉冲个数。
当定时间到的时候关闭外部中断和定时器,读取外部中断计数的个数并计算速度。
M法测速程序流程如图 4-2所示。
图4-2 M法测速流程图4.1.3 T法测速程序设计程序初始化完成后选择T法测速模式,只打开外部中断0,当外部中断检测到脉冲的第一个跳变时打开定时器0的中断开始计时。
当外部中断检测到第二个跳变是关闭外部中断0和定时器并读取计时的时间值。
图4-3T法测速程序流程图:图4-3 T法测速流程图4.1.4 M/T法测速程序设计M/T法测速程序设计如图4-4所示。
图4-4 M/T法测速流程图第5章仿真结果5.1 测速功能仿真测试电路仿真采用Proteus软件,Proteus是世界上著名的EDA工具(仿真软件),从原理图布图、代码调试到单片机与外围电路协同仿真,一键切换到PCB设计,真正实现了从概念到产品的完整设计。
是目前世界上唯一将电路仿真软件、PCB设计软件和虚拟模型仿真软件三合一的设计平台,其处理器模型支持8051、HC11、PIC10/12/16/18/24/30/DsPIC33、AVR、ARM、8086和MSP430等,2010年又增加了Cortex和DSP系列处理器,并持续增加其他系列处理器模型。