luceda ipkiss教程 56:画多端口螺旋线

案例分享:画多端口螺旋线
:spiral的长度不是真实长度,具体可以参考教程28
在这里插入图片描述
代码如下:

from si_fab import all as pdk
import ipkiss3.all as i3
import numpy as np
from scipy.constants import piclass SpiralCircular(i3.PCell):core_width = i3.PositiveNumberProperty(doc="Core width of the bend waveguide", default=0.4)radius = i3.PositiveNumberProperty(doc="Radius of the central bends", default=5.0)spacing = i3.PositiveNumberProperty(doc="Separation between adjacent waveguides", default=2)spiral_length = i3.PositiveNumberProperty(doc="Length of the total spiral waveguide", default=1000.0)layout_properties = i3.NumpyArrayProperty(doc="Calculated layout properties of the spiral.", locked=True)def _default_layout_properties(self):r = self.radiustot_sep = self.spacing + self.core_widthn_o_loops_act = -(2.0 * r / tot_sep) + np.sqrt((2.0 * r / tot_sep) ** 2.0 - ((2.0 * r - self.spiral_length / pi) / tot_sep))n_o_loops = np.floor(n_o_loops_act)theta_nom = self.spiral_length - 2.0 * r * pi * (2.0 * n_o_loops + 1.0) - (n_o_loops ** 2.0) * tot_sep * pitheta_denom = 4.0 * r + (2.0 * n_o_loops + 1.0) * tot_septheta_m = theta_nom / theta_denomr_out = 2.0 * r + (n_o_loops + 0.5) * tot_sepdx0 = tot_sep * 0.5 * np.sin(theta_m)dy0 = r_out * (1.0 - np.cos(theta_m)) + (r_out - 0.5 * tot_sep) * np.cos(theta_m)return np.array([r, tot_sep, n_o_loops, theta_m, r_out, dx0, dy0])class Layout(i3.LayoutView):def _generate_elements(self, elems):for p in self.ports:elems += i3.Label(text=p.name,layer=i3.TECH.PPLAYER.DOC,coordinate=p.position,height=5.0,)return elemsdef _generate_instances(self, insts):r = self.layout_properties[0]tot_sep = self.layout_properties[1]n_o_loops = self.layout_properties[2]theta_m = self.layout_properties[3]r_out = self.layout_properties[4]dx0 = self.layout_properties[5]dy0 = self.layout_properties[6]# spiral waveguidefor index in range(int(n_o_loops + 1)):sign = 1.0 if index % 2 == 0 else -1.0if index == 0:radius1 = rdy1 = 0.0radius2 = rdy2 = 0.0radius3 = r - 0.8dy3 = 0.0 - 0.8radius4 = r + 0.8dy4 = 0.0 + 0.8else:radius1 = 2.0 * r + (2.0 * index - 1.0) * tot_sep * 0.5dy1 = 2.0 * r + (index - 1.0) * tot_sepradius2 = 2.0 * r + (2.0 * index - 1.0) * tot_sep * 0.5dy2 = 2.0 * r + (index - 1.0) * tot_sepradius3 = 2.0 * r + (2.0 * index - 1.0) * tot_sep * 0.5-0.8dy3 = 2.0 * r + (index - 1.0) * tot_sep-0.8radius4 = 2.0 * r + (2.0 * index - 1.0) * tot_sep * 0.5+0.8dy4 = 2.0 * r + (index - 1.0) * tot_sep+0.8shape_wg1 = [(0.0, -sign * dy1),(sign * radius1, -sign * dy1),(sign * radius1, -sign * (dy1 - radius1)),(sign * radius1, -sign * (dy1 - 2.0 * radius1)),(0.0, -sign * (dy1 - 2.0 * radius1)),]shape_wg2 = [(0.0, sign * dy2),(-sign * radius2, sign * dy2),(-sign * radius2, sign * (dy2 - radius2)),(-sign * radius2, sign * (dy2 - 2.0 * radius2)),(0.0, sign * (dy2 - 2.0 * radius2)),]shape_wg3 = [(0.0, -sign * dy3),(sign * radius3, -sign * dy3),(sign * radius3, -sign * (dy3 - radius3)),(sign * radius3, -sign * (dy3 - 2.0 * radius3)),(0.0, -sign * (dy3 - 2.0 * radius3)),]shape_wg4 = [(0.0, sign * dy4),(-sign * radius4, sign * dy4),(-sign * radius4, sign * (dy4 - radius4)),(-sign * radius4, sign * (dy4 - 2.0 * radius4)),(0.0, sign * (dy4 - 2.0 * radius4)),]wg1 = i3.RoundedWaveguide(trace_template=pdk.SWG450())wg2 = i3.RoundedWaveguide(trace_template=pdk.SWG450())wg3 = i3.RoundedWaveguide(trace_template=pdk.SWG450())wg4 = i3.RoundedWaveguide(trace_template=pdk.SWG450())wg1.Layout(bend_radius=radius1, shape=shape_wg1)wg2.Layout(bend_radius=radius2, shape=shape_wg2)wg3.Layout(bend_radius=radius3, shape=shape_wg3)wg4.Layout(bend_radius=radius4, shape=shape_wg4)insts += i3.SRef(wg1, flatten=True)insts += i3.SRef(wg2, flatten=True)insts += i3.SRef(wg3, flatten=True)insts += i3.SRef(wg4, flatten=True)return instsif __name__ == '__main__':SpiralCircular().Layout().visualize(legacy=True)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/637043.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux perf工具使用

参考文章Linux性能调优之perf使用方法_perf交叉编译-CSDN博客 perf是一款Linux性能分析工具。比如打流性能优化的时候,就能够看到是哪些函数消耗的cpu高 那么linux如何编译perf工具呢? perf工具编译 进入perf目录下linux-3.16/tools/perf make ARCH…

HarmonyOS 应用开发入门

HarmonyOS 应用开发入门 前言 DevEco Studio Release版本为:DevEco Studio 3.1.1。 Compile SDK Release版本为:3.1.0(API 9)。 构建方式为 HVigor,而非 Gradle。 最新版本已不再支持 (”Java、JavaScrip…

React16源码: React中的updateHostRoot的源码实现

HostRoot 的更新 1 )概述 HostRoot 是一个比较特殊的节点, 因为在一个react应用当中它只会有一个 HostRoot, 它对应的 Fiber 对象是我们的 RootFiber 对象重点在于它的更新过程 2 )源码 定位到 packages/react-reconciler/src/ReactFiberBeginWork.js…

【Qt】信号和槽

需要云服务器等云产品来学习Linux的同学可以移步/-->腾讯云<--/-->阿里云<--/-->华为云<--/官网&#xff0c;轻量型云服务器低至112元/年&#xff0c;新用户首次下单享超低折扣。 目录 一、Qt中的信号和槽 1、信号 2、槽 3、Q_OBJECT 二、Qt中的connect函…

Windows下 VS2022 编译OpenSSL 库

SSL是Secure Sockets Layer(安全套接层协议)的缩写,可以在Internet上提供秘密性传输。Netscape公司在推出第一个Web浏览器的同时,提出了SSL协议标准。其目标是保证两个应用间通信的保密性和可靠性,可在服务器端和用户端同时实现支持。已经成为Internet上保密通讯的工业标准…

k3s x GitLab Runner Operator,GitLab CI 云原生构建新体验

GitLab CI 是非常常用的一款 CI/CD 工具&#xff0c;只需要在 .gitlab-ci.yml 文件中用 YAML 语法编写 CI/CD 流水线即可。而 GitLab CI 能够运行的关键组件是 GitLab Runner。GitLab Runner 是一个轻量级、高扩展的代理&#xff0c;主要用来执行 GitLab CI/CD 流水线中的 Job&…

stm32 FOC系列 直流有刷控制原理

1、直流有刷驱动板 使用三极管搭建的简易 H 桥电路&#xff0c;如图 5.3.1 所示&#xff1a; 图 5.3.1 是使用三极管搭建的简易 H 桥电路&#xff0c;其中 MOTOR 表示直流有刷电机&#xff0c; Q1、 Q2、 Q3 和 Q4 为 4 个三极管&#xff0c;其中 Q1 和 Q3 接在了电源正极&…

[AutoSar]BSW_OS 08 Autosar OS_内存保护

一、 目录 一、关键词平台说明一、内存保护的概念 关键词 嵌入式、C语言、autosar、OS、BSW 平台说明 项目ValueOSautosar OSautosar厂商vector &#xff0c;芯片厂商TI 英飞凌编程语言C&#xff0c;C编译器HighTec (GCC) >>>>>回到总目录<<<<&l…

matlab appdesigner系列-常用13-标签

标签&#xff0c;用来显示各类文本 此示例&#xff0c;就是在标签之外的画布上单击鼠标左键&#xff0c;显示王勃的《滕王阁诗》 操作如下&#xff1a; 1&#xff09;将2个标签拖拽到画布上&#xff0c;并修改相应文字。将第二个标签的右侧文本信息中的Wordwrap打开&#xf…

【C++】文件操作

文件操作 一、文本文件&#xff08;一&#xff09;写文件读文件 二、二进制文件&#xff08;一&#xff09;写文件&#xff08;二&#xff09;读文件 程序运行时产生的数据都属于临时数据&#xff0c;程序一旦运行结束都会被释放&#xff0c;通过文件可以将数据持久化&#xff…

记录一下uniapp 集成腾讯im特别卡(未解决)

uniapp的项目运行在微信小程序 , 安卓 , ios手机三端 , 之前这个项目集成过im,不过版本太老了,0.x的版本, 现在需要添加客服功能,所以就升级了 由于是二开 , 也为了方便 , 沿用之前的webview嵌套腾讯IM的方案 , 选用uniapp集成ui ,升级之后所有安卓用户反馈点击进去特别卡,几…

基于 OpenVINO, yolov5 推理

OpenVINO 是英特尔开发的一款功能强大的深度学习工具包&#xff0c;可实现跨多个硬件平台的优化神经网络推理。在本文中&#xff0c;我们讨论了 OpenVINO 的特性和优势&#xff0c;以及它如何与领先的计算机视觉平台 Viso Suite 集成&#xff0c;以构建和交付可扩展的应用程序。…

Mysql数据库cpu飙升怎么解决

排查过程 &#xff08;1&#xff09;使用top命令观察&#xff0c;确定是mysql导致还是其他原因。 &#xff08;2&#xff09;如果是mysql导致的&#xff0c;show processlist&#xff0c;查看session情况&#xff0c;确定是不是有消耗资源的sql在运行。 &#xff08;3&#xf…

【OSG案例详细分析与讲解】之十四:【立方体贴图】

文章目录 一、【立方体贴图】前言二、【立方体贴图】实现效果三、【立方体贴图】创建立方体贴图1、实现目标2、实现步骤3、核心代码4、知识要点5、TextureCubeMap详讲6、osg::TexGen详讲7、TexEnvCombine详讲四、【立方体贴图】程序1、程序代码2、qt pro文件五、【立方体贴图】…

李沐深度学习-激活函数/多层感知机文档

multilayer perceptron (MLP)&#xff1a;多层感知机(多层神经网络) (hidden layer)隐藏层&#xff1a; 介于输入层和输出层之间的网络层 输入层不涉及计算&#xff0c;如果一个神将网络由三层组成&#xff0c;则多层感知机层数为2 多层感知机中隐藏层和输出层都是全连接 隐藏…

如何快速打开github

作为一个资深码农&#xff0c;怎么能不熟悉全球最大的同性交友社区——github呢&#xff0c;但头疼的是github有时能打开&#xff0c;有时打不开&#xff0c;这是怎么回事&#xff1f; 其实问题出在github.com解析DNS上&#xff0c;并不是需要FQ。下面提供一个方法&#xff0c;…

hot100:07接雨水

题目链接&#xff1a; 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 算法思想&#xff1a; 这里采取的是暴力解法和双指针的解法&#xff0c;但是这个题目还有其他的两种解法&#xff08;单调栈和动态规划&#xff0c;同学可以自行了解&#xff…

Golang 中高级工程师学习笔记

闭包的作用 闭包&#xff08;Closure&#xff09;是一种函数值&#xff0c;它可以引用在其外部定义的变量。闭包允许这些变量保持在函数内部&#xff0c;而不是被每次调用时重新创建。闭包的作用主要体现在以下几个方面 封装&#xff1a; 闭包允许函数访问其外部作用域中的变…

vue3前端开发,子组件向父组件传递数据练习

vue3前端开发,子组件向父组件传递数据练习&#xff01; <script setup> import Child from ./Child.vue const getMsg (msg)>{console.log(msg); } </script> <template><h3>Parent</h3><!--绑定事件--><Child get-Msg"getM…

K8S-容器运行时(v1.27)

容器运行时 说明&#xff1a; 自 1.24 版起&#xff0c;Dockershim 已从 Kubernetes 项目中移除。阅读 Dockershim 移除的常见问题了解更多详情。 你需要在集群内每个节点上安装一个 容器运行时 以使 Pod 可以运行在上面。本文概述了所涉及的内容并描述了与节点设置相关的任务…