色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器芯片的設(shè)計(jì)

電子設(shè)計(jì) ? 來源:郭婷 ? 作者:電子設(shè)計(jì) ? 2018-12-30 09:03 ? 次閱讀

目前,正弦波信號發(fā)生器技術(shù)正逐漸成熟,各種直接數(shù)字頻率合成器(DDS)集成電路AD9850等已得到廣泛應(yīng)用;FPGA方面也已經(jīng)有相關(guān)的DDS設(shè)計(jì)。但DDS專用芯片還很少見。本文介紹了一種工作頻率為25 MHz、可進(jìn)行異步串行通信、頻率相位可調(diào)的3路正弦波信號發(fā)生器專用芯片的設(shè)計(jì)方法。

本設(shè)計(jì)采用OR1200處理器作為主控制器,通過Wishbone總線將3個(gè)DDS模塊、UART控制器模塊、片內(nèi)RAM模塊連接到系統(tǒng)中,構(gòu)建出一個(gè)硬件平臺;然后對OR1200進(jìn)行軟件編程,使UART控制器接收專用芯片外部異步串口傳送的數(shù)據(jù),將這些數(shù)據(jù)進(jìn)行處理后傳送到DDS模塊相應(yīng)寄存器,從而產(chǎn)生特定頻率相位的正弦波信號;最后將程序固化到片內(nèi)RAM中,在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器專用芯片的設(shè)計(jì)。

1 理論分析

直接數(shù)字頻率合成技術(shù)是20世紀(jì)60年代末出現(xiàn)的第三代頻率合成技術(shù)。該技術(shù)從相位概念出發(fā),以Nyquist時(shí)域采樣定理為基礎(chǔ),在時(shí)域中進(jìn)行頻率合成。DDS頻率轉(zhuǎn)換速度快、頻率分辨率高,并在頻率轉(zhuǎn)換時(shí)可保持相位的連續(xù),因而易于實(shí)現(xiàn)多種調(diào)制功能。DDS是全數(shù)字化技術(shù),其幅度、相位、頻率均可實(shí)現(xiàn)程控,并可通過更換波形數(shù)據(jù)靈活實(shí)現(xiàn)任意波形。本設(shè)計(jì)實(shí)現(xiàn)頻率相位可控的正弦波輸出。所用DDS IP軟核原理框圖如圖1所示(未給出時(shí)鐘和復(fù)位信號)。

在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器芯片的設(shè)計(jì)



圖1中,ftw_i為頻率控制字,phase_i為相位控制字,ampl_o為正弦波信號幅度輸出,phase_o為正弦波信號相位輸出。本設(shè)計(jì)中頻率控制字的位寬為32位,選用的ROM波形數(shù)據(jù)為10×10結(jié)構(gòu),因此相位控制字的位寬為10位,正弦波幅度輸出位寬也為10位。

圖1中第1個(gè)加法器和第1個(gè)單位延時(shí)電路構(gòu)成相位累加器。它在時(shí)鐘的控制下以步長ftw_i做累加,輸出的N位二進(jìn)制碼與M位相位控制字phase_i相加作為波形ROM的地址。由于在ROM中存取的是1/4周期的正弦波形數(shù)據(jù),因此,根據(jù)正弦波不同的象限,由相位控制字的2個(gè)最高有效位(MSB)來控制是否對波形ROM地址進(jìn)行移位或者對幅度輸出進(jìn)行反相,最終輸出10位的正弦波數(shù)字信號

在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器芯片的設(shè)計(jì)

頻率相位值從UART串口輸入,OR1200處理器根據(jù)式(1)和式(2)對數(shù)據(jù)進(jìn)行處理得出頻率相位控制字,賦給相應(yīng)DDS模塊的頻率相位寄存器,從而輸出特定頻率相位的正弦波信號[1]。

2 專用芯片硬件設(shè)計(jì)

2.1 專用芯片總體結(jié)構(gòu)設(shè)計(jì)

正弦波信號發(fā)生器專用芯片的結(jié)構(gòu)框圖如圖2所示。Wishbone總線是整個(gè)硬件平臺的系統(tǒng)總線,OR1200處理器的數(shù)據(jù)BIU(Bus Interface Unit)和指令BIU作為Wishbone總線的主設(shè)備,UART控制器、3個(gè)DDS模塊以及FPGA片上RAM作為Wishbone總線的從設(shè)備,它們通過Wishbone總線連接到系統(tǒng)中。OR1200是整個(gè)硬件平臺的主控制器,控制該專用芯片配置數(shù)據(jù)的讀入與轉(zhuǎn)換。UART控制器模塊主要實(shí)現(xiàn)該專用芯片與外部異步串口的通信,負(fù)責(zé)讀入配置數(shù)據(jù)。3個(gè)DDS模塊是產(chǎn)生正弦波信號的核心模塊,根據(jù)頻率控制字和相位控制字產(chǎn)生特定頻率相位的正弦波信號。FPGA片上RAM作為該專用芯片的片內(nèi)RAM,系統(tǒng)軟件要固化在RAM中。OR1200處理器、Wishbone總線、UART控制器模塊及片內(nèi)RAM模塊的時(shí)鐘直接連到外部時(shí)鐘源上,3個(gè)DDS模塊的時(shí)鐘由外部時(shí)鐘源通過PLL倍頻得到。本專用芯片為低電平復(fù)位。

在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器芯片的設(shè)計(jì)

2.2 OR1200處理器

OpenRISC1200處理器(簡稱OR1200)是Opencores組織發(fā)布維護(hù)的基于GPL并屬于OpenRISC1000序列的一款RISC處理器。OR1200是32位RISC,它具有哈佛結(jié)構(gòu)、5級整數(shù)流水線,支持虛擬內(nèi)存(MMU),帶有基本的DSP功能,并且外部數(shù)據(jù)和地址總線接口符合Wishbone標(biāo)準(zhǔn)[2]。

OR1200通用框架由CPU/DSP核心、直接映射的數(shù)據(jù)Cache、直接映射的指令Cache、基于DTLB的Hash表的數(shù)據(jù)MMU和指令MMU、電源管理單元及接口Tick定時(shí)器,調(diào)試單元及開發(fā)接口、中斷控制器和中斷接口、指令及數(shù)據(jù)Wishbone主機(jī)接口[3]組成。

2.3 片內(nèi)RAM設(shè)計(jì)

片內(nèi)RAM由Altera公司EDA工具QuartusII中MegaWizard Plug-In Manager…生成。它為單端口RAM,數(shù)據(jù)總線32位,大小為8 KB。編寫的固化軟件程序編譯鏈接后轉(zhuǎn)換為hex格式,在RAM初始化時(shí)固化到其中。由QuartusII生成的片內(nèi)RAM模塊不具有Wishbone接口,本設(shè)計(jì)為其添加了1個(gè)Wishbone總線接口。

2.4 DDS模塊

DDS模塊也是Opencores上的開源IP軟核,沒有標(biāo)準(zhǔn)的Wishbone接口模塊,本設(shè)計(jì)為DDS模塊添加了1個(gè)Wishbone總線接口。該DDS模塊主要有兩類配置數(shù)據(jù):頻率控制字和相位控制字。給DDS模塊加入2個(gè)硬件寄存器DDS_FTW和DDS_PHASE,利用這2個(gè)寄存器來控制連接到Wishbone總線接口上的輸出數(shù)據(jù)是頻率控制字還是相位控制字。

2.5 UART控制器模塊

UART控制器模塊是Opencores上符合工業(yè)標(biāo)準(zhǔn)16550A的開源IP核。該IP核的設(shè)計(jì)采用Wishbone總線接口規(guī)范,支持可選擇的32位數(shù)據(jù)模式和8位數(shù)據(jù)模式;使用FIFO操作實(shí)現(xiàn),寄存器及所實(shí)現(xiàn)的具體功能符合NS16550A標(biāo)準(zhǔn)[4]。在本設(shè)計(jì)中,UART控制器的波特率默認(rèn)值為9 600 b/s,UART控制器模塊用于與專用芯片外部UART串口通信,通過URXD引腳接收外部串口數(shù)據(jù),通過UTXD向外部串口發(fā)送數(shù)據(jù)。

2.6 Wishbone總線主從設(shè)備分配

Wishbone總線仲裁采用Opencores上開源軟核wb_conmax,為8×16結(jié)構(gòu),即在該Wishbone總線模塊中可以使用8個(gè)主設(shè)備和16個(gè)從設(shè)備[5]。本系統(tǒng)中,OR1200的指令和數(shù)據(jù)單元為Wishbone總線的主設(shè)備;片內(nèi)RAM模塊、URAT控制器模塊以及3個(gè)DDS模塊為Wishbone總線的從設(shè)備。

根據(jù)各子模塊在Wishbone總線上的位置和wb_conmax的邏輯實(shí)現(xiàn),相應(yīng)從設(shè)備的地址分配如下:

片內(nèi)RAM : 0x00000000

DDS1 : 0x10000000

DDS2 : 0x20000000

DDS3 : 0x30000000

UART : 0x90000000

2.7 頂層模塊設(shè)計(jì)

本系統(tǒng)頂層模塊例化各子模塊,采用Wishbone總線接口技術(shù)將各個(gè)子模塊集成在一起,為每個(gè)子模塊分配時(shí)鐘和復(fù)位信號,實(shí)現(xiàn)硬件平臺的總體設(shè)計(jì)。設(shè)計(jì)中所用FPGA開發(fā)板的時(shí)鐘為50 MHz,OR1200處理器時(shí)鐘為25 MHz,Wishbone總線時(shí)鐘為25 MHz,3個(gè)DDS模塊時(shí)鐘為100 MHz。其他模塊的時(shí)鐘都為25 MHz,設(shè)計(jì)中所用時(shí)鐘都是通過FPGA芯片中的PLL分頻及倍頻實(shí)現(xiàn)的。正弦波專用芯片的時(shí)鐘設(shè)為各模塊時(shí)鐘的最小值(25 MHz),3個(gè)DDS模塊的100 MHz時(shí)鐘通過PLL倍頻實(shí)現(xiàn)。各模塊的復(fù)位信號由頂層模塊統(tǒng)一分配。

3 專用芯片固化程序設(shè)計(jì)

正弦波信號發(fā)生器專用芯片的固化程序主要包括UART控制器初始化程序和串口數(shù)據(jù)處理程序兩部分:UART控制器初始化程序初始化UART控制器中的各個(gè)寄存器,使該控制器能夠正常工作。串口數(shù)據(jù)處理程序采用查詢方式接收串口數(shù)據(jù),將接收到的數(shù)據(jù)賦給相應(yīng)寄存器變量,根據(jù)式(1)和式(2)進(jìn)行計(jì)算,得到3路DDS模塊的頻率控制字和相位控制字,其固化程序流程圖如圖3所示。固化程序首先初始化OR1200處理器的各個(gè)寄存器,然后對UART控制器進(jìn)行初始化,最后循環(huán)處理串口數(shù)據(jù)。

在FPGA上實(shí)現(xiàn)多路正弦波信號發(fā)生器芯片的設(shè)計(jì)

3.1 UART控制器初始化程序

UART控制器中的寄存器都是8位或16位,通過對UART控制器的寄存器賦值來初始化UART控制器。上電復(fù)位后UART控制器的初始化工作包括:

(1)清空接收和發(fā)送FIFO。

(2)清零接收和發(fā)送移位寄存器。

(3)關(guān)閉中斷。

(4)設(shè)置Line控制寄存器為8個(gè)數(shù)據(jù)位、1個(gè)停止位、無奇偶校驗(yàn)的通信模式。

(5)讀取Line控制寄存器的值,將其最高位置1,允許Divisor鎖存器存??;通過設(shè)置Divisor鎖存器的值設(shè)置波特率為9 600 b/s;將LCR賦回原值。

3.2 串口數(shù)據(jù)處理程序

正弦波信號發(fā)生器專用芯片從外部串口接收到的數(shù)據(jù)分為3類:相位、頻率選擇信號,相位或頻率值,3路正弦波選擇信號。固化程序定義了1個(gè)32位的數(shù)據(jù)寄存器變量和1個(gè)8位狀態(tài)寄存器變量。串口數(shù)據(jù)處理程序采用查詢方式接收串口數(shù)據(jù),接收到的前4個(gè)數(shù)據(jù)進(jìn)行相應(yīng)轉(zhuǎn)換后賦給數(shù)據(jù)寄存器變量,第5個(gè)數(shù)據(jù)放入狀態(tài)寄存器變量中,作為相位信號、頻率選擇信號和3路正弦波選擇信號。若為相位信號,則將數(shù)據(jù)寄存器變量中的數(shù)據(jù)與0x3ff相“與”,然后根據(jù)式(2)得到相位控制字;若為頻率信號,則根據(jù)式(1)得到頻率控制字。最后根據(jù)這個(gè)信號將數(shù)據(jù)寄存器變量中的值送入相應(yīng)的DDS模塊硬件寄存器中(DDS_FTW和DDS_PHASE)。

在FPGA上實(shí)現(xiàn)了一個(gè)多路正弦波信號發(fā)生器專用芯片的設(shè)計(jì)。本設(shè)計(jì)在友晶公司的DE2-70開發(fā)板上進(jìn)行了驗(yàn)證,使用開發(fā)板上3路10位視頻數(shù)字信號轉(zhuǎn)模擬信號的控制芯片ADV7123作為D/A轉(zhuǎn)換芯片,最后得到3路頻率相位可調(diào)的正弦波信號。該正弦波信號發(fā)生器專用芯片通過串口控制,而未來的設(shè)計(jì)中可以擴(kuò)展數(shù)字按鍵控制或者觸摸屏控制,不使用外部主控MCU也可以產(chǎ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)注

    1629

    文章

    21729

    瀏覽量

    602998
  • 芯片
    +關(guān)注

    關(guān)注

    455

    文章

    50714

    瀏覽量

    423145
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5336

    瀏覽量

    120230
  • 信號發(fā)生器
    +關(guān)注

    關(guān)注

    28

    文章

    1472

    瀏覽量

    108739
收藏 人收藏

    評論

    相關(guān)推薦

    正弦波發(fā)生器

    正弦波發(fā)生器
    發(fā)表于 10-07 11:51 ?2138次閱讀

    dsp正弦波發(fā)生器

    dsp正弦波發(fā)生器,C5000系列DSP實(shí)現(xiàn)正弦波發(fā)生器
    發(fā)表于 01-02 19:29 ?86次下載

    正弦波信號發(fā)生器VHDL源代碼

    正弦波信號發(fā)生器VHDL源代碼
    發(fā)表于 01-02 20:46 ?238次下載

    正弦波信號發(fā)生器的設(shè)計(jì)及電路圖

    正弦波信號發(fā)生器的設(shè)計(jì)結(jié)構(gòu)看,正弦波振蕩電路就是一個(gè)沒有輸入信號的帶選頻網(wǎng)絡(luò)的正反饋放大電路。
    發(fā)表于 10-22 21:24 ?1299次下載
    <b class='flag-5'>正弦波</b><b class='flag-5'>信號</b><b class='flag-5'>發(fā)生器</b>的設(shè)計(jì)及電路圖

    正弦波發(fā)生電路基礎(chǔ)

    正弦波發(fā)生電路能產(chǎn)生正弦波輸出,它是放大電路的基礎(chǔ)加上正反饋而形成的,它是各類波形發(fā)生器
    發(fā)表于 03-03 10:45 ?246次下載

    正弦波發(fā)生器電路圖

    正弦波發(fā)生器電路圖,電路由IC,TL082組成。 圖二:正弦波信號發(fā)生器電路圖
    發(fā)表于 01-02 19:16 ?3863次閱讀
    <b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>電路圖

    簡單的正弦波發(fā)生器

    簡單的正弦波發(fā)生器
    發(fā)表于 04-08 09:10 ?4818次閱讀
    簡單的<b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>

    數(shù)控正弦波發(fā)生器

    數(shù)控正弦波發(fā)生器
    發(fā)表于 04-08 09:13 ?942次閱讀
    數(shù)控<b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>

    正弦波發(fā)生器

    正弦波發(fā)生器
    發(fā)表于 10-07 11:46 ?989次閱讀
    <b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>

    正弦波信號發(fā)生器的設(shè)計(jì)

    正弦波信號發(fā)生器的設(shè)計(jì) 需要的可以拿去參考一下
    發(fā)表于 08-29 15:02 ?55次下載

    正弦波信號發(fā)生器基本原理與設(shè)計(jì)

    本文主要介紹了一種正弦波信號發(fā)生器基本原理與設(shè)計(jì),正弦信號發(fā)生器主要由兩部分組成:
    發(fā)表于 01-14 13:11 ?8.3w次閱讀
    <b class='flag-5'>正弦波</b><b class='flag-5'>信號</b><b class='flag-5'>發(fā)生器</b>基本原理與設(shè)計(jì)

    正弦波發(fā)生電路原理

    首先介紹了產(chǎn)生正弦波的條件,其次介紹了正弦波發(fā)生電路組成,最后闡述了正弦波發(fā)生電路及工作原理。正弦波
    的頭像 發(fā)表于 09-13 17:54 ?3.9w次閱讀

    正弦波信號發(fā)生器的原理及制作

    正弦波信號發(fā)生器電路原理圖如上圖所示,下圖是為其配套的電源電路。整個(gè)電路可以面包板焊接而成,也可自制PCB圖,效果會更佳。
    的頭像 發(fā)表于 09-28 10:52 ?6.5w次閱讀
    <b class='flag-5'>正弦波</b><b class='flag-5'>信號</b><b class='flag-5'>發(fā)生器</b>的原理及制作

    使用FPGA實(shí)現(xiàn)ROM的正弦波發(fā)生器詳細(xì)資料說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是使用FPGA實(shí)現(xiàn)ROM的正弦波發(fā)生器詳細(xì)資料說明免費(fèi)下載。
    發(fā)表于 03-02 13:52 ?16次下載
    使用<b class='flag-5'>FPGA</b><b class='flag-5'>實(shí)現(xiàn)</b>ROM的<b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>詳細(xì)資料說明

    FPGA實(shí)現(xiàn)基于ROM的正弦波發(fā)生器

    FPGA實(shí)現(xiàn)基于ROM的正弦波發(fā)生器(嵌入式開發(fā)系統(tǒng))-該文檔為FPGA實(shí)現(xiàn)基于ROM的
    發(fā)表于 07-30 11:45 ?32次下載
    <b class='flag-5'>FPGA</b><b class='flag-5'>實(shí)現(xiàn)</b>基于ROM的<b class='flag-5'>正弦波</b><b class='flag-5'>發(fā)生器</b>
    主站蜘蛛池模板: 国产成人啪精视频精东传媒网站| 美女议员被泄裸照| chinese黑人第一次| 国产亚洲综合视频| 日本美女靠逼| 91国内精品久久久久免费影院| 国产在线观看成人免费视频| 日本人HD18HD18| 69精品人妻一区二区三区蜜桃| 国产午夜不卡| 肉欲横流(NP高H)| 999久久免费高清热精品| 精品午夜国产福利观看| 午夜国产免费视频亚洲| 被两根巨大同时进去高H| 刘梓晨啪啪啪| 伊人久久大香线蕉综合亚洲| 国产热久久精| 十大禁止安装的黄台有风险| caoporn 免费视频| 麻豆天美国产一区在线播放| 亚洲色视在线观看视频| 国产美女视频一区二区二三区| 日日碰狠狠躁久久躁综合网| jazzjazzjazz欧美| 免费的黄直播| 中文字幕不卡免费高清视频| 九九热这里只有精品2| 亚洲国产欧美国产综合在线| 国产精品人妻无码久久久2022 | 一本之道高清在线3线观看 | 人与畜禽CROPROATION免费| 9999精品视频| 美国CERANETWORK超清| 在线亚洲黄色| 久久综合色超碰人人| 折磨比基尼美女挠肚子| 久久久久久免费高清电影 | 美女裸露100%奶头视频| 中文字幕人成乱码中国| 老女老肥熟国产在线视频|