微机原理与汇编语言程序设计-直流电机转速控制_第1页
微机原理与汇编语言程序设计-直流电机转速控制_第2页
微机原理与汇编语言程序设计-直流电机转速控制_第3页
微机原理与汇编语言程序设计-直流电机转速控制_第4页
微机原理与汇编语言程序设计-直流电机转速控制_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验课题: 直流电机调速控制实验内容: 本实验完成的是一个实现对直流电机转速调节的应用。编写实验程序,用ADC0809完成模拟信号到数字信号的转换。输入模拟信号有A/D转换单元可调电位器提供的05V,将其转换后的数字信号读入累加器,做为控制电机的给定转速。用8255的B口作为直流电机的控制信号输出口,通过对电机转速反馈量的运算,调节控制信号,达到控制电机匀速转动的的作用。并将累加器中给定的转速和当前测量转速显示在屏幕上。再通过LED灯显示出转速的大小变化。实验目的:(1) 学习掌握模/数信号转换的基本原理。(2) 掌握的ADC0809、8255芯片的使用方法。(3) 学习PC系统中扩展简单I/

2、O接口的方法。(4) 了解实现直流电机转速调节的基本方法。实验要求: 利用微机接口实验系统的硬件资源,运用汇编语言设计实现直流电机的调速控制功能。基本功能要求:1、利用A/D转换方式实现模拟量给定信号的采样;2、实现PWM方式直流电机速度调节;3、LED灯显示当前直流电机速度状态。实验设备:(1) 硬件要求: PC微机一台、TD-PIT实验系统一套(2) 软件要求:唐都编程软件,tdpit编程软件,“轻松编程”软件实验原理: 各芯片的功能简介: (1)8255的基本输出接口电路:并行接口是以数据的字节为单位与I/O设备或被控制对象之间传递信息,CPU和接口之间的数据传递总是并行的,即可以同时进

3、行传递8位,16位,32位等。8255可编程外围接口芯片是具有A、B、C三个并行接口,+5V单电源供电,能在以下三种方式下工作:方式0基本输入/出方式、方式1选通输入/出方式、方式2双向选通工作方式。8255的内部结构图和引脚图如下:本实验利用8255的A口作为输出口,控制8个单色LED灯,来实现电机转速的大小显示。(2)转速调节原理:* PWM的占空比决定输出到直流电机的平均电压. PWM不是调节电流的.PWM的意思是脉宽调节,也就是调节方波高电平和低电平的时间比,一个20%占空比波形,会有20%的高电平时间和80%的低电平时间,而一个60%占空比的波形则具有60%的高电平时间和40%的低电

4、平时间,占空比越大,高电平时间越长,则输出的脉冲幅度越高,即电压越高.如果占空比为0%,那么高电平时间为0,则没有电压输出.如果占空比为100%,那么输出全部电压. 所以通过调节占空比,可以实现调节输出电压的目的,而且输出电压可以无级连续调节.在使用PWM控制的直流无刷电动机中,PWM控制有两种方式: 1.使用PWM信号,控制三极管的导通时间,导通的时间越长,那么做功的时间越长,电机的转速就越高 2.使用PWM控制信号控制三极管导通时间,改变控制电压高低来实现 * 利用实验平台上8255的PB0产生脉冲信号作为控制量,经驱动电路驱动电机运转。霍尔测速元件输出的脉冲信号记录电机转速构成反馈量。在

5、参数给定的情况下,经PID运算,电机可在控制量的作用下,按PC机累加器给定的转速运转。实验通过PC的0号通道,设置为输出1ms方波,作为采样时钟,PB0产生PWM脉冲计时及转速累加,系统总线上INTR中断用于测量电机转速。 (3)A/D转换原理: 本实验用ADC0809完成模拟信号到数字信号的转换。输入模拟信号有A/D转换单元可调电位器提供的05V,将其转换后的数字信号读入累加器,做为控制电机的给定转速。(5) LED灯的工作原理:LED灯显示器有8个单色发光二极管构成,在共阳极接法中,各二极管的阳极被连在一起,使用的时候要将它与+5V项链,而把各段的阴极连到器件的相应引脚上。当某的LED灯的

6、引脚为低电平的时候,该灯工作。本实验上通过8255的A口信号作为输入信号,控制各灯的工作状态。来显示出此时电机转速的大小变化。(6) 实现两位十进制数的显示:在计算机中,对数字的输入和输出是用二进制进行的,而在计算机内部十进制数要转换为二进制来表示,要实现两位十进制数的显示,必须将他们转换为目前最普遍使用的字符编码ASCII码。 本实验中通过作除法。即拆分法。如两位十进制AB转换为A*10+B的形式,再通过A+30H与B+30H来转换为ASCII码,若溢出,加7运算。DECSHOW PROC NEAR ;完成两位十进制数显示子程序 MOV DX,0 MOV BX,10 ;计算AX/10 DIV

7、 BX ADD AL,30H ;商+30H,即为十位数ASCII码 MOV AH,0EH INT 10H ADD DL,30H ;余+30H,即为个位数ASCII码 MOV AH,2 INT 21H RET DECSHOW ENDP实验接线图: PA0PA7D0D7PA0PA7 转速调节程序设计框图:B口转速调节与测量程序 (a)转速调节主程序主程序流程图:说明B口转速控制程序转上页将转换结果以16进制形式显示在屏幕上设置8255工作方式将AD送的结果装入8255初始化8255控制寄存器将结果送到8255A口输出,执行B口的调速程序是否有键按下返回DOS结束启用A/D转换 在屏幕上显示给定的转

8、速 读取转换结果定义寄存器清屏屏幕显示菜单开 始程序清单:;*根据CHECK配置信息修改下列符号值* INTR_IVADD EQU 0038H ;INTR对应的中断矢量地址 INTR_OCW1 EQU 21H ;INTR对应PC机内部8259的OCW1地址 INTR_OCW2 EQU 20H ;INTR对应PC机内部8259的OCW2地址 INTR_IM EQU 0BFH ;INTR对应的中断屏蔽字 PCI_INTCSR EQU 0CC38H ;PCI卡中断控制寄存器地址 IOY0 EQU 0C400H ;片选IOY0对应的端口始地址 IOY1 EQU 0C440H ;片选IOY0对应的端口始

9、地址;* MY8255_A EQU IOY0+00H*4 ;8255的A口地址 MY8255_B EQU IOY0+01H*4 ;8255的B口地址 MY8255_C EQU IOY0+02H*4 ;8255的C口地址 MY8255_MODE EQU IOY0+03H*4 ;8255的控制寄存器地址 AD0809 EQU IOY1+00H ;AD0809的端口地址STACK1 SEGMENT STACK DW 64 DUP(?) TOP LABEL WORD STACK1 ENDS DATA SEGMENT TABLE1 DB Assumed Fan Speed:(/s),0AH,0DH,$

10、;字符串变量 TABLE2 DB Current Fan Speed:(/s),0AH,0DH,$ ;字符串变量 ENT DB 0AH,0DH,$ ;换行,回车 CS_BAK DW ? ;保存INTR原中断处理程序入口段地址的变量 IP_BAK DW ? ;保存INTR原中断处理程序入口偏移地址的变量 IM_BAK DB ? ;保存INTR原中断屏蔽字的变量 CS_BAK1 DW ? ;保存定时器0中断处理程序入口段地址的变量 IP_BAK1 DW ? ;保存定时器0中断处理程序入口偏移地址的变量 IM_BAK1 DB ? ;保存定时器0中断屏蔽字的变量 TS DB 14H ;采样周期 SPE

11、C DW 55 ;转速给定值 IBAND DW 0060H ;积分分离值 KPP DW 1060H ;比例系数 KII DW 0010H ;积分系数 KDD DW 0020H ;微分系数 YK DW ? CK DB ? VADD DW ? ZV DB ? ZVV DB ? TC DB ? FPWM DB ? CK_1 DB ? EK_1 DW ? AEK_1 DW ? BEK DW ? AAAA DB ? VAA DB ? BBB DB ? VBB DB ? MARK DB ? R0 DW ? R1 DW ? R2 DW ? R3 DW ? R4 DW ? R5 DW ? R6 DW ? R7

12、 DB ? R8 DW ? DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX MOV DX,OFFSET TABLE1 ;显示字符串1 MOV AH,09H INT 21H MOV AX,SPEC ;显示给定值 CALL DECSHOW MOV DX,OFFSET ENT ;回车,换行 MOV AH,09H INT 21H MOV DX,OFFSET TABLE2 ;显示字符串2 MOV AH,09H INT 21H CLI MOV AX,0000H MOV ES,AX MOV DI,0020H

13、 MOV AX,ES:DI MOV IP_BAK1,AX ;保存定时器0中断处理程序入口偏移地址 MOV AX,OFFSET TIMERISR MOV ES:DI,AX ;设置实验定时中断处理程序入口偏移地址 ADD DI,2 MOV AX,ES:DI MOV CS_BAK1,AX ;保存定时器0中断处理程序入口段地址 MOV AX,SEG TIMERISR MOV ES:DI,AX ;设置实验定时中断处理程序入口段地址 IN AL,21H MOV IM_BAK1,AL ;保存INTR原中断屏蔽字 AND AL,0F7H OUT 21H,AL ;打开定时器0中断屏蔽位 MOV DX,PCI_I

14、NTCSR ;初始化PCI卡中断控制寄存器 MOV AX,1F00H ;向PCI_INTCSR中写入003F1F00H OUT DX,AX ADD DX,2 MOV AX,003FH OUT DX,AX MOV DI,INTR_IVADD MOV AX,ES:DI MOV IP_BAK,AX ;保存INTR原中断处理程序入口偏移地址 MOV AX,OFFSET MYISR MOV ES:DI,AX ;设置当前中断处理程序入口偏移地址 ADD DI,2 MOV AX,ES:DI MOV CS_BAK,AX ;保存INTR原中断处理程序入口段地址 MOV AX,SEG MYISR MOV ES:D

15、I,AX ;设置当前中断处理程序入口段地址 MOV DX,INTR_OCW1 IN AL,DX MOV IM_BAK,AL ;保存INTR原中断屏蔽字 AND AL,INTR_IM OUT DX,AL ;打开INTR的中断屏蔽位 MOV VADD,0000H ;变量的初始化 MOV ZV,00H MOV ZVV,00H MOV CK,00H MOV YK,0000H MOV CK_1,00H MOV EK_1,0000H MOV AEK_1,0000H MOV BEK,0000H MOV BBB,00H MOV VBB,00H MOV R0,0000H MOV R1,0000H MOV R2,

16、0000H MOV R3,0000H MOV R4,0000H MOV R5,0000H MOV R6,0000H MOV R7,00H MOV R8,0000H MOV MARK,00H MOV FPWM,01H MOV AAAA,7FH MOV VAA,7FH MOV TC,00H MOV AL,80H ;初始化8255 MOV DX,MY8255_MODE OUT DX,AL MOV AL,00H MOV DX,MY8255_B OUT DX,AL MOV DX,MY8255_A OUT DX,AL MOV DX,PC8254_MODE ;初始化PC机定时器0,定时1ms MOV AL,

17、36H OUT DX,AL MOV DX,PC8254_COUNT0 MOV AL,8FH OUT DX,AL MOV AL,04H OUT DX,AL STI M1: MOV AL,TS ;判断采样周期到否? SUB AL,TC JNC M1 ;没到则继续等待 MOV TC,00H ;采样周期到,将采样周期变量清0 MOV AL,ZVV MOV AH,00H MOV YK,AX ;得到反馈量YK LOOP1: MOV DX,AD0809 ;启动A/D转换 OUT DX,AL CALL DALLY MOV DX,AD0809 ;读出转换结果 IN AL,DX MOV DX,MY8255_A ;

18、将结果显示于LED OUT DX,AL MOV BL,AL MOV BH,0 CALL PID ;调用PID子程序,得到控制量CK MOV AL,CK ;把控制量转化成PWM输出 SUB AL,80H JC IS0 MOV AAAA,AL JMP COU IS0: MOV AL,10H ;电机的启动值不能低于10H MOV AAAA,AL COU: MOV AL,7FH SUB AL,AAAA MOV BBB,AL MOV AX,YK ;将反馈值YK送到屏幕显示 CALL DECSHOW MOV DL,0DH ;回车 MOV AH,02H INT 21H MOV AH,1 ;判断是否有按键按下

19、 INT 16H JZ M1 ;无按键则跳回继续等待,有则退出 EXIT: CLI MOV AL,00H ;退出时停止电机运转 MOV DX,MY8255_B OUT DX,AL MOV DX,PC8254_MODE ;恢复PC机定时器0状态 MOV AL,36H OUT DX,AL MOV DX,PC8254_COUNT0 MOV AL,00H OUT DX,AL MOV AL,00H OUT DX,AL MOV DX,PCI_INTCSR ;恢复PCI卡中断控制寄存器 MOV AX,0000H OUT DX,AX MOV AX,0000H ;恢复INTR原中断矢量 MOV ES,AX MO

20、V DI,INTR_IVADD MOV AX,IP_BAK ;恢复INTR原中断处理程序入口偏移地址 MOV ES:DI,AX ADD DI,2 MOV AX,CS_BAK ;恢复INTR原中断处理程序入口段地址 MOV ES:DI,AX MOV DX,INTR_OCW1 ;恢复INTR原中断屏蔽寄存器的屏蔽字 MOV AL,IM_BAK OUT DX,AL MOV DI,0020H MOV AX,IP_BAK1 ;恢复定时器0中断处理程序入口偏移地址 MOV ES:DI,AX ADD DI,2 MOV AX,CS_BAK1 ;恢复定时器0中断处理程序入口段地址 MOV ES:DI,AX MO

21、V AL,IM_BAK1 OUT 21H,AL ;恢复屏蔽字 STI MOV AX,4C00H INT 21H MYISR PROC NEAR ;系统总线INTR中断处理程序 PUSH AX PUSH CX PUSH DX MOV AX,DATA MOV DS,AX MOV AL,MARK CMP AL,01H JZ IN1 MOV MARK,01H JMP IN2 IN1: MOV MARK,00H ;计算转速 VV: MOV DX,0000H MOV AX,03E8H MOV CX,VADD CMP CX,0000H JZ MM1 DIV CX MM: MOV ZV,AL MOV VADD

22、,0000H MM1: MOV AL,ZV MOV ZVV,AL IN2: MOV DX,PCI_INTCSR ;清PCI卡控制寄存器标志位 SUB DX,19H IN AL,DX MOV DX,PCI_INTCSR ADD DX,2 MOV AX,003FH OUT DX,AX MOV DX,INTR_OCW2 ;向PC机内部8259发送中断结束命令 MOV AL,20H OUT DX,AL MOV AL,20H OUT 20H,AL POP DX POP CX POP AX IRET MYISR ENDP TIMERISR PROC NEAR ;PC机定时器0中断处理程序 PUSH AX

23、PUSH CX PUSH DX MOV AX,DATA MOV DS,AX INC TC ;采样周期变量加1 CALL KJ CLC CMP MARK,01H JC TT1 INC VADD CMP VADD,0700H ;转速值溢出,赋极值 JC TT1 MOV VADD,0700H MOV MARK,00H TT1: MOV AL,20H ;中断结束,发EOI命令 OUT 20H,AL POP DX POP CX POP AX IRET TIMERISR ENDP KJ PROC NEAR ;PWM子程序 PUSH AX CMP FPWM,01H ;PWM为1,产生PWM的高电平 JNZ

24、TEST2 CMP VAA,00H JNZ ANOT0 MOV FPWM,02H MOV AL,BBB CLC RCR AL,01H MOV VBB,AL JMP TEST2 ANOT0: DEC VAA MOV AL, 01H ;PB0=1 电机转动 MOV DX, MY8255_B OUT DX,AL TEST2: CMP FPWM,02H ;PWM为2,产生PWM的低电平 JNZ OUTT CMP VBB,00H JNZ BNOT0 MOV FPWM,01H MOV AL,AAAA CLC RCR AL,01H MOV VAA,AL JMP OUTT BNOT0: DEC VBB MOV

25、 AL,00H ;PB0=0 电机停止 MOV DX,MY8255_B OUT DX,AL OUTT: POP AX RET KJ ENDP PID: MOV AX,BX ;PID子程序 SUB AX,YK ;求偏差EK MOV R0,AX MOV R1,AX SUB AX,EK_1 MOV R2,AX SUB AX,AEK_1 ;求BEK MOV BEK,AX MOV R8,AX MOV AX,R1 ;求偏差变化量AEK MOV EK_1,AX MOV AX,R2 MOV AEK_1,AX TEST R1,8000H JZ EK1 ;若偏差EK为正数,则不需要求补码 NEG R1 ;若偏差E

26、K为负数,则求偏差EK的补码 EK1: MOV AX,R1 ;判断偏差EK是否在积分分离值的范围内 SUB AX,IBAND JC II ;在积分分离值范围内,则跳转到II,计算积分项 MOV R3,00H ;若不在积分分离值范围内,则将积分项清0 JMP DDD ;计算微分项 II: MOV AL,TS ;计算积分项,结果放在R3变量中(R3=EK*TS/KII) MOV AH,00H ;其中TS和KII均为正数,所以R3的正负由EK决定 MOV CX,R1 MUL CX MOV CX,KII DIV CX MOV R3,AX TEST R0,8000H ;判断积分项的正负 JZ DDD ;

27、为正数,则跳转去计算微分项 NEG R3 ;为负数,则将积分项的结果求补码 DDD: TEST BEK,8000H ;判断BEK的正负 JZ DDD1 ;为正数,则BEK不变 NEG BEK ;为负数,则求BEK的补码 DDD1: MOV AX,BEK ;计算微分项(R4=KDD*BEK/8TS) MOV CX,KDD MUL CX PUSH AX PUSH DX MOV AL,TS MOV AH,00H ;将微分项缩小8倍,防止溢出 MOV CX,0008H MUL CX MOV CX,AX POP DX POP AX DIV CX MOV R4,AX TEST R8,8000H ;判断微分

28、项的正负 JZ DD1 ;为正数,则结果不需要求补码 NEG R4 ;为负数,则微分项结果R4求补码 DD1: MOV AX,R3 ;积分项和微分项相加,结果放在R5变量中 ADD AX,R4 MOV R5,AX JO L9 ;判断溢出 L2: MOV AX,R5 ADD AX,R2 MOV R6,AX ;R6=R5+R2=积分项+微分项+AEK JO L3 L5: MOV AX,R6 ;计算KPP*R6 MOV CX,KPP IMUL CX MOV CX,1000H IDIV CX MOV CX,AX RCL AH,01H ;判断溢出,溢出赋极值 PUSHF RCR AL,01H POPF

29、JC LLL1 CMP CH,00H JZ LLL2 MOV AL,7FH JMP LLL2 LLL1: CMP CH,0FFH JZ LLL2 MOV AL,80H LLL2: MOV R7,AL ;CK=CK_1+CK ADD AL,CK_1 JO L8 L18: MOV CK_1,AL ADD AL,80H MOV CK,AL RET L8: TEST R7,80H ;CK溢出处理程序 JNZ L17 MOV AL,7FH ;若为正溢出,则赋给正极值7FH JMP L18 L17: MOV AL,80H ;若为负溢出,则赋给赋极值80H JMP L18 L9: TEST R3,8000H JNZ L1 MOV R5,7FFFH ;若为正溢出,则赋给正极值7FFFH JMP L2 L1: MOV R5,8000H ;若为负溢出,则赋给负极值8000H J

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论