通信信号源设计原理

通过设计一个DDS信号源,然后将该信号作为载波信号,再对基带信号进行2ASK、2FSK、2PSK、2DPSK调制,进而产生多种通信信号。

设计框图如下:

将PN序列进行2ASK、2FSK、2PSK、2DPSK调制,其中载波发生器提供三种不同的载波信号,按键设置用来选择当前DAC输出的最终调制信号,DAC输出模块将调制好的数字化波形转换为模拟信号。

PN序列采用的设计方法是m序列,采用3级寄存器生成7序列基带信号。

调制模块分别包含:2ASK、2FSK、2PSK、2DPSK这四种调制方式,可以通过按键选择所要输出的调制信号。

按键设置,主要分为按键消抖和按键编码,用来切换输出信号。

载波发生器,采用DDS的方法进行生成三种载波信号,分别为:500Hz(起始相位为0度),1K(起始相位为0度),1K(起始相位为180度)。

DAC输出模块,这是驱动TLC5615的硬件接口,用于将数字信号转换位模拟信号。

硬件原理图说明

按键操作:

波形输出:

示波器要接LVOUT这个排针的引脚,旁边那个就是地;输出的是经过调制的正弦信号!

136是输出PN序列,135是输出pdsk调制。

将这两个信号接入示波器可以和前面的DAC输出进行对比。

实验代码

  • 顶层接口模块:

/********************************版权声明**************************************

** 大西瓜团队

**

**----------------------------文件信息--------------------------

** 文件名称: DDS_top.v

** 创建日期:

** 功能描述:顶层设计

代开发板 http://daxiguafpga.taobao.com

** 版权声明:本代码属个人知识产权,本代码仅供交流学习.

**---------------------------修改文件的相关信息----------------

** 修改人:

** 修改日期:

** 描述:PN序列频率为500HZ

频率为500HZ

频率为1000Hz

频率为1000Hz相位相差180

*******************************************************************************/

module DDS_top(clk,//内部时钟

reset,//复位

sclk,//DAC时钟输入

din,//DAC数据输入

cs,//DAC片选

m_ser_out,//PN序列输出,25引脚

set_ask,//设置输出为ask

set_fsk,//设置输出为fsk

set_psk,//设置输出为psk

set_dpsk,//设置输出为pdsk

dpsk_code_out //pdsk调制输出,27引脚

);

input clk;

input reset;

output sclk;

output din;

output cs;

input set_ask;

input     set_fsk;

input     set_psk;

input     set_dpsk;

output m_ser_out;

output dpsk_code_out;

wire clk;

wire reset;

wire set_ask_line;

wire     set_fsk_line;

wire     set_psk_line;

wire     set_dpsk_line;

wire clk_div;

] data_line1;

] data_line2;

] data_line3;

] ask_code_sin_out;

] fsk_code_sin_out;

] psk_code_sin_out;

] dpsk_code_sin_out;

] dac_data_in;

DDS u4(.clk(clk),

.reset_n(reset),

.dds_data_out1(data_line1),

.dds_data_out2(data_line2),

.dds_data_out3(data_line3));

m_ser u5(

.clk(clk),//sys clk

.reset_n(reset),//sys reset_n

.clk_div(clk_div),

.m_ser_out(m_ser_out)//PN ser_code out

);

ask_code u6(

.clk(clk),

.m_ser_code_in(m_ser_out),

.dds_sin_data_in(data_line2),//10k正弦波

.ask_code_sin_out(ask_code_sin_out)

);

fsk_code u7(

.clk(clk),

.m_ser_code_in(m_ser_out),

.dds_sin_data_in1(data_line1),//1k正弦波

.dds_sin_data_in2(data_line2),//10k正弦波

.fsk_code_sin_out(fsk_code_sin_out)

);

psk_code u8(

.clk(clk),

.m_ser_code_in(m_ser_out),

.dds_sin_data_in2(data_line2),//10k正弦波

.dds_sin_data_in3(data_line3),//10k正弦波

.psk_code_sin_out(psk_code_sin_out)

);

dpsk_code u9(

.clk(clk_div),//sys 500Hz

.reset_n(reset),//

.m_ser_code_in(m_ser_out),//PN序列输入

.dpsk_code_out(dpsk_code_out),//dpsk调制输出

.dds_sin_data_in2(data_line2),//10k正弦波

.dds_sin_data_in3(data_line3),//10k正弦波,相位相差180

.dpsk_code_sin_out(dpsk_code_sin_out)//

);

key u10(.clk(clk),.key(set_ask),.key_out(set_ask_line));

key u11(.clk(clk),.key(set_fsk),.key_out(set_fsk_line));

key u12(.clk(clk),.key(set_psk),.key_out(set_psk_line));

key u13(.clk(clk),.key(set_dpsk),.key_out(set_dpsk_line));

key_coding u14(

.clk(clk),

.reset_n(reset),

.set_ask(set_ask_line),

.set_fsk(set_fsk_line),

.set_psk(set_psk_line),

.set_dpsk(set_dpsk_line),

.ask_code_sin_out(ask_code_sin_out),//

.fsk_code_sin_out(fsk_code_sin_out),//

.psk_code_sin_out(psk_code_sin_out),//

.dpsk_code_sin_out(dpsk_code_sin_out),//

.code_data_out(dac_data_in));//

TLC5615 u15(

.clk(clk),

.sclk(sclk),

.din(din),

.cs(cs),

.din_in(dac_data_in));

endmodule

  • 按键编码模块:

/********************************版权声明**************************************

** 大西瓜团队

**

**----------------------------文件信息--------------------------

** 文件名称: key_coding.v

** 创建日期:

** 功能描述:按键编码

代开发板 http://daxiguafpga.taobao.com

** 版权声明:本代码属个人知识产权,本代码仅供交流学习.

**---------------------------修改文件的相关信息----------------

** 修改人:

** 修改日期:

** 修改内容:

*******************************************************************************/

module key_coding(

clk,

reset_n,

set_ask,

set_fsk,

set_psk,

set_dpsk,

ask_code_sin_out,//

fsk_code_sin_out,//

psk_code_sin_out,//

dpsk_code_sin_out,//

code_data_out //

);

input clk;

input reset_n;

input set_ask;

input set_fsk;

input set_psk;

input set_dpsk;

] ask_code_sin_out;//

] fsk_code_sin_out;//

] psk_code_sin_out;//

] dpsk_code_sin_out;//

] code_data_out;

wire reset;

wire set_ask;

wire set_fsk;

wire set_psk;

wire set_dpsk;

] ask_code_sin_out;//

] fsk_code_sin_out;//

] psk_code_sin_out;//

] dpsk_code_sin_out;//

] code_data_out;

] set_mode_code;

/******************调制模式选择****************************************/

assign set_mode_code={set_ask,set_fsk,set_psk,set_dpsk};

always@(posedge clk ornegedge reset_n)

begin

if(!reset_n)

begin

code_data_out<=10'd0;

end

else

case(set_mode_code)

4'b0111:code_data_out<=ask_code_sin_out;

4'b1011:code_data_out<=fsk_code_sin_out;

4'b1101:code_data_out<=psk_code_sin_out;

4'b1110:code_data_out<=dpsk_code_sin_out;

default:code_data_out<=ask_code_sin_out;

endcase

end

endmodule

  • 按键消抖模块:

/********************************版权声明**************************************

** 大西瓜团队

**

**----------------------------文件信息--------------------------

** 文件名称: key.v

** 创建日期:

** 功能描述:按键消抖

代开发板 http://daxiguafpga.taobao.com

** 版权声明:本代码属个人知识产权,本代码仅供交流学习.

**---------------------------修改文件的相关信息----------------

** 修改人:

** 修改日期:

** 修改内容:

*******************************************************************************/

module key(

clk,

key,

key_out);

input clk;

input key;//时钟输入,按键输入

output key_out;//经消抖后的按键信号输出

wire clk;

wire key;

reg key_out;

parameter s0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;

] state;

always@(posedge clk)

begin

case(state)

s0:

begin

key_out<=1'b1;

if(key==1'b0)

state<=s1;

else

state<=s0;

end

s1:

begin

if(key==1'b0)

state<=s2;

else

state<=s0;

end

s2:

begin

if(key==1'b0)

state<=s3;

else

state<=s0;

end

s3:

begin

if(key==1'b0)

begin

key_out<=1'b0;

state<=s3;

end

else

begin

key_out<=1'b1;

state<=s0;

end

end

default:

state<=s0;

endcase

end

endmodule

  • DDS模块:

/********************************版权声明**************************************

** 大西瓜团队

**

**----------------------------文件信息--------------------------

** 文件名称: DDS.v

** 创建日期:

** 功能描述:DDS信号发生与嵌入式逻辑分析仪的调用

代开发板 http://daxiguafpga.taobao.com

** 版权声明:本代码属个人知识产权,本代码仅供交流学习.

**---------------------------修改文件的相关信息----------------

** 修改人:

** 修改日期:

** 修改内容:

*******************************************************************************/

module DDS(

clk,

reset_n,

dds_data_out1,

dds_data_out2,

dds_data_out3

);

input clk;//时钟输入

input reset_n;

] dds_data_out1;

] dds_data_out2;

] dds_data_out3;

wire clk;

wire reset_n;

] dds_data_out1;

] dds_data_out2;

] dds_data_out3;

//**************************************************//

//******************产生载波1(500)**********************//

//**************************************************//

/**************连接线***************/

] f32_bus1;//AC频率控制字输入

] p_bus1;

] reg32_out1;//32位寄存器输出

] reg32_in1;//32位寄存器输入

] reg10_in1;

] reg10_out_address1;

/************************************/

] f32_bus_init1=12'd0;

] p10_bus_init1=10'd0;//设置初始相位

]=f32_bus_init1;//初始化,高位置低

]=20'd42950;//低位可以设置DDS的输出频率

assign p_bus1=p10_bus_init1;

/*********************元件例化************************************/

adder_32 u1(.data1(f32_bus1),.data2(reg32_out1),.sum(reg32_in1));

reg32 u2(.clk(clk),.reset_n(reset_n),.data_in(reg32_in1),.data_out(reg32_out1));

]),.sum(reg10_in1));

reg_10 u4(.clk(clk),.reset_n(reset_n),.data_in(reg10_in1),.data_out(reg10_out_address1));

sin_rom u5(.address(reg10_out_address1),.clock(clk),.q(dds_data_out1));//正弦

//**************************************************//

//******************产生载波2(1K)**********************//

//**************************************************//

/**************连接线***************/

] f32_bus2;//AC频率控制字输入

] p_bus2;

] reg32_out2;//32位寄存器输出

] reg32_in2;//32位寄存器输入

] reg10_in2;

] reg10_out_address2;

/************************************/

] f32_bus_init2=12'd0;//

] p10_bus_init2=10'd0;//设置初始相位

]=f32_bus_init2;//初始化,高位置低

]=20'd85899;//低位可以设置DDS的输出频率

assign p_bus2=p10_bus_init2;

/*********************元件例化************************************/

adder_32 u6(.data1(f32_bus2),.data2(reg32_out2),.sum(reg32_in2));

reg32 u7(.clk(clk),.reset_n(reset_n),.data_in(reg32_in2),.data_out(reg32_out2));

]),.sum(reg10_in2));

reg_10 u9(.clk(clk),.reset_n(reset_n),.data_in(reg10_in2),.data_out(reg10_out_address2));

sin_rom u10(.address(reg10_out_address2),.clock(clk),.q(dds_data_out2));//正弦

//**************************************************//

相反)**********************//

//**************************************************//

/**************连接线***************/

] f32_bus3;//AC频率控制字输入

] p_bus3;

] reg32_out3;//32位寄存器输出

] reg32_in3;//32位寄存器输入

] reg10_in3;

] reg10_out_address3;

/************************************/

] f32_bus_init3=12'd0;//

] p10_bus_init3=10'd512;//设置初始相位

]=f32_bus_init3;//初始化,高位置低

]=20'd85899;//低位可以设置DDS的输出频率

assign p_bus3=p10_bus_init3;

/*********************元件例化************************************/

adder_32 u11(.data1(f32_bus3),.data2(reg32_out3),.sum(reg32_in3));

reg32 u12(.clk(clk),.reset_n(reset_n),.data_in(reg32_in3),.data_out(reg32_out3));

]),.sum(reg10_in3));

reg_10 u14(.clk(clk),.reset_n(reset_n),.data_in(reg10_in3),.data_out(reg10_out_address3));

sin_rom u15(.address(reg10_out_address3),.clock(clk),.q(dds_data_out3));//正弦

endmodule

  • m序列生成模块

module m_ser(

clk,//sys clk

reset_n,//sys reset_n

clk_div,

m_ser_out //PN ser_code out

);

input clk;

input reset_n;

output clk_div;

output m_ser_out;

wire clk;

wire reset_n;

reg m_ser_out;

] m_code;

reg clk_div;

]clk_cnt;

always@(posedge clk ornegedge reset_n)

begin

if(!reset_n)

begin

clk_div<=1'b0;

clk_cnt<=18'd0;

end

else

if(clk_cnt==18'd49999)//500Hz PNcode

begin

clk_cnt<=18'd0;

clk_div<=~clk_div;

end

else

clk_cnt<=clk_cnt+1'b1;

end

always@(posedge clk_div ornegedge reset_n)

begin

if(!reset_n)

begin

m_code<=3'b001;//置数初始化

m_ser_out<=1'b0;

end

else

begin

];

和0进行异或然后放到0

进行输出

end

end

endmodule

ModelSim仿真过程

安装ModelSim软件之后,打开该文件夹

打开红色那个文件

点击project出现了仿真的文件

点击:start simulation

选择work

选择这个文件,然后点击OK

按住ctrl,选择这几个信号,然后右击:ADD TO WAVEàSELECTED SIGNAL.

点击红圈,放大窗口

选择这几个信号

右击,radixàunsigned

然后再右击:formatàanalog:

选择那四个信号,再右击properties,

实验效果

2ASK

2FSK

2PSK

PN序列和DPSK序列

2DPSK

每日推送不同科技解读,原创深耕解读当下科技,敬请关注微信公众号“科乎”。

基于FPGA的通信信号源的设计的更多相关文章

  1. 基于FPGA的VGA可移植模块终极设计【转】

    本文转载自:http://www.cnblogs.com/lueguo/p/3373643.html 略过天涯   基于FPGA的VGA可移植模块终极设计 一.VGA的诱惑 首先,VGA的驱动,这事, ...

  2. [置顶] 基于FPGA的VGA简易显存设计&NIOS ii软核接入

    项目简介 本项目基于Altera公司的Cyclone IV型芯片,利用NIOS II软核,2-port RAM与时序控制模块,实现64*48分辨率的显存(再大的显存板载资源m9k不够用) 实现效果如下 ...

  3. 基于FPGA的DDS任意波形发生器设计

    一.简介       DDS技术最初是作为频率合成技术提出的,由于其易于控制,相位连续,输出频率稳定度高,分辨率高, 频率转换速度快等优点,现在被广泛应用于任意波形发生器(AWG).基于DDS技术的任 ...

  4. 基于FPGA的VGA可移植模块终极设计

    一.VGA的诱惑 首先,VGA的驱动,这事,一般的单片机是办不到的:由于FPGA的速度,以及并行的优势,加上可现场配置的优势,VGA的配置,只有俺们FPGA可以胜任,也只有FPGA可以随心所欲地配置( ...

  5. 基于 FPGA 的 PCIE 总线 Linux 驱动设计

    硬件平台 Kintex ®-7 family of FPGAs Intel X86 软件平台 Linux 4.15.0-36-generic #39~16.04.1-Ubuntu Xilinx xap ...

  6. 基于FPGA的VGA显示设计(二)

    上一篇:基于FPGA的VGA显示设计(一)     参照 CrazyBingo 的 基于FPGA的VGA可移植模块终极设计代码  的工程代码风格,模块化处理了上一篇的代码,并增加了一点其它图形. 顶层 ...

  7. 基于FPGA的音频信号的FIR滤波(Matlab+Modelsim验证)

    1 设计内容 本设计是基于FPGA的音频信号FIR低通滤波,根据要求,采用Matlab对WAV音频文件进行读取和添加噪声信号.FFT分析.FIR滤波处理,并分析滤波的效果.通过Matlab的分析验证滤 ...

  8. 【转】简谈基于FPGA的千兆以太网

    原文地址: http://blog.chinaaet.com/luhui/p/5100052903 大家好,又到了学习时间了,学习使人快乐.今天我们来简单的聊一聊以太网,以太网在FPGA学习中属于比较 ...

  9. 基于FPGA的Sobel边缘检测的实现

    前面我们实现了使用PC端上位机串口发送图像数据到VGA显示,通过MATLAB处理的图像数据直接是灰度图像,后面我们在此基础上修改,从而实现,基于FPGA的动态图片的Sobel边缘检测.中值滤波.Can ...

随机推荐

  1. mongo 主从数据不同步

    在从库上执行如下命令: repset:SECONDARY> rs.slaveOk()repset:SECONDARY> db.runCommand({"resync": ...

  2. PlaceHolder的两种实现方式

    placeholder属性是HTML5 中为input添加的.在input上提供一个占位符,文字形式展示输入字段预期值的提示信息(hint),该字段会在输入为空时显示. 如 <input typ ...

  3. AngularJS笔记---数据绑定

    一.数据绑定 1.简单绑定 下面实现了一个简单的加法运算的绑定, A.ng-app:表示该div以内都在AngularJS的应用, 去掉ng-app="" 那么后面的绑定都将无效 ...

  4. ITer的七夕节,你的情人在哪里(2015-08-19)

    自写<一个程序猿的生命周期>连载以来,迎来第一个七夕节,打算写篇文章纪念一下.我主张过中国自己的节日的,也不反对过其他国家的节日,但是要搞清楚其他国家节日的由来,不要把别人的鬼节当成我们的 ...

  5. TeamTalk源码分析之服务端描述

    TTServer(TeamTalk服务器端)主要包含了以下几种服务器: LoginServer (C++): 登录服务器,分配一个负载小的MsgServer给客户端使用 MsgServer (C++) ...

  6. CodeForces 466E Information Graph --树形转线性+并查集

    题意:有三种操作: 1.新增一条边从y连向x,此前x没有父节点 2.x接到一份文件,(文件标号逐次递增),然后将这份文件一路上溯,让所有上溯的节点都接到这份文件 3.查询某个节点x是否接到过文件F 解 ...

  7. python中if __name__ == "__main__":用法解析

    __name__: __name__作为模块的内置属性,简单点说呢,就是.py文件的调用方式. __main__: 如果__name__等于"__main__"就表示是直接执行. ...

  8. Unity3D中的线性插值Lerp()函数解析

    http://www.cnblogs.com/rongweijun/p/5739074.html

  9. Java面向对象一

    一.面向过程的思想和面向对象的思想 面向对象和面向过程的思想有着本质上的区别, 作为面向对象的思维来说,当你拿到一个问题时,你分析这个问题不再是第一步先做什么,第二步再做什么,这是面向过程的思维,你应 ...

  10. IT菜鸟的3(for循环+分支语句)

    第三天学的东西感觉已经不是很容易能想通了,感觉头懵懵的,难道这就是是文科生的障碍吗,我不相信,坚持!相信自己一定会做好! 1:for循环!(1)循环四要素:初始条件,循环条件,循环体,状态改变for( ...