luceda ipkiss教程 19:修复线路中的锐角

文章介绍了一个利用i3.get_stub_elements函数修复电路版图中锐角的方法。通过创建特定的Circuit类和Layout,结合SiWireWaveguideTemplate,定义了线路连接和端口。在demo2中,应用get_stub_elements来识别和添加元素以消除锐角,同时调整参数以优化修复过程。此外,讨论了设置识别图层对提高修复效率的影响。
摘要由CSDN通过智能技术生成

在教程10中介绍了利用i3.get_stub_elements函数来识别和修复版图中的锐角,这次以一个实际的线路来教大家如何去修复线路中的锐角
在这里插入图片描述
所有代码如下:

from si_fab import all as pdk
from ipkiss3 import all as i3


class demo1(i3.Circuit):
    trace_template = i3.TraceTemplateProperty(doc="Trace template of the access waveguide")

    def _default_trace_template(self):
        tre = pdk.SiWireWaveguideTemplate()
        tre.Layout(cladding_width=5, cladding_layer=i3.TECH.PPLAYER.SI_CLADDING)
        return tre

    def _default_specs(self):
        opt1 = i3.OpticalPort(name="opt1", position=(0, 0), angle=0, trace_template=self.trace_template)
        opt2 = i3.OpticalPort(name="opt2", position=(40, 20), angle=180, trace_template=self.trace_template)
        opt3 = i3.OpticalPort(name="opt3", position=(0, 20), angle=0, trace_template=self.trace_template)
        opt4 = i3.OpticalPort(name="opt4", position=(40, 40), angle=180, trace_template=self.trace_template)
        specs = [
            i3.ConnectManhattan(opt1, opt2, bend_radius=5, control_points=[i3.V(20)]),
            i3.ConnectManhattan(opt3, opt4, bend_radius=5, control_points=[i3.V(20)]),
        ]
        return specs


class demo2(demo1):
    class Layout(i3.Circuit.Layout):
        def _generate_elements(self, elems):
            lay = demo1().Layout()
            elems += super()._generate_elements(elems)
            elems_add, elems_subt = i3.get_stub_elements(lay, layers=[i3.TECH.PPLAYER.SI_CLADDING],
                                                         stub_width=2, angle_threshold=0.5, grow_amount=2,
                                                         limit_stub_length=False)
            elems += elems_add
            return elems


if __name__ == '__main__':
    my_circuit = demo2().Layout()
    my_circuit.visualize()
    my_circuit.write_gdsii("demo.gds")

demo1是产生锐角的线路,demo2继承demo1,并在demo1的基础上加了elements:elems_add
elems_add就是用来修复锐角的三角形,

 elems_add, elems_subt = i3.get_stub_elements(lay, layers=[i3.TECH.PPLAYER.SHALLOW],
                        stub_width=2,angle_threshold=0.5, grow_amount=2, limit_stub_length=False)

在利用i3.get_stub_elements识别和修复锐角时,可以设置需要识别的图层,当然不设置也可以,对于大型的线路,设置需要识别的图层,修复速度会快很多,i3.get_stub_elements中的参数大家可以自己调节试试。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值