CPLD/FPGA的CMI编码设计与实现_第1页
CPLD/FPGA的CMI编码设计与实现_第2页
CPLD/FPGA的CMI编码设计与实现_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

【Word版本下载可任意编辑】CPLD/FPGA的CMI编码设计与实现0引言

CMI码是传号反转码的简称,它是一种应用于PCM四次群和光纤传输系统中的常用线路码型,具有码变换设备简单、有较多的电平跃变,含有丰富的定时信息,便于时钟提取,有一定的纠错能力等优点。

在高次脉冲编码调制终端设备中广泛应用作接口码型,在速率低于8448Kb/s的光纤数字传输系统中也被建议作为线路传输码型。

本文针对光纤通信传输码型的要求和CMI码的编码原理,介绍了一种以EPM系列7064芯片为硬件平台,以Max+PlusⅡ为软件平台,以VHDL为开发工具,适合于CPLD实现的CMI编码器的设计方案。

1CMI码的编码规则

CMI编码规则如下表1所示。

在CMI编码中,输入码字0直接输出01码型,较为简单。对于输入为1的码字,其输出CMI码字存在两种结果OO或11码,因而对输入1的状态必须记忆。同时,编码后的速率增加一倍。

2CMI编码器的建模与实现

首先在原始时钟MUX_Clk的上升沿开展翻转得到二分频时钟Clk,周期为原始时钟的2倍。

然后产生伪随机序列,由3个D触发器产生7位伪随机序列,序列产生原理如图1所示。

任何一个D触发器的输出都可以作为要产生的m序列,则序列以7为周期循环出现,在3个D触发器输出都为0时,语句m_buffer(2)<=(m_bu-ffer(1)xorm_buffer(O))Or((notm_buffer(2))and(notm_buffer(1))and(notm_buffer(O))),可以使个D触发器在Clk上升沿到来时输出为1,从而防止陷入“000"的死循环。

为“O”码、“1”码的编码:

“O”编码的实现:在原始时钟信号的下降沿对m序列开展检测,当其值为“0”时,将原始信号的二分频后的信号求非赋值给编码输出,即可实现对“O”开展“01”编码。

“1”编码的实现:在原始时钟信号的二分频信号的上升沿对m序列开展检测,如果其值为“1”,用表达式statel<=statelX0Rm_buff(O)对“1”的奇偶开展记录;在原始时钟的下降沿,将statel的值赋给编码输出即可实现对“1”的“00”,“11”交替编码。

其中:m_test:产生的m序列;

MUX_DT:CMI编码输出;

MUX_CLK:原始时钟。

3仿真结果

在Max+PlusⅡ平台下对CMI编码开展编译和仿真,得到CMI编码仿真结果。图2是CMI码编码波形图。

在时钟MUX_CLK驱动下工作,m_test是产生的m序列1011100,MUX_的DT为CMI编码输出,可以看到,编码为11010011000101,有一定延时,但编码完全正确。

4结语

该设计详细介绍了基于CPLD的CMI编码的实现方法。提出利用原始信号的二分频后的信号求非赋值给编码输出,得到“0”的编码,利用缓存对“1”的个数开展记录,而对“1”开展编码的编程思路,利用VHDL开展程序设计实现,在Max+PlusⅡ平台下对设计结果开展仿真,结果完全正确。

实践说明,运用CPLD实现CMI编码具有软件开发周期短、成本低、执行速度高、实时性强、升级方便等特点,而且可以把该电

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论