PT:pt write_change to innovus 脚本

2024-05-10 13:36
文章标签 脚本 change write pt innovus

本文主要是介绍PT:pt write_change to innovus 脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7b0b406f5e7b4f36a876346d5703a6e8.png

6a628bd160cb49099f8a9622849a011d.png

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧?

拾陆楼知识星球入口

0e09f6874287495aad250a66f26f9d41.png

#!usr/bin/perl
open rf,"$ARGV[0]";
open wf,">test. tcl";

while (<rf>) {
          s/\[(\D[^\s\]]*)?\]/\\\[$1\\\]/g;
          if (/current _ instances$/) {
                 $curinst = "";
                 $hinst = "";
                 $orient_mark=0;
                 next
          }
          if (/current_instance\s+{(\S+)}/) {
                 $curinst = "$1";
                 $curinst =~s/^{//g;
                 $curinst =~s/}$//g;
                 $hinst ="-hinstGuide ${curinst}
                 $curinst ="${curinst}\/";
                 next
          }
          if (/insert _ buffer\s+\[get_ pins\s+\{(.*)\}\]\s+(\S+)\s+-new_net_names\s+\{(\S+)\}\s+-new_cell_names\s+\{(\S+)\}\s+-location\s+\{(.*)\}\s+-orientation\s+(\S+)/ ) {
                 $term_name = "${curinst}$1";
                 $cell_name = $2;
                 $net_name = $3;
                 $name = $4;
                 $location = $5;
                 $ori2 = $6;
                 if ($ori2 eq "N") {$ori = "R0"}

                 if ($ori2 eq"FS") {$ori = "MX"}

                 if ($ori2 eq "S") {$ori = "R180"}

                 if ($ori2 eq"FN") {$ori = "MY"}

                 print wf "set result [ecoAddRepeater -term $term_name -cell $cell_name -newNetName $net_name -name $name -loc {$location} -bufOrient $ori $hinst]\n"; 

                next

        }

       if (/add buffer_on_route\s+\[get _ net -of (.*)\]\s+-user_specified_buffers\s+\{\s*(.*)\s*\}\s+.*/) {

               $pin = $1;

               $ll = $2;

               $i = 0;

               $inst_list = "";

               $cell_list = "";

               $pt = "";

               $j = 0;

               $pin =~ s/^{//g;

               $pin =~ s/}$//g;

               foreach (split(/\s+/,$ll)) {

                       $i+=1;

                       if ($i==1) {

                               $inst_list="$inst_list $_";

                       } elsif ($i==2) {

                               $cell_list="$cell_list $_";

                       } elsif ($i==3) {

                               $pt="$pt $_";

                       } elsif ($i==4) {

                               $pt="$pt $_";

                       } elsif ($i==5) {

                               $i=0;

                       }

                      $orient_mark=1;

             }

             @cell_list = split(/\s+/,$cell _ list);

             if ( @cell_list > 1) {

                      print wf "set result  [ecoAddRepeater -net [get_object_name [get_net -of ${curinst}$pin]] -cell \"$cell _ list\" -loc \"$pt\" -name \"$inst _ list\"]\n";

             } else {

                      print wf "set result [ecoAddRepeater -net [get_object_name [get_net -of ${curinst}$pin]] -cell \"$cell_ list\" -loc \"$pt\" -name \"$inst_list\" $hinst]\n";

            }

    } elsif (/set_cell_location -coordinates\s+{(.*)}\s+-orientation\s+(\S+)\s+\[get_cells\s+{(.*)}/) {

         $ori2= $2;

         $loc2 = $1;

         $c2 = $3;

        if ($ori2 eq"N") {$ori = "R0"}

        if ($ori2 eq"FS") {$ori = "MX"}

        if ($ori2 eq "S") {$ori = "R180"}

        if ($ori2 eq"FN") {$ori = "MY"}

       @cell_list = split(/\s+/,$cell_list);

       if ($orient_mark && @cell_list > 1) {

                  print wf "dbSet [dbGet -p top.inst.name [lindex \$result $j ]].orient $ori\n";

print wf "dbSet [dbGet -p top.inst.name [lindex \$result $j ]]. pt \"$loc2\"\n";

} else {

print wf "dbSet [dbGet -p top.inst.name ${curinst}$c2]. orient $ori\n";

print wf "dbSet [dbGet -p top.inst.name ${curinst}$c2]. pt \"$loc2\"\n";

}

$j+=3;

} elsif (/size_cell\s{(\S+)}\s+{(\S+)}$/) {

print wf "ecoChangeCell -inst ${curinst}$1 -cell $2\n";

$orient_mark=0;

} else {

$j=0;

print wf $_;

}

close rf;

close wf

 

 

这篇关于PT:pt write_change to innovus 脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/976587

相关文章

通过Python脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re

Python3脚本实现Excel与TXT的智能转换

《Python3脚本实现Excel与TXT的智能转换》在数据处理的日常工作中,我们经常需要将Excel中的结构化数据转换为其他格式,本文将使用Python3实现Excel与TXT的智能转换,需要的可以... 目录场景应用:为什么需要这种转换技术解析:代码实现详解核心代码展示改进点说明实战演练:从Excel到

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

shell脚本自动删除30天以前的文件(最新推荐)

《shell脚本自动删除30天以前的文件(最新推荐)》该文章介绍了如何使用Shell脚本自动删除指定目录下30天以前的文件,并通过crontab设置定时任务,此外,还提供了如何使用Shell脚本删除E... 目录shell脚本自动删除30天以前的文件linux按照日期定时删除elasticsearch索引s

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

10个Python Excel自动化脚本分享

《10个PythonExcel自动化脚本分享》在数据处理和分析的过程中,Excel文件是我们日常工作中常见的格式,本文将分享10个实用的Excel自动化脚本,希望可以帮助大家更轻松地掌握这些技能... 目录1. Excel单元格批量填充2. 设置行高与列宽3. 根据条件删除行4. 创建新的Excel工作表5

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用