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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? float.asm

?? PIC16CXX C語言工具
?? ASM
字號:
;*******************************************************************
;       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
;****************************************************************

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人国产视频在线观看| 在线观看网站黄不卡| 欧美变态凌虐bdsm| 美女高潮久久久| 久久夜色精品一区| 成人性生交大片免费看视频在线| 国产精品久久三区| 日本高清不卡一区| 蜜桃久久精品一区二区| 久久人人爽人人爽| 99久久777色| 亚洲va欧美va天堂v国产综合| 欧美巨大另类极品videosbest | 99久久er热在这里只有精品66| 综合激情网...| 欧美在线一区二区三区| 美女诱惑一区二区| 中文字幕在线一区免费| 欧美日韩在线播| 国内外成人在线| 亚洲品质自拍视频| 欧美一区二区三区日韩| 亚洲激情自拍视频| 欧美性xxxxxx少妇| 欧美成人乱码一区二区三区| 亚洲一区免费观看| 成人性生交大片免费看中文 | 日韩精品在线网站| 国产福利一区二区三区| 亚洲黄色在线视频| 久久亚洲综合色一区二区三区| 成人美女视频在线观看18| 亚洲夂夂婷婷色拍ww47| 337p粉嫩大胆色噜噜噜噜亚洲| 99久久久无码国产精品| 日本欧美一区二区在线观看| 亚洲国产精品ⅴa在线观看| 欧美午夜精品一区| 国产白丝精品91爽爽久久| 亚洲va天堂va国产va久| 国产精品传媒视频| 欧美不卡视频一区| 欧美日韩在线观看一区二区| 国产一区二区在线影院| 污片在线观看一区二区| 国产精品视频免费看| 日韩欧美国产综合一区| 色天天综合色天天久久| 国产九九视频一区二区三区| 日本一区中文字幕| 一区二区三区在线视频免费观看| 国产亚洲一区字幕| 日韩精品一区二区三区四区视频 | 在线亚洲+欧美+日本专区| 国产精品综合一区二区三区| 日韩av一区二区在线影视| 亚洲精品高清在线| 亚洲欧美自拍偷拍色图| 国产日韩欧美精品电影三级在线 | 欧美人妖巨大在线| 色综合天天综合网国产成人综合天 | 一区二区三区高清在线| 中文字幕高清不卡| 久久青草国产手机看片福利盒子 | 99这里只有久久精品视频| 国产在线国偷精品产拍免费yy| 性久久久久久久久久久久| 成人免费在线视频观看| 国产精品传媒入口麻豆| 中文字幕免费一区| 国产日韩亚洲欧美综合| 久久先锋影音av鲁色资源网| 欧美mv日韩mv| 精品久久久久久久久久久院品网| 6080yy午夜一二三区久久| 欧美日韩色综合| 欧美日本一道本在线视频| 欧美日韩午夜精品| 在线播放欧美女士性生活| 7777精品伊人久久久大香线蕉的 | 国产suv一区二区三区88区| 狠狠网亚洲精品| 韩国女主播成人在线| 国内精品在线播放| 国产精品一区二区在线观看不卡 | 激情综合色播激情啊| 久久成人免费电影| 国内精品第一页| 岛国一区二区三区| 91首页免费视频| 欧美伊人久久久久久久久影院| 精品视频一区三区九区| 欧美高清hd18日本| 精品国产免费人成在线观看| 国产视频一区二区在线观看| 国产欧美久久久精品影院| 国产精品黄色在线观看| 一区二区三区四区中文字幕| 日韩av二区在线播放| 精品一区二区三区久久| 粉嫩嫩av羞羞动漫久久久| 色婷婷激情一区二区三区| 欧美日产在线观看| 久久精品欧美一区二区三区不卡 | 成人黄色网址在线观看| 91首页免费视频| 欧美成人精品3d动漫h| 国产午夜精品一区二区三区嫩草 | xfplay精品久久| 成人欧美一区二区三区1314| 午夜一区二区三区视频| 国产一区在线看| 色成年激情久久综合| 91精品国产综合久久精品app| 26uuu成人网一区二区三区| 亚洲激情成人在线| 国产一区亚洲一区| 欧美又粗又大又爽| 国产亚洲美州欧州综合国| 亚洲精品写真福利| 国产尤物一区二区在线| 在线观看一区日韩| 国产性做久久久久久| 亚洲成a人v欧美综合天堂| 美女视频黄 久久| 极品美女销魂一区二区三区| 色婷婷精品久久二区二区蜜臀av | 99免费精品视频| 欧美日本国产一区| 日本一区二区在线不卡| 亚洲va欧美va天堂v国产综合| 国产成人亚洲综合a∨婷婷| 欧美人xxxx| 中文字幕一区二| 精品一区二区在线观看| 色婷婷激情久久| 国产精品色呦呦| 精品一区在线看| 欧美性xxxxxx少妇| 亚洲视频免费在线| 国产成人精品亚洲777人妖| 3d动漫精品啪啪一区二区竹菊| 国产精品久久久久永久免费观看| 九九精品视频在线看| 99re热视频这里只精品| 久久嫩草精品久久久精品一| 五月激情综合网| 91精品福利在线| 成人免费小视频| 国产成人精品亚洲777人妖| 日韩手机在线导航| 日韩avvvv在线播放| 欧洲在线/亚洲| 亚洲免费电影在线| 99精品欧美一区二区蜜桃免费| 精品国产乱码久久久久久蜜臀| 午夜久久久久久久久| 91久久精品一区二区| 伊人色综合久久天天人手人婷| 风间由美一区二区三区在线观看 | 日韩和欧美的一区| 欧美三级一区二区| 亚洲不卡一区二区三区| 欧美性色欧美a在线播放| 亚洲美女电影在线| 色综合天天综合网天天狠天天| 综合中文字幕亚洲| www.成人网.com| 中文字幕在线不卡国产视频| 成人黄色av电影| 国产精品国产三级国产aⅴ原创| 成人免费视频视频在线观看免费 | 国产激情一区二区三区桃花岛亚洲| 欧美一级午夜免费电影| 欧美日韩在线免费视频| 国产不卡视频一区二区三区| 久久五月婷婷丁香社区| 激情久久五月天| 国产女主播在线一区二区| 国产成人综合亚洲网站| 国产女人18水真多18精品一级做| 国产精品自拍网站| 国产精品理论片| 91免费看`日韩一区二区| 亚洲三级在线播放| 欧美日韩免费高清一区色橹橹| 午夜一区二区三区视频| 欧美大片在线观看一区二区| 国产一区在线观看麻豆| 中文字幕一区二区三区四区| 色婷婷激情久久| 久久国产欧美日韩精品| 久久精品网站免费观看| 色8久久精品久久久久久蜜| 婷婷中文字幕一区三区| 精品国产乱码久久久久久久| 99国产精品99久久久久久| 亚洲va在线va天堂| 久久精品一区蜜桃臀影院| 色综合色狠狠天天综合色|