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

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

?? float.asm

?? 基于pic的例子程序
?? 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一区二区三区免费野_久草精品视频
成人午夜私人影院| 国产精品久久久久三级| 欧美电影在线免费观看| 色香蕉成人二区免费| 99国产精品一区| 91小视频在线观看| 欧亚一区二区三区| 欧美精品精品一区| 精品日韩av一区二区| 久久久www免费人成精品| 久久精品人人做人人综合| 国产亚洲欧洲一区高清在线观看| 久久亚洲精品小早川怜子| 久久先锋影音av鲁色资源网| 欧美国产国产综合| 中文字幕日韩av资源站| 中文字幕亚洲成人| 亚洲一区二区在线观看视频| 一区二区三区波多野结衣在线观看 | 成人国产亚洲欧美成人综合网| 国产精品亚洲一区二区三区妖精| 成人综合激情网| 91毛片在线观看| 欧美日韩精品一区二区天天拍小说 | 亚洲国产裸拍裸体视频在线观看乱了| 一区二区三区丝袜| 日日噜噜夜夜狠狠视频欧美人 | 欧美日韩精品系列| 精品黑人一区二区三区久久 | 免费的国产精品| 国产一区二区在线视频| 成人精品免费视频| 欧美日韩成人一区二区| 精品国产一区二区三区久久影院| 欧美国产在线观看| 亚洲一二三四区| 韩国中文字幕2020精品| av在线这里只有精品| 欧美精品三级日韩久久| 国产嫩草影院久久久久| 亚洲午夜三级在线| 国产综合色视频| 91亚洲永久精品| 91精品国产综合久久久久久久| 国产色爱av资源综合区| 亚洲综合区在线| 国产精品一区在线观看你懂的| av电影在线不卡| 日韩一区二区精品葵司在线 | 国产成人在线视频网站| 在线亚洲高清视频| 久久久久久久网| 亚洲丰满少妇videoshd| 国产成人午夜精品5599| 欧美日韩国产高清一区二区| 中文字幕va一区二区三区| 日韩高清不卡一区| 色婷婷国产精品久久包臀| xnxx国产精品| 日韩成人午夜电影| 91激情五月电影| 亚洲国产精品成人综合| 日韩avvvv在线播放| 色成年激情久久综合| 国产欧美1区2区3区| 蜜桃av噜噜一区二区三区小说| 91在线小视频| 国产日韩欧美亚洲| 美女视频黄久久| 欧美日韩另类一区| 亚洲欧美区自拍先锋| 国产精品456| 日韩欧美中文一区| 性欧美大战久久久久久久久| 91啪亚洲精品| 中文字幕一区av| 高清beeg欧美| 国产亚洲一区二区三区| 久久精品久久综合| 欧美精品xxxxbbbb| 亚洲国产精品精华液网站| gogogo免费视频观看亚洲一| 久久久精品2019中文字幕之3| 美女网站色91| 欧美一卡2卡3卡4卡| 亚洲成人av在线电影| 91视频国产资源| 国产精品麻豆久久久| 国产乱码精品一区二区三| 欧美白人最猛性xxxxx69交| 日本亚洲三级在线| 69p69国产精品| 午夜欧美电影在线观看| 欧洲一区二区三区免费视频| 一区二区三区在线免费观看 | xnxx国产精品| 国内外成人在线| 精品国产亚洲在线| 国产一区二区网址| 久久久欧美精品sm网站 | 精品国产免费人成电影在线观看四季 | 欧美一级二级三级乱码| 日韩av电影免费观看高清完整版在线观看 | 国产福利一区二区三区视频在线| 久久久亚洲精华液精华液精华液 | 欧美精品久久99| 日韩av中文字幕一区二区三区| 6080yy午夜一二三区久久| 日韩黄色免费电影| 欧美大片免费久久精品三p| 麻豆精品一区二区三区| 久久影院午夜论| 成人av网站在线| 亚洲少妇中出一区| 欧美亚洲一区二区在线| 亚洲午夜电影在线| 制服丝袜av成人在线看| 麻豆精品视频在线观看免费| 久久精品一区二区三区不卡牛牛| 成人免费视频播放| 亚洲理论在线观看| 91精品国产综合久久精品麻豆| 捆绑紧缚一区二区三区视频| 久久久亚洲精品一区二区三区| 成人激情av网| 亚洲午夜电影网| 欧美tickling挠脚心丨vk| 国产精品系列在线观看| 亚洲欧美日韩在线播放| 欧美少妇一区二区| 韩国女主播一区| 中文字幕日本不卡| 欧美日韩一区二区三区四区 | 97久久精品人人做人人爽50路 | 91国产成人在线| 免费精品99久久国产综合精品| 久久久亚洲精华液精华液精华液| 不卡的av中国片| 亚洲成人免费av| 日本一区二区不卡视频| 欧美日韩一区在线观看| 国产精品一区二区在线播放| 亚洲男人的天堂在线观看| 91精品国产综合久久蜜臀| 国产成人在线免费| 性欧美疯狂xxxxbbbb| 欧美国产综合一区二区| 欧美喷潮久久久xxxxx| 国产精品正在播放| 亚洲一区二区三区四区在线免费观看 | 久久成人精品无人区| 亚洲素人一区二区| 欧美大片一区二区| 色综合中文综合网| 亚洲国产激情av| 欧美日韩成人综合在线一区二区| 国产精品系列在线观看| 午夜欧美电影在线观看| 国产精品每日更新在线播放网址| 欧美一区二区网站| 色菇凉天天综合网| 福利一区在线观看| 日本不卡视频在线观看| 亚洲免费观看视频| 久久精品亚洲一区二区三区浴池 | 一区二区三区中文免费| 精品女同一区二区| 欧美日韩国产综合视频在线观看| 成人免费毛片高清视频| 九九精品一区二区| 日韩高清一级片| 亚洲午夜激情av| 亚洲色图视频网站| 久久精品免费在线观看| 日韩欧美一级二级三级久久久| 97久久精品人人做人人爽50路| 国产老肥熟一区二区三区| 天天av天天翘天天综合网色鬼国产 | 在线不卡一区二区| 色哟哟一区二区| kk眼镜猥琐国模调教系列一区二区 | av电影在线观看完整版一区二区| 精品在线播放免费| 日本中文字幕一区二区视频| 一区二区三区日韩| 中文字幕一区二区在线观看| 久久综合色婷婷| 日韩无一区二区| 欧美人牲a欧美精品| 欧美午夜影院一区| 在线观看一区日韩| 91国偷自产一区二区三区观看 | 日韩一区二区三区在线| 欧美日韩国产精品成人| 欧美日韩在线播放一区| 欧洲人成人精品| 欧美日韩在线直播| 欧美精品视频www在线观看| 欧美日韩久久久一区| 欧美日韩日日夜夜|