【HFSS】在CMOS工艺下自动修改金属属性和设置端口

2023-11-02 16:41

本文主要是介绍【HFSS】在CMOS工艺下自动修改金属属性和设置端口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1.待解决的问题描述
  • 2.代码实现
    • 2.1 预定义
    • 2.2 获取HFSS object的名称并分类
    • 2.3 改变金属属性
    • 2.4 设置端口
  • 3.使用步骤和结果展示

1.待解决的问题描述

从ADS画好的版图导出为gds文件后,再导入到HFSS进行仿真时,金属层和通孔都是没有定义的,需要人为定义。如果端口过多,设置起来也比较麻烦。计算机正好处理这种重复的工作,因此可以用HFSS script实现。
在这里插入图片描述
在这里插入图片描述

2.代码实现

2.1 预定义

# ----------------------------------------------
# Script Recorded by ANSYS Electronics Desktop Version 2021.1.0
# created by wujunyu 2022/04/08
# ----------------------------------------------
# coding=<UTF-8>
import ScriptEnvScriptEnv.Initialize("Ansoft.ElectronicsDesktop")
oDesktop.RestoreWindow()
oProject = oDesktop.GetActiveProject()
oProject = oDesktop.SetActiveProject(oProject.GetName())
oDesign = oProject.SetActiveDesign("HFSS_0407_passive1")
oEditor = oDesign.SetActiveEditor("3D Modeler")objname = oEditor.GetObjectName(0)
object_num = oEditor.GetNumObjects()# all object name
object_list = []
# Matels and Vias name
Matels_Vias = [0, "\"Copper_M1\"", "\"Copper_M2\"", "\"Copper_M3\"", "\"Copper_M4\"", "\"Copper_M5\"", "\"Copper_M6\"","\"Copper_M7\"", "\"Copper_M8\"", "\"Copper_M9\"",0, "\"VIA1\"", "\"VIA2\"", "\"VIA3\"", "\"VIA4\"", "\"VIA5\"", "\"VIA6\"", "\"VIA7\"", "\"VIA8\""]
# heigth: for example: h[9] is the distance from M9 to M1
h = [0, 0.18*1e-6, 0.575*1e-6, 0.97*1e-6, 1.365*1e-6, 1.76*1e-6, 2.155*1e-6, 2.55*1e-6, 4.045*1e-6, 8.185*1e-6]object_Material_list = []
object_change_list = []
port_face_list = []
face_change_list = []
GND_M1 = []

需要修改的是这一行:
oDesign = oProject.SetActiveDesign(“HFSS_0407_passive1”)
如图,改成自己project下的文件名
在这里插入图片描述

2.2 获取HFSS object的名称并分类

# get object name from HFSS to object_list
for i in range(object_num):object_name = oEditor.GetObjectName(i)object_list.append(object_name)
# print(object_list)# Judge material from object_list
for i in range(object_num):object = object_list[i].split('_')object_front = object[0]if 'ObjectFromEdge' in object_list[i]:# lumped port lineif object_front == 'm1':port_face_list.append(1)face_change_list.append(object_list[i])elif object_front == 'm2':port_face_list.append(2)face_change_list.append(object_list[i])elif object_front == 'm3':port_face_list.append(3)face_change_list.append(object_list[i])elif object_front == 'm4':port_face_list.append(4)face_change_list.append(object_list[i])elif object_front == 'm5':port_face_list.append(5)face_change_list.append(object_list[i])elif object_front == 'm6':port_face_list.append(6)face_change_list.append(object_list[i])elif object_front == 'm7':port_face_list.append(7)face_change_list.append(object_list[i])elif object_front == 'm8':port_face_list.append(8)face_change_list.append(object_list[i])elif object_front == 'm9':port_face_list.append(9)face_change_list.append(object_list[i])else:# metal or viasif object_front == 'm1':object_Material_list.append(1)object_change_list.append(object_list[i])GND_M1.append(object_list[i])elif object_front == 'm2':object_Material_list.append(2)object_change_list.append(object_list[i])elif object_front == 'm3':object_Material_list.append(3)object_change_list.append(object_list[i])elif object_front == 'm4':object_Material_list.append(4)object_change_list.append(object_list[i])elif object_front == 'm5':object_Material_list.append(5)object_change_list.append(object_list[i])elif object_front == 'm6':object_Material_list.append(6)object_change_list.append(object_list[i])elif object_front == 'm7':object_Material_list.append(7)object_change_list.append(object_list[i])elif object_front == 'm8':object_Material_list.append(8)object_change_list.append(object_list[i])elif object_front == 'm9':object_Material_list.append(9)object_change_list.append(object_list[i])elif object_front == 'via1':object_Material_list.append(11)object_change_list.append(object_list[i])elif object_front == 'via2':object_Material_list.append(12)object_change_list.append(object_list[i])elif object_front == 'via3':object_Material_list.append(13)object_change_list.append(object_list[i])elif object_front == 'via4':object_Material_list.append(14)object_change_list.append(object_list[i])elif object_front == 'via5':object_Material_list.append(15)object_change_list.append(object_list[i])elif object_front == 'via6':object_Material_list.append(16)object_change_list.append(object_list[i])elif object_front == 'via7':object_Material_list.append(17)object_change_list.append(object_list[i])elif object_front == 'via8':object_Material_list.append(18)object_change_list.append(object_list[i])

2.3 改变金属属性

# change material
for i in range(len(object_change_list)):print(object_change_list[i], Matels_Vias[object_Material_list[i]])oEditor.ChangeProperty(["NAME:AllTabs",["NAME:Geometry3DAttributeTab",["NAME:PropServers",object_change_list[i]],["NAME:ChangedProps",["NAME:Material","Value:="		, Matels_Vias[object_Material_list[i]]]]]])print(object_change_list[i], Matels_Vias[object_Material_list[i]])

2.4 设置端口

# Add lumped port face
for i in range(len(port_face_list)):oEditor.SweepAlongVector(["NAME:Selections","Selections:="		, face_change_list[i],"NewPartsModelFlag:="	, "Model"],["NAME:VectorSweepParameters","DraftAngle:="		, "0deg","DraftType:="		, "Round","CheckFaceFaceIntersection:=", False,"SweepVectorX:="	, "0um","SweepVectorY:="	, "0um","SweepVectorZ:="	, -h[port_face_list[i]]])# Add lumped port by FaceID
# Unite M1 as GND
GND_M1_str = ','.join([str(i) for i in GND_M1])
print('"{}"'.format(GND_M1_str))
if len(GND_M1) != 1:oEditor.Unite(["NAME:Selections","Selections:="		, GND_M1_str],["NAME:UniteParameters","KeepOriginals:="	, False])
# Get faceID and  Add port
faceID = []
for i in range(len(face_change_list)):ID = oEditor.GetFaceIDs(face_change_list[i])faceID.append(ID[0])oModule = oDesign.GetModule("BoundarySetup")oModule.AutoIdentifyPorts(["NAME:Faces",faceID[i]], False,["NAME:ReferenceConductors",GND_M1[0]], "1", True)
print(faceID)oProject.Save()
# oProject.Close()

设置端口的方法为:
在HFSS按“E”,即选择端口所在的Edge,再在draw->Edge->create object from edge
设置完后,如图
在这里插入图片描述

3.使用步骤和结果展示

1.修改为自己的project下的文件的名称,保存文件
oDesign = oProject.SetActiveDesign(“HFSS_0407_passive1”)
2.在HFSS按“E”,即选择端口所在的Edge,再在draw->Edge->create object from edge
3.完成所有的端口选择后,在Automation->run script->选择脚本

可以看到自动分类定义好了属性,还设置了lumped port 端口
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这篇关于【HFSS】在CMOS工艺下自动修改金属属性和设置端口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

Python3 BeautifulSoup爬虫 POJ自动提交

POJ 提交代码采用Base64加密方式 import http.cookiejarimport loggingimport urllib.parseimport urllib.requestimport base64from bs4 import BeautifulSoupfrom submitcode import SubmitCodeclass SubmitPoj():de

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

uniapp设置微信小程序的交互反馈

链接:uni.showToast(OBJECT) | uni-app官网 (dcloud.net.cn) 设置操作成功的弹窗: title是我们弹窗提示的文字 showToast是我们在加载的时候进入就会弹出的提示。 2.设置失败的提示窗口和标签 icon:'error'是设置我们失败的logo 设置的文字上限是7个文字,如果需要设置的提示文字过长就需要设置icon并给

Tomcat性能参数设置

转自:http://blog.csdn.net/chinadeng/article/details/6591542 Tomcat性能参数设置 2010 - 12 - 27 Tomcat性能参数设置 博客分类: Java Linux Tomcat 网络应用 多线程 Socket 默认参数不适合生产环境使用,因此需要修改一些参数   1、修改启动时内存参数、并指定J

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d