当前位置: 首页>編程日記>正文

【GMSK+FPGA】基于verilog的GMSK调制系统设计

【GMSK+FPGA】基于verilog的GMSK调制系统设计

1.软件版本

ISE14.7,modelsimSE 6.1

2.本算法理论知识

GMSK的整体结构如下所示:

从上面的仿真结果可以看到,主要分为如下几个模块:

      信号产生模块,差分编码模块,高斯滤波模块,累加模块,期中三个方块是产生正弦和余弦模块,最后相加得到GMSK调制信号。

3.部分源码

`timescale 1ns / 1psmodule tops(i_clk,i_rst,o_binary_gen,o_chafen_encode,o_gauss_filter,o_adder,o_cos_I,o_sin_Q,o_cos,o_sin,o_GMSK_I,o_GMSK_Q,o_GMSK_R				);
input              i_clk;
input              i_rst;
output             o_binary_gen;
output             o_chafen_encode;
output signed[15:0]o_gauss_filter;
output signed[31:0]o_adder;
output signed[15:0]o_cos_I;
output signed[15:0]o_sin_Q;
output signed[15:0]o_cos;
output signed[15:0]o_sin;
output signed[15:0]o_GMSK_I;
output signed[15:0]o_GMSK_Q;
output signed[15:0]o_GMSK_R;reg[3:0]cnt;
wire    clk_16div;
always @(posedge i_clk or posedge i_rst)
beginif(i_rst)begincnt <= 4'b0000;end 
else begincnt <= cnt + 4'd1;end
end
assign clk_16div = cnt[3];binary_gen binary_gen_u(.i_clk  (clk_16div), .i_rst  (i_rst), .o_dout (o_binary_gen));chafen_encode chafen_encode_u(.i_clk  (clk_16div), .i_rst  (i_rst), .i_din  (o_binary_gen), .o_dout (o_chafen_encode));gauss_filter gauss_filter_u(.i_clk  (i_clk), .i_rst  (i_rst), .i_din  ({~o_chafen_encode,1'b1}), .o_dout (o_gauss_filter));adder adder_u(.i_clk  (i_clk), .i_rst  (i_rst), .i_din  (o_gauss_filter), .o_dout (o_adder));nco_gen nco_gen_u(.i_clk(i_clk), .i_rst(i_rst), .i_adder(o_adder), .o_cos(o_cos_I), .o_sin(o_sin_Q));	 nco_gen2 nco_gen2_u(.i_clk(i_clk), .i_rst(i_rst), .o_cos(o_cos), .o_sin(o_sin));wire signed[31:0]I_tmps;
wire signed[31:0]Q_tmps;multer multer_u1(.clk (i_clk),.a   (o_cos_I), // Bus [15 : 0] .b   (o_cos), // Bus [15 : 0] .sclr(i_rst),.p   (I_tmps)); // Bus [31 : 0] multer multer_u2(.clk (i_clk),.a   (o_sin_Q), // Bus [15 : 0] .b   (o_sin), // Bus [15 : 0] .sclr(i_rst),.p   (Q_tmps)); // Bus [31 : 0] 	 assign o_GMSK_I = I_tmps[31:16];	 
assign o_GMSK_Q = Q_tmps[31:16];	 	 assign o_GMSK_R = o_GMSK_I + o_GMSK_Q;endmodule

4.仿真分析

信号产生模块:

binary_gen.v

这个模块的仿真结果如下所示:

差分编码模块:

chafen_encode.v

这个模块的主要原理为:

这个模块的仿真结果如下所示:

高斯滤波模块:

    gauss_filter.v

    高斯滤波器的主要公式为:

这里,我们主要通过ISE中的滤波器fir核来实现。仿真结果如下所示:

累加模块:

    Adder.v

累加模块,就是对信号进行累加,从而得到相应的相位。仿真结果如下所示:

产生正弦和余弦模块:

Nco_gen.v

    最后仿真结果如下所示:

最后,将得到的IQ两路基带信号和载波相城完成GMSK调制。

5.参考文献

[1]陈亮, 韩方景. GMSK调制器的FPGA实现[J]. 微计算机信息, 2007(29):3.A01-84


https://www.fengoutiyan.com/post/14379.html

相关文章:

  • fpga verilog
  • fpga功能仿真
  • FPGA仿真
  • FPGA代码
  • FPGA系统
  • FPGA通信
  • verilog fpga
  • verilog仿真
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機