介绍
这几天突然就不知道要使用FPGA实现什么样的功能了,然后就跑去学习数电了,学的也是晕晕的。正好之前写了一个使用FPGA发送伪随机序列的代码,然后因为需要使用曼彻斯特编码,所以又加了一个模块吧,使得最后输出的波形经过曼彻斯特编码。
曼彻斯特编码
首先,曼彻斯特编码是一种常见的数字编码方式。在曼彻斯特编码中,每个数据位都有两位数据来表示,下面我写给出对应关系。
设计文件
因为这次的文件比较多,所以就只列举一下,曼彻斯特编码的代码,其余的代码都在压缩包里了。因为我是对FPGA内部的时钟进行了10000分频,所以在这个文件中我设置的计数器为5000,当计满5000个数据时,信号实现反转。
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity rz is
Port (
clk : in STD_LOGIC;
rst_n : in STD_LOGIC;
input_data : in STD_LOGIC;
output_pwm : out STD_LOGIC
);
end entity;
architecture Behavioral of rz is
signal pwm_counter : integer := 0;
signal half_period : integer :=