《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 直接數字頻率合成器DDS的優化設計
直接數字頻率合成器DDS的優化設計
藍 天,張金林
摘要: 在深入理解DDS基本原理的基礎上,采用多級流水線控制技術對DDS的VHDL語言實現進行了優化,并進行了異步接口的同步化設計,給出了DDS系統的時序仿真結果及其在FPGA中的資源占有率。
Abstract:
Key words :

  摘 要: 在深入理解DDS基本原理的基礎上,采用多級流水線控制技術對DDS的VHDL語言實現進行了優化,并進行了異步接口的同步化設計,給出了DDS系統的時序仿真結果及其在FPGA中的資源占有率。
  關鍵詞: DDS  流水線  累加器  ROM  接口同步

  新一代的直接數字頻率合成器DDS,采用全數字的方式實現頻率合成。與傳統的頻率合成技術相比DDS具有以下特點:(1)頻率轉換快。直接數字頻率合成是一個開環系統,無任何反饋環節,其頻率轉換時間主要由頻率控制字狀態改變所需的時間及各電路的延時時間所決定,轉換時間很短。(2)頻率分辨率高、頻點數多。DDS輸出頻率的分辨率和頻點數隨相位累加器位數的增長而呈指數增長,分辨率高達μHz。(3)相位連續。DDS在改變頻率時只需改變頻率控制字(即累加器累加步長),而不需改變原有的累加值,故改變頻率時相位是連續的。(4)相位噪聲小。DDS的相位噪聲主要取決于參考源的相位噪聲。(5)控制容易、穩定可靠。高集成度、高速和高可靠是FPGA/CPLD最明顯的特點,其時鐘延遲可達納秒級,結合其并行工作方式,在超高速應用領域和實時測控方面有非常廣闊的應用前景。在高可靠應用領域,如果設計得當,將不會存在類似于MCU的復位不可靠和PC可能跑飛等問題。CPLD/FPGA的高可靠性還表現在,幾乎可將整個系統下載于同一芯片中,實現所謂片上系統,從而大大縮小了體積,易于管理和屏蔽。所以,本文將在對DDS的基本原理進行深入理解的基礎上,采用多級流水線控制技術對DDS的VHDL語言實現進行優化,同時考慮到系統設計中的異步接口的同步化設計問題,把該設計適配到Xilinx公司的最新90nm工藝的Spartan3E系列的FPGA中。
1 DDS基本原理及工作過程
  一個基本的DDS由相位累加器、波形存儲器ROM、D/A轉換器和低通濾波器組成,如圖1所示。


  在圖1中,fc為時鐘頻率,K為頻率控制字(N位),m為ROM地址線位數,n為ROM數據線寬度(一般也為D/A轉換器的位數),f0為輸出頻率。DDS的基本工作過程如下:每來一個時鐘
脈沖fc,加法器將頻率控制字K與累加寄存器輸出的累加相位數據相加,把相加后的結果送至累加寄存器的數據輸入端。其中相位累加器由N位加法器與N位累加寄存器級聯構成,累加寄存器將加法器在上一個時鐘脈沖作用后所產生的新相位數據反饋到加法器的輸入端,以使加法器在下一個時鐘脈沖的作用下繼續與頻率控制字相加。這樣,相位累加器在時鐘作用下,不斷對頻率控制字進行線性相位累加。由此可見,相位累加器在每一個時鐘脈沖輸入時,把頻率控制字累加一次,相位累加器輸出的數據就是合成信號的相位,相位累加器的溢出頻率就是DDS輸出的信號頻率。用相位累加器輸出的數據作為波形存儲器ROM的相位取樣地址,可把存儲在波形存儲器內的波形抽樣值(二進制編碼)經查找表查出,完成相位到幅值轉換。波形存儲器的輸出送到D/A轉換器,D/A轉換器將數字量形式的波形幅值轉換成所要求合成頻率的模擬量形式信號,由低通濾波器濾除雜散波和諧波以后,輸出一個頻率為f0的正弦波。輸出頻率f0與時鐘頻率fc之間的關系滿足下式:
  

  由式(1)可見,輸出頻率f0由fc和K共同決定,保持時鐘頻率一定,改變一次K值,即可合成一個新頻率的正弦波。DDS的最小輸出頻率(頻率分辨率)△f可由方程△f=f0/2N確定。可見,頻率分辨率在fc固定時,取決于相位累加器的位數N。只要N足夠大,理論上就可以獲得足夠高的頻率分辨精度。另外,由采樣定理,合成信號的頻率不能超過時鐘頻率的一半,即f0≤f0/2,因此頻率控制值的最大值Kmax應滿足Kmax≤2N-1
2 DDS的優化設計與實現
  采用VHDL硬件描述語言實現整個電路,不僅利于設計文檔的管理,而且方便了設計的修改和擴充,還可以實現在不同FPGA器件[4]之間的移植。以下采用VHDL語言,探討對FPGA
實現DDS電路的三點優化方法。
2.1 流水線累加器
  在用FPGA設計DDS電路時,相位累加器是決定DDS電路性能的一個關鍵部分。為使輸出波形具有較高的分辨率,本系統采用32位累加器。但若直接用32位加法器構成累加器,則
加法器的延時會大大限制累加器的操作速度。因此,這里引入了流水線算法,即采用4個8位累加器級聯結構,每級用一個8位累加器實現該部分相位相加,然后將進位值傳給下一級做進一步累加。這樣可大幅提高系統的工作速度。但由于累加器是一個閉環反饋電路,因此必須使用寄存器,以保證系統的同步、準確運行。具體實現如圖2所示。


2.2 相位/幅度轉換電路
  相位/幅度轉換電路是DDS電路中的另一個關鍵部分,設計中面臨的主要問題就是資源的開銷。該電路通常采用ROM結構,相位累加器的輸出是一種數字式鋸齒波,通過取它的若
干位作為ROM的地址輸入,而后通過查表和運算,ROM就能輸出所需波形的量化數據。考慮到正弦函數的對稱性:在[0,2π]內,正弦函數關于x=π成奇對稱,在[0,π]內,關于x=π/2成軸對稱。因此,在正弦查找表中只須存儲相位在[0,π/2]的函數值。這樣,通過一個正弦碼表的前1/4周期就可以變換得到整個周期碼表,節省了近3/4的資源,非常可觀。具體實現如表1所示,為節省ROM資源,取相位累加器輸出的高8位做為ROM的輸入地址,其中最高位(MSB)控制對輸出信號符號的處理,次高位(MSB-1)控制對輸入地址的處理。


  當MSB-1為‘0’(一,三象限)時,對查找地址phase(5...0)不做任何處理;當其為‘1’(二,四象限)時,對phase(5...0)取反。ROM的輸出為10位數據,其中最高位為符號位
。當MSB為‘0’(一,二象限)時,輸出信號符號位為‘0’,低9為ROM中的幅度數據;當其為‘1’(三,四象限)時,輸出信號符號位為‘1’,低9位為ROM中的幅度數據的相反數的補碼。ROM的VHDL實現的主要部分如下:
  architecture Behavioral of rom is
  signal sin:STD_LOGIC_VECTOR(8 downto 0);
  signal temp:STD_LOGIC_VECTOR(5 downto 0);
  begin
  temp<=phase when MSB-1=′0′ else
    not phase;
  process(temp)
  begin
    case temp is
      when ″000000″=>
        sin<=″000000000″;
       …… --正弦查找表由MATLAB生成
    end case;
  end process;
  data_out<=″0″ & sin when MSB=′0′ else
     ″1″ & not sin+″000000001″;
  end Behavioral;
2.3 同步接口電路設計
  在使用DDS時,需要為其提供頻率控制字K的值,一般通過中央控制單元MCU來完成,其以數據總線及寫時鐘信號的方式與FPGA內的DDS實體進行通訊,同時DDS在FPGA內部又是在本地時鐘fc驅動下運行。由于MCU的寫時鐘和FPGA內的本地時鐘異步,兩者之間進行通訊難免存在數據不穩等問題,特別是在通訊速度較高時,這一異步接口問題會更加突出。為了實現異步接口的同步化,本文提出了如圖3所示的接口同步電路。


3 硬件實現及仿真結果
  本文使用VHDL 語言對各個模塊及DDS系統進行描述。頂層文件如下所示:
  Entity dds is
    Port(reset:in std_logic;--全局復位信號
    fre:in std_logic_vector(7 downto 0);
                    --頻率控制字輸入
    clk:in std_logic;
                    --系統時鐘
    fwwrn:in std_logic;      --頻率控制字寫信號
    gen:in std_logic_vector(0 downto 0);--波形控制字
    amp_out:out std_logic_vector(9 downto 0));
                   --正弦波幅度輸出
  end dds;
  architecture Behavioral of dds is
  component fcwld--接口同步模塊
    Port(reset:in std_logic;
      clk:in std_logic;
      fre:in std_logic_vector(7 downto 0);
      fwwrn:in std_logic;
      syncfreq:out std_logic_vector(31 downto 0));
                     --合成頻率控制字
  end component;
  component accumulator        --流水線累加器塊
    Port(reset:in STD_LOGIC;
      clk:in STD_LOGIC;
      syncfreq:in STD_LOGIC_VECTOR(31 downto 0);
      phase:out STD_LOGIC_VECTOR(7 downto 0));
                    --相位高八位輸出
  end component;
  component rom--波形存儲器模塊
    Port(phase:in STD_LOGIC_VECTOR(7 downto 0);
      gen:in STD_LOGIC_VECTOR(0 downto 0);
      amp_out:out STD_LOGIC_VECTOR(9 downto 0));
  end component;
  為了對DDS進行評估,將以上設計在Xilinx公司的開發軟件中進行了設計及優化,目標器件為其最新的90nm工藝器件Spartan3E中最小器件XC3S100E-4VQ100C,該設計所占用的
FPGA資源如表2所示。


  由表2可以看出,本文給出的DDS設計占用資源很少,由于XC3S100E的市場價格在2美金左右,故本設計所占的硬件成本可以縮減到0.2美金左右。同時在ISE8.2中該設計的系統
時鐘最大達到159.6MHz。以上的設計性能幾乎和現有的專用芯片相當,但成本下降很多。
  為了進一步驗證本文給出的DDS設計系統在功能和時序上的正確性,對其進行了時序仿真,使用的仿真軟件為Modelsim6.1。仿真結果表明,該DDS系統可以運行在較高的工作頻率下。
  本文在對DDS的基本原理進行深入理解的基礎上,通過采用三種優化與設計技術:(1)使用流水線累加器在不過多增加門數的條件下,大幅提高了芯片的工作速度;(2)壓縮成正
弦查找表,在保證芯片使用精度的情況下減少了近3/4面積,大大節約了ROM的容量。(3)采用同步接口電路設計方案,消除了系統的接口不穩定性。同時使用VHDL語言實現了優化,并把該設計適配到Xilinx公司的最新90nm工藝的Spartan3E系列的FPGA中,實際結果表明了本文給出的DDS設計方案在硬件開銷方面的優勢。
參考文獻
[1] TIEREY J,RADER C,GOLD B.A digital frequency synthe-sizer.IEEE trans.Audio and electroacoust.1971,48:57.
[2] VANKKA J,WALTARI M.Direct digital synthesizer with on-Chip D/A-Converter.IEEE J.of SCC,VoL33,1998,218:227.
[3] 褚振勇,翁木云.FPGA設計及應用[M].西安:西安電子科技大學出版社,2003:288-293.
[4] 林名權.VHDL數字控制系統設計范例[M].北京:電子工業出版社,2003.
[5] 徐彬,譚征,袁蕾,等.基于DDS技術的任意波形發生器[J].電子世界,2001,1:58-60.

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲欧美中文字幕| 亚洲人成7777| 91久久精品美女高潮| 国产亚洲成精品久久| 欧美亚一区二区| 欧美日韩二区三区| 欧美日韩激情网| 欧美区亚洲区| 欧美精品在线视频观看| 欧美成人精品在线视频| 免费成人黄色| 欧美大成色www永久网站婷| 久久伊人免费视频| 麻豆成人在线播放| 美腿丝袜亚洲色图| 欧美成人精品三级在线观看 | 蜜臀a∨国产成人精品| 六月婷婷一区| 欧美韩日亚洲| 欧美人牲a欧美精品| 欧美日韩另类字幕中文| 欧美午夜不卡影院在线观看完整版免费| 欧美日韩亚洲国产精品| 欧美性开放视频| 国产精品一区免费观看| 国产亚洲欧美一级| 精品51国产黑色丝袜高跟鞋| 在线免费一区三区| 亚洲欧洲一区二区三区在线观看 | av成人黄色| 亚洲一区二区三区三| 亚洲欧美日产图| 久久久久久网站| 欧美91视频| 欧美色图一区二区三区| 国产精品视频内| 韩国一区电影| 亚洲精品国产拍免费91在线| 日韩午夜电影在线观看| 亚洲主播在线观看| 亚洲国产精品黑人久久久| 亚洲精品在线免费观看视频| 黄色影院成人| 国产精品久久777777毛茸茸| 国产九九精品视频| 激情婷婷欧美| 亚洲九九精品| 亚洲高清一区二| 国产精品青草久久久久福利99| 国产欧美一区二区精品仙草咪| 激情综合色丁香一区二区| 亚洲精品国产视频| 亚洲欧美欧美一区二区三区| 亚洲国产精品免费| 亚洲少妇诱惑| 久久国产精品一区二区| 欧美黄色一区| 国产日韩欧美一区二区| 亚洲人成网站影音先锋播放| 亚洲欧美日韩第一区| 亚洲片在线观看| 午夜视频一区| 欧美激情视频一区二区三区免费 | 一本到高清视频免费精品| 欧美亚洲日本一区| 99pao成人国产永久免费视频| 午夜精品久久久久久久白皮肤| 久热精品在线视频| 国产精品v欧美精品v日韩精品 | 亚洲电影观看| 亚洲欧美激情一区二区| 久久亚洲一区| 国产精品高潮呻吟久久av无限| 韩国成人福利片在线播放| 宅男精品视频| 亚洲黄页一区| 欧美在线视频观看| 欧美日韩的一区二区| 国内精品久久久久影院薰衣草| 一本色道久久综合亚洲精品不| 亚洲国产精品一区二区三区| 午夜视频久久久| 欧美日韩一区二| 在线观看欧美一区| 欧美亚洲免费电影| 亚洲欧美日韩另类| 欧美理论电影在线观看| 黄色av成人| 亚洲欧美日韩一区| 亚洲一区二区三区在线观看视频| 免费在线观看一区二区| 国产视频一区欧美| 亚洲少妇在线| 99v久久综合狠狠综合久久| 久久全球大尺度高清视频| 国产精品女人毛片| 亚洲国产免费| 久久精品观看| 久久精品视频播放| 国产精品入口麻豆原神| 亚洲精品之草原avav久久| 亚洲国产成人久久综合| 久久xxxx| 国产精品一区二区在线观看网站| 野花国产精品入口| 日韩一级网站| 欧美aⅴ一区二区三区视频| 国内精品久久久久久| 欧美在线播放| 欧美在线视频免费| 国产精品劲爆视频| 亚洲视频 欧洲视频| 国产精品99久久久久久宅男| 麻豆国产精品一区二区三区| 国语自产精品视频在线看抢先版结局 | 一区二区免费在线视频| 日韩亚洲一区在线播放| 老鸭窝亚洲一区二区三区| 国产午夜精品久久| 亚洲一区3d动漫同人无遮挡| 亚洲视频在线观看网站| 欧美日本中文字幕| 91久久精品美女| 99国产精品久久久久老师| 欧美激情一区二区三区高清视频| 亚洲成人自拍视频| 亚洲人成在线影院| 欧美a级在线| 亚洲国产小视频| 日韩视频免费观看高清完整版| 欧美gay视频激情| 亚洲国产精品电影| 夜夜爽夜夜爽精品视频| 欧美日韩国产精品专区 | 小黄鸭视频精品导航| 久久久福利视频| 国产有码一区二区| 久久精品亚洲一区| 另类成人小视频在线| 亚洲国产精品成人精品| 日韩一级在线| 欧美三级电影网| 亚洲欧美日韩精品久久奇米色影视| 亚洲亚洲精品三区日韩精品在线视频| 欧美视频在线视频| 亚洲图色在线| 久久精品国产清高在天天线| 狠狠色综合色区| 亚洲毛片在线| 久久中文字幕一区二区三区| 亚洲国产高清在线观看视频| 99精品免费| 国产精品欧美日韩一区二区| 午夜精品久久| 蜜臀va亚洲va欧美va天堂| 亚洲国产一成人久久精品| 亚洲先锋成人| 国产欧美日韩一区二区三区在线| 久久国产精品毛片| 欧美激情精品久久久久久蜜臀| 夜夜嗨av一区二区三区网站四季av| 午夜欧美电影在线观看| 国内视频一区| 亚洲视频免费| 国产农村妇女毛片精品久久麻豆| 欧美在现视频| 欧美日韩国产成人在线观看| 亚洲综合视频一区| 美女日韩在线中文字幕| 99亚洲精品| 久久精品视频在线免费观看| 亚洲人成绝费网站色www| 亚洲欧美日韩国产综合| 国产一级一区二区| 日韩午夜电影在线观看| 国产精品影视天天线| 亚洲国产精品一区在线观看不卡 | 日韩网站免费观看| 国产精品日韩电影| 亚洲国产精品女人久久久| 欧美午夜视频在线观看| 久久国内精品视频| 欧美日韩一二区| 亚洲激情视频网| 国产精品午夜视频| 亚洲精品乱码久久久久| 国产精品一国产精品k频道56| 亚洲电影在线免费观看| 国产精品s色| 亚洲精品日韩综合观看成人91| 国产美女精品| 一区二区免费在线视频| 好看的日韩视频| 亚洲欧美日韩在线播放| 亚洲国产欧美国产综合一区| 久久精品一本久久99精品| 99视频在线精品国自产拍免费观看| 久久天堂国产精品| 亚洲午夜精品视频| 欧美紧缚bdsm在线视频|