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

          新聞中心

          EEPW首頁 > EDA/PCB > 設計應用 > 基于FPGA的24×24位低功耗乘法器的設計

          基于FPGA的24×24位低功耗乘法器的設計

          作者: 時間:2011-02-10 來源:網(wǎng)絡 收藏

          O 引言
          被廣泛應用于各種數(shù)字電路系統(tǒng)中,如DSP、數(shù)字圖像處理等系統(tǒng)。隨著便攜電予設備的普及,系統(tǒng)的集成度越來越高,這也對產(chǎn)品的功耗及芯片的散熱提出了更高的要求。本文提出了一種新的編碼算法,通過這種算法實現(xiàn)的可以進一步降,從而降低整個電子系統(tǒng)的功耗。

          1 結構
          本文介紹的24×乘法器的基本結構如圖1所示。其中,“降低乘數(shù)中‘1’的數(shù)量”實現(xiàn)對乘數(shù)y的編碼,以降低乘數(shù)y中“1”的數(shù)量,這可以在“部分積產(chǎn)生電路”中降低部分積的數(shù)量,“部分積產(chǎn)生電路”產(chǎn)生的部分積在“改進后的陣列加法器”和“超前進位加法器”中相加,最后得到乘積z。

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



          2 降低部分積數(shù)量的編碼算法
          設x,y是被乘數(shù)和乘數(shù),它們分別用二進制數(shù)表示,最高位是符號位,z是乘積,用47位二進制表示,最高位是符號位,“1”表示負數(shù),“0”表示正數(shù)。則它們的關系可以用下式表示:


          式中:xi,yi分別是x,y的權位。如果按式(3)進行乘法計算,需要將與所有的yi相乘,產(chǎn)生23行部分積,然后再將其相加,即使yi=0,也要進行上述運算,這樣就勢必增加乘法器的功耗和延時,因此,在下面將會對全加器和半加器進行改進,使僅與yi=1相乘,從而避免與yi=0相乘。首先介紹降低乘數(shù)y中“1”的數(shù)量的編碼算法。用一個事例說明本文介紹的算法的優(yōu)越性。設m1,m2分別是乘數(shù)和被乘數(shù),且令m1=01110111,如果用m2與m1中的每一位相乘,則會產(chǎn)生6個m2和2個“0”列,如果按照Sanjiv Kumar Mangal和 R. M. Patrikar所建議的方法,則:
          01110111(m1)=10001000(n1)-00010001(n2) (4)
          將m2分別與n1和n2相乘,再將它們的乘積相減即得乘積結果。但是,在這一過程中,一共產(chǎn)生4個m2。如果按照本文所建議的方法,會進一步降低m2的數(shù)量,即:
          01110111(m1)=10000000(n1)-00001001(n2) (5)
          由式(5)可以看出,n1和n2中共有3個“1”,因此,可以進一步降低部分積的數(shù)量。當乘數(shù)的位數(shù)較大時,本文提出的算法優(yōu)越性更大。具體編碼流程如圖2所示。



          3 部分積的產(chǎn)生及相加
          在數(shù)字電路中,功耗主要由3部分構成,即:


          上一頁 1 2 3 下一頁

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁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); })();