<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > EDA/PCB > 設計應用 > 基于FPGA高精度浮點運算器的FFT設計與仿真

          基于FPGA高精度浮點運算器的FFT設計與仿真

          作者: 時間:2012-03-09 來源:網(wǎng)絡 收藏

          1.3.1 蝶形處理單元
          蝶形處理單元是整個的中心環(huán)節(jié),采用復數(shù)表示,將實部與虛部分別存儲,利用基2的DIT-算法實現(xiàn)運算。

          本文引用地址:http://www.ex-cimer.com/article/190672.htm

          e.jpg


          蝶形運算過程包括一個乘法運算o.jpg和一個加/減法運算f.jpg。數(shù)據(jù)的讀取由時鐘單元的信號來控制:當時鐘為c0時,讀取y;c1時,讀取Y;c2時,讀取x;c3時,讀取X。經(jīng)蝶形運算后得到x’=x+(ycosφ+Ysinφ),X’=X+(Ycosφ-ysinφ),y’=x-(ycosφ+Ysinφ),Y’=X-(Ycosφ-ysinφ)然后將數(shù)據(jù)寫入同樣地址的RAM中,至此,2點的蝶形運算單元完成。在蝶形運算共需一個乘法器和兩個加法器。
          (1)浮點乘法器。乘法過程對浮點數(shù)的符號位、指數(shù)以及尾數(shù)分別進行計算,符號異或,指數(shù)相加再減127,尾數(shù)加入隱含的‘1’后再進行乘法運算,如果尾數(shù)相乘的結(jié)果有溢出則指數(shù)加1尾數(shù)取前23位,若無溢出,則取最高位后的23位。但若輸入的數(shù)據(jù)有一個是0,則輸出為0。
          g.jpg
          圖5的波形為兩浮點數(shù)的乘法運算,輸入以16進制表示,分別將不同類型的數(shù)據(jù)搭配進行測試,結(jié)果表示仿真正確。

          h.jpg


          (2)浮點加法器。加法運算是將兩數(shù)指數(shù)比較,存儲較大的指數(shù),將指數(shù)小的尾數(shù)移位,再進行加減操作,規(guī)格化后輸出。加法過程由多個模塊組合實現(xiàn),包括比較模塊,右移模塊、加/減法模塊、前導零檢測模塊、左移模塊和結(jié)果整合輸出模塊。
          比較模塊主要對指數(shù)操作,判斷指數(shù)的大小,較大的指數(shù)暫作結(jié)果的指數(shù),較小指數(shù)的數(shù)做移位操作,其階差為移位量。以下程序采用for循環(huán)來實現(xiàn)移位,S(5 downto 0)存儲階差,最大值是32。
          i.jpg

          fpga相關(guān)文章:fpga是什么




          關(guān)鍵詞: FPGA FFT 高精度 浮點運算器

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();