本文在程序的实体中定义了2个输入端口:时钟、伪随机序列,一个两位的输出数据(编码后的输出)。程序的结构体中使用的是进程语句,共采用4个进程,分别完成判断4连“0”位置并插入V、记相邻V码间1个数、跟踪V码位置及编码输出的功能。敏感信号均选用的是时钟信号,对于其任一变化都将同时启动4个进程,并行执行。在程序中共使用了5个信号,代表了电路的寄存器效果,配置到电路中也相当于寄存器。
3.2 解码器设计
解码设计是根据HDB3码的特点首先检测出极性破坏点,即找出4连零码中添加V码的位置(破坏点位置),其次去掉添加的V码,最后去掉4连零码中添加的B码以将其还原成单极性不归零码。
由HDB3码的编码规则可知,“0000”都被“000+1”或“000-1”或“+100+1”或“-100-1”取代,所以,只要能检测出“+1000+1”、“-1000-1”、 “+100+1”、“-100-1”、将它们分别改为“10000” 、“10000”、“0000”、“0000”就可以了。
当然“+1”、“-1”、“0”还是由Data1,Data0来表示,那么就需要有两个5位移位寄存器(C和D),Data0通过D,Data1通过C。通过D,C来检测,如果测到两个移位寄存器分别为“10001”、“0xxx0”或“10001”、“1xxx1”或“1001x”、“1xx1x”或“1001x”、“0xx0x”,数据输出是将D里面的
数据流输出。所以只要将D中所测到的以上数据分别改为“10000”、“10000”、“0000x”、“0000x”,这样就可以得到HDB3码的解码了。
4 仿真和实验结果分析
编译码器在QuartusII上仿真的波形分别如图2和图3所示。图2中fen_clk为分频后时钟信号,load 为使能信号,Q为伪随机序列,data为编码输出。由于输入的
数据流经过了5个寄存器,所以输出延迟了4个时钟脉冲周期。但由于时钟频率很高,所以影响不大。
图2 编码器时序仿真波形图
图3 解码器仿真波形
把上述设计下载到Altera EP1C3T144C8芯片上,并通过硬件调试、测试,在示波器上得到伪随机信号波形、编码波形和解码波形分别如图4和5所示。其中,CH1为伪随机信号,CH2分别为编码和解码信号。测试结果和时序仿真结果无失真。随机信号输入相对编码信号输出延迟了5个单位时钟。解码信号延时了11个单位时钟。
图2 编码器时序仿真波形图
图5 伪随机信号和解码信号波形
5 结论
实践表明,运用FPGA来实现NRZ码到HDB3码的转换与采用专用集成电路CD22103相比,不仅给调试带来了方便,而且可以把编码电路和解码电路及其它电路集成在同一块FPGA芯片中,减少了外接元件,提高了集成度。该设计已成功应用于网络化集中照明控制系统中。