《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 利用FPGA實現的任意波形發生器的研究設計
利用FPGA實現的任意波形發生器的研究設計
電子設計工程
封治華 杜改麗
摘要: 本文詳細闡述了產生任意波形數據和基于FPGA的硬件設計部分,以QuartusⅡ8.O軟件平臺作為開發工具,選用CycloneII系列的EP2C5-F256C6 FPGA芯片實現DDS結構中的數字部分,其中相位累加器是DDS的核心部件,重點闡述了相位累加器部分的設計,采用8級流水線結構借助前5級的超前進位模塊,編譯的最高工作頻率,由317.97 MHz提高到336.7 MHz,采用此種設計方法,節約了成本,縮短了開發周期,具有可行性。
Abstract:
Key words :

  波形發生器廣泛應用于電子電路、自動控制和科學試驗領域,是一種為電子測量工作提供符合嚴格技術要求的電信號設備,和示波器、電壓表、頻率計等儀器一樣是最普通、最基本也是應用最為廣泛的電子儀器之一,幾乎所有電參量的測量都要用到波形發生器。隨著通信、雷達的不斷發展,對信號源的頻率穩定度、頻譜純度、頻率范圍和輸出頻率的個數以及信號波形的形狀也提出越來越多的要求。不僅要求能產生正弦波、方波等標準波形,還能根據需要產生任意波形,且操作方便,輸出波形質量好,輸出頻率范圍寬,輸出頻率穩定度、準確度及分辨率高,頻率轉換速度快且頻率轉換時輸出波形相位連續等??梢?,研究制作高性能的任意波形發生器" title="任意波形發生器">任意波形發生器十分有必要,而且意義重大。

  1 任意波形發生器的FPGA" title="FPGA">FPGA實現

  系統框架如圖1所示,上位機產生任意波形數據,經USB2.0控制器CY7C68013A與FPGA(現場可編程門陣列)相連。將數據下載到FPGA的RAM當中,再通過硬件電路依次從波形存儲器中讀取出來,經D/A轉換及濾波后得到所需信號波形輸出。

  關于DDS的基本原理與結構在這里就不再加以闡述,用FPGA按照DDS的基本原理和結構設計和實現一個任意波形發生器,所以DDS的幾個基本部分都是應當具備的。實現任意波形發生的關鍵在于把存放波形量化表的ROM換成了可以改寫的RAM,這樣通過與RAM的接口可以改變存放在波形RAM中的數據從而實現任意波形發生。這里主要介紹控制部分、相位累加器、波形RAM幾個模塊來敘述任意波形發生器的實現。

  1.1 控制部分

  這個部分主要是要解決DDS模塊與單片機的接口問題。在FPGA的實現中,主要設計了2個模塊,一個是輸入寄存器模塊,為了接收單片機寫入的頻率控制字。另外一個是地址分配模塊,這樣單片機就可以通過不同的地址來選通FPGA各個模塊工作。設計中DDS采用了32位的相位累加器。這樣對于一個頻率控制字,單片機要分4次分別寫入4個字節;基于這樣的要求,設計了輸入寄存器模塊如圖2,這個部分主要是要解決DDS模塊與單片機的接口問題。

  din[7..0]是該模塊與單片機數據線的接口,clr是低電平異步清零,en是高電平使能,elk為數據寫入時鐘,dout[31..O]是寄存器輸出的32位頻率控制字。該模塊工作過程為:當en為高電平,clr也為高電平時,elk的上升沿將輸入的8位數據鎖存進該模塊中,當鎖存完4個字節的數據后,自動將該4個字節的數據按照先寫入的在高位的順序組合成一個32 bit的數據輸出到dout[31..0]。

  該模塊的功能仿真圖如圖3所示,看到當clr=‘1’并且en=‘1’時,經過4個時鐘,dout上將前4個時鐘的值‘00’、‘01’、‘02’、‘03’組成32位的‘00010203’數值輸出在dout上。

關鍵字:FPGA 任意波形發生器

 

  地址分配模塊采用一個3/8譯碼器來實現地址選通的功能,如圖4所示。

  由于累加器的清零是當“clr”=1的時候,所以在與門后加一個反相器,而頻率寄存器清零的條件是“clr”=0,所以,就可以直接與門后相連即可。3/8譯碼器的使能端接VCC,G2AN和G2BN連起來接CS,作為整個任意波形發生器模塊的片選信號,當低電平的時候選中,各模塊才開始工作。

  地址鎖存模塊主要解決單片機P0口的分時復用問題。本設計選用的單片機為51系列單片機,其PO口既作為數據口,又作為地址總線的低8位,因此在使用時,需要將地址信號從分時復用的地址/數據總線中分離出來。本設計選用8D鎖存器7415373來作為地址鎖存器。當74LS373用作為地址鎖存器時,應使OEN為低電平導通輸出,此時,鎖存使能端G為高電平時,輸出Q1~Q8狀態與輸入D1~D8狀態相同;當G發生負跳變時,輸入端數據D1~D8鎖入Q1~Q8。因此在使用74LS373時,51單片機的ALE信號可以直接與74LS373的G相連。

  1.2 相位累加器設計

  相位累加器用于對輸入頻率控制字進行累加運算,輸入頻率控制字決定輸出信號的頻率和頻率分辨率。因此相位累加器是整個DDS性能的關鍵部分。傳統的相位累加器是用1個加法器加1個D觸發器組成,調用其中的1個宏模塊設置成32位數據相加,再加另一個32位的宏模塊,就可以組成相位累加器。它在QuartusII軟件中的最高編譯頻率只有262.12 MHz,顯然不能滿足設計要求。其時序仿真如圖5所示。

  通過仿真,當直接采用32 bit累加器的時候系統時鐘最大只能達到大約25 MHz,顯然是達不到要求的。從設計上看,它實質上是一個帶反饋的32位加法器,把輸出數據作為另一路輸入數據和從單片機傳來的頻率控制連續相加,產生有規律的32位相位地址碼。一般位數小的累加器可以通過FPGA中的進位鏈得到快速高效的電路,但是進位鏈必須位于臨近的LE(邏輯單元)或LAB(邏輯陣列塊)中,長的進位鏈會減少供其他邏輯使用的布線資源,同時過長的進位鏈也會制約系統頻率的提高,所以進位鏈不能太長。因此,在相位累加器的設計中,要解決的難題是設法提高工作速度。為了解決速度難題,需從兩個方面進行改進。

  1.2.1 改進的流水線結構

  在時序電路設計中為了提高速度,流水線結構是一種常用的設計方法。對于累加器來講,流水線結構就是把一個位數很長的加法拆分成N個位數較短的加法,在N個時鐘周期內做完然后輸出運算結果,N就是流水線的級數。采用流水結構以后由于加法器的字長變短了,對于FPGA來講加法器字長變短對工作頻率的提高是相當可觀的。當然,流水結構的使用并不能無限制地提高電路的工作速度。因此對于不同的器件來說,采用多少級流水對性能的提升比較大這個要經過仿真實驗才能得到一個比較肯定的值。

  本文運用流水線結構對相位累加器進行設計,當m=8、n=4的情況下,相位累加器的工作頻率是最高的,達到了約70 MHz。但是為了進一步提高工作頻率,還需要結合下面的并行進位方法。

  1.2.2 并行進位加法器

  DDS累加器電路的設計采用了流水線結構,由8級4位加法器完成對32位控制字的累加。32位累加器的結果在送入相位幅度變化電路時,進行了高位截斷,只取高12位數據進行查表。因而,在8級的流水線結構中,前5級4位加法器實際上只貢獻了進位,在設計時,前4級加法器采用了超前進位鏈,而高位加法器不僅要給出進位值,還要獲得加法的結果,因此采用了QuartusII自帶的宏模塊結構。通過每一位的Pi、Gi和Ci-1值很容易求得該位進位值Ci。再與該位的和(Ai+Bi)相異或就得到最后的結果Si。即

  采用上述結構,極大地提高了累加器的工作速度,其功能仿真圖如圖6所示,從圖中可以看出,此4 bit超前進位加法器完全滿足4位全加器的邏輯功能。

關鍵字:FPGA 任意波形發生器

 

  下面就將前5級采用超前進位加法器的32位累加器和宏模塊中調用的4位全加器組成的32位相位累加器性能進行比較。

  普通流水線累加器的模塊是由4位D觸發器,5位D觸發器和4位全加器作為基本元件,采用原理圖輸入的方法設計FPGA的流水線累加器。該模塊的設計參照流水線累加器結構進行,不同之處在于:由于相位累加器只用高位尋址,所以低位上為了和高位結果同時輸出而做延時作用的D觸發器件均被去掉了。這樣做的結果是,相位累加器輸出的低20位會因為提前輸出而混亂,但是由于高12位的輸出一定是正確的,這樣做既節省了資源,對結果又沒有任何影響。仿真結果證明假如不用流水線結構,32 bit相位累加器工作頻率最高達到約25 MHz。消耗的資源是82個LEs,而用了8級流水線結構后,編譯工作頻率最高達到了約317.79 MHz,資源消耗為186個LEs??梢娫谫Y源上的消耗換來了在性能上的極大提高。

  流水線累加器的時序仿真如圖7所示:可以看出當輸入數據確定后,輸出結果要經過8個時鐘周期的延時后輸出,這是因為采用了8級流水結構。采用多少級流水結構,輸出就會延時多少個周期。同時也說明,對于輸入數據切換來說,該系統會有8個時鐘周期的延時,這是累加器采用流水線結構所不可避免的后果。事實上目前許多DDS專用芯片由于也采用流水線結構,所以本身也存在這樣的問題。由于8個時鐘周期的延時與系統時鐘相比,實際上還是很小的,在一般的應用場合下也是可以接受的。由于輸出的低20位未用,被省略了,只用了輸出的高12位,所以仿真波形中只有高12位的輸出結果。從輸出結果來看,高12位的輸出值是沒有錯誤的,與設計思想吻合。

  下面介紹超進位流水線累加器的構成,比較流水線累加器內部結構圖和超前進位加法器的32位相位累加器的結構圖,可以看出兩個圖的區別,經過編譯以后的報告如圖8所示,可以看出經過改進后,編譯的最大工作頻率提高到了336.7 MHz。比單純的流水線累加器提高了將近20 MHz。

  圖9是其時序仿真圖,從圖上可以看出,其值完全和功能仿真一致。

關鍵字:FPGA 任意波形發生器

 

  1.3 雙口RAM設計

  在設計波形存取電路時,首先應確定波形RAM的深度和字長。波形RAM的深度和字長與很多因素有關系。存儲器內部存儲的是一個或N個整周期的標準波形數據,存儲器容量越大,存儲的被采樣波形點數就越多,采樣效果就越好。存儲器的讀取速度是產生高頻波形的重要保證,讀取速度必須滿足相位累加器的累加速度,這樣才能保證直接數字合成過程的正常進行。同時,為了保證整個速度的同步性,選用一種同步RAM也是很必要的。

  首先要確定波形RAM的深度和字長,由于任意波形發生器設計中選擇的DAC的字長是12位,很明顯波形RAM的字長也應該是12位;由于選擇的地址線位數為12位(即相位累加器輸出的高12位),尋址空間為4 K(4 096)個單元,即RAM存儲空間應為4 096x12 bit=49 152 bits,由于本設計所選擇的FPGA內部RAM最大可配置為119 808 bits,完全可以滿足49 152 bits的RAM空間設計。所以波形RAM設計為字長12位,地址線12位。針對任意波形發生器與普通DDS的不同,波形RAM的設計主要要求RAM具有讀寫兩個端口,這樣可以通過兩套地址系統,方便地進行RAM內容更新,即對RAM的寫操作;波形幅度量化數據的輸出,即對RAM的讀操作。結合ALTERA公司FPGA的特點,選擇了EP2C5F256C6這個芯片內部的雙口RAM來實現這個功能,如圖10所示。

  芯片內部的雙口RAM具有讀地址和寫地址兩組地址線,數據線也分成了讀數據線和寫數據線兩組。這樣波形RAM的設計就非常簡單了,將寫數據線、寫地址線和單片機的數據線、地址線相連,用單片機更新RAM中的數據;將讀地址線和讀數據線分別與相位累加器的輸出和DAC的數據輸入相連,讀數據線上即輸出了波形幅度量化數據。

  2 結束語

  本文詳細闡述了產生任意波形數據和基于FPGA的硬件設計部分,以QuartusⅡ8.O軟件平臺作為開發工具,選用CycloneII" title="CycloneII">CycloneII系列的EP2C5-F256C6 FPGA芯片實現DDS結構中的數字部分,其中相位累加器是DDS的核心部件,重點闡述了相位累加器部分的設計,采用8級流水線結構借助前5級的超前進位模塊,編譯的最高工作頻率,由317.97 MHz提高到336.7 MHz,采用此種設計方法,節約了成本,縮短了開發周期,具有可行性。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          99在线精品观看| 欧美成人国产va精品日本一级| 欧美va日韩va| 国产乱码精品一区二区三区五月婷| 久久久视频精品| 欧美日韩国产美| 亚洲国产日韩精品| 欧美激情视频一区二区三区在线播放| 影院欧美亚洲| 欧美日韩综合在线| 欧美日韩一区二区三区视频| 国产精品美女久久久免费| 国产精品国产三级国产普通话99| 欧美日韩直播| 一区二区免费看| 国产精品色婷婷久久58| 久久精品国产在热久久| 国产精品区免费视频| 欧美久久久久久久久| 欧美视频一区二区在线观看| 一区二区三区四区精品| 欧美日韩一二三四五区| 麻豆乱码国产一区二区三区| 国产精品v亚洲精品v日韩精品| 麻豆国产精品一区二区三区| 黄色成人av| 欧美一级视频免费在线观看| 在线精品高清中文字幕| 国产精品美女久久| 欧美日韩一区二区三| 久久亚洲二区| 免费在线成人av| 欧美四级伦理在线| 樱桃视频在线观看一区| 男女av一区三区二区色多| 亚洲一区二区免费视频| 亚洲人体偷拍| 国产日韩欧美不卡| 国产日本欧美一区二区三区在线| aa级大片欧美| 黑人一区二区| 欧美性猛交视频| 99精品欧美| 亚洲四色影视在线观看| 国产欧美一区二区精品性色| 国产精品一区二区在线观看| 免费精品99久久国产综合精品| 国产自产女人91一区在线观看| 欧美极品欧美精品欧美视频| 亚洲视频你懂的| 一本色道久久99精品综合| 亚洲成人在线免费| 国产日韩精品一区二区三区在线| 久久riav二区三区| 国产精品视频xxxx| 国产亚洲欧美日韩精品| 亚洲线精品一区二区三区八戒| 欧美一区网站| 国产偷国产偷精品高清尤物| 亚洲国内精品| 国产午夜久久| 亚洲日本aⅴ片在线观看香蕉| 国内视频精品| 性色av一区二区三区在线观看| 亚洲网站啪啪| 欧美伊人久久久久久久久影院| 一区二区三区高清在线观看| 日韩亚洲视频在线| 欧美一级日韩一级| 欧美黄色aa电影| 欧美一级一区| 99热在线精品观看| 久久久亚洲一区| 亚洲精品欧美日韩专区| 午夜精品久久久久久久男人的天堂| 欧美精品1区2区3区| 尤物yw午夜国产精品视频| 欧美一区91| 欧美专区在线观看| 亚洲欧美精品在线观看| 久久精品99国产精品酒店日本| 免费国产一区二区| 欧美日本二区| 国外精品视频| 亚洲大胆美女视频| 亚洲欧美激情视频| 91久久香蕉国产日韩欧美9色| 久久一区二区三区av| 亚洲欧美日韩视频一区| 久久亚洲私人国产精品va媚药| 国产日韩亚洲| 欧美二区视频| 欧美与黑人午夜性猛交久久久| 久久精品欧美日韩精品| 影音先锋中文字幕一区| 欧美激情1区2区| 国产精品亚洲激情| 亚洲国产高清一区| 国产精品久久久久久久久免费| 中日韩美女免费视频网址在线观看| 亚洲国产岛国毛片在线| 欧美日韩国产精品专区| 黄色成人免费网站| 久久综合久久美利坚合众国| 国产精品夜夜夜一区二区三区尤| 欧美精品一区二区三区在线看午夜| 亚洲三级电影全部在线观看高清| 一区二区视频免费在线观看| 欧美激情第4页| 国产综合色一区二区三区| 在线综合亚洲| 欧美日韩亚洲网| 一区二区三区无毛| 欧美午夜片欧美片在线观看| 亚洲欧美日韩一区二区| 午夜精品一区二区三区在线视| 国产精品亚洲人在线观看| 激情小说另类小说亚洲欧美| 亚洲国产欧美另类丝袜| 最新亚洲视频| 亚洲每日在线| 国产精品美女主播| 欧美精品 国产精品| 最新国产拍偷乱拍精品| 欧美一区在线视频| 欧美日韩一区二区三区在线| 国产亚洲va综合人人澡精品| 欧美一区二区日韩一区二区| 亚洲激情不卡| 国产精品麻豆va在线播放| 99riav久久精品riav| 久久精品午夜| 99视频精品免费观看| 欧美日韩亚洲国产一区| 亚洲午夜免费福利视频| 亚洲一区二区日本| 一本色道久久88综合亚洲精品ⅰ| 国产精品成人播放| 国产精品久久久久久久久免费樱桃| 亚洲成色777777在线观看影院| 欧美日本国产在线| 一个色综合导航| 欧美日韩麻豆| 在线观看91精品国产入口| 黄色成人在线免费| 亚洲人被黑人高潮完整版| 男人的天堂亚洲在线| 欧美精品免费观看二区| 午夜在线a亚洲v天堂网2018| 欧美福利网址| 国产美女一区| 久久九九久精品国产免费直播| 国产精品视频免费在线观看| 国产欧美日本一区二区三区| 亚洲欧美日韩在线不卡| 久久精品欧洲| 亚洲宅男天堂在线观看无病毒| 狠狠v欧美v日韩v亚洲ⅴ| 欧美中文字幕在线视频| 国产精品第13页| 久久av一区二区三区亚洲| 一区二区三区欧美在线观看| 一区在线电影| 国产亚洲欧美另类一区二区三区| 亚洲三级视频| 久久久久国色av免费看影院| 亚洲美女诱惑| 在线一区欧美| 欧美色欧美亚洲另类二区| 99爱精品视频| 亚洲伦理在线免费看| 在线国产精品一区| 黄色av一区| 欧美好吊妞视频| 亚洲另类春色国产| 亚洲欧美色一区| 亚洲视频在线视频| 国产精品超碰97尤物18| 性xx色xx综合久久久xx| 欧美日韩国产精品成人| 亚洲国产精品va在线看黑人| 久久久人成影片一区二区三区观看| 欧美日韩综合视频| 美女视频一区免费观看| 亚洲欧洲在线观看| 美国成人毛片| 国产精品美女www爽爽爽| 欧美日本国产一区| 亚洲日本成人| 国产一区二区三区直播精品电影| 免费欧美在线视频| 国产日韩欧美黄色| 黄色成人在线观看| 久久久久久久久久久成人| 久久婷婷激情| 在线亚洲成人| 欧美黑人多人双交| 亚洲国产精品悠悠久久琪琪| 午夜精品久久久久久久蜜桃app| 欧美区一区二区三区| 亚洲高清在线视频| 久久人人97超碰国产公开结果| 欧美成人午夜免费视在线看片| 中文亚洲欧美| 欧美日韩视频在线一区二区观看视频| 欧美剧在线观看| 国产精品免费在线| 国产综合香蕉五月婷在线| 欧美中文在线观看国产| 欧美成人网在线| 欧美三级视频| 91久久一区二区| 最新亚洲电影| 欧美精品免费观看二区| 在线色欧美三级视频| 在线观看欧美黄色| 亚洲国产另类 国产精品国产免费| 国产视频自拍一区| 午夜精品一区二区三区四区| 欧美三日本三级少妇三99| 亚洲欧美一区二区三区在线| 欧美亚州一区二区三区| 欧美3dxxxxhd| 国产区精品视频| 国产精品啊啊啊| 国产精品一区久久久久| 欧美a级片网| 欧美精品国产精品| 久久九九全国免费精品观看| 欧美三区在线视频| 亚洲一区二区三区精品在线| 一区二区日韩伦理片| 亚洲国产你懂的| 亚洲欧美日韩一区二区三区在线| 国产精品久久久亚洲一区| 一本一道久久综合狠狠老精东影业| 老司机精品福利视频| 欧美日韩在线大尺度| 欧美巨乳在线| 精品99视频| 欧美日韩在线视频首页| 巨胸喷奶水www久久久免费动漫| 国产欧美一区二区三区另类精品| 亚洲午夜精品久久久久久app| 免费成人高清视频| 国产日韩精品一区二区三区| 午夜精品久久99蜜桃的功能介绍| 欧美护士18xxxxhd| 午夜视频一区| 欧美与黑人午夜性猛交久久久| 国产欧美精品国产国产专区| 欧美精品一区二区高清在线观看| 亚洲丝袜av一区| 亚洲成人资源网| 亚洲激情在线观看视频免费| 国产一区二区三区精品久久久| 欧美激情精品久久久久久| 精品av久久707| 黄色成人在线| 国产精品久久激情| 欧美激情一区在线观看| 亚洲综合大片69999| 欧美日韩中文字幕在线视频| 在线欧美日韩精品| 国产精品美女久久久浪潮软件| 欧美日韩国产丝袜另类| 国产精品性做久久久久久| 在线日本欧美| 久久精品国产一区二区三区免费看| 在线综合亚洲| 国产日韩在线视频| 一区二区三区精品国产| 久久国产高清| 欧美一级视频| 欧美一区二区高清在线观看| 欧美激情精品久久久久久黑人| 99精品欧美一区二区蜜桃免费| 久久精品国产欧美激情| 亚洲看片一区| 欧美精品在线免费播放| 国产精品你懂的| 亚洲欧美日韩电影| 欧美日本精品在线| 久久久久国色av免费看影院| 99国产精品视频免费观看一公开| 亚洲高清视频一区| 午夜精品偷拍| 欧美精品一区二区三区在线播放| 欧美日韩成人在线观看| 另类天堂av| 欧美一级久久| 香蕉国产精品偷在线观看不卡| 欧美激情性爽国产精品17p| 性色av一区二区怡红| 在线观看视频一区二区| 国产精品美女久久福利网站| 久久一区二区三区国产精品| 亚洲欧洲精品一区二区三区波多野1战4| 亚洲一级黄色| 欧美一级午夜免费电影| 一本色道久久综合亚洲91| 亚洲欧洲另类国产综合| 一区二区欧美在线| 亚洲曰本av电影| 中文av一区二区| 亚洲国产欧美不卡在线观看| 国产在线精品一区二区中文| 久久久亚洲国产天美传媒修理工| 一区二区久久久久| 免费一级欧美片在线观看| 亚洲二区在线视频| 亚洲综合社区| 欧美视频免费在线观看| 一区二区三区视频免费在线观看| 国产亚洲欧美另类一区二区三区| 亚洲砖区区免费| 欧美三区在线视频| 久久久久久尹人网香蕉| 欧美gay视频| 欧美高清在线一区| 欧美视频一区在线观看| 一区二区在线观看视频在线观看| 欧美视频一区二区三区| 老司机凹凸av亚洲导航| 黑人一区二区三区四区五区| 欧美另类在线观看| 日韩系列在线| 一本综合精品|