MPSK,即多进制数字相位调制。它利用具有多个相位状态的正弦波来代表多组二进制信息码元,即用载波的一个相位对应于一组二进制信息码元。
MPSK调制电路封装为一个模块,利用VHDL程序及仿真。
基于VHDL硬件描述语言,对基带信号进行MPSK调制(这里--M=4)
library ieee;
use ieee.std_logic_arith.all;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity MPSK is
port(clk :in std_logic; --系统时钟
start :in std_logic; --开始调制信号
x :in std_logic; --基带信号
y :out std_logic); --调制信号
end MPSK;
architecture behav of MPSK is
signal q:integer range 0 to 7; --计数器
signal xx:std_logic_vector(1 downto 0);--中间寄存器
signal yy:std_logic_vector(1 downto 0);--2位并行码寄存器
signal f:std_logic_vector(3 downto 0); --载波f
begin
process(clk)--通过对clk分频,得到4种相位;并完成基带信号的串并转换
begin
if clk'event and clk='1' then
if start='0' then q<=0;
elsif q=0 then q<=1;f(3)<='1'; f(1)<='0'; xx(1)<=x;yy<=xx;
elsif q=2 then q<=3;f(2)<='0'; f(0)<='1';
elsif q=4 then q<=5;f(3)<='0'; f(1)<='1'; xx(0)<=x;
elsif q=6 then q<=7;f(2)<='1'; f(0)<='0';
else q<=q+1;
end if;
end if;
end process;
y<=f(0) when yy="11" else
f(1) when yy="10" else
f(2) when yy="01" else
f(3); --根据yy寄存器数据,输出对应的载波
end behav;
参考资料: http://wenku.baidu.com/view/0ac761649b6648d7c1c74612.html
2011-11-12