ORCAD 层次化原理图使用TCL获取位号的方法

学习ORCAD TCL已经好一阵子了。但是一直未能找到较好的获取器件位号的方法(也就是获取黄色部分位号的方法)。使用DboPartInst对象 的GetReferenceDesignator(RefDes)或者 GetReference(Ref)方法获取的位号,都是平面设计的位号(通常带有?,图示例子中会得到U?),不是想要的位号(U44)。

#GetReference
    $lInst GetReference $lname
    set strName [DboTclHelper_sGetConstCharPtr $lname]
    puts [format "%30s = %-30s" GetReference $strName]

按照参考手册OrCAD_Capture_TclTk_Extensions.pdf的章节“3.2.28.2  Iterate over instance occurrence hierarchy ”的方法,总觉得不是好的方法。后发现,DboPartInst对象有如下方法应用可以获取DboPartInst对象的Occurrecne对象,但未找到例子。

在cadence官网community上发文寻求帮助。得到回复,按厂家给出了样例写代码,终于可以获取occurrence的位号。太好了。

set lPartOcc {}
set lSelObj [GetSelectedObjects]
foreach lObj $lSelObj {
    set lOccCount [$lObj GetOccurrencesCount]
    for {set i 0} {$i<$lOccCount} {incr i} {
        set lOcc [$lObj GetOccurrencesAtPos $i]

        set lName [DboTclHelper_sMakeCString]
        $lOcc GetPathName $lName
        set PathName [DboTclHelper_sGetConstCharPtr  $lName]
        puts $PathName

        lappend lPartOcc $lOcc
    }
puts $lPartOcc
}

回头再看,DboPartInst对象的基对象为(DboGraphicInstance,DboInstOccMapper),例子中正好使用DboInstOccMapper的方法GetOccurrenceAtPos得到Occurrence对象,并用其方法GetPathName获取到层次路径或者位号。GetOccurrencesCount方法正是对象DboInstOccMapper的方法。

理解又进了一步,欢喜耶

最后,说明一下位号的提取方法。GetPathName得到的位号类似TOP/POWER/U10这们的值,这是层次化路径,真正想要的位号是U10,使用正则表达式即可提取出来。

regexp {/\w+)$} $PathName -> ref

puts $ref

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值