【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

相关文章

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Python如何调用另一个类的方法和属性

《Python如何调用另一个类的方法和属性》在Python面向对象编程中,类与类之间的交互是非常常见的场景,本文将详细介绍在Python中一个类如何调用另一个类的方法和属性,大家可以根据需要进行选择... 目录一、前言二、基本调用方式通过实例化调用通过类继承调用三、高级调用方式通过组合方式调用通过类方法/静

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录