《匠人手记》推荐网上购书渠道:
  互动出版网(china-pub)   >>>
  当当网(dangdang)   >>>
  卓越亚马逊网    >>>
  淘宝网(taobao)   >>>
  更多购书渠道……   >>> 

设为首页加入收藏联系匠人管理入口21IC首页21IC博客21IC社区侃单片机回复的贴参与的贴新100贴

载入中...

广告3号位
百宝日历
载入中...

百宝专栏

说明:请先返回首页,再点击下列专栏即可进入。
  • 首页 相册 标签
  • 匠人公告(87)
  • 匠人笔记(144)
  • 匠人文集(167)
  • 写书近况(189)
  • 团队撰写(96)
  • 与非门专栏(566)
  • 比尔熊专栏(12)
  • 网络酷文(492)
  • 程序宝典(477)
  • 程序算法(28)
  • 编程技巧(482)
  • 资料宝藏(280)
  • 硬件技术(178)
  • 汽车电子(52)
  • 藏经宝阁(47)
  • 项目管理(15)
  • 趣味设计(6)
  • 社区热贴(5)
  • 开发工具(19)
  • 电脑应用(66)
  • 供需信息(24)
  • 最新货色

    载入中...

    粉丝评论

    载入中...

    载入中...



    百宝信息

    载入中...

    百宝流量

    (2006-07-01开始)


    匠人手记

    购书攻略勘误表

    开发板专卖——淘宝店

     编程技巧: 优质代码的十诫

    PIC 运算子程序(4)
    程序匠人 发表于 2005-5-21 11:07:00  阅读全文 | 回复(0) | 引用通告 | 编辑

               3.3  浮点数除法子程序
                以下为浮点数除法子程序清单。
                    LIST            p=16f877
                    INCLUDE        p16f877.inc
                    ACCALO         EQU     20        ;存放除数的尾数

                    ACCAHI         EQU     21
                    EXPA        EQU     22        ;存放除数的阶码
                    ACCBLO         EQU     23        ;存放被除数的尾数和商的尾数
                    ACCBHI         EQU     24
                    EXPB         EQU     25        ;存放被除数和商的阶码
                    ACCCLO         EQU     26        ;存放余数
                    ACCCHI         EQU     27
                    ACCDLO         EQU     28        ;临时寄存器
                    ACCDHI         EQU     29        ;临时寄存器
                    TEMP         EQU     2A        ;临时寄存器
                    TEMP1         EQU     30        ;临时寄存器
                    TIMES         EQU     31        ;临时寄存器
                    SIGN         EQU     2B        ;存放商的符号
                    COUNT         EQU     2F        ;临时寄存器
                    ACCEHI        EQU    30        ;临时寄存器
                    ACCELO        EQU    31        ;临时寄存器
                    ORG            0X0000
                START    GOTO        MAIN
                    ORG            0X0100
                ;***浮点数除法子程序,入口地址(ACCB、EXPB)/(ACCA、EXPA),出口地址ACCB、EXPB***
                F_div    CALL         S_SIGN        ;确定商的符号,并将负数取补
                    CLRF        ACCCHI        ;初始化ACCC寄存器
                    CLRF         ACCCLO
                    CALL         F_norm        ;规格化ACCB
                    CLRF         ACCCLO
                    CLRF         ACCCHI
                    CLRF         TIMES
                    MOVF         ACCAHI        ;除数为零?
                    BTFSS         STATUS,Z
                    GOTO         FD0            ;否,求商
                    MOVF         ACCALO
                    BTFSC         STATUS,Z
                    RETLW         01            ;是,返回
                FD0    CALL         NEG_A        ;除数取补
                FD1    MOVF         ACCBHI,0    ;ACCBHI送ACCDLO
                    MOVWF         ACCDLO
                    CALL         D_add1        ;被除数尾数大于除数尾数?
                    BTFSS         STATUS,C
                    GOTO         FD2
                RRF1    BCF             STATUS,C    ;是,被除数右移规格化,直到小于除数为止
                    RRF             ACCBHI
                    RRF             ACCBLO
                    INCF         TIMES
                    RRF             ACCCHI
                    BCF             STATUS,C
                    GOTO         FD1
                FD2    CALL         DDIV        ;否,调用双字节除法子程序,求商的尾数
                    MOVF         TIMES,0        ;根据右移规格化次数调整ACCB阶码
                    ADDWF         EXPB
                    MOVF         EXPA,0        ;求商的阶码
                    SUBWF         EXPB
                    CALL         F_norm        ;商规格化
                    BTFSC         SIGN,7        ;商为负?
                    CALL         NEG_B        ;是,取补
                    CALL         NEG_A        ;除数还原
                    RETURN                    ;浮点数除法完成,返回
                ;***********双字节纯小数除法子程序***************
                DDIV    MOVLW         0X0F            ;初始化ACCDHI
                    MOVWF         ACCDHI
                DV1    BCF             STATUS,C
                    RLF             ACCCLO        ;左移商
                    RLF             ACCCHI
                    RLF             ACCBLO        ;左移余数
                    RLF             ACCBHI
                    MOVF         STATUS,0    ;暂存STATUS寄存器
                    MOVWF         ACCDLO
                    MOVF         ACCBHI,0    ;ACCBHI送TEMP1
                    MOVWF         TEMP1
                    MOVF         ACCALO,0    ;ACCB-ACCA
                    ADDWF         ACCBLO,0
                    MOVWF         TEMP
                    BTFSC         STATUS,C       
                    INCF         TEMP1           
                    MOVF         ACCAHI,0       
                    ADDWF         TEMP1,0
                    BTFSC         ACCDLO,0    ;左移余数时移出来的数为1?
                    GOTO         DV2
                TESTC    BTFSS         STATUS,C    ;是,再判断ACCB尾数是否大于ACCA
                    GOTO         DV3
                DV2    MOVWF         ACCBHI        ;是,余数送ACCB
                    MOVF         TEMP,0
                    MOVWF         ACCBLO
                    INCF         ACCCLO        ;商加1
                DV3    DECFSZ        ACCDHI        ;商求取完毕?
                    GOTO         DV1
                    MOVF         ACCCHI,0    ;是,将商送ACCB
                    MOVWF         ACCBHI
                    MOVF         ACCCLO,0
                    MOVWF         ACCBLO
                    RETLW         00   
                ;**********本子程序用于判断比较ACCB与ACCA的大小**********
                D_add1    MOVF         ACCALO,0    ;加数、被加数低半字节相加
                    ADDWF         ACCBLO,0
                    BTFSC         STATUS,C    ;有进位?
                    INCF         ACCDLO        ;ACCD低半字节加1
                    MOVF         ACCAHI,0       ;ACCAHI+ACCDLO
                    ADDWF         ACCDLO
                    RETLW         0            ;子程序返回
                ;****************************************
                SETUP    MOVLW         .15
                    MOVWF         TEMP
                    MOVF         ACCBHI,0
                    MOVWF         ACCDHI
                    MOVF         ACCBLO,0
                    MOVWF         ACCDLO
                    CLRF         ACCBHI
                    CLRF         ACCBLO
                    RETLW         0
                ;*************** ACCA取补子程序*************
                NEG_A    COMF         ACCALO        ;ACCALO取反加1
                    INCF         ACCALO
                    BTFSC         STATUS,Z    ;低8位有进位吗?
                    DECF         ACCAHI        ;有,ACCAHI减1,再取反
                    COMF         ACCAHI        ;否,ACCAHI直接取反
                    RETLW         0
                ;********* ACCB取补子程序*************
                NEG_B    DECF         ACCBLO        ;ACCBLO取反加1
                    COMF         ACCBLO
                    BTFSC         STATUS,Z    ;低8位有进位吗?
                    DECF         ACCBHI        ;有,ACCBHI减1,再取反
                    COMF         ACCBHI        ;否,ACCBHI直接取反
                    RETLW         0       
                ;*********浮点乘除法运算确定结果符号子程序**********
                S_SIGN    MOVF        ACCAHI,0    ;ACCAHI异或ACCBHI,结果送SIGN单元
                    XORWF         ACCBHI,0
                    MOVWF         SIGN           
                    BTFSS         ACCBHI,7    ;ACCB为负?
                    GOTO         CHEK_A        ;否,检查ACCA
                    COMF         ACCBLO        ;是,ACCB取补
                    INCF         ACCBLO
                    BTFSC         STATUS,Z
                    DECF         ACCBHI
                    COMF         ACCBHI
                CHEK_A        BTFSC         ACCAHI,7    ;ACCA为负?
                    CALL         NEG_A        ;ACCA为负,取补
                    RETLW         0            ;ACCA和ACCB均为负,返回
                ;************浮点运算结果规格化子程序***************
                F_norm      MOVF         ACCBHI        ;ACCB=0?
                    BTFSS         STATUS,Z
                    GOTO         C_norm
                    MOVF         ACCBLO
                    BTFSC         STATUS,Z
                    RETLW         0            ;是,不需规格化,返回
                C_norm    BTFSC        ACCBHI,7    ;否。ACCB为负?
                     GOTO        C_norm2
                C_norm1    BTFSC         ACCBHI,6    ;为正。规格化完毕?
                    RETLW         0            ;ACCBHI.6=1,规格化结束
                    CALL         SHFTSL        ;否。ACCB左移
                    DECF         EXPB        ;EXPB减1
                    GOTO         C_norm1        ;重新判断规格化完毕否?
                C_norm2    BTFSS        ACCBHI,6    ;ACCB为负。规格化完毕否?
                    RETLW        0            ;ACCBHI.6=0,规格化结束
                    BCF            STATUS,C   
                    CALL        SHFTSL        ;否,ACCB左移
                    BSF            ACCBHI,7    ;加符号
                    DECF        EXPB        ;EXPB减1
                    GOTO        C_norm2        ;重新判断规格化完毕否?
                SHFTSL    BCF             STATUS ,C    ;ACCB左移子程序   
                    RLF             ACCCLO       
                    RLF             ACCCHI
                    RLF             ACCBLO
                    RLF             ACCBHI
                    RETLW         0
                【校验举例1】 0.0019531÷(-0.00016594)=-12.7699
                化为十六进制数:4000F8÷A900F4
                结果:A1D704
                【校验举例2】 0.26222÷3.5025=0.074867
                化为十六进制数: 4321FF÷701502
                结果:4CA9FD
                【例程】
                MAIN        MOVLW        0X21            ;被除数的尾数4321H送ACCB
                    MOVWF        ACCBLO
                    MOVLW        0X43
                    MOVWF        ACCBHI
                        MOVLW        0XFF            ;被除数的阶码FFH送EXPB
                        MOVWF        EXPB
                    MOVLW        0X15            ;除数尾数7015H送ACCA
                    MOVWF        ACCALO
                    MOVLW        0X70
                    MOVWF        ACCAHI
                    MOVLW        0X02            ;除数阶码送EXPA
                    MOVWF        EXPA
                    CALL        F_div            ;调用浮点数除法子程序,求商
                    END

    看《匠人手记》,与匠人同行!北航出版,正在热卖!

    发表评论:
    载入中...

    芯片专题

    器件专题

    软件专题

    硬件专题

    综合专题

    项目专题

    原创专题

    器件检测
    LCD LED
    按键 触摸键
    E2PROM
    电池 电机
    电阻 电容 电感

    指令系统
    软件算法
    编程规范
    滤波算法
    串行通讯

    PCB设计
    I2C PWM
    红外遥控
    充电技术
    中断 ADC 

    匠人手记
    匠人夜话
    网络心路
    一周热点串烧
    从零开始玩PIC
    DIY旋转时钟

    广告5号位 [投放]

    广告3号位 [投放]

    站内搜索


    站外搜索


    百度  google
    mp3  歌词 
    图片  FLASH 
    知道  文档
    新闻  词典 
    地图  mp3 
    软件  天网 
    雅虎  爱问 
    搜狗  讯雷 
    网讯  华军 
    天空 

    21IC器件搜索
    百宝箱分站
  • 《匠人的百宝箱》21IC站
  • 《匠人的百宝箱》21IC笔记团队
  • 《匠人手记》21IC书友会
  • 《匠人的百宝箱》MCUBLOG站
  • 《匠人的百宝箱》MCUBLOG笔记团队
  • 《匠人的百宝箱》EDN站
  • 《匠人手记》EDN书友会
  • 《匠人的百宝箱》废站
  • 《匠人的百宝箱》土豆视频站
  • 《匠人的百宝箱》新浪站
  • 《匠人的百宝箱》百度站
  • 《匠人的百宝箱》网易126站
  • 《匠人的百宝箱》网易163站
  • 《匠人的百宝箱》互动出版网站
  • 广告4号位 [投放]

     

    推荐阅读

     

    友情连接

     [更多酷站连接]

     

     

     

     

    [欢迎交换连接]

    [百宝箱之与非门分舵]

    [电脑圈圈的家当]

    [IC921的博客]

    [hotpower 的水潭]

    [八楼的呼吸]

    [柔月阁]

    [PIC论坛]

    [SMARTCODE电子书斋]

    [阿摆手记]

    [电子伙伴]

    [xwj的文君阁]

    [所长的BLOG]

    [海边淘沙]

    [单片机开发联盟]

    [数字电视之家]

    [软件开发之窗]

    [unaided的笔记]

    [小飞的笔记]

    [ICC AVR开发网]

    [我爱研发网]

    [infernal的笔记]

    [网址之家]

    [好东西网址大全]

    [美萍中文精选]

    [水牛的仓库]

    [逍遥电子]

    [ningpanda的博客]

    [雄鹰的空中加油站]

    [一网见天下]

    [Armoric]

    [股剩是怎样炼成的]

    [嵌入式365]

    [C-Design]

    [AVR猎手的地盘]

    [中国高校自动化网]

    [SunK]

    [工控365网]

    [煮透社]

    [白沙的香烟盒]

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

    大学生电子网 

     

     

     

     

     

     

     

     《匠人的百宝箱》