《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 一種基于DDS和Qt的“所見即所得”波形發生器
一種基于DDS和Qt的“所見即所得”波形發生器
張康康 王中訓 王 恒 劉建英
摘要: 提出一種基于直接數字頻率合成(DDS)技術和Qt鳊程的任意波形發生器(AWG)的整體設計方案。完成了DDS在FPGA中的硬件修改設計以及在Linux環境下Qt程序的軟件設計和內核驅動程序的開發,并給出實驗結果。實驗結果表明:通過觸摸筆繪制任意波形,即可產生與所繪波形在時間和電壓上均相同的實際電信號,達到“所見即所得”的效果,以滿足各種測試和試驗的要求。
Abstract:
Key words :

0 引言
    隨著電路設計的多樣化,電路測試也對信號源提出了更高的要求。傳統的信號源只能產生幾種固定的波形,靈活度較差。任意信號發生器(AWG)很好地滿足了這個要求,它不僅可以輸出標準信號,而且可以方便地產生任意波形,在測控、通信,醫療等領域有著廣泛的應用。任意信號發生器通常采用直接數字頻率合成(direct digital frequency synthesizer,DDS)技術實現。DDS技術是J.Tiemev在1971年首次提出的一種以全數字技術,它從相位概念出發直接合成所需波形的一種新的合成原理。Qt是一個跨平臺的C++圖形用戶界面應用程序框架。它提供給應用程序開發者建立圖形用戶界面所需的所用功能。Qt是完全面向對象的,模塊化程度非常高,很容易擴展,并且允許真正地組件編程。  Qt具有優良的跨平臺特性,支持多種系統和平臺,包括Windows系統,所有的UNIX系統以及嵌入式系統等。Qt遵循GPL(general public lice-nse)協議,開放主要的源代碼,用戶可以在GPL的規定下自由添加新特性。

1 DDS模塊的設計
1.1 DDS在FPGA中的實現

    DDS由相位累加器,波形存儲器,D/A轉換器,低通濾波器等部分組成。該系統的DDS模塊根據需要做了適當的修改。其結構框圖如圖1所示。


    (1)增加了通信接口電路和DD8控制模塊用于接收用戶數據和控制DDS的運行狀態。
    (2)基準時鐘采用5 MHz,經過可控分頻器分頻后作為DDS的時鐘信號,周期分辨率最高可達200 ns(即分頻為1)。
    (3)相位累加器的頻率控制字固定為1,相位控制字固定為0。
    (4)波形存儲器采用RAM,可以寫入用戶自定義的波形數據以產生任意波形,其地址寬度設置為11 b,這樣存儲深度可達2K點。
    (5)電平偏移電路用于消除D/A輸出信號中疊加的無效直流分量,對于有效的直流分量會保留。
1.2 通信接口及控制寄存器的設計
   
DDS控制寄存器控制整個DDS模塊的運行參數和狀態,并通過通信接口接收來自ARM的數據。根據需要共設置了8個寄存器,地址從O~7。其功能和分配如表1所示。


   表1其中:
    (1)0~3 B存儲分頻參數,占用32位,因此分頻范圍為1~232。
    (2)4~5 B存儲相位累加器的參數,用于控制波形點數和觸發模式,其各位的含義如表2所示。


    (3)6 B只使用了最低位,為1啟動DDS,為0則停止DDS。
    (4)地址7是一個虛地址,并不對應著實際的物理寄存器,而是與相位累加器組合指向RAM的某一個單元,通過對地址7的寫操作就間接的實現了對整個RAM的操作,這樣大大簡化了對DDS的控制操作。
1.3 電平偏移及放大電路
   
電平偏移及放大電路用于消除輸出信號中疊加的無效直流分量(允許有效直流量輸出)和調整信號增益,其電路圖如圖2所示。


    根據圖2電路有:
   
    式中:Rv是R4兩部分的并聯電阻,當
   

2 Qt程序設計
2.1 GUI設計

    GUI(圖形用戶界面)是人機交互的窗口,GUI的設計直接關系到產品的可操作性,是軟件設計中非常重要部分。考慮到觸摸屏面板的空間有限,因此控件(Widgets)的設計盡量緊湊。該系統的GUI設計見圖3。


    左側為工具欄,右側黃色區域為繪圖區。繪圖區提供了滾動條,用于繪制超出屏幕范圍的波形。可以繪制較長的序列信號。工具欄從上到下分為繪圖模式選擇區,波形輸出設定區,時間設定區及清屏和退出按鈕。波形的繪制只允許從左向右進行,一個時刻只對應一個數據點;已繪制波形允許修改,修改過程中自動變成紅色,修改完畢自動變成默認顏色。
2.2 Qt編程原理和方法
   
Qt程序設計采用面向對象和事件驅動的方法,整個GUI程序劃分為兩個類,其中主窗口為一個類,類名為MainWindow,繼承自Qt的QMa-inWindow類,它提供了工具條(toolbar)和一個主窗口(mainwindow);另一個類是DrawWidget,提供了一個繪圖區域,有4種事件,分別為觸摸筆按下(mousePressEvent),移動(mouseMoveEvent),松開(mouseReleaseEvent)和繪圖區重繪事件(paintEvent)。同時提供了處理波形的函數waveProcess和調用底層驅動的接口。滾動條是通過QScrollView類提供的視圖功能來實現的。延遲輸出功能通過Qtimer類來實現,延遲范圍0~999 s。觸摸筆的3個事件的發生順序和處理過程見圖4。


    信號/槽機制是Qt的一個中心特征,用于對象間的通訊。繪圖事件(paintEvent)采用雙緩沖機制。雙緩沖技術是一種GUI編程技術,它指的是在一個不在屏幕上的位圖上渲染一個物件并把此位圖拷貝到屏幕上,常用于消除閃爍和提供一個快速用戶界面。該程序采用了Qpixmap類來實現雙緩沖。
2.3 驅動程序設計
   
Linux設備驅動程序是系統內核的一部分,運行于內核態。其可以以兩種方式被編譯和加載:直接編譯進Linux內核和編譯成一個可加載和刪除的模塊,通過modprobe/insmod和rmmod來加載和卸載驅動模塊。該系統即采用字符設備驅動。在系統內部,I/O設備的存/取通過一組固定的入口點來進行,具體到Linux系統,設備驅動程序所提供的這組入口點由一個文件操作結構file_operation來向系統進行說明。該系統的驅動函數需要提供3個函數調用,read函數用于讀取DDS運行狀態,write函數用于向DDS寫入參數和波形數據,ioctl函數用于復位/啟動/停止DDS。另外還需要打開(open)和關閉設備函數(close)。File_operatio的定義如下:
   
    驅動程序在wave_ioctl,wave_wirte,wave-read等幾個函數中具體實現。所需的波形參數和數據通過Qt程序打包,調用write函數(對應驅動程序中的wave_wrtie函數)一次性寫入DDS模塊。最終將驅動程序編譯為模塊文件(*.ko),通過命令modprobe和rmmod來加載和卸載驅動模塊。

3 系統操作及測試
   
(1)設置波形參數,包括繪圖模式,時間軸刻度,輸出延時等。
    (2)繪制波形,并作相應的修改,最終完成波形繪制。在松開觸摸筆之后Qt程序根據所選擇的波形繪制模式對波形進行處理和優化并重新顯示出來。
    (3)點擊單次觸發模式或重復(循環)觸發模式,此時Qt程序提取時間軸刻度參數,轉換為DDS中可控分頻器的分頻參數,并將這些參數和處理后的波形數據打包傳輸給DDS模塊,輸出延時完畢則啟動DDS,即產生與所繪波形相同的實際電信號,達到“所見即所得”的效果,如圖5所示(時間刻度為100μs)。



4 結語
   
任意波形發生器是現代電子技術的一個新發展,本文給出了一種基于DDS和Qt的任意波形發生器的整體設計方案,分析了DDS在FPGA中的實現和Linux下Qt程序的設計。該設計最大的特點是“所見即所得”,即繪制何種波形就可立即產生何種波形,非常直觀,從而以滿足各種電路測試,通信等領域快速產生任意波形信號的要求。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲国产精品高清久久久| 制服诱惑一区二区| 国产精品videossex久久发布| 麻豆成人综合网| 久久久久久久精| 欧美在线视频一区二区三区| 亚洲免费一在线| 亚洲一区二区免费看| 99国内精品久久| 亚洲三级国产| 亚洲黄色在线| 亚洲国产成人av| 亚洲成人在线网| 亚洲成人在线视频网站| 久久精品水蜜桃av综合天堂| 欧美亚洲自偷自偷| 性欧美18~19sex高清播放| 亚洲综合成人在线| 亚洲欧美色婷婷| 亚洲欧美国产va在线影院| 亚洲——在线| 午夜精品视频在线观看| 性做久久久久久免费观看欧美| 亚洲欧美综合国产精品一区| 午夜日本精品| 欧美中文字幕在线| 亚洲高清免费视频| 亚洲欧洲在线播放| 一本一本大道香蕉久在线精品| aa级大片欧美三级| 亚洲天堂网在线观看| 一区二区三区欧美视频| 亚洲午夜一区| 午夜宅男久久久| 久久精品观看| 蜜臀久久99精品久久久久久9 | 亚洲无线视频| 亚洲欧美日韩专区| 久久久久国产一区二区| 免费欧美在线视频| 欧美日韩一卡二卡| 国产精品一区免费观看| 狠狠色丁香久久婷婷综合丁香| 在线观看视频一区二区| 日韩午夜在线播放| 亚洲欧美日本国产专区一区| 亚洲大胆视频| 在线亚洲一区观看| 久久精品三级| 欧美国产亚洲视频| 国产精品美女www爽爽爽| 国产夜色精品一区二区av| 亚洲国产日韩一区| 亚洲天堂免费观看| 久久精品一二三| 亚洲免费成人av| 午夜精品久久久久久久99樱桃| 久久久久久久欧美精品| 欧美日本三区| 国产亚洲女人久久久久毛片| 亚洲国产综合91精品麻豆| 亚洲影音一区| 91久久国产综合久久| 午夜精品视频网站| 欧美xxx成人| 国产精品你懂的在线欣赏| 影音先锋另类| 亚洲在线国产日韩欧美| 亚洲精品久久久久中文字幕欢迎你| 亚洲午夜在线观看| 狼人天天伊人久久| 国产精品国产三级国产a| 亚洲电影免费观看高清完整版| 中文在线资源观看网站视频免费不卡| 欧美在线看片| 亚洲你懂的在线视频| 免费av成人在线| 国产麻豆视频精品| 亚洲免费成人| 久久激情综合| 亚洲欧美日韩国产一区| 欧美aⅴ99久久黑人专区| 国产欧美韩日| 日韩午夜一区| 亚洲丰满在线| 国产亚洲欧美一区二区三区| 亚洲精品自在久久| 亚洲国产成人高清精品| 亚洲综合精品一区二区| 欧美成人蜜桃| 国内精品久久久久影院色| 一区二区三区视频观看| 91久久国产自产拍夜夜嗨| 欧美伊人久久久久久久久影院| 欧美激情欧美狂野欧美精品| 国产一区二区三区四区老人| 中文欧美日韩| 一区二区三区福利| 欧美不卡一卡二卡免费版| 国产欧美日韩在线播放| 99视频一区| 亚洲精品视频在线观看免费| 久久精品中文字幕一区二区三区| 欧美色欧美亚洲另类二区| 亚洲成人自拍视频| 欧美在线视频一区二区三区| 午夜亚洲伦理| 欧美性jizz18性欧美| 亚洲精品欧美一区二区三区| 亚洲国产成人在线播放| 久久精品国产亚洲aⅴ| 国产精品午夜av在线| 99热这里只有精品8| 夜夜爽www精品| 欧美激情视频网站| 一区二区亚洲精品| 亚洲第一区在线| 久久精品99| 国产午夜一区二区三区| 亚洲综合欧美日韩| 午夜伦理片一区| 国产精品久久久久婷婷| 在线视频中文亚洲| 亚洲性图久久| 国产精品久久国产三级国电话系列| 日韩午夜中文字幕| 亚洲少妇诱惑| 国产精品草莓在线免费观看| 亚洲无限av看| 午夜精品亚洲一区二区三区嫩草| 国产精品视频精品视频| 亚洲欧美日韩专区| 久久精品亚洲精品国产欧美kt∨| 国产欧美日韩视频一区二区| 欧美一二三视频| 久久免费高清视频| 黄色成人在线网址| 亚洲人成人一区二区三区| 欧美大片在线观看一区二区| 亚洲国产小视频| 亚洲视频axxx| 国产精品美女久久久久aⅴ国产馆| 亚洲一区二区毛片| 久久er精品视频| 合欧美一区二区三区| 亚洲欧洲日产国产网站| 欧美黑人在线播放| 一区二区三区波多野结衣在线观看| 亚洲一区三区视频在线观看| 国产精品日韩一区二区| 欧美一区二区视频免费观看| 久久一二三区| 亚洲激情一区| 亚洲尤物在线视频观看| 国产日产精品一区二区三区四区的观看方式| 亚洲欧美日韩直播| 久久综合狠狠综合久久激情| 亚洲欧洲精品一区二区| 这里只有精品视频| 国产精品一区在线播放| 亚洲第一区中文99精品| 欧美激情视频在线播放| 一区二区三区精品视频在线观看| 性感少妇一区| 在线观看不卡| 亚洲一区二区三区精品在线| 久久国产精彩视频| 91久久国产综合久久91精品网站 | 亚洲国产欧美在线| 欧美日韩大片| 亚洲欧美激情四射在线日 | 亚洲永久在线| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 狂野欧美一区| 在线视频欧美日韩精品| 久久视频在线视频| 一本色道久久综合亚洲精品高清 | 久久频这里精品99香蕉| 亚洲精品欧洲精品| 久久精品av麻豆的观看方式| 亚洲欧洲视频在线| 欧美一区在线直播| 91久久黄色| 久久精品99久久香蕉国产色戒| 国产欧美日韩综合一区在线播放| 亚洲国产成人精品女人久久久| 欧美视频中文一区二区三区在线观看| 欧美亚洲专区| 欧美视频一区二区三区…| 久久精品网址| 国产精品视频免费在线观看| 亚洲看片网站| 国产一区二区三区网站| 亚洲午夜视频在线观看| 在线观看亚洲精品| 欧美一区二区三区另类| 亚洲精品视频在线看| 久久综合狠狠| 亚洲欧美日韩精品久久亚洲区| 欧美全黄视频|