在教程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中的参数大家可以自己调节试试。