Cadence Skill 论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 21470|回复: 13

route keep out skill,请帮忙提供

[复制链接]
发表于 2013-6-27 07:53:27 | 显示全部楼层 |阅读模式
在布RF模块时,trace下面的铜皮也要挖掉,很麻烦,请帮忙提供
发表于 2013-6-27 12:38:34 | 显示全部楼层
同求,同求了~~~
发表于 2013-6-27 21:35:37 | 显示全部楼层
你是想根据走线来创建一个route keep out 吗????如果是的话,这个SKILL应该很好写的。
发表于 2013-6-27 23:55:55 | 显示全部楼层
是不是还要有挖孔隔离的啊
 楼主| 发表于 2013-6-28 08:28:14 | 显示全部楼层
是呀,还没写过,帮忙啦
发表于 2013-6-28 08:33:18 | 显示全部楼层
本帖最后由 XYX365 于 2013-6-28 08:36 编辑

4  RF线次层挖空
skill操作步聚:
1) 快捷键ctrl+R,在option页选择挖空层及设定间距。其中间距有两种设置方式:按线宽倍数及直接设定间距,任选一种。
   
2) 在板中选择次层要挖空的pin、via或chines,可单选、框选也可使用右键菜单的Temp Group命令多选(多选后必须再次右键选取complete完成;
3)点击add keepout,在选定层产生route keepout(如2)中选择不包含clines,无法判定线宽,间距设定自动跟从第二种方式)
4)选择两个pin,点击add line keepout,在两pin之间产生route keepout ,其他设置与上同。
  1. axlCmdRegister("clear_RF" `clear_RF)
  2. axlSetAlias( "~R" "clear_RF")

  3. defun( clear_RF ()
  4.     clear_RF_form()
  5.     axlSetFindFilter(?enabled `("NOALL" "CLINES" "pins" "vias" )        ?onButtons `("CLINES"))
  6.     axlClearSelSet()
  7.    
  8.     cline_list=nil
  9.     while( axlSelect()
  10.         ls=axlGetSelSet()
  11.         a=car(ls)
  12.         if( a->objType=="path" then
  13.             a=nthelem(2 parseString(a->layer "/"))
  14.         else
  15.             a=nthelem(2 parseString(car(a->startEnd) "/"))
  16.         )
  17.         if( a=="TOP" then
  18.             layer=nthelem(2 layer_list)
  19.             axlFormListSelect(fs "layer_name" layer)        
  20.         else
  21.             if( a=="BOTTOM" then
  22.                 layer=nthelem(length(layer_list)-1 layer_list)
  23.                 axlFormListSelect(fs "layer_name" layer)        
  24.             )
  25.         )
  26.     )
  27.     axlFinishEnterFun()
  28. )

  29. defun( clear_RF_form ()
  30.    clear_RF_file="./clesr_RF_file.form"
  31.    p=outfile(clear_RF_file "w")
  32.     if( car(axlDBGetDesignUnits())=="mils" then
  33.         s="mil"
  34.     else
  35.         s="mm"
  36.     )
  37.     if(p != nil then
  38.         fprintf(p "FILE_TYPE=FORM_DEFN VERSION=2\n")
  39.         fprintf(p "FORM\n")
  40.         fprintf(p "FIXED\n")
  41.         fprintf(p "PORT 40 60\n")
  42.         fprintf(p "HEADER "fanout BBvia"\n")
  43.         fprintf(p "TILE\n")
  44.         fprintf(p "\n")
  45.         
  46.         fprintf(p "TEXT "clear layer"\n")
  47.         fprintf(p "TLOC 1 1\n")
  48.         fprintf(p "ENDTEXT\n")
  49.         fprintf(p "\n")

  50.         fprintf(p "FIELD layer_name\n")
  51.         fprintf(p "FLOC 9 1\n")
  52.         fprintf(p "LIST "" 12 5\n")
  53.         fprintf(p "ENDFIELD\n")
  54.         fprintf(p "\n")


  55.             fprintf(p "GROUP "clear space"\n")
  56.         fprintf(p "GLOC 1 11\n")
  57.         fprintf(p "GSIZE 20 7\n")
  58.         fprintf(p "ENDGROUP\n")
  59.         fprintf(p "\n")
  60.         fprintf(p "FIELD xws\n")
  61.         fprintf(p "FLOC 2 13\n")
  62.         fprintf(p "CHECKLIST " " "1"\n")
  63.         fprintf(p "ENDFIELD\n")
  64.         fprintf(p "\n")
  65.         fprintf(p "FIELD width\n")
  66.         fprintf(p "FLOC 2 15\n")
  67.         fprintf(p "CHECKLIST " " "1"\n")
  68.         fprintf(p "ENDFIELD\n")
  69.         fprintf(p "\n")
  70.         
  71.         fprintf(p "FIELD xw\n")
  72.         fprintf(p "FLOC 5 13\n")
  73.         fprintf(p "REALFILLIN 6 3\n")
  74.         fprintf(p "ENDFIELD\n")
  75.         fprintf(p "\n")
  76.         
  77.         fprintf(p "FIELD um\n")
  78.         fprintf(p "FLOC 5 15\n")
  79.         fprintf(p "REALFILLIN 6 6\n")
  80.         fprintf(p "ENDFIELD\n")
  81.         fprintf(p "\n")

  82.         fprintf(p "TEXT "W"\n")
  83.         fprintf(p "TLOC 13 13\n")
  84.         fprintf(p "ENDTEXT\n")
  85.         fprintf(p "\n")
  86.         
  87.         fprintf(p "TEXT "%s"\n" s)
  88.         fprintf(p "TLOC 13 15\n")
  89.         fprintf(p "ENDTEXT\n")
  90.         fprintf(p "\n")

  91.         fprintf(p "FIELD add_s\n")
  92.         fprintf(p "FLOC 1 19\n")
  93.         fprintf(p "MENUBUTTON "add keepout" 15 3\n")
  94.         fprintf(p "ENDFIELD\n")
  95.         fprintf(p "\n")
  96.         
  97.         fprintf(p "FIELD add_L\n")
  98.         fprintf(p "FLOC 1 22\n")
  99.         fprintf(p "MENUBUTTON "add line keepout" 15 3\n")
  100.         fprintf(p "ENDFIELD\n")
  101.         fprintf(p "\n")
  102.         
  103.         fprintf(p "ENDTILE\n")
  104.         fprintf(p "ENDFORM\n")
  105.     else
  106.         printf("ERROR,can't create form file!")
  107. )
  108.     close(p)
  109.     ;axlFormCreate('fs clear_RF_file '("msgLines" 0) 'do_clear_RF nil nil )
  110.     axlMiniStatusLoad( 'fs clear_RF_file  'do_clear_RF t )
  111.    
  112.    a=axlLayerGet("ETCH/TOP")
  113.     s=""
  114.     layer_list=nil
  115.     while( s!=nil
  116.         s=a->name
  117.         layer_list=append1(layer_list s)
  118.         s=a->nextLayer
  119.         if( s!=nil then
  120.             nextlayer=strcat("ETCH" "/" s)
  121.            a=axlLayerGet(nextlayer)
  122.         )
  123.     )

  124.    
  125.     layer=nthelem(2 layer_list)
  126.     axlFormListDeleteAll(fs "layer_name")
  127.     axlFormSetField(fs "layer_name" layer_list)
  128.     axlFormListSelect(fs "layer_name" layer)        
  129.     axlFormSetField(fs "xws" t)
  130.     if( boundp('xs)==nil then
  131.         xs="2.0"
  132.         xum="0.6"
  133.     )
  134.     axlFormSetField(fs "xw" xs)
  135.     axlFormSetField(fs "um" xum)
  136.     axlFormDisplay(fs)
  137.    if(isFile( clear_RF_file) then
  138.         deleteFile(clear_RF_file)
  139.     )
  140. )
  141. defun( do_clear_RF (fs)
  142.     case( fs->curField
  143.     ("layer_name"
  144.         layer=fs->curValue
  145.     )
  146.     ("xw"
  147.         xs=fs->curValue
  148.     )
  149.     ("um"
  150.         xum=fs->curValue
  151.     )
  152.     ("add_s"
  153.         if( ls!=nil then
  154.             foreach(a ls
  155.                 polydbid = axlPolyFromDB(a, ?layer car(a->startEnd) ?padType 'REGULAR)
  156.                 if( axlFormGetField( fs "xws")=="1" then
  157.                     i=1
  158.                     while( nthelem(i ls)->objType!="path" && i<length(ls)
  159.                         i=i+1
  160.                     )
  161.                     b=nthelem(i ls)
  162.                     if( b->objType=="path" then
  163.                         if( b->isSameWidth==t then
  164.                             s=car(b->segments)->width*atof(xs)
  165.                         else
  166.                             s=0
  167.                             foreach(c b->segments
  168.                                 if( c->width>s then s=c->width)
  169.                             )
  170.                             s=s*atof(xs)
  171.                         )
  172.                     else
  173.                         s=atof(xum)
  174.                         axlFormSetField(fs "width" t)
  175.                     )
  176.                     
  177.                 else
  178.                     s=atof(xum)
  179.                 )
  180.                 exp_poly = (axlPolyExpand polydbid s 'ACU_ARC)
  181.                 axlDBCreateShape(car(exp_poly) t strcat("ROUTE KEEPOUT/" layer))
  182.                 sprintf(xum "%f" s)
  183.                 axlFormSetField(fs "um" xum)
  184.             )
  185.         )
  186.     )
  187.     ("add_L"
  188.         if( length(ls)==2 then
  189.             if( car(ls)->objType="pin" && cadr(ls)->objType=="pin" then
  190.                 s=atof(xum)
  191.                 polydbid = axlPolyFromDB(car(ls), ?layer car(car(ls)->startEnd) ?padType 'REGULAR)
  192.                 exp_poly = (axlPolyExpand polydbid s 'NONE)
  193.                 a=car(exp_poly)->bBox
  194.                 w1=abs(caar(a)-caadr(a))/2
  195.                 h1=abs(cadar(a)-cadadr(a))/2
  196.                
  197.                 polydbid = axlPolyFromDB(cadr(ls), ?layer car(cadr(ls)->startEnd) ?padType 'REGULAR)
  198.                 exp_poly = (axlPolyExpand polydbid s 'NONE)
  199.                 a=car(exp_poly)->bBox
  200.                 w2=abs(caar(a)-caadr(a))/2
  201.                 h2=abs(cadar(a)-cadadr(a))/2

  202.                 s=atof(xum)
  203.                 a=car(ls)->xy
  204.                 b=cadr(ls)->xy
  205.                 if( abs(car(a)-car(b))>abs(cadr(a)-cadr(b)) then
  206.                     path = axlPathStart( list(car(a):cadr(a)-h1 car(a):cadr(a)+h1 car(b):cadr(b)+h2 car(b):cadr(b)-h2 car(a):cadr(a)-h1 ))
  207.                 else
  208.                     path = axlPathStart( list(car(a)-w1:cadr(a) car(a)+w1:cadr(a) car(b)+w2:cadr(b) car(b)-w2:cadr(b) car(a)-w1:cadr(a)))
  209.                 )
  210.                 axlDBCreateShape(path t strcat("ROUTE KEEPOUT/" layer))
  211.             else
  212.                 print("Select two pins.")
  213.             )
  214.         else
  215.             print("Select two pins.")
  216.         )
  217.     )
  218.     )
  219.    
  220. )
复制代码

点评

很不错。。建议添加张图片,更直观。  发表于 2013-7-1 10:15

评分

参与人数 1威望 +2 SKILL币 +4 贡献 +2 收起 理由
vivienluo + 2 + 4 + 2 赞一个!

查看全部评分

 楼主| 发表于 2013-6-29 09:46:24 | 显示全部楼层
试一下啦,楼主,多谢
 楼主| 发表于 2013-6-29 10:06:53 | 显示全部楼层
多谢楼主了,试了下,真不错,有没有10度走线的skill,能否再给一个
发表于 2013-12-31 23:46:59 | 显示全部楼层
很好用  收藏起來  謝謝喔
发表于 2014-8-9 21:27:15 | 显示全部楼层
XYX365 发表于 2013-6-28 08:33
4  RF线次层挖空
skill操作步聚:
1) 快捷键ctrl+R,在option页选择挖空层及设定间距。其中间距有两种设 ...

赞一个,很不错,由于使用负片层需要添加antietch切割线,楼主可否在这个skill里面增加这个功能,或告知如何修改
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|网站地图|Cadence Skill 论坛 ( 蜀ICP备13024417号 )

GMT+8, 2024-4-28 04:48 , Processed in 0.147031 second(s), 17 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

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