亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? float.asm

?? PIC系列單片機(jī)典型應(yīng)用程序集
?? ASM
字號(hào):
;*******************************************************************
;       Binary Floating Point Addition, Subtraction, Multiplication
;                       and Divide routines.
;
;*******************************************************************;
;
;   Addition :  ACCb(16 bits) + ACCa(16 bits) -> ACCb(16 bits)
;      (a) Load the 1st operand in location ACCaLO & ACCaHI ( 16 bits ) with
;          the 8 bit exponent in EXPa.
;      (b) Load the 2nd operand in location ACCbLO & ACCbHI ( 16 bits ) with
;          the 8 bit exponent in EXPb.
;      (c) CALL F_add
;      (d) The result is in location ACCbLO & ACCbHI ( 16 bits ) with
;          the 8 bit exponent in EXPb
;
;       Program Memory :        55 locations
;
;*******************************************************************;
;
;   Subtraction : ACCb(16 bits) - ACCa(16 bits) -> ACCb(16 bits)
;      (a) Load the 1st operand in location ACCaLO & ACCaHI ( 16 bits ) with
;          the 8 bit exponent in EXPa .
;      (b) Load the 2nd operand in location ACCbLO & ACCbHI ( 16 bits ) with
;          the 8 bit exponent in EXPb .
;      (c) CALL F_sub
;      (d) The result is in location ACCbLO & ACCbHI ( 16 bits ) with
;          the 8 bit exponent in EXPb.
;
;       Program Memory :        61 locations
;
;*******************************************************************;
;
;   Multiplication :
;   ACCb(16 bits)EXP(b) * ACCa(16 bits)EXPa -> ACCb(16 bits)EXPb
;   where, EXP(x) represents an 8 bit exponent.
;      (a) Load the 1st operand in location ACCaLO & ACCaHI ( 16 bits ) with
;                               an 8 bit exponent in location EXPa
;      (b) Load the 2nd operand in location ACCbLO & ACCbHI ( 16 bits ) with
;                               an 8 bit exponent in location EXPb
;      (c) CALL F_mpy
;      (d) The 16 bit result overwrites ACCb(ACCbLO & ACCbHI). The exponent
;               is stored in EXPb and the results are normalized.
;
; NOTE : If one needs to get a 32 bit product( & an 8 bit exponent ),
;        re assemble the program after changing the line " Mode16 equ TRUE"
;        to " Mode16  equ  FALSE ".
;        If this option is chosen, then the 32 bit result is returned in
;        ( ACCbHI, ACCbLO, ACCcHI, ACCcLO ) and the 8 bit exponent in EXPb.
;        This method ( with " Mode16 equ FALSE " ) is NOT Recommended.
;
;       Program Memory :        102 locations
;
;*******************************************************************;
;
;   Division :
;       ACCb(16 bits)EXP(b) / ACCa(16 bits)EXP(a) -> ACCb(16 bits)EXP(b)
;                                       with Remainder in ACCc (16 bits)
;      (a) Load the Denominator in location ACCaHI & ACCaLO ( 16 bits )
;                                               with exponent in EXPa
;      (b) Load the Numerator in location ACCbHI & ACCbLO ( 16 bits )
;                                               with exponent in EXPa
;      (c) CALL F_div
;      (d) The 16 bit result is in location ACCbHI & ACCbLO
;                                       with exponent in EXPb
;      (e) The 16 bit Remainder is in locations ACCcHI & ACCcLO
;
;       Program Memory :        86 locations
;
;*******************************************************************;
;
ACCaLO  equ     10
ACCaHI  equ     11
EXPa    equ     12
ACCbLO  equ     13
ACCbHI  equ     14
EXPb    equ     15
ACCcLO  equ     16
ACCcHI  equ     17
ACCdLO  equ     18
ACCdHI  equ     19
temp    equ     1A
sign    equ     1B
;
	include "picreg.h"
;
Mode16  equ     TRUE            ; Change this to FALSE if a 32 bit propduct
;                               ; is desired for F_mpy routine.
;
	org     0
;*******************************************************************
;       Floating Point Subtraction  ( ACCb - ACCa -> ACCb )
;
F_sub   call    neg_A           ; At first negate ACCa; Then add
;
F_add   movf    EXPa,w          ; scale mantissas
	subwf   EXPb,w          ; find the greater exponent
	btfsc   STATUS,Z_bit
	goto    padd            ; exponents are equal
	btfsc   STATUS,CARRY    ;
	call    F_swap          ; if A > B then swap ( A<->B )
	movf    EXPa,w
	subwf   EXPb
scloop  call    shftSR
	incfsz  EXPb
	goto    scloop
	movf    EXPa,w
	movwf   EXPb
padd    movf    ACCaHI,w
	iorwf   ACCbHI,w
	movwf   sign
	call    D_add           ; compute double precision integer add
	btfss   sign,MSB
	btfss   ACCbHI,MSB
	retlw   0
	bcf     STATUS,CARRY
	incf    EXPb
	goto    shftR
;
;*******************************************************************
;         Double Precision Subtraction ( ACCb - ACCa -> ACCb )
;
D_sub   call    neg_A           ; At first negate ACCa; Then add
;
D_add   movf    ACCaLO,w        ; Addition ( ACCb + ACCa -> ACCb )
	addwf   ACCbLO          ;add lsb
	btfsc   STATUS,CARRY    ;add in carry
	incf    ACCbHI
	movf    ACCaHI,w
	addwf   ACCbHI            ;add msb
	retlw   0
;*******************************************************************
;
;
shftSR  bcf     STATUS,CARRY
	btfsc   ACCbHI,MSB
	bsf     STATUS,CARRY            ; set carry if < 0
shftR   rrf     ACCbHI
	rrf     ACCbLO
	retlw   0
;
shftSL  bcf     STATUS,CARRY
;
	if   Mode16
	rlf     ACCcLO
	rlf     ACCcHI
	endif
;
	rlf     ACCbLO
	rlf     ACCbHI
	bcf     ACCbHI,MSB
	btfsc   STATUS,CARRY
	bsf     ACCbHI,MSB
	retlw   0
;
;*******************************************************************
;   Binary Floating Point Multiplication :
;   ACCb(16 bits)EXP(b) * ACCa(16 bits)EXPa -> ACCb(16 bits)EXPb
;
F_mpy
	call    S_SIGN
	call    setup
mloop   bcf     STATUS,CARRY    ; clear carry bit       ??????????
	rrf     ACCdHI          ;rotate d right
	rrf     ACCdLO
	btfsc   STATUS,CARRY    ;need to add?
	call    D_add
	rrf     ACCbHI
	rrf     ACCbLO
	rrf     ACCcHI
	rrf     ACCcLO
	decfsz  temp            ;loop until all bits checked
	goto    mloop
;
	movf    EXPa,w
	addwf   EXPb
;
	IF   Mode16
	movf    ACCbHI
	btfss   STATUS,Z_bit
	goto    finup           ; if ACCbHI != 0
	movf    ACCbLO
	btfss   STATUS,Z_bit
	goto    Shft08          ; if ACCbLO != 0 && ACCbHI == 0
;
	movf    ACCcHI,w
	movwf   ACCbHI          ; if ACCb == 0, then move ACCc to ACCb
	movf    ACCcLO,w
	movwf   ACCbLO
	movlw   .16
	addwf   EXPb
	goto    finup
;
Shft08  movf    ACCbLO,w
	movwf   ACCbHI
	movf    ACCcHI,w
	movwf   ACCbLO
	movlw   .8
	addwf   EXPb
;
	ENDIF                   ; matching endif for IF Mode16
;
finup   btfss   sign,MSB
	goto    F_norm
;
	decf    ACCcLO          ; negate ACCc
	comf    ACCcLO
	btfsc   STATUS,Z_bit
	decf    ACCcHI
	comf    ACCcHI
	btfsc   STATUS,Z_bit
;
neg_B   decf    ACCbLO          ; negate ACCb
	comf    ACCbLO
	btfsc   STATUS,Z_bit
	decf    ACCbHI
	comf    ACCbHI
;
	goto    F_norm
;
;
;*******************************************************************
;
setup   movlw   .16             ; for 16 shifts
	movwf   temp
	movf    ACCbHI,w          ;move ACCb to ACCd
	movwf   ACCdHI
	movf    ACCbLO,w
	movwf   ACCdLO
	clrf    ACCbHI
	clrf    ACCbLO          ; clear ACCb ( ACCbLO & ACCbHI )
	retlw   0
;

;*******************************************************************
;   Floating Point Division :
;   ACCb(16 bits)EXP(b) / ACCa(16 bits)EXPa -> ACCb(16 bits)EXPb , with
;                               remainder in ACCc ( 16 bits ).
;
F_div   call    S_SIGN
	call    setup
	clrf    ACCcHI
	clrf    ACCcLO
dloop   bcf     STATUS,CARRY     ;????????
	rlf     ACCdLO
	rlf     ACCdHI
	rlf     ACCcLO
	rlf     ACCcHI
	movf    ACCaHI,w        ; check if ACCa > ACCb
	subwf   ACCcHI,w
	btfss   STATUS,Z_bit
	goto    nochk
	movf    ACCaLO,w
	subwf   ACCcLO,w        ;if msb equal then check lsb
nochk   btfss   STATUS,CARRY    ;carry set if c>a
	goto    nogo
	movf    ACCaLO,w        ;c-a into c
	subwf   ACCcLO
	btfss   STATUS,CARRY
	decf    ACCcHI
	movf    ACCaHI,w
	subwf   ACCcHI
	bsf     STATUS,CARRY    ;shift a 1 into b (result)
nogo    rlf     ACCbLO
	rlf     ACCbHI
	decfsz  temp            ;loop untill all bits checked
	goto    dloop
	movf    EXPa,w
	subwf   EXPb
	btfss   sign,MSB
	goto    F_norm
	decf    ACCbLO          ; negate ACCb
	comf    ACCbLO
	btfsc   STATUS,Z_bit
	decf    ACCbHI
	comf    ACCbHI
	goto    F_norm
;
;*******************************************************************
;
neg_A   comf    ACCaLO          ; negate ACCa ( -ACCa -> ACCa )
	incf    ACCaLO
	btfsc   STATUS,Z_bit
	decf    ACCaHI
	comf    ACCaHI
	retlw   0
;
;*******************************************************************
;
S_SIGN  movf    ACCaHI,W
	xorwf   ACCbHI,W
	movwf   sign
	btfss   ACCbHI,MSB        ; if MSB set go & negate ACCb
	goto    chek_A
;
	comf    ACCbLO          ; negate ACCb
	incf    ACCbLO
	btfsc   STATUS,Z_bit
	decf    ACCbHI
	comf    ACCbHI
;
chek_A  btfss   ACCaHI,MSB        ; if MSB set go & negate ACCa
	retlw   0
	goto    neg_A
;
;*******************************************************************
;      Normalize Routine
; Normalizes ACCb for use in floating point calculations.
; Call this routine as often as possible to minimize the loss
; of precission. This routine normalizes ACCb so that the
; mantissa is maximized and the exponent minimized.
;
;
;
F_norm  movf    ACCbHI
	btfss   STATUS,Z_bit
	goto    C_norm
	movf    ACCbLO
	btfsc   STATUS,Z_bit
	retlw   0
C_norm  btfsc   ACCbHI,6
	retlw   0
	call    shftSL
	decf    EXPb
	goto    C_norm
;
;*******************************************************************
;  Swap ACCa & ACCb   [ (ACCa,EXPa) <--> (ACCb,EXPb) ]
;
F_swap
	movf    ACCaHI,w
	movwf   temp
	movf    ACCbHI,w        ;ACCaHI <--> ACCbHI
	movwf   ACCaHI
	movf    temp,w
	movwf   ACCbHI
;
	movf    ACCaLO,w
	movwf   temp
	movf    ACCbLO,w        ;ACCaLO <--> ACCbLO
	movwf   ACCaLO
	movf    temp,w
	movwf   ACCbLO
;
	movf    EXPa,w
	movwf   temp
	movf    EXPb,w          ;EXPa <--> EXPb
	movwf   EXPa
	movf    temp,w
	movwf   EXPb
;
	retlw   0
;
;*******************************************************************
;                       Test Program
;*******************************************************************
;    Load constant values to (ACCa, EXPa) & (ACCb, EXPb) for testing
;
loadAB  movlw   1
	movwf   ACCaHI
	movlw   0FF             ; loads ACCa = 01FF EXP(4)
	movwf   ACCaLO
	movlw   04
	movwf   EXPa
;
	movlw   07F
	movwf   ACCbHI
	movlw   0FF             ; loads ACCb = 7FFF EXP(6)
	movwf   ACCbLO
	movlw   06
	movwf   EXPb
	retlw   0
;
main    nop
;
	call    loadAB          ; result of adding ACCb(EXPb)+ACCa(EXPa)->ACCb(EXPb)
	call    F_add           ; Here Accb = 403F, EXPb = 07
;
	call    loadAB          ; result of subtracting ACCb(EXPb)-ACCa(EXPa)->ACCb(EXPb)
	call    F_sub           ; Here Accb = 7F7F, EXPb = 06
;
	call    loadAB          ; result of multiplying ACCb(EXPb) * ACCa(EXPa)->ACCb(EXPb)
	call    F_mpy           ; Here ACCb = FF7E, EXPb = 12
;
	call    loadAB          ; result of dividing ACCb(EXPb) / ACCa(EXPa)->ACCb(EXPb) with
	call    F_div           ; remainder in ACCc. Here ACCb =4000, EXPb = FA (same as -6)
;                               ; & the remainder ACCc = 003F
;
self    goto    self
;
	org     PIC54
	goto    main
	END
;****************************************************************

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av在线资源网| 欧美调教femdomvk| 艳妇臀荡乳欲伦亚洲一区| 日韩视频一区二区三区在线播放| 成人免费毛片高清视频| 青青草国产精品97视觉盛宴| 中文字幕一区免费在线观看| 欧美一区二区三区公司| 色综合久久久久| 国产精品77777竹菊影视小说| 亚洲bt欧美bt精品777| 国产精品久久久一本精品 | 一区二区三区在线免费视频| 精品美女一区二区| 欧美日韩一区二区三区免费看 | 国产一区啦啦啦在线观看| 亚洲亚洲精品在线观看| 国产精品传媒视频| 久久看人人爽人人| 日韩欧美一区在线观看| 欧美日韩一卡二卡| 在线精品视频一区二区| 99久久夜色精品国产网站| 国产成人精品免费网站| 青青草伊人久久| 五月婷婷色综合| 亚洲国产欧美在线| 一区二区不卡在线播放| 亚洲人被黑人高潮完整版| 国产精品区一区二区三区| 久久精品免费在线观看| 欧美精品一区二区蜜臀亚洲| 欧美一区二区三区小说| 在线成人av网站| 666欧美在线视频| 欧美高清激情brazzers| 欧美午夜一区二区| 91久久精品一区二区| 一本一道久久a久久精品综合蜜臀| 成人av中文字幕| jizzjizzjizz欧美| 不卡av在线免费观看| 成人高清免费观看| 99久久精品国产一区| av在线播放不卡| voyeur盗摄精品| 99精品欧美一区二区三区小说| 菠萝蜜视频在线观看一区| 成人91在线观看| 91首页免费视频| 91久久精品国产91性色tv| 欧洲亚洲国产日韩| 7777精品伊人久久久大香线蕉经典版下载| 欧美日韩免费一区二区三区 | 欧美变态凌虐bdsm| 久久蜜臀中文字幕| 欧美国产欧美综合| 亚洲人成在线观看一区二区| 亚洲制服欧美中文字幕中文字幕| 亚洲成人激情av| 男男视频亚洲欧美| 国产麻豆精品在线| 91美女片黄在线观看| 色94色欧美sute亚洲线路一ni | 欧美xxxxxxxx| 国产清纯在线一区二区www| 欧美国产日产图区| 亚洲一区二区三区爽爽爽爽爽| 日韩中文字幕亚洲一区二区va在线| 日本不卡高清视频| 国产成人av资源| 欧美性一级生活| 精品国产青草久久久久福利| 日本一区二区三区久久久久久久久不| 亚洲乱码日产精品bd| 亚洲成a人片在线不卡一二三区| 日韩av一区二| 国产91富婆露脸刺激对白| 日本伦理一区二区| 日韩视频免费观看高清完整版| 欧美国产亚洲另类动漫| 亚洲成人1区2区| 高清beeg欧美| 欧美日韩国产大片| 国产亚洲短视频| 亚洲高清在线精品| 国产盗摄视频一区二区三区| 在线亚洲一区二区| 久久久国产精华| 亚洲一区日韩精品中文字幕| 激情综合色丁香一区二区| av不卡在线播放| 精品国产精品网麻豆系列| 1区2区3区精品视频| 久久99蜜桃精品| 欧洲亚洲精品在线| 国产精品无遮挡| 天堂在线一区二区| 不卡在线观看av| xnxx国产精品| 婷婷六月综合亚洲| 91网站最新网址| 2021中文字幕一区亚洲| 亚洲va欧美va天堂v国产综合| 高清不卡一二三区| 日韩欧美卡一卡二| 亚洲成人动漫精品| 99久久精品免费看| 亚洲国产精品二十页| 蜜桃视频一区二区三区在线观看| 色综合色综合色综合| 国产日产欧美一区二区三区| 奇米色一区二区三区四区| 色菇凉天天综合网| 中文一区在线播放| 国产精品一二三| 精品国产人成亚洲区| 日韩电影在线观看一区| 91黄色激情网站| 亚洲视频狠狠干| 北岛玲一区二区三区四区 | 亚洲网友自拍偷拍| 91免费看片在线观看| 国产欧美视频在线观看| 玖玖九九国产精品| 欧美一区二区在线免费观看| 亚洲一区二区欧美激情| 一本大道久久a久久综合| 亚洲国产成人午夜在线一区| 国产二区国产一区在线观看| 精品国产91久久久久久久妲己| 日本亚洲欧美天堂免费| 51精品国自产在线| 日韩精品一级二级| 欧美绝品在线观看成人午夜影视| 亚洲国产一区二区视频| 91福利资源站| 亚洲成人激情综合网| 欧美高清激情brazzers| 天堂一区二区在线| 日韩一级在线观看| 人人狠狠综合久久亚洲| 91精品国产综合久久久久久漫画 | www.av亚洲| 亚洲欧美色综合| 91国产福利在线| 午夜激情久久久| 日韩一区二区在线观看视频播放| 日韩主播视频在线| 欧美电影免费提供在线观看| 精品一区二区三区不卡 | 久久久久99精品一区| 国产成人高清在线| 亚洲色图在线播放| 欧美日韩精品免费观看视频| 日日摸夜夜添夜夜添国产精品| 日韩欧美一区二区免费| 激情国产一区二区 | 日韩电影一区二区三区| 精品国产凹凸成av人导航| 国产高清在线观看免费不卡| 综合自拍亚洲综合图不卡区| 在线观看免费成人| 久久精品国产免费| 国产精品视频九色porn| 91欧美一区二区| 丝袜亚洲另类欧美综合| 久久老女人爱爱| 一本色道久久综合亚洲aⅴ蜜桃| 午夜精品久久久久久久99樱桃 | 亚洲一卡二卡三卡四卡无卡久久| 欧美日韩精品一区视频| 国内精品不卡在线| ㊣最新国产の精品bt伙计久久| 欧美影院一区二区三区| 国内外精品视频| 亚洲精品网站在线观看| 日韩一区二区电影在线| 成人精品一区二区三区中文字幕| 亚洲伊人伊色伊影伊综合网| 26uuu成人网一区二区三区| 色妞www精品视频| 久久99精品一区二区三区三区| 国产精品久久久久久久裸模| 欧美精选一区二区| 国产aⅴ综合色| 婷婷激情综合网| 综合精品久久久| 欧美精品一区二区三| 在线免费亚洲电影| 国产高清精品网站| 亚洲电影第三页| 国产精品久久久久国产精品日日| 欧美裸体一区二区三区| 丁香啪啪综合成人亚洲小说| 丝袜亚洲另类欧美| 亚洲另类一区二区| 国产女人水真多18毛片18精品视频| 成人福利视频在线看| 亚洲一区二区欧美激情|