原文链接:http://www.eda365.com/forum.php?_dsign=74fe4957&mod=viewthread&page=1&tid=110710
在设计多组相同模块的板子的时候,我们经常会用到AD的多通道复用功能,
那么很多人都会在设计的时候,就把这个模块的原理图做成一个整体,这个时候进行简单设置之后,就可以运用复用功能实现我们要的效果;
不过在这里介绍另外一种方法,这种方法比较繁琐,奇葩,我觉得应该没人会想到吧(不过我真希望有人站出来跟我说我也是用这种方法);
既然繁琐,那为什么,我还会想出这招呢,这要说回一个话题,PCB工程师这个职位并不是在所有的公司,都有地位的,硬件工程师也许会认为你只是摆摆器件,连连线,顶多佩服你有耐心而已,为什么说这么多坏话呢,其实也不是坏话,确实有的,正因为如此,所以有些时候你即使知道怎么在原理图做好模块,方便PCB的复用,但是人家硬件工程师也没这个闲工夫去学你的方法画原理图;
所以很多时候,你要进行复用,你还得乖乖先将每一个模块当中,起着相同作用
的器件分配给相同的ID(也就是Channel Offset),然后在复用设置的时候选择依据Channel Offset进行匹配,才能进行复用,这个时候最最蛋疼的事情出现了,就是如何准确为这些器件分配Channel Offset;
说到这里,我真的想吐槽AD为啥不学学Allegro,能自动识别每个模块中拥有相同作用的器件,手工分配ChannelOffset有时候真的不现实,一个模块里面有10个器件,还可以接受,如果几百个上千个器件呢?
于是通过一些试验,我自己摸索出这种方法,来实现半自动分配ChannelOffset的方法,方法比较繁琐,不过至少对于我以前的那份工作,还是能很明显提示效率的,因为我接触的模块,动不动都就是几百个器件在里面的。
*********************************************************************************
首先我简单介绍一下AD的复用的操作:
1.  按照模块,把器件都一堆堆放好;
2.  给每一个模块当中,给器件分配ID(Channel Offset),相同模块中的器件ID是唯一的,但是不同模块中都含有相同ID的器件,也就是说,ID相同,表明在模块中起着相同作用;
3.  为每个模块套上一个room,并做一个class,这样AD才能知道哪几个模块是相同的
4.  摆好其中一个模块,走线走好;
5. 启用复用命令,并设置好按照ID进行匹配,然后执行即可。
*********************************************************************************
好那么我现在开始一步一步介绍这种方法:
在原理图编辑界面,打开SCH list:
<ignore_js_op>
让其显示器件信息,显示设置如图:
<ignore_js_op>
右键选项栏,调出设置窗口:
<ignore_js_op>

, Q. o' V% N2 A

我们来设置一下,让SCH list只显示我们需要的元器件详情,并且适当排序下:
<ignore_js_op>

9 E0 n* i9 j4 M6 w( _* L

好了,现在我们就把SCH list调出来了,并且依照我们的需要列出了几项元器件信息:
<ignore_js_op>

: W4 s$ v, b$ `7 V+ B/ u

接下来我们切换到PCB界面,用类似的方法,调出并设置PCB list窗口:
<ignore_js_op>
在PCB编辑界面,打开PCB list:
<ignore_js_op>
让其显示器件信息,显示设置如图:
<ignore_js_op>

' O0 A5 Q2 j  y+ D! Q$ T% @6 I

右键选项栏,调出设置窗口:
<ignore_js_op>
我们来设置一下,让PCB list只显示我们需要的元器件详情,并且适当排序下:
<ignore_js_op>

) ]; p6 h# _5 Q# M$ w. H3 }9 n$ T/ {

好了,现在我们就把PCB list调出来了,并且依照我们的需要列出了几项元器件信息:
<ignore_js_op>

" N8 W" a/ Q$ S1 v+ ~. y

好了,到了这一步,我们需要做的很简单,就是在SCH list和PCB list都按照位号把器件重新排序:

( [9 p# T% b, G) c

怎么排序?例如在PCB list中,我点击这个Name这选项,这个时候会出现箭头所指的小三角,表示现在PCB list是按照Name的顺序升序排列,SCH list排序方式也是类似;
<ignore_js_op>

8 \+ ?/ {6 q+ @: r

然后把SCH list中器件的位置信息(也就是X与Y列),全选之后复制下来,并且粘贴到PCB list中X与Y列中(注意,PCB 编辑界面的单位应该选择mil),这个操作很容易理解,就是然后PCB器件的摆放与原理图器件的摆放相一致,虽然看起来好像是堆在一起,这没关系;
(因为别人在绘制原理图的时候,一般是先画好一个模块,然后复制出n个出来,这意味着其实原理图各个模块器件的摆放位置是一样的,而且原理图中器件是没有重叠的,也就是说器件的位置信息是唯一的,所以我们就能用利用器件位置唯一这个信息,给每个器件分配一个唯一的Channel Offset,我就是利用这种特点想出了这个方法,经过刚才的复制粘贴操作,PCB中每个模块的器件摆放情况应该是一样的了)
<ignore_js_op>

5 X# V" |/ Y0 Q+ D, e# g+ D( `) ]

接下来我们需要重新设置一下PCB list窗口,让其只是显示选中的器件而不是PCB所有器件,方法很简单,可以看到,列表下面会提示你选中了多少个器件,我们可以每个模块都框选一遍,看看是不是各个模块都有同数量的器件;
<ignore_js_op>

$ E( O0 l& O$ H0 ]  h3 D

接下来就是为各个模块,起到相同作用的器件,分配相同的Channel Offset,之前已经说过,Channel Offset是软件完成复用的关键,问题来了,我们按照什么规则来分配呢,就是按照器件的位置信息来分配。
接下来我们要对所有的模块都做一遍这样的操作了:

! _; l0 Z3 M2 F* E+ r! y! u

1.把原点移动到当前模块的一个特定位置,比如这次我们选模块中这个大电感的pin脚:
<ignore_js_op>

$ w% _, m. h- [

2.创建一份EXCEL;

6 F& p: ~  J9 j0 I% b3 H8 c' b

3.确认已经选中模块中的所有器件:
4.在PCB list中按照位号排序,然后将前四列都复制到EXCEL中:
<ignore_js_op>
5. 在EXCEL的任意空列中,将目前的排序编一个号,如箭头显示,因为等下我们要打乱这个表的顺序,处理之后再还原排序:
<ignore_js_op>

0 E, \# C1 P  ]2 Q% S" ~1 ]/ e

6.我们按照先B列,后C列的方式进行排序(其实先C后B都可以的),然后在D列中,重新填写Channel Offset数值,比如有37个器件,那我们就从1填写到37:
<ignore_js_op>

0 b8 z! o0 `* m6 o; V) i  ^

7.完成之后,我们重新还原排序,并且复制Channel Offset数值所在的列,粘贴到PCB list中的Channel Offset列中,请注意,粘贴前需要确认PCB list是不是依然按照位号排序:
<ignore_js_op>
好,接下来我们安装这7步,把其他模块这么操作:

# a1 A0 p3 ?) e; H. z8 c. p

完成之后,我们可以检验一下,比如我们选中每个模块的相同的器件,
<ignore_js_op>
确认其ChannelOffset是不是一致的:
<ignore_js_op>

- F: e& w. R- L$ y8 F" G$ p, _8 i

完成之后就接近成功了,

7 }* u# R4 q' z& e6 l

首先给每个模块添加一个room:
<ignore_js_op>

; v5 x; K* ?/ Z% ^: j7 D% W" q

然后双击每个room,把Name改为跟InComponentClass一样的名字:
<ignore_js_op>
完成之后,我们在Classer Explorer中,新建一个DesignChannel Class,并将这几个room设置为同属于相同的Design Channel Class:
<ignore_js_op>
接下来我们选择任意模块,布局布线好;
<ignore_js_op>
好戏上演:我们开始执行复用的命令,冰冻三尺非一日之寒啊,启用命令后点击摆好模块的room,然后再点击另外任意一个room:
<ignore_js_op>
弹出了一个设置窗口,如下设置,看到左边下面的选项没有,因为我们在原理图没有把模块电路做成一个模块,所以我们只能选择按照Channel Offset进行匹配:
<ignore_js_op>
点击确定,我们看看效果:
<ignore_js_op>
搞定了啊啊。。。
****************************************************************
我们再把方法回顾一下:
首先是将PCB里面的器件,按照原理图的器件位置进行摆放;
其次利用每个模块中器件相对位置是一样这个规律,分配Channel Offset;
第三,进行必要的复用前设置,然后执行复用;
第四,顶帖啊!哈
****************************************************************
其实就这么简单,只要你理解了每一步操作的意图之后,你会把这种繁琐的操作牢牢记住,我已经快三年没用到了,想起为大家写这份东西的时候,还是能够准确的进行操作并且一次成功;
当遇见每个模块里面有几百上千个器件,你们就会知道这方法能在Channel Offset分配这一关键步骤剩下非常多的时间,而且又准确;
谨以此帖,献给广大EDA365 的小伙伴特别是仍然奋斗在PCB设计前线的人们。

转载于:https://www.cnblogs.com/ydvely521/p/9601828.html

转载:介绍AD另外一种奇葩的多通道复用的方法相关推荐

  1. 介绍python中几种遍历列表的for循环方法

    我们在使用列表的过程中,经常需要遍历列表的所有元素,对每个元素执行相同的操作.今天就给大家介绍python中几种遍历列表的for循环方法. 首先我们先构造一个numbers列表,如下: numbers ...

  2. matlab红外遥感温度反演,一种地表温度多通道热红外遥感反演方法与流程

    本发明涉及一种反演方法,尤其涉及一种地表温度多通道热红外遥感反演方法,属于遥感反演技术领域. 背景技术: 地表温度是描述区域及全球水热变化的重要物理量,也是驱动陆地与大气之间能量交换的关键因素.精确的 ...

  3. java 三种将list转换为map的方法详解

    这篇文章主要介绍了java 三种将list转换为map的方法详解的相关资料,需要的朋友可以参考下 java 三种将list转换为map的方法详解 在本文中,介绍三种将list转换为map的方法: 1) ...

  4. rust种的南瓜为什么老是消失_科技的力量!3种“奇葩”的发明,你都见过吗?...

    3种"奇葩"的发明,你都见过吗? 为什么说人类是地球上最高级的动物呢?因为不同于没有智慧的野兽,我们人类善于使用工具,随着时间的流逝,我们的大脑也越来越发达, 不仅各种各样的发明被 ...

  5. word2vec应用场景_介绍Word2Vec和Glove这两种最流行的词嵌入方法背后的直觉

    NLP 的首要问题就是寻求恰当的文本表示方法. 因为, 良好的文本表示形式, 是后续进一步处理的基础.近年来,词嵌入方法越来越流行,在各种各样的 NLP 任务中 得到了广泛的应用.简单而言,词嵌入是通 ...

  6. 刚看了一个视频,介绍了实体店十几种线上线下引流方法

    刚看了一个视频,介绍了实体店十几种线上线下引流方法,学习引流方法固然重要. 但是,还要明确的是引流方法要为引流目标服务的,每种方法有它的最佳适用条件. 这时,必然要考虑营销系统闭环,结合实体店的资源( ...

  7. 关于OSPF的五种报文类型介绍、OSPF八种状态机变化与报文交互介绍。

    4.2.2 路由 OSPF(OSPF的5种报文.8种状态机.邻居与邻接的形成) 目录 OSPF的5种报文 Hello报文 报文字段简介 DD/DBD报文 DD报文字段简介(首个DD报文) DD报文字段 ...

  8. 【转载】三种证明欧拉恒等式的方法(3 methods of proving Euler's Formula )

    [转载]三种证明欧拉恒等式的方法(3 methods of proving Euler's Formula ) 如下证明来自维基百科,本文属于转载如有版权涉及问题,概不负责. These proofs ...

  9. 介绍linux上两种rootkits检测工具: Rootkit Hunter和Chkrootkit

    原贴:http://blog.csdn.net/linkboy2004/archive/2007/03/22/1537890.aspx 介绍linux上两种rootkits检测工具: Rootkit ...

最新文章

  1. node.js入门 - 9.api:http
  2. STM32 基础系列教程 10 - 单线串口(半双工)
  3. 正则表达式匹配多行注解/**/
  4. 使用hive中beeline引擎来访问hive数据库
  5. html5视频播放自定义视频播放暂停,解决暂停按钮在视频画面中的问题
  6. 强强联合,OpenCV搭载飞桨模型,帮你轻松玩转深度学习
  7. 记一次Kafka集群的故障恢复
  8. GDI+ Graphics类
  9. activiti 文档_Activiti快速入门 kft-activiti-demo
  10. 几个C#关于Html解析的类
  11. win10计算机百度云盘,windows10系统中怎样安装百度云盘?
  12. 系统明文密码加密传输
  13. 非802.11r的Fast Roaming
  14. 能否去大厂的关键内功!
  15. html用if函数,if函数怎么用的实例
  16. 第19章 特殊工具与技术【C++】
  17. mplfinance绘制K线图
  18. 使用tushare抓取股票日线数据包
  19. 稚晖君被曝离职华为!两年前加入华为天才少年计划,下一步创业方向可能是机器人!...
  20. IBM Power6、7配件FC号描述翻译(unix360.part06)

热门文章

  1. 关于逆元的概念、用途和可行性的思考(附51nod 1013 和 51nod 1256)
  2. golang中的go mod开发
  3. 《深入解析 MAC OS X iOS 操作系统》PDF 带书签
  4. 对CAN、USART、SPI、SCI等常见总线的简单介绍
  5. numpy 之 np.diff函数
  6. 源码注释TODO/ FIXME/XXX,
  7. js 只准输入数字_js实现文本框只允许输入数字并限制数字大小的方法
  8. x265-确定slice type-1
  9. jre java.security_java.security.NoSuchProviderException: no suc...
  10. Struts2内置拦截器的简要介绍