热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

层次电路原理图的设计

层次电路原理图的设计是为了在某些元件非常复杂的情况下进行模块化的设计方法,可以让原理图非常的清晰。一般有两种设计方法:自上而下设计、自下而上设计。所谓的自上而下设计是指先设计好模块

层次电路原理图的设计是为了在某些元件非常复杂的情况下进行模块化的设计方法,可以让原理图非常的清晰。一般有两种设计方法:自上而下设计、自下而上设计。
所谓的自上而下设计是指先设计好模块化后的封装器件,再设计该器件具体的电路;反之,自下而上的设计方法就是先设计好每个模块的原理图,再将每个模块的原理图进行生成器件的操作。
个人更倾向于后者,因为具体的原理图电路往往是自己设计过的,很多时候可以直接拿现成的用,在经过考虑之后设计每个模块的电路后,确定每个模块的输出输入端口即可。
首先介绍下模块化原理图是怎样的,我这里以图1举例。
《层次电路原理图的设计》

可以看到图1所示有四个模块,每个模块之间都有输入输出或者是双向的端口,通过这个端口就可以实现数据信号的交换。
这里说明两种情况,也就是我们如果是自上而下的设计方法,那么我们设计好了这个总图之后就可以设计每个模块中具体的电路图了。这里可以选择:设计——>产生图纸这个选项,选择你要产生图纸的模块即可,产生的图纸中会自动生成该模块里已经设计好的端口。另外要说明的就是这个绿色模块我们称之为图表符,可以直接找到放置一下即可;这个黄色的端口,称之为图纸入口,同样找到之后放置即可,该入口的方向则是自己根据模块信号的情况进行具体分析,这里不再赘述。
之后,我们就可以设计对应模块的具体电路了,这里我以图2为例,举个例子。
《层次电路原理图的设计》

可以看到这是整体的控制电路,与平常设计的不同是这里多了许多的端口,也就是port,这也是可以直接找到的,可以自己设置名称和输入输出。具体接口的电路如图3所示。
《层次电路原理图的设计》
我把所有的接口都放在了一起,这样子的好处就是可以很清晰的看到,哪些是输入输出。按照这样的操作设计好之后,对整个工程进行编译即可出现总图纸下包含多个子图纸的情况,如图4所示。
《层次电路原理图的设计》

但是在编译的过程中可以发现会报错。报错的具体内容就是说,重复定义了线的名称,也就是相同的端口或者网络标识被多次使用并产生了多条在不同图纸的线。这种情况一般是不需要理会的,我直接将该错误改成了警告,之后PCB画图的时候相关的网络没有问题即可。具体修改的地方如图5所示。
《层次电路原理图的设计》
该页面是在:工程——>工程参数——>Error Reporting里面。
至此,自上而下的设计流程就结束了,如果自下而上设计的话,只要在设计好每一个子图之后,新建一个原理图,在新的原理图里选择:设计——>HDL文件或图纸生成图表符即可。生成的图表符自带图纸入口的,蛮方便。


推荐阅读
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文深入探讨了如何通过调整InnoDB的关键配置参数来优化MySQL的随机IO性能,涵盖了缓存、日志文件、预读机制等多个方面,帮助读者全面提升数据库系统的性能。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文详细探讨了在Android 8.0设备上使用ChinaCock的TCCBarcodeScanner进行扫码时出现的应用闪退问题,并提供了解决方案。通过调整配置文件,可以有效避免这一问题。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
author-avatar
天空的鸟儿飞
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有