数字系统设计方法

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

数字系统设计方法主讲人:徐向民教授内容纲要数字系统的层次化结构数字系统设计过程的四个级别:性能级、功能级、结构级、物理级。自顶向下(top-down)设计方法自顶向下的设计方法是一种由抽象的定义到具体的实现、由高层次到低层次的转换逐步求精的设计方法。模块设计(系统设计)模块化技术就是将系统总的功能分解成若干个子功能,通过仔细定义和描述的子系统来实现相应子功能。设计举例:串行数据接收器详述串行数据接收器的设计过程设计举例:迭代技术从逻辑设计转换成电路实现的物理设计过程当中,迭代是一类很有用的技术。可编程专用芯片设计的流程数字系统层次化结构数字系统设计过程可以分为四个层次:1.性能级2.功能级3.结构级4.物理级系统设计:将性能级的说明映射为功能级的设计过程逻辑设计:将功能级的描述转换为结构(逻辑)的过程物理设计:将逻辑结构转换为物理级(电路)的实现性能级功能级系统设计逻辑设计结构级物理设计物理级数字系统层次化结构数字系统设计的四个层次性能级:要求回答开发系统“做什么”这个问题功能级:把系统划分为若干子系统结构级:将模块的功能描述转化为实现模块功能的具体硬件和软件的描述物理级:物理级也称为电路级。它把上一步描述功能的算法转为物理实现自顶向下设计方法性能级功能级系统设计逻辑设计结构级物理设计物理级自顶向下的设计方法采用系统层次结构,将系统的设计分成几个层次进行描述。由系统的性能级描述导出实现系统功能的算法,即系统设计。由功能级描述设计出系统结构框图,然后进行逻辑设计,详细给出实现系统的硬件和软件描述。模块技术(系统设计)模块化技术就是将系统总的功能分解成若干个子功能,通过仔细定义和描述的子系统来实现相应子功能。模块技术是系统设计中的主要技术一个系统的实现可以有多种方案,划分功能模块也有多种模块结构。结构决定系统的品质,一个结构合理的系统可望通过参数的调整获得最佳的性能。在划分系统的模块结构时,应考虑以下几个方面:限制条件:技术的先进性和可行性、经费、开发时间、可获得的资料等期望的目标:功能、易理解性、可靠性、易维护性等如何将系统划分为一组相对独立又相互联系的模块模块之间有哪些数据流和控制流信息如何有规则地控制各模块交互作用如何评价模块结构的质量模块技术(系统设计)系统模块结构的方法模块结构框图:以框图的形式表示系统由哪些模块组成以及模块之间的相互关系。模块功能说明:采用自然语言或专用语言,以算法形式描述模块的输入/输出信号和模块的功能、作用和限制。例:串行数据接收器性能级设计数据多少位?传输格式?传输速率?信号电平?其他?设串行数据8位,奇校验,按RS232C格式传输(如上图所示),TTL电平,传输速率≤100KBPS。要求并行输出接收数据且指出所收数据是否有奇偶误差。系统结构级设计设定输入输出变量构思数据处理器功能部件列出控制器应输出的控制信号列出数据处理器应输出的状态信号外部输入数据为X,输出分别为Z(8位数据),C(输出标志),P(奇偶误差指示)。其中:C=1输出数据有效;C=0输出数据无效P=1有奇偶误差;P=0无奇偶误差移位寄存器(R),计数器(CNT),触发器(C),触发器(P)和相关组合逻辑等清零信号,移位信号,计数控制信号,触发器P和触发器C置1置0信号等起始信号,收到8位,奇偶误差例:串行数据接收器根据上面的分析,可以得到系统的结构框图如下:组合电路CNTRCP控制器XZST控制器应该输出的信号:清零信号、移位信号、计数器控制信号、触发器P和触发器C置1置0信号。数据处理器反馈给控制器的信号:起始信号、已收到8位数据、有奇偶误差虚线框内对应的是数据处理器例:串行数据接收器逻辑级设计:(A)处理器设计和选择各功能部件:右移移位寄存器74194计数器74163触发器741109奇偶校验电路743280定义处理器状态信号,列出状态变量表设处理器的输出状态信息为S1(起始位),S2(已收到8位),S3(有奇偶误差),如表:例:串行数据接收器画出数据处理器逻辑图:例:串行数据接收器T1194DsrQ3Q0~Q3MAMBT1194DsrQ3Q0~Q3MAMBZ(MSB)Z(LSB)T1163S1CrQDS2QKJQT1190QKJQT1190+S2xSTCPCLRREADSTCS144T3280FE8S3xz串行数据接收器数据处理器逻辑图例:串行数据接收器逻辑级设计:(B)控制器1.根据系统功能画控制器的ASM图(右图):S1CLRS2S3READSTCPSTCT00T11011002.求控制器逻辑表达式和控制信号表达式如下:3.画出控制器的逻辑图:例:串行数据接收器QQDS1S2S3STCPCLRREADSTCCRT1T0+串行数据接收器控制器逻辑图串行数据接收器物理级设计:系统布局、布线、PCB、组装、调试等(略)至此,我们完成了串行数据接收器的整个设计工作。由于其本身功能就不复杂,所以其设计工作不太复杂。用VHDL可以轻松的简化设计过程(当然,设计思路仍然是自顶而下的设计方法和模块划分),使设计过程尽可能脱离硬件。具体程序见教材P127给出的VHDL实现。迭代技术从逻辑设计转换成电路实现的物理设计过程当中,迭代是一类很有用的技术。迭代的思想是利用问题本身包含的结构特性,用简单的逻辑子网络代替复杂的组合逻辑网络,实现要求的处理功能。从而最大限度降低了逻辑网络的设计难度,简化了设计过程。提高系统的性能/价格比。迭代可以是时间意义上的迭代,即由简单的逻辑子网络,在时钟控制下对被处理的信息重复执行基本的运算,最终以串行处理的方式完成复杂网络所要完成的功能。迭代也可以是空间意义上的迭代,即由简单的逻辑子网络重复组合,以并行处理方式完成复杂网络的功能当然,也可以是时间迭代和空间迭代的组合。网络输入迭代技术空间迭代网络基本模型由于迭代网络是结构高度重复的组合逻辑网络,所以有可能利用结构相同的子网络作为单元电路,通过适当的串接来形成所要求的结构,以达到空间意义上的迭代。下图(左),示出了单元电路的一般形式。单元电路通常有两种不同类型的输入,即来自外部的一次输入和来自串接链路前级的二次输入。同样输出也有两类,即直接输出到外部的一次输出和输出到串接链路次级的二次输出。二次输入和二次输出是建立子网络之间联系的纽带。………单位1………单位2……单位n…………网络输出边界输出边界输入空间网络迭代基本模型………………………X1jX2jXnjZ1jZ2jZnjy1jy2jymjy1,j+1y2,j+1ym,j+1来自j-1级的二次输入输出到j+1级的二次输出第j个子网络一次输入一次输出迭代技术时间迭代网络基本模型子网络在时钟控制下,接收来自信息寄存器A,...E通过移位的串行输入,在子网络内作串行处理后,串行输出到结果寄存器R1,…Rn。暂存单元C用于寄存子网络的二次输出,以便在时钟的下一个节拍作为子网络的二次输入参加运算和操作。暂存单元C对应空间迭代方式中的边界输入。子网络R1RnEA………………C边界输出时钟y1jymjy1,j+1ym,j+1时间迭代网络基本模型例:4位二进制加法器迭代网络设计分析:根据二进制数相加的运算规则可知,任意一位的和Si等于被加数Ai、Bi及来自低位的进位Ci-1,而其进位Ci则为相加后的溢出值。实现1:根据这个结构特性,选用全加器FA作为子网络的单元电路,以低位向高位的进位值作为子网络的二次输入/输出,通过空间迭代法构成的四位并行加法器如下图。通常最低位的进位输入Cin置为0,而最高位的Cout作为溢出标志。FAFAFAFAA1A4A3A2B4B3B2B1S4S3S2S1C3COUT=C4C1C2Cin四位并行加法器例:4位二进制加法器迭代网络设计实现2:下图是通过时间迭代法实现的4位串行加法器。分析:该网络在时钟的控制下,从两个移位寄存器A和B的低位端串行输出一位加数和被加数,在全加器FA中生成相应的和及进位,和作为结果存入S寄存器,进位则由D触发器寄存作为高一位的二次输入。D触发器的初置值为0,其终值表示了溢出标志。四位串行加法器迭代技术二维迭代网络前面介绍的都是利用子网络作为基本单元,在时间或空间意义上重复构成的一维迭代网络。也可以利用基本单元构成二维或多维网络。二维迭代网络可以用多种方法构成:1.完全空间意义上的迭代2.完全时间意义上的迭代3.水平方向为空间迭代,垂直方向为时间迭代4.水平方向为时间迭代,垂直方向为空间迭代例:乘法器设计1、性能级设计4位数字乘法器。2、结构级设计方案1:空间迭代分析:方案1通过完全空间意义上的迭代,实现4位二进制数相乘的迭代网络。特点:速度快、硬件复杂例:乘法器设计Ba8Ba4Ba2Ba1Ba8Ba4Ba2Ba1Ba8Ba4Ba2Ba1Ba8Ba4Ba2Ba100000000b1b4b3b2P1P2P4P8P16P32P64P128方案2:时间迭代-部分积左移累加算法例:乘法器设计方案2:时间迭代-部分积左移累加算法例:乘法器设计A7A6A5A4A3A2A1A0M7M6M5M4M3M2M1M0Q7Q6Q5Q4可控全加器控制器左移命令右移命令乘数寄存器Q累加寄存器A被乘数寄存器M加命令方案2:时间迭代-部分积左移累加算法优点:直观缺点:寄存器利用率低例:乘法器设计方案2:时间迭代-部分和右移与部分积累加算法例:乘法器设计可控全加器控制器右移命令乘数寄存器Q累加寄存器A被乘数寄存器M加命令……Ar-1A2A1A0……Mr-1M2M1M0Qr-1Q2Q1Q0……方案2:时间迭代-部分和右移与部分积累加算法优点:寄存器利用率高。例:乘法器设计经比较,决定采用下面的系统结构图:例:乘法器设计……Ar-1A0Qr-1Q0……M组合逻辑网络控制单元AQTSCNTZ总结数字系统设计过程可以分为4个层次:性能级功能级系统设计逻辑设计结构级物理设计物理级性能级:明确要“做什么”功能级:将功能划分为模块结构级:把系统划分为若干子系统物理级:将结构级中描述功能的算法转换成物理实现自顶向下的设计方法是一种由抽象的定义到具体的实现、由高层次到低层次的转换逐步求精的设计方法,并在设计过程中不断修正错误。这种设计方法更加接近人的一般思维方式,利于更高效的设计开发。总结模块技术模块化技术就是将系统总的功能分解成若干个子功能,通过仔细定义和描述的子系统来实现相应子功能。迭代技术时间意义上的迭代空间意义上的迭代二维迭代网络可编程专用芯片设计专用芯片的设计要求:为了将产品推出市场,必须保证产品符合一定的设计要求。稳定可靠满足客户基本需要可维护和可继承,便于改进和升级设计规范可用的产品可移植性,便于技术经验共享,加快设计进度可编程专用芯片设计可编程专用芯片设计最基本的流程是:确定关键电路时序和模块间接口时序具体电路设计设计验证功能模块划分设计目标分析可编程专用芯片设计设计目标分析:主要目的是确定芯片的功能需求,一般应按照产品的发展计划,将目标分若干步骤来实现。基本目标:确定基本功能目标设计分析可能目标:分析未来可能增加的功能阶段目标:确定划分阶段ASIC计划:确定是否转ASIC,什么时候转ASIC可编程专用芯片设计功能模块划分:主要目的是让设计层次分明,条理清晰。设计时序在模块划分中对于数字电路设计异常重要,这与软件编程中模块划分有很大的不同。软件设计电路设计区别直接进行功能模块的划分,再进行系统联调关键:设计各模块间的接口时序,确定关键电路的时序,再进行模块的具体设计原因软件的程序是顺序执行的,相互间不会造成影响,不存在时序的问题硬件电路是并行处理的,时序是电路中关键的一部分,对电路设计有决定性的影响打比方一个人可以决定什么时候做什么事,不会造成冲突多个人协作时,就要明细分工,协调,否则一直无成。可编程专用芯片设计确定关键电路时序和模块间接口时序:事实上,在功能模块划分过程中,就必须考虑时序方面的问题。有时在确定设计目标时,就得考虑关键路径时序。在做总体方案时,应该深入模块间的时序划分,关键时序确定。“时序是实现设计出来的,而不是事后测出来的”。当我们的电路不能满足时序的要求时,

1 / 40
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功