找回密码
 注册
查看: 2760|回复: 10
打印 上一主题 下一主题

AD设计fpga的时候,在原理图里面改管脚名,有什么方便的方法吗?

[复制链接]
  • TA的每日心情
    开心
    2022-11-1 15:51
  • 签到天数: 62 天

    [LV.6]常住居民II

    跳转到指定楼层
    1#
    发表于 2015-2-25 07:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    AD设计的原理图,FPGA的管脚名要做一些改变,库里面的fpga symbol是通用的,不能改,只可以在原理图里面改。通过双击原件,改pin的话太痛苦了,上百个管脚,在edit pin的界面上不能一起copy和past,只能一个一个改。有没有什么快捷的方法一次改多个管脚?考虑用脚本,找到了个ad的读管脚名的脚本,修修改改可以用来读指定的某个原件的所有管脚,再在文本文件里面改,就可以大量的拷贝了,但是不知道怎么写回到ad里面,有高手指点一下?谢谢5 X- F) q& \! B3 y4 d2 j* j; x# c9 v
    {..............................................................................}
    1 M5 {" f+ A1 _9 }) p{ Summary Demo how to fetch pins of components.                                }
    3 P! I( T1 v/ |' s% [{                                                                              }* V' A$ x' [- n
    { Copyright (c) 2008 by altium Limited                                         }
    / h: A  V! B: }8 ^7 G" }" S' G; `{..............................................................................}; \2 H0 R. u( _3 m9 z" X

    5 w2 t6 V' ^" \7 q; z1 W: {& Z{..............................................................................}
    3 Y* Q/ C4 @0 G" ^Procedure FetchPinsOfComponents_U1;
    * C/ _; G% ~. T. c/ g# ]* vVar5 P" ?, x2 |# i, R0 U1 W& J* o
        CurrentSch : ISch_Sheet;% {( Z; h& z" v' G  a. h& b( U: g
        Iterator   : ISch_Iterator;
    ( J7 I- j$ C* a1 Y5 m* y% ]    PIterator  : ISch_Iterator;
    ' p5 K1 o  a2 H- S& O/ g    AComponent : ISch_Component;
    - W4 r$ V$ _3 C# J" y# w4 l) H    AnIndex    : Integer;6 s5 s* R0 g' f4 [# F

    1 Y3 R& n4 L" {' b& c    ReportList : TStringList;9 }0 Z; s. z* }
        Pin        : ISch_Pin;$ _: C# c: v, ?* I9 S  @! p
        Document   : IServerDocument;
    ' V* r# T3 ]1 mBegin
    : C+ D5 F/ Q0 z, j7 A8 R: F) L9 x    // Check if schematic server exists or not.
    # w1 W. {" ~( [' a: P    If SchServer = Nil Then Exit;
    ; x/ e  d! B4 V. D  {2 g7 m
    8 O, ]% `, ]+ n! h8 x    // Obtain the current schematic document inteRFace.
    6 x' F$ \% `$ g# N  N8 g2 G$ j9 y* r    CurrentSch := SchServer.GetCurrentSchDocument;' B* P6 T- W9 a6 S+ R
        If CurrentSch = Nil Then Exit;
    4 P5 J( o$ F  _/ x' f; b' U% H8 l8 P/ |
        // Look for components only
    1 B5 D8 P; q: z1 g! _" K% s    Iterator := CurrentSch.SchIterator_Create;- r4 j) m. \7 f2 b) ]
        Iterator.AddFilter_ObjectSet(MkSet(eSchComponent));
    ; I. S" v/ n$ \% d9 m* r; u$ d% H8 L0 [. B' d6 V
        ReportList := TStringList.Create;
    0 l% U4 Y( F, g, ?2 `* I* u  b2 e    Try
    ! \* ]1 }! a# \; y        AComponent := Iterator.FirstSchObject;* y) M1 O6 }# P0 [3 W& B
            While AComponent <> Nil Do
    1 @  }1 C. u$ F2 n        Begin
    9 m1 [6 M2 a( g1 r# X% U" p            if AComponent.Designator.Text = 'U1' Then   // change to the designator number you want....." x  y! h% J: b1 ?0 o
                Begin" N. R! }( k% y9 s3 R; s' j- I
                ReportList.Add(AComponent.Designator.Name + ' ' + AComponent.Designator.Text);7 i  C# H0 F/ C, S" P
                ReportList.Add(' Pins');/ a, o- ^- N, n3 n

    ! j. u4 M" T; c" O  s9 D3 ~            Try
    : |* ]0 _/ ]4 f8 \+ t- U                PIterator := AComponent.SchIterator_Create;& Z* h( y  G' b1 p1 y
                    PIterator.AddFilter_ObjectSet(MkSet(ePin));
    ; ~3 g  r/ m7 B8 Q7 @
    ' S; T# O' I$ H7 E                Pin := PIterator.FirstSchObject;5 `4 [: N$ D$ D
                    While Pin <> Nil Do
    " ~% M8 t5 _6 O* Y                Begin1 N6 p4 ~! m1 R" j
                        { ReportList.Add('  Name: ' + Pin.Name + ' Designator: ' + Pin.Designator); }% M- x* o- d% O- J
                        ReportList.Add('  Name: ' + Pin.Name + ' Designator: ' + Pin.Designator);& w2 K  ^$ }4 G! C, k
                        Pin := PIterator.NextSchObject;6 W  n! F& h+ I
                    End;
    % ~7 L" v" e3 _; x3 ~4 D* A            Finally
    1 F* z: I" v, m: O                AComponent.SchIterator_Destroy(PIterator);" {- f7 J) b% b1 j' z" Y% w
                End;
    % W( e4 o- u6 L$ c. ]" N" m; C4 ]5 {  J8 ^6 Y9 w4 |5 M3 M, H7 [' l
                ReportList.Add('');& S0 R! b/ h  y  h/ d) F: O
    + B  c: v2 i. h: k0 f
                End;
    2 W. l0 U5 d, k, D7 T- g+ I
    ( j% ^$ z0 q# l, L; m( d            AComponent := Iterator.NextSchObject;
    8 _! i6 b3 ]2 o4 f9 D: K        End;
    1 y: y& a2 s2 o1 w* R    Finally! x1 ^3 E$ S4 w8 D- |- ]
            CurrentSch.SchIterator_Destroy(Iterator);
    % m; W9 ^4 B8 @0 a2 q$ R" N    End;# e- L. y+ ?5 [# H' m

    0 f: m0 E4 \8 Z% |+ V4 Q    ReportList.SaveToFile('d:\PinReportU1.Txt');3 s0 d" x! A( h) |, D
        ReportList.Free;+ d1 ?9 [* ]' G! K7 I; x4 X( |8 I
    : x: y1 [; E  ~7 z2 p; W
        // Display the report for all components found and their associated pins.5 {6 x6 ], o  n! ]5 f5 T# @/ C
        Document := Client.OpenDocument('Text','d:\PinReportU1.txt');% m" K# I1 N, }0 D1 H2 h
        If Document <> Nil Then8 g. U2 D1 ~( p) M% O
            Client.ShowDocument(Document);
    6 `* h# A& Q7 @" l8 b, jEnd;2 ^& S  L0 u8 H% Y5 j
    {..............................................................................}4 y" [( ?% b+ _, f  j1 \3 [- Z4 b

    $ T! J3 m- z$ L7 w{..............................................................................}' K+ I7 [6 _/ X0 {' [0 A9 w
    End.
      k4 N2 }% d2 K' s9 i
    - m9 b0 P5 [9 q% B8 }0 B

    该用户从未签到

    2#
    发表于 2015-2-25 09:20 | 只看该作者
    我是用ORCAD来做这种多管脚的封装,ORCAD支持导入EXCEL表格。
    2 _) }# q; k( p: u! ~- t% H9 W% a; {" y3 r% ?3 I" V' U
    AD做这种类似的封装,我一直没去尝试它。

    该用户从未签到

    3#
    发表于 2015-2-25 14:02 | 只看该作者
    altium 可以利用  datasheet 或 excel 来快速建立多管脚的器件库,具体的文档你可以查看altium相关的操作说明。0 x; O- f" J" ]* w
    类似的资料汇总  在  【给初学3-...】系列汇总帖中有过汇总,链接地址略,网上找不到时可到pcbbbs论坛找寻之前的资料汇总。
    3 r, @  }' `9 p+ l( E8 A: a
    8 k% r. H. N1 ^" J: `+ U0 R* I5 A  {altium不同的版本对某些字符的处理方式不同,仅提示: 比如某些版本 对  软回车 或硬回车 的处理(或者理解为兼容性)不同...
    & ~# |3 W2 S1 \4 W! M
  • TA的每日心情
    开心
    2022-11-1 15:51
  • 签到天数: 62 天

    [LV.6]常住居民II

    4#
     楼主| 发表于 2015-2-26 01:14 | 只看该作者
    说明一下,我语文是体育老师教的,没讲清楚啊,请谅解。
    ) Q1 K! @  C6 G1. 已经建立了原件库了,用的是excel导入的方法,smart grid tool,搜一下这个关键词就可以找到。
    $ o( W4 A  _5 u- F( A2. 库里的原件各个管脚是通用名,直接就是从datasheet上来的。- J. E. t. ^  v
    3. 做到具体不同的产品,fpga的管脚都有各自项目直接的管脚信号名。
    8 r8 T3 e; h0 ]) l* t$ p4. 在原理图里面,直接改component的管脚名,这个改名只是在这个特定的altium project里面,就只是为了每个特定项目调试和测试方便,直接根据fpga内部的设计文件定义的各个信号命名直接用到原来图里面的管脚名上面。3 k5 X2 `8 \1 X( l/ `0 V7 b
    5. 在原理图里面,直接双击一个器件,出porperties窗,左下角可以点edit pins,可以改管脚名,但是只能一个一个改,没办法选中一些管脚直接copy&paste。 一个fpga有几百个管脚,一个一个改要累死啊,所以想是不是用脚本直接自动改原理图里面的管脚名。不是要改库里面的管脚名,库里面的原件是不更改的。
    - x9 K# {! u" B( |1 {0 m谢谢

    该用户从未签到

    5#
    发表于 2015-2-26 08:49 | 只看该作者
    SCH List也支持Edit並將資料粘貼的功能+ q& e# X' K# @* y) n( E3 Q
    1.雙擊器件,不勾選Lock Pins
    2 _- R, E' d8 Q* n' j6 ~2.選中該器件其中一個pin來做Find Similar Object.: y3 T6 e3 _$ S, l! A8 L' D  A
    3.FSO條件將 Object Specific區段的Owner設置為Same.這樣可以選中該器件的全部Pin
    + W2 y& w5 e( p1 T8 @4.開啟SCH List面板 上方左到右設置為Edit / Selected Objects / Current Document / Pin) e6 s/ |9 E1 H! E, t- Z3 Q
    5.你就可以針對下方用粘貼(EXCEL複製的資料)的方式將資料覆蓋過去8 d* M9 b! T% _4 Q  ?) M; `
    建議粘貼前先做排序(Sort)確保粘貼的數據順序是一致的
    8 R$ e# K2 B8 H8 e( P- \8 d( k' J, z% P/ n9 n  ~: @

    点评

    支持!: 0.0
    支持!: 0
    这个方法不错,谢谢。  发表于 2015-2-28 06:10
    ^_^ ^_^ 春节快乐! icm 的方法可以在 原理图 或 原理图库 界面 内进行,此时 altium 的器件名 不会因器件修改而自动改变,建议为了避免后期不必要的错误,通常可以将 需要进行管脚重分配的器件做更名处理(  详情 回复 发表于 2015-2-26 12:54

    评分

    参与人数 1威望 +2 收起 理由
    wanghanq + 2 ^_^^_^

    查看全部评分

    该用户从未签到

    6#
    发表于 2015-2-26 12:54 | 只看该作者
    icm 发表于 2015-2-26 08:49
    + F3 F8 l/ k3 [" F7 e+ j+ |$ OSCH List也支持Edit並將資料粘貼的功能
    + P+ @5 _6 q( r4 ~1 J2 F. n1.雙擊器件,不勾選Lock Pins8 I' ^5 X7 }6 {. }3 a/ C
    2.選中該器件其中一個pin來做Find Si ...
    : G5 |+ U: ?' L* d) K; s+ g
    ^_^ ^_^   春节快乐!
    . S# m$ J# ~* ]* U4 D
    / A2 N9 h1 u4 A* d( f5 I/ ?6 L& oicm 的方法可以在 原理图 或 原理图库  界面 内进行,此时 altium 的器件名 不会因器件修改而自动改变,建议为了避免后期不必要的错误,通常可以将 需要进行管脚重分配的器件做更名处理(以区别和原始库文档中的初始库)。1 z. e$ h$ m/ ]- G0 T7 d: O
    1 C: P1 V8 i$ W$ S
    另外,FPGA的管脚调整 可参 其他的资料进行:关键字 如      “ FPGA-PCB管脚同步”     “管脚交换功能”! C% _$ L# h" X- r' z- h

    $ H7 N7 E5 |; h% x9 A0 q建议楼主 在讨论类似话题时 给一个简单 的案例过来,这样 关注的网友可快速交互式的进行试操作和交流
    ' `  M: Q; R' D. r! \6 V2 V! V

    点评

    谢谢回复。fpga pcb管脚同步和管脚交换都不是我要的功能。 不是进行管脚重分配。只是改原理图里面的管脚名字。不同项目里面fpga的同一个管脚有不同的信号名。改名只是为了方便查信号和调试。不是因为pcb的layout。  发表于 2015-2-28 06:15
  • TA的每日心情
    开心
    2022-11-1 15:51
  • 签到天数: 62 天

    [LV.6]常住居民II

    7#
     楼主| 发表于 2015-2-28 08:18 | 只看该作者
    后来想想,其实可以改ad自己带的那个导入pin到lib的脚本文件。aD的脚本看着还是比较强大,就是对Delphiscript和vbscript不精通,也没找到什么好的教程。有人有好的推荐吗?谢谢

    点评

    脚本的学习和使用不妨 去 allegro 或 pads 论坛看看,里面有相关的脚本文档学习沟通(就看你能否搜索到之前沟通的内容了) altium脚本沟通见的比较少  详情 回复 发表于 2015-3-1 11:07

    该用户从未签到

    8#
    发表于 2015-3-1 11:07 | 只看该作者
    wxwxw 发表于 2015-2-28 08:187 }1 F( o' g" c4 b
    后来想想,其实可以改ad自己带的那个导入pin到lib的脚本文件。aD的脚本看着还是比较强大,就是对Delphiscri ...

    & B3 v4 e) g) R8 {/ v脚本的学习和使用不妨 去 allegro  或 pads 论坛看看,里面有相关的脚本文档学习沟通(就看你能否搜索到之前沟通的内容了)
    ( Q. d* J* y# g9 w- E5 galtium脚本沟通见的比较少
    5 H) t2 h& u( _( ]; k0 r* W: C2 {
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-5-24 09:55 , Processed in 0.109375 second(s), 24 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表