5.3 层次原理图的设计方法
根据上面所讲的层次原理图的模块化结构,我们知道,层次电路原理图的设计实际上就是对顶层原理图和若干子原理图分别进行设计的过程。设计过程的关键在于不同层次间的信号如何正确地传递,这一点主要就是通过在顶层原理图中放置图纸符号、电路端口,而在各个子原理图中放置相同名称的输入/输出端口来实现的。
基于上述的设计理念,层次电路原理图设计的具体实现方法有两种:一种是自上而下的层次原理图设计,另一种是自下而上的层次原理图设计。
自上而下的设计思想是在绘制电路原理图之前,要求设计者对这个设计有一个整体的把握。把整个电路设计分成多个模块,确定每个模块的设计内容,然后对每一模块进行详细的设计。在C语言中,这种设计方法被称为自顶向下,逐步细化。该设计方法要求设计者在绘制原理图之前就对系统有比较深入的了解,对于电路的模块划分比较清楚。
自下而上的设计思想则是设计者先绘制原理图子图,根据原理图子图生成方块电路图,进而生成上层原理图,最后生成整个设计。这种方法比较适用于对整个设计不是非常熟悉的用户,这也是初学者一种不错的选择方法。
5.3.1 自上而下的层次原理图设计
本节以“基于通用串行数据总线USB的数据采集系统”电路设计为例,详细介绍自上而下层次电路的具体设计过程。
各种数据的采集和实时处理在科学研究及工业控制中是必不可少的。在一个实用的数据采集处理系统中,外设与主机的通信接口非常关键。一方面,接口应该简单灵活且有比较高的数据传输率;另一方面,主机能够对较大的数据量作出快速响应,并能进行实时分析和处理。采用USB接口能满足上述的要求,而且与传统的接口如PCI总线和RS-232串行总线相比,具有传输速度高,功耗低,支持即插即用,可以同时连接多个外设等优点。因此,将USB接口应用在数据采集系统中是非常适用的。
我们采用层次电路的设计方法,将实际的总体电路按照电路模块的划分原则划分为4个电路模块:CPU模块和三路传感器模块Sensor1、Sensor2、Sensor3。首先绘制出层次原理图中的顶层原理图,然后再分别绘制出每一电路模块的具体原理图。
自上而下绘制层次原理图的具体步骤如下:
(1)执行“开始”→“所有程序”→Altium→Altium Designer命令,或者双击桌面上的快捷方式图标,启动Altium Designer 16程序。
(2)打开“Files(文件)”面板,在“新的”选项栏中单击“Blank Project(PCB)(空白项目文件)”选项,则在“Projects(工程)”面板中出现了新建的项目文件,另存为“USB采集系统.PrjPCB”。
(3)在项目文件“USB采集系统.PrjPCB”上右击,在弹出的快捷菜单中选择“给工程添加新的”→“Schematic(原理图)”命令,在该项目文件中新建一个电路原理图文件,另存为“Mother.SchDoc”,并完成图纸相关参数的设置。
(4)执行“放置”→“图表符”命令,或者单击“连线”工具栏中的(放置原理图符号)按钮,光标将变为十字形状,并带有一个原理图符号标志。
(5)移动光标到需要放置原理图符号的地方,单击确定原理图符号的一个顶点,移动光标到合适的位置再一次单击确定其对角顶点,即可完成原理图符号的放置。
此时放置的图纸符号并没有具体的意义,需要进行进一步设置,包括其标识符、所表示的子原理图文件及一些相关的参数等。
(6)此时,光标仍处于放置原理图符号的状态,重复步骤(5)的操作即可放置其他原理图符号。右击或者按Esc键即可退出操作。
(7)设置原理图符号的属性。双击需要设置属性的原理图符号或在绘制状态时按Tab键,系统将弹出相应的“方块符号”对话框,如图5-3所示。原理图符号属性的主要参数含义如下。
图5-3 “方块符号”对话框
位置:表示原理图符号在原理图上的X轴和Y轴坐标,可以输入数值。
X-Size(宽度), Y-Size(高度):表示原理图符号的宽度和高度,可以输入数值。
板的颜色:用于设置原理图符号边框的颜色。
填充色:用于设置原理图符号的填充颜色。
“Draw Solid(是否填充)”复选框:选中该复选框,则原理图符号将以Fill Color(填充颜色)中的颜色填充多边形。
板的宽度:用于设置原理图符号的边框粗细,包括Smallest(最小)、Small(小)、Medium(中等)和Large(大)4种线宽。
“标识”文本框:用于输入相应原理图符号的名称。所起作用与普通电路原理图中的元件标识符相似,是层次电路图中用来表示原理图符号的唯一标志,不同的原理图符号应该有不同的标识符。在这里输入“U-Sensor1”。
“文件名”文本框:用于输入该原理图符号所代表的下层子原理图的文件名。在这里输入“Sensor1.SchDoc”。
“显示此处隐藏文本文件”复选框:用于确定是显示还是隐藏原理图符号的文本域。
(8)在“方块符号”对话框中,选择“参数”选项卡,如图5-4所示,用户可以在该选项卡中执行添加、删除和编辑原理图符号等其他有关参数的操作。单击“添加”按钮,系统将弹出如图5-5所示的“参数属性”对话框。在该对话框中,可以设置追加的参数名称、数值等属性。
图5-4 “参数”选项卡
图5-5 “参数属性”对话框
(9)在“名称”选项组的文本框中输入“Description”,在“值”选项组的文本框中输入“U-Sensor1”,选中下面的“可见的”复选框。单击“确定”按钮,关闭该对话框。单击“方块符号”对话框中的“确定”按钮,关闭该对话框。按照上述方法放置另外3个原理图符号U-Sensor2、U-Sensor3和U-Cpu,并设置好相应的属性,如图5-6所示。
图5-6 设置好的4个原理图符号
放置好原理图符号以后,下一步就需要在上面放置电路端口。电路端口是原理图符号代表的子原理图之间所传输的信号在电气上的连接通道,应放置在原理图符号边缘的内侧。
(10)执行“放置”→“添加图纸入口”命令,或者单击“连线”工具栏中的(放置图纸入口)按钮,光标将变为十字形状。
(11)移动光标到原理图符号内部,选择放置电路端口的位置,单击会出现一个随光标移动的电路端口,但其只能在原理图符号内部的边框上移动,在适当的位置再次单击即可完成电路端口的放置。此时,光标仍处于放置电路端口的状态,继续放置其他的电路端口。右击或者按Esc键即可退出操作。
(12)设置电路端口的属性。根据层次电路图的设计要求,在顶层原理图中,每一个原理图符号上的所有电路端口都应该与其所代表的子原理图上的一个电路输入/输出端口相对应,包括端口名称及接口形式等。因此,需要对电路端口的属性加以设置。双击需要设置属性的电路端口或在绘制状态时按Tab键,系统将弹出相应的“方块入口”对话框,如图5-7所示。电路端口属性的主要参数含义如下。
图5-7 “方块入口”对话框
填充色:设置电路端口内部的填充颜色。
文本颜色:设置电路端口标注文本的颜色。
板的颜色:设置电路端口边框的颜色。
边:设置电路端口在原理图符号中的大致方位,包括Top(顶部)、Left(左侧)、Bottom(底部)和Right(右侧)4个选项。
类型:设置电路端口的形状。这里设置为“Right”。
“I/O类型”下拉列表框:用于设置电路的端口属性,包括Unspecified(未指明)、Output(输出)、Input(输入)和Bidirectional(双向)4个选项。该下拉列表框通常与电路端口外形的设置一一对应,这样有利于直观理解。端口的属性是由I/O类型决定的,这是电路端口最重要的属性。这里将端口属性设置为“Output(输出)”。
“名称”下拉列表框:设置电路端口的名称,应该与层次原理图子图中的端口名称对应,只有这样才能完成层次原理图的电气连接。这里设置为“Port1”。
“位置”文本框:设置电路端口的位置。该文本框的内容将根据端口移动而自动设置,用户不需要进行更改。
属性设置完毕后单击“确定”按钮关闭该对话框。
(13)按照同样的方法,把所有的电路端口放在合适的位置处,并一一完成属性设置。
(14)使用导线或总线把每一个原理图符号上的相应电路端口连接起来,并放置好接地符号,完成顶层原理图的绘制,如图5-8所示。
图5-8 顶层原理图
根据顶层原理图中的原理图符号,把与之相对应的子原理图分别绘制出来,这一过程就是使用原理图符号来建立子原理图的过程。
(15)执行“设计”→“产生图纸”命令,此时光标将变为十字形状。移动光标到原理图符号“UCpu”内部,单击,系统自动生成一个新的原理图文件,名称为“Cpu.SchDoc”,与相应的原理图符号所代表的子原理图文件名一致,如图5-9所示。此时可以看到,在该原理图中已经自动放置好了与4个电路端口方向一致的输入/输出端口。
图5-9 由原理图符号“U-Cpu”建立的子原理图
(16)使用普通电路原理图的绘制方法,放置各种所需的元件并进行电气连接,完成“Cpu”子原理图的绘制,如图5-10所示。
图5-10 子原理图“Cpu.SchDoc”
(17)使用同样的方法,用顶层原理图中的另外3个原理图符号(U-Sensor1、U-Sensor2和U-Sensor3)建立与其相对应的3个子原理图(Sensor1.SchDoc、Sensor2.SchDoc和Sensor3. SchDoc),并且分别绘制出来。
至此,采用自上而下的层次电路图设计方法,完成了整个USB数据采集系统的电路原理图绘制。
5.3.2 自下而上的层次原理图设计
对于一个功能明确、结构清晰的电路系统来说,采用层次电路设计方法,使用自上而下的设计流程,能够清晰地表达出设计者的设计理念。但在有些情况下,特别是在电路的模块化设计过程中,不同电路模块的不同组合,会形成功能完全不同的电路系统。用户可以根据自己的具体设计需要,选择若干个已有的电路模块,组合产生一个符合设计要求的完整电路系统。此时,该电路系统可以使用自下而上的层次电路设计流程来完成。
下面还是以“基于通用串行数据总线USB的数据采集系统”电路设计为例,介绍自下而上层次电路的具体设计过程。自下而上绘制层次原理图的操作步骤如下:
(1)启动Altium Designer 16,新建项目文件。打开“Files(文件)”面板,在“新的”选项栏中单击“Blank Project(PCB)(空白项目文件)”选项,则在“Projects(工程)”面板中出现了新建的项目文件,另存为“USB采集系统.PrjPCB”。
(2)新建原理图文件作为子原理图。在项目文件“USB采集系统.PrjPCB”上右击,在弹出的快捷菜单中选择“给工程添加新的”→“Schematic(原理图)”命令,在该项目文件中新建原理图文件,另存为“Cpu.SchDoc”,并完成图纸相关参数的设置。采用同样的方法建立原理图文件Sensor1.SchDoc、Sensor2.SchDoc和Sensor3.SchDoc。
(3)绘制各个子原理图。根据每一模块的具体功能要求,绘制电路原理图。例如,CPU模块主要完成主机与采集到的传感器信号之间的USB接口通信,这里使用带有USB接口的单片机“C8051F320”来完成。而三路传感器模块Sensor1、Sensor2、Sensor3则主要完成对三路传感器信号的放大和调制,具体绘制过程不再赘述。
(4)放置各子原理图中的输入/输出端口。子原理图中的输入/输出端口是子原理图与顶层原理图之间进行电气连接的重要通道,应该根据具体设计要求进行放置。
例如,在原理图“Cpu.SchDoc”中,三路传感器信号分别通过单片机P2口的3个引脚P2.1、P2.2、P2.3输入到单片机中,是原理图“Cpu.SchDoc”与其他3个原理图之间的信号传递通道,所以在这3个引脚处放置了3个输入端口,名称分别为Port1、Port2和Port3。除此之外,还放置了一个共同的接地端口“GND”。放置的输入/输出电路端口电路原理图“Cpu.SchDoc”与图5-10完全相同。
同样,在子原理图“Sensor1.SchDoc”的信号输出端放置一个输出端口“Port1”,在子原理图“Sensor2.SchDoc”的信号输出端放置一个输出端口“Port2”,在子原理图“Sensor3.SchDoc”的信号输出端放置一个输出端口“Port3”,分别与子原理图“Cpu.SchDoc”中的3个输入端口相对应,并且都放置了共同的接地端口。移动光标到需要放置原理图符号的地方,单击确定原理图符号的一个顶点,移动光标到合适的位置再一次单击确定其对角顶点,即可完成原理图符号的放置。
放置了输入/输出电路端口的3个子原理图(Sensor1.SchDoc、Sensor2.SchDoc和Sensor3.SchDoc)分别如图5-11、图5-12和图5-13所示。
图5-11 子原理图“Sensor1.SchDoc”
图5-12 子原理图“Sensor2.SchDoc”
图5-13 子原理图“Sensor3.SchDoc”
(5)在项目“USB采集系统.PrjPCB”中新建一个原理图文件“Mother1.PrjPCB”,以便进行顶层原理图的绘制。
(6)打开原理图文件“Mother1.PrjPCB”,执行“设计”→“HDL文件或原理图生成图纸符”命令,系统将弹出如图5-14所示的“Choose Document to Place(选择文件放置)”对话框。
图5-14 Choose Document to Place对话框
在该对话框中,系统列出了同一项目中除当前原理图外的所有原理图文件,用户可以选择其中的任何一个原理图来建立原理图符号。例如,这里选中“Cpu.SchDoc”,单击OK按钮,关闭该对话框。
(7)此时光标变成十字形状,并带有一个原理图符号的虚影。选择适当的位置,将该原理图符号放置在顶层原理图中,如图5-15所示。该原理图符号的标识符为“U-Cpu”,边缘已经放置了4个电路端口,方向与相应的子原理图中输入/输出端口一致。
图5-15 放置U_Cpu原理图符号
(8)按照同样的操作方法,由3个子原理图(Sensor1.SchDoc、Sensor2.SchDoc和Sensor3. SchDoc)可以在顶层原理图中分别建立3个原理图符号(U-Sensor1、U-Sensor2和U-Sensor3),如图5-16所示。
图5-16 顶层原理图符号
(9)设置原理图符号和电路端口的属性。由系统自动生成的原理图符号不一定完全符合我们的设计要求,很多时候还需要进行编辑,如原理图符号的形状、大小、电路端口的位置要有利于布线连接,电路端口的属性需要重新设置等。
(10)用导线或总线将原理图符号通过电路端口连接起来,并放置接地符号,完成顶层原理图的绘制,结果和图5-8完全一致。