【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

相关文章

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

HTML5中下拉框<select>标签的属性和样式详解

《HTML5中下拉框<select>标签的属性和样式详解》在HTML5中,下拉框(select标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中选择值的方式,本文将深入探讨select标签的... 在html5中,下拉框(<select>标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

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

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

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re