基于FPGA的通信信号源的设计
通信信号源设计原理
通过设计一个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的通信信号源的设计的更多相关文章
- 基于FPGA的VGA可移植模块终极设计【转】
本文转载自:http://www.cnblogs.com/lueguo/p/3373643.html 略过天涯 基于FPGA的VGA可移植模块终极设计 一.VGA的诱惑 首先,VGA的驱动,这事, ...
- [置顶]
基于FPGA的VGA简易显存设计&NIOS ii软核接入
项目简介 本项目基于Altera公司的Cyclone IV型芯片,利用NIOS II软核,2-port RAM与时序控制模块,实现64*48分辨率的显存(再大的显存板载资源m9k不够用) 实现效果如下 ...
- 基于FPGA的DDS任意波形发生器设计
一.简介 DDS技术最初是作为频率合成技术提出的,由于其易于控制,相位连续,输出频率稳定度高,分辨率高, 频率转换速度快等优点,现在被广泛应用于任意波形发生器(AWG).基于DDS技术的任 ...
- 基于FPGA的VGA可移植模块终极设计
一.VGA的诱惑 首先,VGA的驱动,这事,一般的单片机是办不到的:由于FPGA的速度,以及并行的优势,加上可现场配置的优势,VGA的配置,只有俺们FPGA可以胜任,也只有FPGA可以随心所欲地配置( ...
- 基于 FPGA 的 PCIE 总线 Linux 驱动设计
硬件平台 Kintex ®-7 family of FPGAs Intel X86 软件平台 Linux 4.15.0-36-generic #39~16.04.1-Ubuntu Xilinx xap ...
- 基于FPGA的VGA显示设计(二)
上一篇:基于FPGA的VGA显示设计(一) 参照 CrazyBingo 的 基于FPGA的VGA可移植模块终极设计代码 的工程代码风格,模块化处理了上一篇的代码,并增加了一点其它图形. 顶层 ...
- 基于FPGA的音频信号的FIR滤波(Matlab+Modelsim验证)
1 设计内容 本设计是基于FPGA的音频信号FIR低通滤波,根据要求,采用Matlab对WAV音频文件进行读取和添加噪声信号.FFT分析.FIR滤波处理,并分析滤波的效果.通过Matlab的分析验证滤 ...
- 【转】简谈基于FPGA的千兆以太网
原文地址: http://blog.chinaaet.com/luhui/p/5100052903 大家好,又到了学习时间了,学习使人快乐.今天我们来简单的聊一聊以太网,以太网在FPGA学习中属于比较 ...
- 基于FPGA的Sobel边缘检测的实现
前面我们实现了使用PC端上位机串口发送图像数据到VGA显示,通过MATLAB处理的图像数据直接是灰度图像,后面我们在此基础上修改,从而实现,基于FPGA的动态图片的Sobel边缘检测.中值滤波.Can ...
随机推荐
- Linux磁盘管理之实现多文件系统及VFS06
待续 Linux如何支持多文件系统 不同磁盘需要不同类型的磁盘驱动程序,驱动向上提供接口,不同驱动提供的接口格式不同,在上层是块设备层,用来屏蔽下边驱动接口的差别,向上统一提供,把所有硬盘当成块设备, ...
- SQLServer中比较末尾带有空格的字符串遇到的坑
最近发现SQLServer中比较字符串的时候 如果字符串末尾是空格 那么SQLServer会无视那些空格直接进行比较 这和程序中平时的字符串判断逻辑不统一 );set @a=N'happycat198 ...
- Mysql引起的spring事务失效
老项目加新功能,导致出现service调用service的情况..一共2张表有数据的添加删除.然后测试了一下事务,表A和表B,我在表B中抛了异常,但结果发现,表B回滚正常,但是表A并没有回滚.显示事务 ...
- 如何把报表放到网页中显示(Web页面与报表简单集成例子)
1.问题描述 现在用户开发的系统基本上趋向于BS架构的浏览器/服务器模式,这些系统可能由不同的语言开发,如HTML.ASP.JSP.PHP等,因此需要将制作好的报表嵌入到这些页面中. FineRepo ...
- 理解 OpenStack + Ceph (5):OpenStack 与 Ceph 之间的集成 [OpenStack Integration with Ceph]
理解 OpenStack + Ceph 系列文章: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 (5)Ceph 与 OpenS ...
- [转]关于信息安全认证CISP与CISSP的对比及分析
本文转自:https://www.douban.com/group/topic/89081816/ 最近好多信息安全行业或者打算转行的职场人在纠结学CISP还是学CISSP,我给大家就CISP和CIS ...
- Linux 中如何卸载已安装的软件(转载)
Linux 中如何卸载已安装的软件. Linux软件的安装和卸载一直是困扰许多新用户的难题.在Windows中,我们可以使用软件自带的安装卸载程序或在控制面板中的“添加/删除程序”来实 ...
- 32-bit Assembly on x86_64 Linux (Use Nasm and ld&gcc)
Assembly on x86_64 Linux Some instructions in Intel assembly set are invalid in x86_64 env. e.g. aaa ...
- Java虚拟机详解----JVM常见问题总结
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- Unity C# 反编译
前言 结合前篇:[反编译U3D]Decompile Unity Resources 修正 本篇说说如何查看unity项目(apk) 的源代码,前提是这个apk的代码未经过加密. 写这篇的目地就是看看别 ...