ImageVerifierCode 换一换
格式:DOC , 页数:32 ,大小:244KB ,
资源ID:3106825      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/3106825.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(中南大学机电一体化实验数字PIDpwm调压调速设计报告珍藏版.doc)为本站上传会员【胜****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

中南大学机电一体化实验数字PIDpwm调压调速设计报告珍藏版.doc

1、 基于单片机的数字PID控制直流电机 PWM调压调速器系统设计 所在学院: 机电工程学院 专业班级: 学生姓名: 学生学号: 30 目 录 PID简介及设计要求 错误!未定义书签。 设计原理与思路 错误!未定义书签。 设计方案 4 心得体会 7 PID简介及设计要求 PID (比例积分微分,英文全称为Prop

2、ortion Integration Differentiation)控制器由比例单元(P)、积分单元(I)和微分单元(D)组成。它是根据被控过程的特性确定PID控制器的比例系数、积分时间和微分时间的大小来实现自动控制,实际中也有PI和PD控制。简单来说,就是测量关心的变量,与期望值相比较,用这个误差纠正调节控制系统的响应。 问世至今已有近70年历史,它以其结构简单、稳定性好、工作可靠、调整方便而成为工业控制的主要技术之一。当被控对象的结构和参数不能完全掌握,或得不到精确的数学模型时,控制理论的 其它技术难以采用时,系统控制器的结构和参数必须依靠经验和现场调试来确定,这时应用PID控制技

3、术最为方便。即当我们不完全了解一个系统和被控对象,或不能通过有效的测量手段来获得系统参数时,最适合用PID控制技术。 PID控制器其输入e (t)与输出u (t)的关系为 u(t)=kp(e((t)+1/TI∫e(t)dt+TD*de(t)/dt) 式中积分的上下限分别是0和t 因此它的传递函数为:G(s)=U(s)/E(s)=kp(1+1/(TI*s)+TD*s)其中kp为比例系数; TI为积分时间常数; TD为微分时间常数。使用中只需设定三个参数(Kp,Ti和Td)即可。在很多情况下,并不一定需要全部三个单元,可以取其中的一到两个单元,但比例控制单元是必不可少的。 本次实

4、验就是应用数字PID模型作单片机控制编程,其中P、I、D参数可根据实际情况进行输入调节。利用单片机PWM输出调节施加于直流电机两端的电压,实现对直流电机的PID调压调速功能。 . 设计原理与思路 PID调速设计原理图 如图所示,此为一闭环控制系统: §反馈量 运用单片机来控制AD芯片来转换模拟电压到数字电压。具体过程如下:实际转速通过压频转换器转换为频率,输入AD转换芯片。直流电机实际转速越大,则AD给定的电压越大,则产生的数字量越大。再将通过AD转换后得到的八位二进制数输入单片机。单片机利用输入的实际频率值和预先设定的值进行比较

5、通过运算得到一个偏差。 §PID运算 借助单片机实现PID运算。PID调节器通过这个偏差进行PID运算,得到PWM的占空比值。如若实际的转速比期望转速小则这样就相当于加大了PWM的占空比,相当于增大直流电机的给定电压,要是比设定值大,这样也会得到一个偏差,就把这个变差与给定的电压向减,这样就可以减少PWM的占空比,同理则减小直流电机的给定电压,直到下一次PID运算。如此往复反馈调节,直到所得实际转速与期望转速接近,达到调节电动机速度的目的。 §PWM输出调制 PWM的意思是脉宽调节,也就是调节方波高电平和低电平的时间比。例如,一个20%占空比波形,会有20%的高电平时间和80

6、的低电平时间占空比越大,高电平时间越长,则输出的脉冲幅度越高,即电压越高。如果占空比为0%,那么高电平时间为0,则没有电压输出。如果占空比为100%,那么输出全部电压。所以通过调节占空比,可以实现调节输出电压的目的,而且输出电压可以无级连续调节。 §提高控制精度 为提高系统实际调节时的精度,在PID运算过程中所有数据均采用浮点数运算。在单片机应用系统的数据处理过程中,浮点数的结构相对复杂,但它能够以固定的字节长度保持相对精度不变,用较少的字节表示很大的数的范围,便于存储和运算,在处理的数据范围较大和要求精度较高时,采用浮点数。

7、 设计方案 1. 硬件介绍 在产生PWM波形我们采用ADC0809芯片和AT89C51两个核心器件。 ADC0809芯片是要外加电压和时钟,当输入不同的电压的时候,就可以把不同的电压模拟量转化为数字值,输入的电压越大,其转换的相应的数字也就会越大,ADC0809芯片有8个通道输入和8个通道输出。其具体的管脚图如下: ADC0809芯片管脚图 AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROM—Falsh Program

8、mable and Erasable Read Only Memory)的低电压,高性能CMOS8位微处理器,俗称单片机。AT89C51是一种带2K字节闪烁可编程可擦除只读存储器的单片机。AT89C51单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。外形及引脚排列如图所示 AT89C51芯片管脚图 2. PWM输出程序设计 PWM通过占空比来调节方波高电平和低电平的时间比。 由单片机进行控制的实际过程为:将单片机的P1.0 、P1.2与直流电机的电压输入端相接,利用定时器中断来置位复位P1.0 、P1.2来输出电压,于是我们就可以通过改变定时

9、器初值从而改变定时时间来决定输出方波的占空比。利用T0定时器产生时间为1ms的中断(当单片机晶振频率为12MHz时置初值为0FC18H),此为输出方波的周期。利用T1产生时间为0~1ms的中断(即定时器初值为0FC18H~0FFFFH之间,依据PID调节计算值决定),此为一个方波周期中高电平的时间。 将PID运算后得到的频率值转为定时器的初值,赋予定时器T1,即可改变控制电压的等效值。 %PWM源程序 ORG 0000H AJMP MAIN ORG 000BH AJMP INT0_P ORG 001BH AJMP INT1_P ORG 0030H MAIN

10、 MOV TMOD,#11H MOV TH0,#0FCH MOV TL0,#18H MOV TH1,#0 MOV TL1,#0 MOV R1,#0FCH MOV R0,#29H SETB TR0 SETB TR1 SETB EA SETB ET0 SETB ET1 SJMP $ INT0_P: MOV TH0,#0FCH MOV TL0,#18H MOV TH1,R1 MOV TL1,R0 SETB P1.0 SETB P1.2 SETB TR1 NOP RETI INT1_P: CLR P1.0 CLR

11、 P1.2 CLR TR1 NOP RETI END 3. 如何将实际转速采集输入单片机 直流电机在转动的过程中,光电开关会将实际的转速情况采集为电脉冲,再经压频转换器输入AD转换器。而实际输入单片机进行运算的并不是转速对应的频率值,而是经AD转换后的八位二进制数。因此,我们要求得频率值与AD转换后的八位二进制数的对应关系。具体过程如下: 1. 将单片机与串行数据显示器相连,利用串行数据显示器将输入单片机的八位二进制数显示。 2. 将直流电机与电源连接,启动运行。通过调节转换器上的可变电阻,使显示数据为0FEH时(此为保证数据准确,防止饱和失真),记录下

12、实际转速对应的频率值。 3. 计算转速频率值与AD转换后的八位二进制数的对应系数。 4.对PID控制器参数的调节 比例系数Kp对系统性能的影响: (1)对系统的动态性能影响:Kp加大,将使系统响应速度加快,Kp偏大时,系统振荡次数增多,调节时间加长;;Kp太小又会使系统的响应速度缓慢。Kp的选择以输出响应产生4:1衰减过程为宜。 (2)对系统的稳态性能影响:在系统稳定的前提下,加大Kp可以减少稳态误差,但不能消除稳态误差。因此Kp的整定主要依据系统的动态性能。 积分时间TI对系统性能的影响: (1)对系统的动态性能影响:积分控制通常影响系统的稳定性。TI太

13、小,系统可能不稳定,且振荡次数较多;TI太大,对系统的影响将削弱;当TI较适合时,系统的过渡过程特性比较理想。 (2)对系统的稳态性能影响:积分控制有助于消除系统稳态误差,提高系统的控制精度,但若TI太大,积分作用太弱,则不能减少余差。 微分时间TD对系统性能的影响: (1)对系统的动态性能影响:微分时间TD的增加即微分作用的增加可以改善系统的动态特性,如减少超调量,缩短调节时间等。适当加大比例控制,可以减少稳态误差,提高控制精度。但TD值偏大或偏小都会适得其反。另外微分作用有可能放大系统的噪声,降低系统的抗干扰能力。 (2)对系统的稳态性能影响:微分环节的加入,可以在误差出现或变

14、化瞬间,按偏差变化的趋向进行控制。它引进一个早期的修正作用,有助于增加系统的稳定性。 PID控制器的参数必须根据工程问题的具体要求来考虑。一般来说,要同时满足这些要求是很难做到的,必须根据系统的具体情况,满足主要的性能指标,同时兼顾其它方面的要求。 心得体会 本次实验完成了基于单片机的数字PID控制器的设计,并通过实验过程对PID参数进行调节,实现了对直流电机的调压调速过程。 世上无难事,只怕有心人。从最初接触到设计题目时些许的茫然到最终实验报告的完成,这其间并不是一帆风顺。在最初阶段查阅资料中,程序设计过程中,对PID参数的调节过程中我都遇到了一些问题。通过与张老师和

15、周围的同学交流讨论,在解决问题的同时,我不仅增长了知识也提高了发现问题解决问题的能力。此时,站在“山顶”回看来路,虽然付出的过程充满了坎坷,但成功的完成设计要求也给了我很大的鼓舞与前进的动力。而在今后的人生与工作中还有很多座大山等着我。 同时,细节决定成败!在程序设计的过程中,我遇到了平常容易忽视的一些问题,诸如数据存储器空间的复用,语句的书写错误,参数的符号错误等等。俗话说“千里之堤毁于蚁穴”,而这些看似细小的问题却导致了实验的失败,反复更正花费了大量时间。对于我们做工程的人,细节不容忽视!这也是我经过本次实验我的亲身认知。 此外,我想真诚地感谢张老师!在学习的过程中,一个方向比一个解答

16、更为重要!张老师为我们指明了方向,而“路”完全靠我们自己去走。在提高学生自主性的同时,也增加了学生的学习与思考的动力。无论实在程序设计过程中还是实验参数调节过程中与同学讨论,都使我受益匪浅。 附录:PID程序 EK0 EQU 40H EK1 EQU 43H EK2 EQU 46H KPP EQU 60H KII EQU 63H KDD EQU 66H PP EQU 76H II EQU 79H DD EQU 7CH AIM EQU 50H UK0 EQU 70H UK1 EQU 73H ORG 0000H

17、 AJMP MAIN ORG 000BH AJMP INT0_P ORG 001BH AJMP INT1_P ORG 0030H MAIN: LCALL SET0 SETB TR0 SETB TR1 SETB EA SETB ET0 SETB ET1 SJMP $ INT0_P: INC 4FH MOV R0,#4FH CJNE @R0,#20,UNDO LCALL INPUT MOV 4FH,#0 UNDO: MOV TH0,#0FCH MOV TL0,#18H MOV TH1,4DH MO

18、V TL1,4EH SETB P1.0 SETB P1.2 SETB TR1 NOP RETI INT1_P: CLR P1.0 CLR P1.2 CLR TR1 NOP RETI SET0: MOV 73H,#0 MOV 74H,#0 MOV 75H,#0;%UK1 MOV R0,#UK1 LCALL BTOF MOV 40H,#00H MOV 41H,#00H MOV 42H,#0 MOV R0,#EK0

19、 LCALL BTOF MOV 43H,#00H MOV 44H,#00H MOV 45H,#0;%EK1 MOV R0,#EK1 LCALL BTOF MOV 46H,#0 MOV 47H,#0 MOV 48H,#0;%EK2 MOV R0,#EK2 LCALL BTOF MOV 60H,#7FH MOV 61H,#10H MOV 62H,#0;%KPP

20、 MOV R0,#KPP LCALL BTOF MOV 63H,#7FH MOV 64H,#10H MOV 65H,#0;%KII MOV R0,#KII LCALL BTOF MOV 66H,#00H MOV 67H,#00H MOV 68H,#0;%KDD MOV R0,#KDD LCALL BTOF MOV 50H,#03H MOV 51H,#20H

21、 MOV 52H,#00H;%AIM频率期望值给定%%%%%%%%此值根据实际需要输入%%%%%% MOV R0,#AIM LCALL BTOF MOV 53H,#01H MOV 54H,#12H MOV 55H,#90H;%求取采样的八位二进制数与对应频率值之间的系数根据实际计算所得 MOV R0,#53H LCALL BTOF MOV TMOD,#11H MOV TH0,#0FCH MOV TL0,#18H MOV TH

22、1,#0 MOV TL1,#0 MOV 4DH,#0FCH MOV 4EH,#29H;%置定时器初值 RET INPUT: MOV DPTR,#0FEF0H MOV A,#0 MOVX @DPTR,A WAIT: JB P3.3,WAIT MOVX A,@DPTR;%实际值读入 MOV A,#0FFH; MOV 57H,A MOV 56H,#8 MOV 58H,#0;阶码赋值8,将AD读入的八位二进制转为浮点数

23、 MOV R0,#56H MOV R1,#53H;求得八位二进制数对应的频率 LCALL FMUL ;%计算偏差 MOV R1,#EK1 MOV R0,#EK2 LCALL FMOV MOV R1,#EK0 MOV R0,#EK1 LCALL FMOV MOV R1,#AIM MOV R0,#EK0 LCALL FMOV MOV R1,#56H LCA

24、LL FSUB ;%PP计算 MOV R1,#EK0 MOV R0,#PP LCALL FMOV MOV R1,#EK1 LCALL FSUB MOV R1,#KPP LCALL FMUL ;%II计算 MOV R0,#II MOV R1,#EK0 LCALL FMOV MOV R1,#KII LCALL FMUL ;%DD; MOV R1,#EK1 MOV R0,#4AH LCA

25、LL FMOV MOV A,4AH ADD A,#1 MOV 4AH,A;%阶码加一即原数乘以2; MOV R1,#EK0 MOV R0,#DD LCALL FMOV MOV R1,#4AH LCALL FSUB MOV R1,#EK2 LCALL FADD MOV R1,#KDD LCALL FMUL ;%PID MOV R0,#UK1 M

26、OV R1,#PP LCALL FADD MOV R1,#II LCALL FADD MOV R1,#DD LCALL FADD MOV R1,#UK1 MOV R0,#UK0;检验UK1是否在0~5之间; LCALL FMOV ;%对UK判定处理 MOV R0,#UK0 LCALL FSGN CJNE A,#1,SETZERO MOV 4AH,#01H MOV 4B

27、H,#50H MOV 4CH,#00H MOV R0,#4AH LCALL BTOF MOV R1,#UK0 LCALL FCMP JNC SETT MOV R0,#UK0 MOV R1,#4AH LCALL FMOV LJMP SETT SETZERO:LCALL FCLR ;%用UK计算T1的初值 SETT: MOV 4AH,#03H MOV 4BH,#20H MO

28、V 4CH,#00H MOV R0,#4AH LCALL BTOF MOV R1,#UK0 LCALL FMUL LCALL FTOD JC ZANDX CLR C CLR A SUBB A,4BH MOV 4BH,A CLR A SUBB A,4AH MOV 4AH,A CJNE A,#0FCH,FUZHI CLR C

29、 MOV A,#29H SUBB A,4BH JC FUZHI MOV 4BH,#29H LJMP FUZHI ZANDX: CLR C CLR A SUBB A,4AH MOV 4BH,A MOV 4AH,#0FFH FUZHI: MOV 4DH,4AH MOV 4EH,4BH RET ;浮点数格式化 FSDT: LCALL MVR0 ;将待格式化操作数传送到第一工作区中 LCALL RLN

30、 ;通过左规完成格式化 LJMP MOV0 ;将已格式化浮点操作数传回到[R0]中 ;FADD 功能:浮点数加法 FADD: CLR F0 ;设立加法标志 SJMP AS ;计算代数和 ;FSUB 功能:浮点数减法 FSUB: SETB F0 ;设立减法标志 AS: LCALL MVR1 ;计算代数和?先将[R1]传送到第二工作区 MOV C,F0 ;用加减标志来校正第二操作数的有效符号 RRC A XRL A,@R1 MOV C,ACC.7 ASN: MOV 1EH,C ;将第二操作数的有效符号存入位1EH中 XRL A,@R0 ;与第一操作数的符号比较 RLC

31、A MOV F0,C ;保存比较结果 LCALL MVR0 ;将[R0]传送到第一工作区中 LCALL AS1 ;在工作寄存器中完成代数运算 MOV0: INC R0 ;将结果传回到[R0]中的子程序入口 INC R0 MOV A,R4 ;传回尾数的低字节 MOV @R0,A DEC R0 MOV A,R3 ;传回尾数的高字节 MOV @R0,A DEC R0 MOV A,R2 ;取结果的阶码 MOV C,1FH ;取结果的数符 MOV ACC.7,C ;拼入阶码中 MOV @R0,A CLR ACC.7 ;不考虑数符 CLR OV ;清除溢出标志 CJNE

32、 A,#3FH,MV01;阶码是否上溢? SETB OV ;设立溢出标志 MV01: MOV A,@R0 ;取出带数符的阶码 RET MVR0: MOV A,@R0 ;将[R0]传送到第一工作区中的子程序 MOV C,ACC.7 ;将数符保存在位1FH中 MOV 1FH,C MOV C,ACC.6 ;将阶码扩充为8bit补码 MOV ACC.7,C MOV R2,A ;存放在R2中 INC R0 MOV A,@R0 ;将尾数高字节存放在R3中 MOV R3,A INC R0 MOV A,@R0 ;将尾数低字节存放在R4中 MOV R4,A DEC R0 ;恢复数

33、据指针 DEC R0 RET MVR1: MOV A,@R1 ;将[R1]传送到第二工作区中的子程序 MOV C,ACC.7 ;将数符保存在位1EH中 MOV 1EH,C MOV C,ACC.6 ;将阶码扩充为8bit补码 MOV ACC.7,C MOV R5,A ;存放在R5中 INC R1 MOV A,@R1 ;将尾数高字节存放在R6中 MOV R6,A INC R1 MOV A,@R1 ;将尾数低字节存放在R7中 MOV R7,A DEC R1 ;恢复数据指针 DEC R1 RET AS1: MOV A,R6 ;读取第二操作数尾数高字节 ORL A,

34、R7 JZ AS2 ;第二操作数为零,不必运算 MOV A,R3 ;读取第一操作数尾数高字节 ORL A,R4 JNZ EQ1 MOV A,R6 ;第一操作数为零,结果以第二操作数为准 MOV R3,A MOV A,R7 MOV R4,A MOV A,R5 MOV R2,A MOV C,1EH MOV 1FH,C AS2: RET EQ1: MOV A,R2 ;对阶,比较两个操作数的阶码 XRL A,R5 JZ AS4 ;阶码相同,对阶结束 JB ACC.7,EQ3;阶符互异 MOV A,R2 ;阶符相同,比较大小 CLR C SUBB A,R5 JC

35、 EQ4 EQ2: CLR C ;第二操作数右规一次 MOV A,R6 ;尾数缩小一半 RRC A MOV R6,A MOV A,R7 RRC A MOV R7,A INC R5 ;阶码加一 ORL A,R6 ;尾数为零否? JNZ EQ1 ;尾数不为零,继续对阶 MOV A,R2 ;尾数为零,提前结束对阶 MOV R5,A SJMP AS4 EQ3: MOV A,R2 ;判断第一操作数阶符 JNB ACC.7,EQ2;如为正,右规第二操作数 EQ4: CLR C LCALL RR1 ;第一操作数右规一次 ORL A,R3 ;尾数为零否? JNZ EQ1

36、不为零,继续对阶 MOV A,R5 ;尾数为零,提前结束对阶 MOV R2,A AS4: JB F0,AS5 ;尾数加减判断 MOV A,R4 ;尾数相加 ADD A,R7 MOV R4,A MOV A,R3 ADDC A,R6 MOV R3,A JNC AS2 LJMP RR1 ;有进位,右规一次 AS5: CLR C ;比较绝对值大小 MOV A,R4 SUBB A,R7 MOV B,A MOV A,R3 SUBB A,R6 JC AS6 MOV R4,B ;第一尾数减第二尾数 MOV R3,A LJMP RLN ;结果规格化 AS6: CPL

37、 1FH ;结果的符号与第一操作数相反 CLR C ;结果的绝对值为第二尾数减第一尾数 MOV A,R7 SUBB A,R4 MOV R4,A MOV A,R6 SUBB A,R3 MOV R3,A RLN: MOV A,R3 ;浮点数规格化 ORL A,R4 ;尾数为零否? JNZ RLN1 MOV R2,#0C1H;阶码取最小值 RET RLN1: MOV A,R3 JB ACC.7,RLN2;尾数最高位为一否? CLR C ;不为一,左规一次 LCALL RL1 SJMP RLN ;继续判断 RLN2: CLR OV ;规格化结束 RET RL1:

38、 MOV A,R4 ;第一操作数左规一次 RLC A ;尾数扩大一倍 MOV R4,A MOV A,R3 RLC A MOV R3,A DEC R2 ;阶码减一 CJNE R2,#0C0H,RL1E;阶码下溢否? CLR A MOV R3,A ;阶码下溢,操作数以零计 MOV R4,A MOV R2,#0C1H RL1E: CLR OV RET RR1: MOV A,R3 ;第一操作数右规一次 RRC A ;尾数缩小一半 MOV R3,A MOV A,R4 RRC A MOV R4,A INC R2 ;阶码加一 CLR OV ;清溢出标志 CJNE

39、R2,#40H,RR1E;阶码上溢否? MOV R2,#3FH ;阶码溢出 SETB OV RR1E: RET ;FMUL 功能:浮点数乘法 FMUL: LCALL MVR0 ;将[R0]传送到第一工作区中 MOV A,@R0 XRL A,@R1 ;比较两个操作数的符号 RLC A MOV 1FH,C ;保存积的符号 LCALL MUL0 ;计算积的绝对值 LJMP MOV0 ;将结果传回到[R0]中 MUL0: LCALL MVR1 ;将[R1]传送到第二工作区中 MUL1: MOV A,R3 ;第一尾数为零否? ORL A,R4 JZ MUL6 MOV A,

40、R6 ;第二尾数为零否? ORL A,R7 JZ MUL5 MOV A,R7 ;计算R3R4×R6R7-→R3R4 MOV B,R4 MUL AB MOV A,B XCH A,R7 MOV B,R3 MUL AB ADD A,R7 MOV R7,A CLR A ADDC A,B XCH A,R4 MOV B,R6 MUL AB ADD A,R7 MOV R7,A MOV A,B ADDC A,R4 MOV R4,A CLR A RLC A XCH A,R3 MOV B,R6 MUL AB ADD A,R4 MOV R4,A MOV A,

41、B ADDC A,R3 MOV R3,A JB ACC.7,MUL2;积为规格化数否? MOV A,R7 ;左规一次 RLC A MOV R7,A LCALL RL1 MUL2: MOV A,R7 JNB ACC.7,MUL3 INC R4 MOV A,R4 JNZ MUL3 INC R3 MOV A,R3 JNZ MUL3 MOV R3,#80H INC R2 MUL3: MOV A,R2 ;求积的阶码 ADD A,R5 MD: MOV R2,A ;阶码溢出判断 JB ACC.7,MUL4 JNB ACC.6,MUL6 MOV R2,#3FH ;

42、阶码上溢,设立标志 SETB OV RET MUL4: JB ACC.6,MUL6 MUL5: CLR A ;结果清零(因子为零或阶码下溢) MOV R3,A MOV R4,A MOV R2,#41H MUL6: CLR OV RET ;FCLR 功能:浮点数清零 FCLR: INC R0 INC R0 CLR A MOV @R0,A DEC R0 MOV @R0,A DEC R0 MOV @R0,#41H RET ;FMOV 功能:浮点数传送 FMOV: INC R0 INC R0 INC R1 INC R1 MOV A,@R1 MOV @

43、R0,A DEC R0 DEC R1 MOV A,@R1 MOV @R0,A DEC R0 DEC R1 MOV A,@R1 MOV @R0,A RET ;FCMP 功能:浮点数代数值比较(不影响待比较操作数) FCMP: MOV A,@R0 ;数符比较 XRL A,@R1 JNB ACC.7,CMP2 MOV A,@R0 ;两数异号,以[R0]数符为准 RLC A MOV A,#0FFH RET CMP2: MOV A,@R1 ;两数同号,准备比较阶码 MOV C,ACC.6 MOV ACC.7,C MOV B,A MOV A,@R0 MOV C

44、ACC.7 MOV F0,C ;保存[R0]的数符 MOV C,ACC.6 MOV ACC.7,C CLR C ;比较阶码 SUBB A,B JZ CMP6 RLC A ;取阶码之差的符号 JNB F0,CMP5 CPL C ;[R0]为负时,结果取反 CMP5: MOV A,#0FFH ;两数不相等 RET CMP6: INC R0 ;阶码相同时,准备比较尾数 INC R0 INC R1 INC R1 CLR C MOV A,@R0 SUBB A,@R1 MOV B,A ;保存部分差 DEC R0 DEC R1 MOV A,@R0 SUBB A

45、@R1 DEC R0 DEC R1 ORL A,B ;生成是否相等信息 JZ CMP7 JNB F0,CMP7 CPL C ;[R0]为负时,结果取反 CMP7: RET ;FSGN 功能:浮点符号函数 FSGN: INC R0 ;读尾数 MOV A,@R0 INC R0 ORL A,@R0 DEC R0 DEC R0 JNZ SGN RET ;尾数为零,结束 SGN: MOV A,@R0 ;读取操作数的阶码 RLC A ;取数符 MOV A,#1 ;按正数初始化 JNC SGN1 ;是正数,结束 MOV A,#0FFH ;是负数,改变标志 SGN

46、1: RET ;DTOF 功能:双字节十六进制定点数转换成格式化浮点数 DTOF: MOV R2,A ;按整数的位数初始化阶码 MOV A,@R0 ;将定点数作尾数 MOV R3,A INC R0 MOV A,@R0 MOV R4,A DEC R0 LCALL RLN ;进行规格化 LJMP MOV0 ;传送结果到[R0]中 ;FTOD 功能:格式化浮点数转换成双字节定点数 FTOD: LCALL MVR0 ;将[R0]传送到第一工作区 MOV A,R2 JZ FTD4 ;阶码为零,纯小数 JB ACC.7,FTD4;阶码为负,纯小数 SETB C SUBB

47、A,#10H JC FTD1 SETB OV ;阶码大于16,溢出 RET FTD1: SETB C MOV A,R2 SUBB A,#8 ;阶码大于8否? JC FTD3 FTD2: MOV B,#10H ;阶码大于8,按双字节整数转换 LCALL FTD8 SETB F0 ;设立双字节整数标志 CLR C CLR OV RET FTD3: MOV B,#8 ;按一字节整数一字节小数转换 LCALL FTD8 SETB C ;设立一字节整数一字节小数标志 CLR F0 CLR OV RET FTD4: MOV B,#0 ;按纯小数转换 LCALL F

48、TD8 CLR OV ;设立纯小数标志 CLR F0 CLR C RET FTD8: MOV A,R2 ;按规定的整数位数进行右规 CJNE A,B,FTD9 MOV A,R3 ;将双字节结果传送到[R0]中 MOV @R0,A INC R0 MOV A,R4 MOV @R0,A DEC R0 RET FTD9: CLR C LCALL RR1 ;右规一次 SJMP FTD8 ;BTOF 功能:浮点BCD码转换成格式化浮点数 BTOF: INC R0 ;判断是否为零? INC R0 MOV A,@R0 MOV R7,A DEC R0 MOV A,@

49、R0 MOV R6,A DEC R0 ORL A,R7 JNZ BTF0 MOV @R0,#41H;为零,转换结束? RET BTF0: MOV A,@R0 MOV C,ACC.7 MOV 1DH,C ;保存数符? CLR 1FH ;以绝对值进行转换? MOV C,ACC.6 ;扩充阶码为八位? MOV ACC.7,C MOV @R0,A JNC BTF1 ADD A,#19 ;是否小于1E-19? JC BTF2 MOV @R0,#41H;小于1E-19时以0计? INC R0 MOV @R0,#0 INC R0 MOV @R0,#0 DEC R0

50、 DEC R0 RET BTF1: SUBB A,#19 JC BTF2 MOV A,#3FH ;大于1E19时封顶? MOV C,1DH MOV ACC.7,C MOV @R0,A INC R0 MOV @R0,#0FFH INC R0 MOV @R0,#0FFH DEC R0 DEC R0 RET BTF2: CLR A ;准备将BCD码尾数转换成十六进制浮点数? MOV R4,A MOV R3,A MOV R2,#10H ;至少两个字节? BTF3: MOV A,R7 ADD A,R7 DA A MOV R7,A MOV A,R6 ADD

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服