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

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

?? fft.asm

?? DSP5000系列有關濾波器的源碼,可以直接運行希望對大家有用!
?? ASM
字號:
;
;   fft.asm - Radix-2 complex FFT (for N=2^EXP points)
;             Using table lookup method
;                               
;   Prototype: void fft(complex *, int, complex *, int); 
;
;   Entry:  arg0: AR0-FFT input sample buffer pointer   
;           arg1: T0-number of FFT stage, EXP
;           arg2: AR1-twiddle factor array pointer     
;           arg3: T1-scale flag 
;                 if scale needed, (T1==1) SCALE=2;
;                 if don't need scale (T1==0) SCALE=1;
;                                                      
;   Note: 1. When used as the FFT routine it takes in time domain 
;         samples in Q15 and generates Q14 frequency domain samples
;         2. When used as the IFFT routine it takes in frequency domain 
;         samples in Q14 and generates Q15 time domain samples
;
;    Revised: Dec. 3, 2001
;             Add an instruction to copy XAR0 to XAR5 for addressing extended page

        .global _fft

;
;	Declare local variables in SP address mode for C-callable
;
ARGS    .set    0       ; Number of variables passed via stack

FFT_var .struct         ; Define local variable structure
d_temp      .int (2)    ; Temporary variables (Re, Im)
d_L         .int
d_N         .int  
d_T2        .int        ; Used to save content of T2
d_ST1       .int        ; Used to save content of ST1
d_ST3       .int        ; Used to save content of ST3
return_addr .int        ; Space for routine return address
Size        .endstruct
fft         .set 0
fft         .tag FFT_var  

    .sect "fft_code"       
	
_fft:
    aadd #(ARGS-Size+1),SP      ; Adjust stack for local vars

    mov  mmap(ST1_55),AR2       ; Save ST1,ST3
    mov  mmap(ST3_55),AR3   
    mov  AR2,fft.d_ST1
    mov  AR3,fft.d_ST3
    btst @#0,T1,TC1             ; Check SCALE flag set		
    mov  #0x6340,mmap(ST1_55)   ; Set CPL,XF,SATD,SXAM,FRCT (SCALE=1) 
    mov  #0x1f22,mmap(ST3_55)   ; Set: HINT,SATA,SMUL   
    xcc  do_scale,TC1
    mov  #0x6300,mmap(ST1_55)   ; Set CPL,XF,SATD,SXAM (SCALE=2) 
do_scale
    
    mov  T2,fft.d_T2            ; Save T2                     
||  mov  #1,AC0
    mov  AC0,fft.d_L            ; Initialize L=1
||  sfts AC0,T0                 ; T0=EXP
    mov  AC0,fft.d_N            ; N=1<<EXP
    mov  XAR1,XCDP              ; CDP = pointer to U[]
    mov  XSP,XAR4	
    add  #fft.d_temp,AR4        ; AR4 = pointer to temp
    mov  XAR0,XAR1              ; AR1 points to sample buffer
    mov  T0,T1
    mov  XAR0,XAR5              ; Copy externd bits to XAR5
			
outer_loop                      ; for (L=1; L<=EXP; L++)    
    mov  fft.d_L,T0             ; note: Since the buffer is
||  mov  #2,AC0                 ;       arranged in re,im pairs
    sfts AC0,T0                 ;       the index to the buffer
    neg  T0	                    ;       is doubled
||  mov  fft.d_N,AC1            ;       But the repeat coutners
    sftl AC1,T0                 ;       are not doubled
    mov  AC0,T0                 ; LE=2<<L 	
||  sfts AC0,#-1  
    mov  AC0,AR0                ; LE1=LE>>1           
||  sfts AC0,#-1                              
    sub  #1,AC0                 ; Init mid_loop counter
    mov  mmap(AC0L),BRC0        ;   BRC0=LE1-1
    sub  #1,AC1                 ; Init inner loop counter
    mov  mmap(AC1L),BRC1        ;   BRC1=(N>>L)-1   
    add  AR1,AR0   
    mov  #0,T2                  ; j=0 
||  rptblocal mid_loop-1        ; for (j=0; j<LE1;j++) 
    mov  T2,AR5                 ; AR5=id=i+LE1
    mov  T2,AR3	
    add  AR0,AR5                ; AR5 = pointer to X[id].re   
    add  #1,AR5,AR2             ; AR2 = pointer to X[id].im  
    add  AR1,AR3                ; AR3 = pointer to X[i].re 
||  rptblocal inner_loop-1      ; for(i=j; i<N; i+=LE) 
    mpy  *AR5+,*CDP+,AC0        ; AC0=(X[id].re*U.re
::  mpy  *AR2-,*CDP+,AC1        ;     -X[id].im*U.im)/SCALE	 
    masr *AR5-,*CDP-,AC0        ; AC1=(X[id].im*U.re                       
::  macr *AR2+,*CDP-,AC1        ;     +X[id].re*U.im)/SCALE
    mov  pair(hi(AC0)),dbl(*AR4); AC0H=temp.re AC1H=temp.im 
||  mov  dbl(*AR3),AC2
    xcc  scale,TC1
||  mov  AC2>>#1,dual(*AR3)     ; Scale X[i] by 1/SCALE
    mov  dbl(*AR3),AC2  
scale
    add  T0,AR2
||  sub  dual(*AR4),AC2,AC1     ; X[id].re=X[i].re/SCALE-temp.re
    mov  AC1,dbl(*(AR5+T0))     ; X[id].im=X[i].im/SCALE-temp.im
||  add  dual(*AR4),AC2         ; X[i].re=X[i].re/SCALE+temp.re
    mov  AC2,dbl(*(AR3+T0))     ; X[i].im=X[i].im/SCALE+temp.im
inner_loop                      ; End of inner loop       
    amar *CDP+
    amar *CDP+                  ; Update k for pointer to U[k]
||  add  #2,T2                  ; Update j    
mid_loop                        ; End of mid-loop      
    sub  #1,T1          
    add  #1,fft.d_L             ; Update L
    bcc  outer_loop,T1>0        ; End of outer-loop

    mov  fft.d_ST1,AR2          ; Restore ST1,ST3,T2
    mov  fft.d_ST3,AR3
    mov  AR2,mmap(ST1_55)
    mov  AR3,mmap(ST3_55)                              
    mov  fft.d_T2,T2
    aadd #(Size-ARGS-1),SP      ; Reset SP
    ret

    .end 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区在线观看 | 日韩女优毛片在线| 国产91富婆露脸刺激对白| 亚洲一区免费观看| 中文字幕的久久| 91精品国产麻豆| 色婷婷av一区二区三区gif| 开心九九激情九九欧美日韩精美视频电影 | 国产一区二区三区蝌蚪| 亚洲一区二区四区蜜桃| 国产精品国产馆在线真实露脸| 日韩一卡二卡三卡四卡| 精品视频一区三区九区| 99久久综合狠狠综合久久| 久久99热这里只有精品| 无吗不卡中文字幕| 一区二区三区丝袜| 国产精品福利av| 久久久久久毛片| 精品国产乱码久久久久久闺蜜| 欧美日韩国产精品成人| 91国内精品野花午夜精品| www.成人在线| 成人黄色综合网站| 国产精品一二三区在线| 精一区二区三区| 蜜桃久久av一区| 日本欧美一区二区三区| 天天av天天翘天天综合网色鬼国产| 亚洲欧美日韩国产一区二区三区| 亚洲欧洲精品一区二区精品久久久 | 欧美日韩国产片| 精品视频免费在线| 91国模大尺度私拍在线视频| 色视频欧美一区二区三区| 91免费国产视频网站| 91在线精品一区二区| 91污在线观看| 色综合久久中文字幕综合网| 一本到一区二区三区| 色婷婷综合五月| 91成人在线免费观看| 欧美性猛交xxxxxxxx| 欧美日韩中文字幕一区| 欧美日韩国产片| 欧美一区二区三区在| 精品日本一线二线三线不卡| 久久久不卡网国产精品二区 | 午夜不卡av在线| 日本不卡在线视频| 美女一区二区久久| 国内精品久久久久影院一蜜桃| 国产精品1区二区.| www.欧美精品一二区| 在线观看日韩电影| 91精品国产免费| 久久久精品免费网站| 中文字幕五月欧美| 午夜在线电影亚洲一区| 精品一区二区免费视频| 国产高清精品在线| 在线日韩一区二区| 欧美一区二区视频网站| 久久精子c满五个校花| 成人欧美一区二区三区1314| 亚洲chinese男男1069| 韩国成人精品a∨在线观看| 成人在线视频首页| 欧美中文字幕一二三区视频| 日韩视频一区二区三区在线播放| 欧美videossexotv100| 亚洲国产精品高清| 亚洲成av人片| 丁香激情综合国产| 欧美人伦禁忌dvd放荡欲情| 久久久99久久精品欧美| 亚洲国产综合人成综合网站| 免费成人你懂的| 95精品视频在线| 欧美一区二区三区性视频| 国产精品毛片高清在线完整版| 亚洲高清免费观看| 国产精品18久久久久| 欧美午夜精品久久久久久孕妇| 精品久久久久久久人人人人传媒| 亚洲乱码一区二区三区在线观看| 麻豆一区二区在线| 在线日韩一区二区| 久久精品欧美一区二区三区不卡| 亚洲一区二区在线免费看| 国产乱淫av一区二区三区| 在线视频观看一区| 国产无一区二区| 日韩精品亚洲专区| 91视频免费播放| 精品国产电影一区二区| 午夜久久久久久久久| 成人av午夜影院| 精品三级在线看| 亚洲成人午夜影院| 91视频一区二区| 日本一区免费视频| 国产曰批免费观看久久久| 欧美日韩高清一区| 一二三四区精品视频| 成人午夜视频在线观看| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲成人午夜影院| 91久久精品国产91性色tv| 欧美国产视频在线| 韩国欧美国产1区| 日韩三级免费观看| 视频一区视频二区中文字幕| 欧美在线视频不卡| 亚洲精品欧美在线| 色综合网色综合| 国产精品另类一区| 国产一二三精品| 精品国产乱码久久久久久蜜臀 | 亚洲精品在线电影| 免费在线观看成人| 欧美一区二区三区日韩视频| 亚洲电影第三页| 欧美性色黄大片手机版| 亚洲综合图片区| 欧美午夜精品久久久久久孕妇 | 欧美激情一区二区三区不卡| 国产麻豆成人传媒免费观看| 日韩免费成人网| 久久99精品国产.久久久久久| 91精品在线观看入口| 天堂成人国产精品一区| 欧美美女一区二区在线观看| 五月婷婷综合网| 91精品国产综合久久香蕉麻豆| 亚洲成人1区2区| 日韩一级片网址| 美女被吸乳得到大胸91| 精品久久国产字幕高潮| 国产精品一区二区在线观看网站 | 中文字幕在线观看一区| 色综合久久久久| 亚洲国产综合91精品麻豆| 欧美日精品一区视频| 日韩福利视频网| 精品国产污污免费网站入口 | 亚洲天堂网中文字| 一本到不卡精品视频在线观看| 亚洲精品成人精品456| 精品视频一区二区不卡| 男女男精品视频网| 久久综合色婷婷| 成人高清免费在线播放| 亚洲欧美日韩久久| 欧美日韩一区二区不卡| 欧美96一区二区免费视频| www国产亚洲精品久久麻豆| 大胆欧美人体老妇| 亚洲激情成人在线| 欧美一二三四区在线| 国产精品一区专区| 亚洲精品国产视频| 欧美丰满美乳xxx高潮www| 国产真实乱子伦精品视频| 亚洲欧洲精品天堂一级| 欧美日韩国产美女| 国产馆精品极品| 亚洲国产综合视频在线观看| 欧美不卡一二三| 91影视在线播放| 欧美96一区二区免费视频| 中文一区二区在线观看| 在线欧美日韩国产| 国产综合成人久久大片91| 国产精品传媒视频| 日韩一区二区免费电影| av一本久道久久综合久久鬼色| 日本麻豆一区二区三区视频| 国产精品视频一区二区三区不卡| 91福利视频网站| 国产福利一区二区三区视频| 一区二区三区日韩精品| 久久久久99精品国产片| 欧美人牲a欧美精品| 成人手机在线视频| 琪琪久久久久日韩精品| 亚洲欧美另类图片小说| 精品国产一区久久| 欧美三级蜜桃2在线观看| 国产盗摄女厕一区二区三区| 婷婷开心激情综合| 国产精品成人一区二区艾草| 日韩午夜在线影院| 在线观看中文字幕不卡| 国产高清精品久久久久| 日韩av电影一区| 亚洲一区二区三区视频在线 | 国产精品伦一区| 精品国产区一区| 欧美日韩免费一区二区三区|