《匠人手记》推荐网上购书渠道:
  互动出版网(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 运算子程序(3)
    程序匠人 发表于 2005-5-21 11:05:00  阅读全文 | 回复(0) | 引用通告 | 编辑

                3.2  浮点数乘法子程序
                以下为浮点数乘法的程序清单。
                    LIST            p=16f877
                    INCLUDE        p16f877.inc
                    ACCALO         EQU     20        ;存放乘数尾数
                    ACCAHI         EQU     21
                    EXPA        EQU     22        ;存放乘数阶码
                    ACCBLO         EQU     23        ;存放被乘数尾数和乘积高16位
                    ACCBHI         EQU     24
                    EXPB         EQU     25        ;存放被乘数阶码
                    ACCCLO         EQU     26        ;存放乘积低16位
                    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_mpy    CALL         S_SIGN        ;求取乘积的符号,并对负数取补
                     CALL         SETUP        ;调用子程序将ACCB的值送ACCD
                    CLRF         ACCCHI        ;清ACCC
                    CLRF         ACCCLO
                MLOOP    BCF             STATUS,C    ;清进位位
                    RRF             ACCDHI        ;ACCD右移
                    RRF             ACCDLO
                    BTFSC         STATUS,C    ;判断是否需要相加
                    CALL         D_add        ;加乘数至ACCB
                    BCF             STATUS,C    ;清进位位
                    RRF             ACCBHI        ;右移部分乘积
                    RRF             ACCBLO
                    RRF             ACCCHI
                    RRF             ACCCLO
                    DECFSZ         TEMP        ;乘法完成否?
                    GOTO         MLOOP        ;否,继续循环
                    MOVF         EXPA,0        ;是,乘数与被乘数阶码相加,得积的阶码
                    ADDWF        EXPB
                    MOVF         ACCBHI        ;ACCBHI=0?
                    BTFSS         STATUS,Z
                    GOTO         FINUP        ;否,转FINUP
                    MOVF         ACCBLO        ;ACCB=0?
                    BTFSS         STATUS ,Z
                    GOTO         SHFT08        ;否,只有ACCBHI=0,转SHFT08
                    MOVF         ACCCHI,0    ;ACCB=0,将乘积左移15位
                    MOVWF         ACCBHI
                    MOVF         ACCCLO,0
                    MOVWF         ACCBLO
                    BCF             STATUS,C
                    RRF             ACCBHI
                    RRF             ACCBLO
                    MOVLW         .15            ;乘积阶码减15(十进制数)
                    SUBWF         EXPB
                    GOTO         FINUP
                SHFT08    MOVF         ACCBLO,0    ;只有ACCBHI=0,乘积左移7位
                    MOVWF         ACCBHI
                    MOVF         ACCCHI,0
                    MOVWF         ACCBLO
                    BCF             STATUS,C
                    RRF             ACCBHI
                    RRF             ACCBLO
                    MOVLW         .7            ;乘积阶码减7
                    SUBWF         EXPB
                FINUP    CALL         F_norm        ;对乘积进行规格化
                    BTFSS         SIGN,7        ;确定乘积的符号
                    GOTO         OVER        ;为正,乘法结束
                    COMF         ACCCLO        ;为负,乘积取补
                    INCF         ACCCLO
                    BTFSC         STATUS,Z
                    DECF         ACCCHI
                    COMF         ACCCHI
                    BTFSC         STATUS,Z
                NEG_B    DECF         ACCBLO
                    COMF         ACCBLO
                    BTFSC         STATUS,Z
                    DECF         ACCBHI
                    COMF         ACCBHI
                OVER    RETURN                    ;乘法结束,子程序返回
                ;********浮点乘除法运算确定结果符号子程序***********
                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取补
                    RETURN                    ;返回
                ;*********浮点运算结果规格化子程序*************
                F_norm      MOVF         ACCBHI        ;ACCB=0?
                    BTFSS         STATUS,Z
                    GOTO         C_norm
                    MOVF         ACCBLO
                    BTFSC         STATUS,Z
                    RETURN                    ;是,不需规格化,返回
                C_norm    BTFSC        ACCBHI,7    ;否。ACCB为负?
                     GOTO        C_norm2
                C_norm1    BTFSC         ACCBHI,6    ;为正。规格化完毕?
                    RETURN                    ;ACCBHI.6=1,规格化结束
                    CALL         SHFTSL        ;否。ACCB左移
                    DECF         EXPB        ;EXPB减1
                    GOTO         C_norm1        ;重新判断规格化完毕否?
                C_norm2    BTFSS        ACCBHI,6    ;ACCB为负。规格化完毕否?
                    RETURN                    ;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
                    RETURN
                【校验举例1】 0.0019531×(-0.00016594)=-0.000000324
                化为十六进制数:4000F8×A900F4
                结果:A900EB
                【校验举例2】 0.26222×3.5025=0.91842
                化为十六进制数: 4321FF×701502
                结果:758F00
                【例程】
                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_mpy        ;调用浮点数乘法子程序,求积
                    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网]

    [煮透社]

    [白沙的香烟盒]

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

    大学生电子网 

     

     

     

     

     

     

     

     《匠人的百宝箱》