实验课题:直流电机调速控制实验内容:本实验完成的是一个实现对直流电机转速调节的应用。
编写实验程序,用ADC0809完成模拟信号到数字信号的转换。
输入模拟信号有A/D转换单元可调电位器提供的0~5V,将其转换后的数字信号读入累加器,做为控制电机的给定转速。
用8255的B口作为直流电机的控制信号输出口,通过对电机转速反馈量的运算,调节控制信号,达到控制电机匀速转动的的作用。
并将累加器中给定的转速和当前测量转速显示在屏幕上。
再通过LED灯显示出转速的大小变化。
实验目的:(1)学习掌握模/数信号转换的基本原理。
(2)掌握的ADC0809、8255芯片的使用方法。
(3)学习PC系统中扩展简单I/O接口的方法。
(4)了解实现直流电机转速调节的基本方法。
实验要求:利用微机接口实验系统的硬件资源,运用汇编语言设计实现直流电机的调速控制功能。
基本功能要求:1、利用A/D转换方式实现模拟量给定信号的采样;2、实现PWM方式直流电机速度调节;3、LED灯显示当前直流电机速度状态。
实验设备:(1)硬件要求: PC微机一台、TD-PIT实验系统一套(2)软件要求:唐都编程软件,tdpit编程软件,“轻松编程”软件实验原理:各芯片的功能简介:(1)8255的基本输出接口电路:并行接口是以数据的字节为单位与I/O设备或被控制对象之间传递信息,CPU 和接口之间的数据传递总是并行的,即可以同时进行传递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%的低电平时间,占空比越大,高电平时间越长,则输出的脉冲幅度越高,即电压越高.如果占空比为0%,那么高电平时间为0,则没有电压输出.如果占空比为100%,那么输出全部电压.所以通过调节占空比,可以实现调节输出电压的目的,而且输出电压可以无级连续调节.在使用PWM控制的直流无刷电动机中,PWM控制有两种方式:1.使用PWM信号,控制三极管的导通时间,导通的时间越长,那么做功的时间越长,电机的转速就越高2.使用PWM控制信号控制三极管导通时间,改变控制电压高低来实现** 利用实验平台上8255的PB0产生脉冲信号作为控制量,经驱动电路驱动电机运转。
霍尔测速元件输出的脉冲信号记录电机转速构成反馈量。
在参数给定的情况下,经PID运算,电机可在控制量的作用下,按PC机累加器给定的转速运转。
实验通过PC的0号通道,设置为输出1ms方波,作为采样时钟,PB0产生PWM脉冲计时及转速累加,系统总线上INTR中断用于测量电机转速。
(3)A/D转换原理:本实验用ADC0809完成模拟信号到数字信号的转换。
输入模拟信号有A/D转换单元可调电位器提供的0~5V,将其转换后的数字信号读入累加器,做为控制电机的给定转速。
(5) LED灯的工作原理:LED灯显示器有8个单色发光二极管构成,在共阳极接法中,各二极管的阳极被连在一起,使用的时候要将它与+5V项链,而把各段的阴极连到器件的相应引脚上。
当某的LED灯的引脚为低电平的时候,该灯工作。
本实验上通过8255的A口信号作为输入信号,控制各灯的工作状态。
来显示出此时电机转速的大小变化。
(6)实现两位十进制数的显示:在计算机中,对数字的输入和输出是用二进制进行的,而在计算机内部十进制数要转换为二进制来表示,要实现两位十进制数的显示,必须将他们转换为目前最普遍使用的字符编码ASCII码。
本实验中通过作除法。
即拆分法。
如两位十进制AB转换为A*10+B的形式,再通过A+30H与B+30H来转换为ASCII码,若溢出,加7运算。
DECSHOW PROC NEAR ;完成两位十进制数显示子程序MOV DX,0MOV BX,10 ;计算AX/10DIV BXADD AL,30H ;商+30H,即为十位数ASCII码MOV AH,0EHINT 10HADD DL,30H ;余+30H,即为个位数ASCII码MOV AH,2INT 21HRETDECSHOW ENDP实验接线图:D0~D7 PA0~PA7PA0~PA7转速调节程序设计框图:B口转速调节与测量程序(a)转速调节主程序主程序流程图:程序清单:;***************根据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对应的端口始地址;***************************************************************** 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 STACKDW 64 DUP(?)TOP LABEL WORDSTACK1 ENDSDATA SEGMENTTABLE1 DB 'Assumed Fan Speed:(/s)',0AH,0DH,'$' ;字符串变量 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 ;采样周期SPEC 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 DB ?R8 DW ?DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,DATAMOV DS,AXMOV DX,OFFSET TABLE1 ;显示字符串1 MOV AH,09HINT 21HMOV AX,SPEC ;显示给定值CALL DECSHOWMOV DX,OFFSET ENT ;回车,换行MOV AH,09HINT 21HMOV DX,OFFSET TABLE2 ;显示字符串2 MOV AH,09HINT 21HCLIMOV AX,0000HMOV ES,AXMOV DI,0020HMOV AX,ES:[DI]MOV IP_BAK1,AX ;保存定时器0中断处理程序入口偏移地址MOV AX,OFFSET TIMERISRMOV ES:[DI],AX ;设置实验定时中断处理程序入口偏移地址ADD DI,2MOV AX,ES:[DI]MOV CS_BAK1,AX ;保存定时器0中断处理程序入口段地址MOV AX,SEG TIMERISRMOV ES:[DI],AX ;设置实验定时中断处理程序入口段地址IN AL,21HMOV IM_BAK1,AL ;保存INTR原中断屏蔽字AND AL,0F7HOUT 21H,AL ;打开定时器0中断屏蔽位MOV DX,PCI_INTCSR ;初始化PCI卡中断控制寄存器MOV AX,1F00H ;向PCI_INTCSR中写入003F1F00HOUT DX,AXADD DX,2MOV AX,003FHOUT DX,AXMOV DI,INTR_IVADDMOV AX,ES:[DI]MOV IP_BAK,AX ;保存INTR原中断处理程序入口偏移地址MOV AX,OFFSET MYISRMOV ES:[DI],AX ;设置当前中断处理程序入口偏移地址 ADD DI,2MOV AX,ES:[DI]MOV CS_BAK,AX ;保存INTR原中断处理程序入口段地址MOV AX,SEG MYISRMOV ES:[DI],AX ;设置当前中断处理程序入口段地址MOV DX,INTR_OCW1IN AL,DXMOV IM_BAK,AL ;保存INTR原中断屏蔽字AND AL,INTR_IMOUT DX,AL ;打开INTR的中断屏蔽位MOV VADD,0000H ;变量的初始化MOV ZV,00HMOV ZVV,00HMOV CK,00HMOV YK,0000HMOV CK_1,00HMOV EK_1,0000HMOV AEK_1,0000HMOV BEK,0000HMOV BBB,00HMOV VBB,00HMOV R0,0000HMOV R1,0000HMOV R2,0000HMOV R3,0000HMOV R4,0000HMOV R5,0000HMOV R6,0000HMOV R7,00HMOV R8,0000HMOV MARK,00HMOV FPWM,01HMOV AAAA,7FHMOV VAA,7FHMOV TC,00HMOV AL,80H ;初始化8255MOV DX,MY8255_MODEOUT DX,ALMOV AL,00HMOV DX,MY8255_BOUT DX,ALMOV DX,MY8255_AOUT DX,ALMOV DX,PC8254_MODE ;初始化PC机定时器0,定时1msMOV AL,36HOUT DX,ALMOV DX,PC8254_COUNT0MOV AL,8FHMOV AL,04HOUT DX,ALSTIM1: MOV AL,TS ;判断采样周期到否?SUB AL,TCJNC M1 ;没到则继续等待MOV TC,00H ;采样周期到,将采样周期变量清0 MOV AL,ZVVMOV AH,00HMOV YK,AX ;得到反馈量YKLOOP1: MOV DX,AD0809 ;启动A/D转换OUT DX,ALCALL DALLYMOV DX,AD0809 ;读出转换结果IN AL,DXMOV DX,MY8255_A ;将结果显示于LEDOUT DX,ALMOV BL,ALMOV BH,0CALL PID ;调用PID子程序,得到控制量CK MOV AL,CK ;把控制量转化成PWM输出SUB AL,80HJC IS0MOV AAAA,ALJMP COUIS0: MOV AL,10H ;电机的启动值不能低于10HMOV AAAA,ALCOU: MOV AL,7FHSUB AL,AAAAMOV BBB,ALMOV AX,YK ;将反馈值YK送到屏幕显示CALL DECSHOWMOV DL,0DH ;回车MOV AH,02HMOV AH,1 ;判断是否有按键按下INT 16HJZ M1 ;无按键则跳回继续等待,有则退出EXIT: CLIMOV AL,00H ;退出时停止电机运转MOV DX,MY8255_BOUT DX,ALMOV DX,PC8254_MODE ;恢复PC机定时器0状态 MOV AL,36HOUT DX,ALMOV DX,PC8254_COUNT0MOV AL,00HOUT DX,ALMOV AL,00HOUT DX,ALMOV DX,PCI_INTCSR ;恢复PCI卡中断控制寄存器MOV AX,0000HOUT DX,AXMOV AX,0000H ;恢复INTR原中断矢量MOV ES,AXMOV DI,INTR_IVADDMOV AX,IP_BAK ;恢复INTR原中断处理程序入口偏移地址MOV ES:[DI],AXADD DI,2MOV AX,CS_BAK ;恢复INTR原中断处理程序入口段地址MOV ES:[DI],AXMOV DX,INTR_OCW1 ;恢复INTR原中断屏蔽寄存器的屏蔽字MOV AL,IM_BAKOUT DX,ALMOV DI,0020HMOV AX,IP_BAK1 ;恢复定时器0中断处理程序入口偏移地址MOV ES:[DI],AXADD DI,2MOV AX,CS_BAK1 ;恢复定时器0中断处理程序入口段地址MOV ES:[DI],AXMOV AL,IM_BAK1OUT 21H,AL ;恢复屏蔽字STIMOV AX,4C00HINT 21HMYISR PROC NEAR ;系统总线INTR中断处理程序PUSH AXPUSH CXPUSH DXMOV AX,DATAMOV DS,AXMOV AL,MARKCMP AL,01HJZ IN1MOV MARK,01HJMP IN2IN1: MOV MARK,00H ;计算转速VV: MOV DX,0000HMOV AX,03E8HMOV CX,VADDCMP CX,0000HJZ MM1DIV CXMM: MOV ZV,ALMOV VADD,0000HMM1: MOV AL,ZVMOV ZVV,ALIN2: MOV DX,PCI_INTCSR ;清PCI卡控制寄存器标志位SUB DX,19HIN AL,DXMOV DX,PCI_INTCSRMOV AX,003FHOUT DX,AXMOV DX,INTR_OCW2 ;向PC机内部8259发送中断结束命令MOV AL,20HOUT DX,ALMOV AL,20HOUT 20H,ALPOP DXPOP CXPOP AXIRETMYISR ENDPTIMERISR PROC NEAR ;PC机定时器0中断处理程序PUSH AXPUSH CXPUSH DXMOV AX,DATAMOV DS,AXINC TC ;采样周期变量加1CALL KJCLCCMP MARK,01HJC TT1INC VADDCMP VADD,0700H ;转速值溢出,赋极值JC TT1MOV VADD,0700HMOV MARK,00HTT1: MOV AL,20H ;中断结束,发EOI命令OUT 20H,ALPOP DXPOP CXPOP AXIRETTIMERISR ENDPKJ PROC NEAR ;PWM子程序CMP FPWM,01H ;PWM为1,产生PWM的高电平 JNZ TEST2CMP VAA,00HJNZ ANOT0MOV FPWM,02HMOV AL,BBBCLCRCR AL,01HMOV VBB,ALJMP TEST2ANOT0: DEC VAAMOV AL, 01H ;PB0=1 电机转动MOV DX, MY8255_BOUT DX,ALTEST2: CMP FPWM,02H ;PWM为2,产生PWM的低电平 JNZ OUTTCMP VBB,00HJNZ BNOT0MOV FPWM,01HMOV AL,AAAACLCRCR AL,01HMOV VAA,ALJMP OUTTBNOT0: DEC VBBMOV AL,00H ;PB0=0 电机停止MOV DX,MY8255_BOUT DX,ALOUTT: POP AXRETKJ ENDPPID: MOV AX,BX ;PID子程序SUB AX,YK ;求偏差EKMOV R0,AXMOV R1,AXSUB AX,EK_1MOV R2,AXSUB AX,AEK_1 ;求BEKMOV BEK,AXMOV R8,AXMOV AX,R1 ;求偏差变化量AEKMOV EK_1,AXMOV AX,R2MOV AEK_1,AXTEST R1,8000HJZ EK1 ;若偏差EK为正数,则不需要求补码 NEG R1 ;若偏差EK为负数,则求偏差EK的补码EK1: MOV AX,R1 ;判断偏差EK是否在积分分离值的范围内SUB AX,IBANDJC II ;在积分分离值范围内,则跳转到II,计算积分项MOV R3,00H ;若不在积分分离值范围内,则将积分项清0JMP DDD ;计算微分项II: MOV AL,TS ;计算积分项,结果放在R3变量中(R3=EK*TS/KII)MOV AH,00H ;其中TS和KII均为正数,所以R3的正负由EK决定MOV CX,R1MUL CXMOV CX,KIIDIV CXMOV R3,AXTEST R0,8000H ;判断积分项的正负JZ DDD ;为正数,则跳转去计算微分项NEG R3 ;为负数,则将积分项的结果求补码DDD: TEST BEK,8000H ;判断BEK的正负JZ DDD1 ;为正数,则BEK不变NEG BEK ;为负数,则求BEK的补码DDD1: MOV AX,BEK ;计算微分项(R4=KDD*BEK/8TS)MOV CX,KDDMUL CXPUSH AXPUSH DXMOV AL,TSMOV AH,00H ;将微分项缩小8倍,防止溢出MOV CX,0008HMUL CXMOV CX,AXPOP AXDIV CXMOV R4,AXTEST R8,8000H ;判断微分项的正负JZ DD1 ;为正数,则结果不需要求补码NEG R4 ;为负数,则微分项结果R4求补码DD1: MOV AX,R3 ;积分项和微分项相加,结果放在R5变量中ADD AX,R4MOV R5,AXJO L9 ;判断溢出L2: MOV AX,R5ADD AX,R2MOV R6,AX ;R6=R5+R2=积分项+微分项+AEKJO L3L5: MOV AX,R6 ;计算KPP*R6MOV CX,KPPIMUL CXMOV CX,1000HIDIV CXMOV CX,AXRCL AH,01H ;判断溢出,溢出赋极值PUSHFRCR AL,01HPOPFJC LLL1CMP CH,00HJZ LLL2MOV AL,7FHJMP LLL2LLL1: CMP CH,0FFHJZ LLL2MOV AL,80HLLL2: MOV R7,AL ;CK=CK_1+CKADD AL,CK_1JO L8L18: MOV CK_1,ALADD AL,80HMOV CK,ALRETL8: TEST R7,80H ;CK溢出处理程序JNZ L17MOV AL,7FH ;若为正溢出,则赋给正极值7FHL17: MOV AL,80H ;若为负溢出,则赋给赋极值80H JMP L18L9: TEST R3,8000HJNZ L1MOV R5,7FFFH ;若为正溢出,则赋给正极值7FFFH JMP L2L1: MOV R5,8000H ;若为负溢出,则赋给负极值8000H JMP L2L3: TEST R2,8000HJNZ L4MOV R6,7FFFHJMP L5L4: MOV R6,8000HJMP L5DALLY PROC NEAR ;软件延时子程序PUSH CXPUSH AXMOV CX,4000HD1: MOV AX,0600HD2: DEC AXJNZ D2LOOP D1POP AXPOP CXRETDALLY ENDPDECSHOW PROC NEAR ;完成两位十进制数显示子程序MOV DX,0MOV BX,10 ;计算AX/10DIV BXADD AL,30H ;商+30H,即为十位数ASCII码MOV AH,0EHINT 10HADD DL,30H ;余+30H,即为个位数ASCII码MOV AH,2INT 21HRETDECSHOW ENDPCODE ENDSEND START实验调试步骤:(1)确认从PC机引出的两根扁平电缆已经连接在实验平台上。