精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

該如何提高電路的工作頻率

FPGA設(shè)計(jì)論壇 ? 來源:FPGA設(shè)計(jì)論壇 ? 作者:FPGA設(shè)計(jì)論壇 ? 2022-03-25 09:41 ? 次閱讀

對(duì)于設(shè)計(jì)者來說,當(dāng)然希望我們設(shè)計(jì)的電路的工作頻率(在這里如無特別說明,工作頻率指FPGA片內(nèi)的工作頻率)盡量高。我們也經(jīng)常聽說用資源換速度,用流水的方式可以提高工作頻率,這確實(shí)是一個(gè)很重要的方法,今天我想進(jìn)一步去分析該如何提高電路的工作頻率。

我們先來分析下是什么影響了電路的工作頻率。我們電路的工作頻率主要與寄存器到寄存器之間的信號(hào)傳播時(shí)延及clock skew有關(guān)。在FPGA內(nèi)部如果時(shí)鐘走長線的話,clock skew很小,基本上可以忽略, 在這里為了簡單起見,我們只考慮信號(hào)的傳播時(shí)延的因素。信號(hào)的傳播時(shí)延包括寄存器的開關(guān)時(shí)延、走線時(shí)延、經(jīng)過組合邏輯的時(shí)延(這樣劃分或許不是很準(zhǔn)確,不過對(duì)分析問題來說應(yīng)該是沒有可以的),要提高電路的工作頻率,我們就要在這三個(gè)時(shí)延中做文章,使其盡可能的小。

我們先來看開關(guān)時(shí)延,這個(gè)時(shí)延是由器件物理特性決定的,我們沒有辦法去改變,所以我們只能通過改變走線方式和減少組合邏輯的方法來提高工作頻率。

1.通過改變走線的方式減少時(shí)延。以altera的器件為例,我們在quartus里面的timing closure floorplan可以看到有很多條條塊塊,我們可以將條條塊塊按行和按列分,每一個(gè)條塊代表1個(gè)LAB,每個(gè)LAB里有8個(gè)或者是10個(gè)LE。它們的走線時(shí)延的關(guān)系如下:同一個(gè)LAB中(最快) < 同列或者同行 < 不同行且不同列。

我們通過給綜合器加適當(dāng)?shù)募s束(不可貪心,一般以加5%裕量較為合適,比如電路工作在100Mhz,則加約束加到105Mhz就可以了,貪心效果反而不好,且極大增加綜合時(shí)間)可以將相關(guān)的邏輯在布線時(shí)盡量布的靠近一點(diǎn),從而減少走線的時(shí)延。(注:約束的實(shí)現(xiàn)不完全是通過改進(jìn)布局布線方式去提高工作頻率,還有其它的改進(jìn)措施)

2.通過減少組合邏輯的減少時(shí)延。上面我們講了可以通過加約束來提高工作頻率,但是我們在做設(shè)計(jì)之初可萬萬不可將提高工作頻率的美好愿望寄托在加約束上,我們要通過合理的設(shè)計(jì)去避免出現(xiàn)大的組合邏輯,從而提高電路的工作頻率,這才能增強(qiáng)設(shè)計(jì)的可移植性,才可以使得我們的設(shè)計(jì)在移植到另一同等速度級(jí)別的芯片時(shí)還能使用。

我們知道,目前大部分FPGA都基于4輸入LUT的,如果一個(gè)輸出對(duì)應(yīng)的判斷條件大于四輸入的話就要由多個(gè)LUT級(jí)聯(lián)才能完成,這樣就引入一級(jí)組合邏輯時(shí)延,我們要減少組合邏輯,無非就是要輸入條件盡可能的少,這樣就可以級(jí)聯(lián)的LUT更少,從而減少了組合邏輯引起的時(shí)延。

我們平時(shí)聽說的流水就是一種通過切割大的組合邏輯(在其中插入一級(jí)或多級(jí)D觸發(fā)器,從而使寄存器與寄存器之間的組合邏輯減少)來提高工作頻率的方法。比如一個(gè)32位的計(jì)數(shù)器,該計(jì)數(shù)器的進(jìn)位鏈很長,必然會(huì)降低工作頻率,我們可以將其分割成4位和8位的計(jì)數(shù),每當(dāng)4位的計(jì)數(shù)器計(jì)到15后觸發(fā)一次8位的計(jì)數(shù)器,這樣就實(shí)現(xiàn)了計(jì)數(shù)器的切割,也提高了工作頻率。

在狀態(tài)機(jī)中,一般也要將大的計(jì)數(shù)器移到狀態(tài)機(jī)外,因?yàn)橛?jì)數(shù)器這東西一般是經(jīng)常是大于4輸入的,如果再和其它條件一起做為狀態(tài)的跳變判據(jù)的話,必然會(huì)增加LUT的級(jí)聯(lián),從而增大組合邏輯。以一個(gè)6輸入的計(jì)數(shù)器為例,我們原希望當(dāng)計(jì)數(shù)器計(jì)到111100后狀態(tài)跳變,現(xiàn)在我們將計(jì)數(shù)器放到狀態(tài)機(jī)外,當(dāng)計(jì)數(shù)器計(jì)到111011后產(chǎn)生個(gè)enable信號(hào)去觸發(fā)狀態(tài)跳變,這樣就將組合邏輯減少了。

上面說的都是可以通過流水的方式切割組合邏輯的情況,但是有些情況下我們是很難去切割組合邏輯的,在這些情況下我們又該怎么做呢?

狀態(tài)機(jī)就是這么一個(gè)例子,我們不能通過往狀態(tài)譯碼組合邏輯中加入流水。如果我們的設(shè)計(jì)中有一個(gè)幾十個(gè)狀態(tài)的狀態(tài)機(jī),它的狀態(tài)譯碼邏輯將非常之巨大,毫無疑問,這極有可能是設(shè)計(jì)中的關(guān)鍵路徑。那我們該怎么做呢?還是老思路,減少組合邏輯。我們可以對(duì)狀態(tài)的輸出進(jìn)行分析,對(duì)它們進(jìn)行重新分類,并根據(jù)這個(gè)重新定義成一組組小狀態(tài)機(jī),通過對(duì)輸入進(jìn)行選擇(case語句)并去觸發(fā)相應(yīng)的小狀態(tài)機(jī),從而實(shí)現(xiàn)了將大的狀態(tài)機(jī)切割成小的狀態(tài)機(jī)。在ATA6的規(guī)范中(硬盤的標(biāo)準(zhǔn)),輸入的命令大概有20十種,每一個(gè)命令又對(duì)應(yīng)很多種狀態(tài),如果用一個(gè)大的狀態(tài)機(jī)(狀態(tài)套狀態(tài))去做那是不可想象的,我們可以通過case語句去對(duì)命令進(jìn)行譯碼,并觸發(fā)相應(yīng)的狀態(tài)機(jī),這樣做下來這一個(gè)模塊的頻率就可以跑得比較高了。

總結(jié):提高工作頻率的本質(zhì)就是要減少寄存器到寄存器的時(shí)延,最有效的方法就是避免出現(xiàn)大的組合邏輯,也就是要盡量去滿足四輸入的條件,減少LUT級(jí)聯(lián)的數(shù)量。我們可以通過加約束、流水、切割狀態(tài)的方法提高工作頻率。

原文標(biāo)題:如何提高FPGA的運(yùn)行速度

文章出處:【微信公眾號(hào):FPGA設(shè)計(jì)論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1626

    文章

    21678

    瀏覽量

    602032
  • 電路
    +關(guān)注

    關(guān)注

    172

    文章

    5852

    瀏覽量

    171942
  • 頻率
    +關(guān)注

    關(guān)注

    4

    文章

    1459

    瀏覽量

    59163

原文標(biāo)題:如何提高FPGA的運(yùn)行速度

文章出處:【微信號(hào):gh_9d70b445f494,微信公眾號(hào):FPGA設(shè)計(jì)論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用FPGA搭建的電路,其工作頻率如何設(shè)置

    如題,使用FPGA搭建的電路,其工作頻率如何設(shè)置。是受制于晶振嗎?
    發(fā)表于 05-12 21:15

    設(shè)計(jì)一個(gè)儀表放大電路,其中的性能如何提高?

    現(xiàn)在需要設(shè)計(jì)一個(gè)儀表放大電路,其中的性能如何提高?如:溫漂、壓擺率、失調(diào)電壓、帶寬
    發(fā)表于 09-11 06:06

    求解釋無線發(fā)射電路工作原理

    本帖最后由 木偶托車 于 2016-4-21 18:04 編輯 1、求解釋無線發(fā)射電路工作原理2、如何改變輸出波形的頻率發(fā)射電路發(fā)射
    發(fā)表于 04-21 17:56

    電路工作原理?

    電路工作原理,器件參數(shù)如何調(diào)到最好?
    發(fā)表于 04-25 09:31

    求教電路工作原理?

    求教電路工作原理?
    發(fā)表于 06-18 15:17

    如何提高FPGA的運(yùn)行速度(轉(zhuǎn))

    ,今天我想進(jìn)一步去分析如何提高電路工作頻率。我們先來分析下是什么影響了電路
    發(fā)表于 08-08 11:16

    labview通過myrio采樣 采樣頻率過低 如何提高

    通過myrio采集聲音,labview中通過調(diào)節(jié)時(shí)間循環(huán)來改變聲音采樣率,再通過udp通訊將數(shù)據(jù)發(fā)出,但是我發(fā)現(xiàn)因?yàn)榇嬖趗dp通訊,采樣頻率之后1-2K,請問怎么改才能提高采樣頻率,
    發(fā)表于 05-10 16:35

    工作接地按工作頻率而采用的幾種接地方式

    方式:1 單點(diǎn)接地工作頻率低(0.83L (1)式中:L——地線的長度,m;S——地線的截面,mm2。2 多點(diǎn)接地工作頻率高(>30MHz)的采用多點(diǎn)接地式(即在
    發(fā)表于 05-29 06:26

    請教如何提高rkvdec的工作頻率

    問題描述及復(fù)現(xiàn)步驟:各位大神: 有哪位知道如何提供rkvdec的工作頻率嗎?目前在開發(fā)demo中遇到同時(shí)解 8 路 1080p@25 幀的rtsp流 幀率不足的問題,目前只能維持在17幀左右。
    發(fā)表于 02-13 10:56

    提高變?nèi)荻O管調(diào)頻電路頻率穩(wěn)定度的溫度補(bǔ)償方法

    提高變?nèi)荻O管調(diào)頻電路頻率穩(wěn)定度的溫度補(bǔ)償方法 在變?nèi)荻O管調(diào)頻電路中,載頻頻率的不穩(wěn)定性主要由溫度變化、電源電壓變化、負(fù)載阻抗變
    發(fā)表于 10-20 15:19 ?1474次閱讀
    <b class='flag-5'>提高</b>變?nèi)荻O管調(diào)頻<b class='flag-5'>電路</b><b class='flag-5'>頻率</b>穩(wěn)定度的溫度補(bǔ)償方法

    工作頻率可變的信號(hào)發(fā)生器電路

    本內(nèi)容提供了工作頻率可變的信號(hào)發(fā)生器電路,歡迎大家參考學(xué)習(xí)
    發(fā)表于 06-22 11:25 ?2782次閱讀
    <b class='flag-5'>工作</b><b class='flag-5'>頻率</b>可變的信號(hào)發(fā)生器<b class='flag-5'>電路</b>

    頻率解調(diào)器設(shè)計(jì)電路

    電子發(fā)燒友為您提供了靈敏的頻率解調(diào)電路電路采用鎖相集成電路LM565構(gòu)成,能在很寬的頻率范圍
    發(fā)表于 07-12 10:09 ?1605次閱讀
    <b class='flag-5'>頻率</b>解調(diào)器設(shè)計(jì)<b class='flag-5'>電路</b>

    FPGA片內(nèi)的工作頻率如何提高?

    ,今天我想進(jìn)一步去分析如何提高電路工作頻率。 我們先來分析下是什么影響了電路
    的頭像 發(fā)表于 10-30 12:31 ?591次閱讀

    FPGA片內(nèi)的工作頻率應(yīng)該如何提高

    ,今天我想進(jìn)一步去分析如何提高電路工作頻率。我們先來分析下是什么影響了電路
    發(fā)表于 12-15 13:05 ?6次下載

    如何提高FPGA的工作頻率

    頻率,這確實(shí)是一個(gè)很重要的方法,今天我想進(jìn)一步去分析如何提高電路工作頻率。 我們先來分析下是
    的頭像 發(fā)表于 11-16 12:10 ?1015次閱讀