?? base-t0-vhdl-dsp.txt
字號:
FSK調制與解調VHDL程序及仿真
1. FSK調制VHDL程序
--文件名:PL_FSK
--功能:基于VHDL硬件描述語言,對基帶信號進行FSK調制
--最后修改日期:2004.3.16
library ieee;
use ieee.std_logic_arith.all;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity PL_FSK is
port(clk :in std_logic; --系統(tǒng)時鐘
start :in std_logic; --開始調制信號
x :in std_logic; --基帶信號
y :out std_logic); --調制信號
end PL_FSK;
architecture behav of PL_FSK is
signal q1:integer range 0 to 11; --載波信號f1的分頻計數(shù)器
signal q2:integer range 0 to 3; --載波信號f2的分頻計數(shù)器
signal f1,f2:std_logic; --載波信號f1,f2
begin
process(clk) --此進程通過對系統(tǒng)時鐘clk的分頻,得到載波f1
begin
if clk'event and clk='1' then
if start='0' then q1<=0;
elsif q1<=5 then f1<='1';q1<=q1+1; --改變q1后面的數(shù)字可以改變,載波f1的占空比
elsif q1=11 then f1<='0';q1<=0; --改變q1后面的數(shù)字可以改變,載波f1的頻率
else f1<='0';q1<=q1+1;
end if;
end if;
end process;
process(clk) --此進程通過對系統(tǒng)時鐘clk的分頻,得到載波f2
begin
if clk'event and clk='1' then
if start='0' then q2<=0;
elsif q2<=0 then f2<='1';q2<=q2+1; --改變q2后面的數(shù)字可以改變,載波f2的占空比
elsif q2=1 then f2<='0';q2<=0; --改變q2后面的數(shù)字可以改變,載波f2的頻率
else f2<='0';q2<=q2+1;
end if;
end if;
end process;
process(clk,x) --此進程完成對基帶信號的FSK調制
begin
if clk'event and clk='1' then
if x='0' then y<=f1; --當輸入的基帶信號x=‘0’時,輸出的調制信號y為f1
else y<=f2; --當輸入的基帶信號x=‘1’時,輸出的調制信號y為f2
end if;
end if;
end process;
end behav;
2. FSK調制VHDL程序仿真圖
FSK調制VHDL程序仿真圖如圖8.10.7所示。
(a)FSK調制VHDL程序仿真全圖
注:a. 載波f1、f2分別是通過對clk的12分頻和2分頻得到的。
b.基帶碼長為載波f1的2個周期,為載波f2的6個周期。
c.輸出的調制信號y在時間上滯后于載波信號一個clk,滯后于系統(tǒng)時鐘2個clk。
(b)FSK調制VHDL程序仿真局部放大圖
圖8.10.7 FSK調制VHDL程序仿真圖
8.10.5 FSK解調方框圖及電路符號
FSK解調方框圖如圖8.10.8所示, FSK解調電路符號如圖8.10.9所示。說明:圖中沒有包含模擬電路部分,調制信號為數(shù)字信號形式。
FPGA
clk
start
調制信號
分頻器q
寄存器xx
計數(shù)器m
判決
基帶信號
圖8.10.8 FSK解調方框圖
圖8.10.9 FSK解調電路符號
8.10.6 FSK解調VHDL程序及仿真
1. FSK解調VHDL程序
--文件名:PL_FSK2
--功能:基于VHDL硬件描述語言,對FSK調制信號進行解調
--最后修改日期:2004.3.16
library ieee;
use ieee.std_logic_arith.all;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity PL_FSK2 is
port(clk :in std_logic; --系統(tǒng)時鐘
start :in std_logic; --同步信號
x :in std_logic; --調制信號
y :out std_logic); --基帶信號
end PL_FSK2;
architecture behav of PL_FSK2 is
signal q:integer range 0 to 11; --分頻計數(shù)器
signal xx:std_logic; --寄存器
signal m:integer range 0 to 5; --計數(shù)器
begin
process(clk) --對系統(tǒng)時鐘進行q分頻
begin
if clk'event and clk='1' then xx<=x; --在clk信上升沿時,x信號對中間信號xx賦值
if start='0' then q<=0; --if語句完成Q的循環(huán)計數(shù)
elsif q=11 then q<=0;
else q<=q+1;
end if;
end if;
end process;
process(xx,q) --此進程完成FSK解調
begin
if q=11 then m<=0; --m計數(shù)器清零
elsif q=10 then
if m<=3 then y<='0'; --if語句通過對m大小,來判決y輸出的電平
else y<='1';
end if;
elsif xx'event and xx='1'then m<=m+1; --計xx信號的脈沖個數(shù)
end if;
end process;
end behav;
2.FSK解調VHDL程序仿真圖及注釋
FSK解調VHDL程序仿真圖及注釋如圖8.10.10所示。
(a)FSK解調VHDL程序仿真全圖
注:a.在q=11時,m清零。
b.在q=10時,根據(jù)m的大小,進行對輸出基帶信號y的電平的判決。
c.在q為其它值時,計數(shù)器m計下xx(寄存x信號)的脈沖數(shù)。
d.輸出信號y滯后輸入信號x 10個clk。
(b)FSK解調VHDL程序仿真局部放大圖
圖8.10.10 FSK解調VHDL程序仿真圖及注釋
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -