IP核配置
定制輸出數(shù)據(jù)位寬
這里的輸出數(shù)據(jù)指的是輸出的波形數(shù)據(jù),其位寬相關(guān)參數(shù)介紹如下:
可見,輸出數(shù)據(jù)寬度和SFDR以及Noise Shaping有關(guān),你可先不必知道Noise Shaping和SFDR是什么?只需要暫時(shí)知道在IP核定制時(shí)需要選擇即可,如果Noise Shaping選擇了None and Dithering,則輸出數(shù)據(jù)寬度為:
如果為Taylor:
而Spurious Free Dynamic Range (SFDR)翻譯為無雜散動(dòng)態(tài)范圍,和輸出數(shù)據(jù)寬度以內(nèi)部總線寬度以及各種實(shí)現(xiàn)策略有關(guān);假設(shè)我需求的數(shù)據(jù)寬度為10位,Noise Shaping選為None,則SFDR為60,輸入IP定制頁面:
查看輸出是否為10bit:
定制相位位寬(或頻率分辨率)
根據(jù)數(shù)據(jù)手冊(cè)對(duì)頻率分辨率的描述:
頻率分辨率:以赫茲為單位指定,指定最小頻率分辨率,用于確定相位累加器使用的相位寬度及其相關(guān)的相位增量(PINC)和相位偏移(POFF)值。較小的值可提供較高的頻率分辨率,并且需要較大的累加器。較大的值會(huì)減少硬件資源。根據(jù)噪聲整形的選擇,可以增加相位寬度,并且頻率分辨率高于指定的分辨率。
對(duì)于光柵化模式(rasterized mode),頻率分辨率由系統(tǒng)時(shí)鐘、通道數(shù)和所選模數(shù)固定。從這段描述,我們得出信息,頻率分辨率可以用來控制相位位寬。如果操作模式選擇標(biāo)準(zhǔn)模式,如下IP 核定制頁面:
頻率分辨率可以這樣計(jì)算:
我們先給定需求的相位寬度,又已知系統(tǒng)頻率值,根據(jù)公式就可以算出頻率分辨率;將頻率分辨率代入IP核定制頁面,即可自動(dòng)得到相位寬度。 其實(shí)從上式也可以直接推出相位寬度:
本例我們的系統(tǒng)頻率為100MHz,如果想要相位寬度為16位,則頻率 分辨率為:
在IP核定制頁面,如下圖,我們輸入頻率分辨率的值:
查看相位寬度為16位:
上面選擇的是標(biāo)準(zhǔn)模式,如果選擇另一種模式呢?Rasterized Mode of Operation:光柵化操作模式;我們可以根據(jù)下面公式得到頻率分辨率, 但和相位寬度沒有直接關(guān)系 ,為了知識(shí)完整性,簡介如下:
在IP核定制頁面提現(xiàn)如下:
輸出頻率
本示例選擇的是單通道,也即通道數(shù)為1,因此輸出頻率也只能選擇一個(gè):
輸出頻率值也不是隨便選擇的,而是有其范圍的,例如我輸入105MHz,則通過不了:
提示超出范圍,范圍為(0,100).
輸出正余弦選擇以及數(shù)據(jù)格式
可以在IP核定制頁面選擇輸出正弦還是余弦還或者是都輸出:
本示例選擇輸出正余弦,由于輸出采用的是axi總線,因此輸出數(shù)據(jù)位于M_AXIS_DATA_TDATA中,那么正余弦輸出結(jié)果是如何組合成M_AXIS_DATA_TDATA的呢?
數(shù)據(jù)手冊(cè)給出解釋:
輸出DATA通道TDATA結(jié)構(gòu)將正弦和余弦輸出字段符號(hào)擴(kuò)展到下一個(gè)字節(jié)邊界,然后以最低有效部分的余弦進(jìn)行連接,以創(chuàng)建m_axis_data_tdata。如果僅選擇正弦或余弦之一,則將其符號(hào)擴(kuò)展并放入m_axis_data_tdata的最低有效部分。
下圖顯示了這三種配置的TDATA的內(nèi)部結(jié)構(gòu)。正交輸出,僅余弦和僅正弦。例如,在圖中顯示了11位輸出,符號(hào)擴(kuò)展到16位。<<<表示符號(hào)擴(kuò)展名:
因此我們可以這么認(rèn)為,由于存在擴(kuò)展符號(hào)位的關(guān)系,我們可以提取低一半的數(shù)據(jù)為COS,高一半的數(shù)據(jù)未SIN。
其他設(shè)置
有了上面的定制參數(shù),輸出波形是沒有問題了,至于其他的定制參數(shù),本文選擇默認(rèn):
點(diǎn)擊OK,等待IP核定制完成。
電路設(shè)計(jì)
本示例設(shè)計(jì)十分簡單,就是單純例化下IP核:
復(fù)制例化模板:
給出設(shè)計(jì)文件:
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer: Reborn Lee
// Module Name: waveform_gen
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer: Reborn Lee
// Module Name: waveform_gen
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
module waveform_gen(
input i_clk,
output o_data_valid,
output [31 : 0] o_data,
output o_phase_valid,
output [15 : 0] o_phase
);
dds_compiler_0 inst_dds (
.aclk(i_clk), // input wire aclk
.m_axis_data_tvalid(o_data_valid), // output wire m_axis_data_tvalid
.m_axis_data_tdata(o_data), // output wire [31 : 0] m_axis_data_tdata
.m_axis_phase_tvalid(o_phase_valid), // output wire m_axis_phase_tvalid
.m_axis_phase_tdata(o_phase) // output wire [15 : 0] m_axis_phase_tdata
);
endmodule