Reusing cells in circuits
In this section we explain how to build a new cell in L-Edit, that can be reused in user designs.
We will go through the following steps:
Create a new design MZI in the filters_ledit library
Instantiate a splitter and a combiner
Draw waveguides between the splitter and combiner
Propagate the unconnected ports (the input of the splitter, the output of the combiner)
Create a new design test_design_mzi
Instantiate several MZI components and grating couplers, draw waveguide routes
Finish by generating the waveguides
The crucial step here is step 4: this ensures that the unconnected ports are recognized in step 6. If you are routing waveguides, there always has to be a port defined.
Create the MZI design
Create a new design MZI
Instantiate a splitter and a combiner
We start by creating an MZI cell in the filters_ledit library (see figures below).
data:image/s3,"s3://crabby-images/45e77/45e77d514c2669a89b84cace16cf9f022107f075" alt="Create a new cell called `MZI`. We create it in the `filters_ledit` library."
In the filters_ledit
library, create a new cell called MZI.
data:image/s3,"s3://crabby-images/0e58b/0e58b917da3a114ef183c5ba443529bdd9930088" alt="Instantiate a splitter (one for splitting, one for combining)."
Instantiate a splitter (one for splitting, one for combining).
data:image/s3,"s3://crabby-images/768e3/768e30a2b5028fe23b668a5f5e051580ccc94770" alt="Place, align and mirror the components."
Place, align and mirror the components.
data:image/s3,"s3://crabby-images/2d680/2d6803b5b39a5606ed5df664e55914575c78124f" alt="Rename the first splitter to `splitter`, rename the second to `combiner`."
Rename the first splitter to splitter, rename the second to combiner.
We generate the waveguide control shapes, and generate the waveguides, as shown in Figure Generate the waveguides and Figure Propagate the ports.
Draw waveguides between the splitter and the combiner
data:image/s3,"s3://crabby-images/b17dc/b17dcf48f27864b3f79f169790aa4346c18c44f8" alt="Draw the waveguide control shapes on the SI:TRC layer."
Draw the waveguide control shapes on the SI:TRC layer.
data:image/s3,"s3://crabby-images/ce81f/ce81f00a034f8d7c73d91d742123b69d89a9c665" alt="Generate the waveguides (from menu bar, :menuselection:`Luceda --> Waveguides --> Generate all waveguides`)"
Generate the waveguides (from menu bar, )
To finalize our component, we need to ensure the unconnected ports are duplicated in the top-level design. That way, we will be able to use these ports in other designs as well. To do so, we use the Propagate pins function from the Luceda menu.
Propagate the unconnected ports
data:image/s3,"s3://crabby-images/75791/75791f7eb73c13f6f76b91352dd012bb4a20e243" alt="Propagate the ports (from menu bar, :menuselection:`Luceda --> Connection --> Propagate pins`)."
Propagate the ports (from menu bar, ).
Create the test design
Create a new design test_design_mzi
Instantiate several MZI components and grating couplers, draw waveguide routes
We now create a test design, in which we cascade three MZI components. We then connect the MZIs themselves, and connect the two of them to fiber couplers (Figure Cascaded MZI components).
data:image/s3,"s3://crabby-images/27324/27324caa7fb5b413fbe600de63211083ff835b80" alt="Create a design `test_design_mzi`, place three cascaded MZI components, two fiber grating couplers and draw the connecting wires."
Create a design test_design_mzi, place three cascaded MZI components, two fiber grating couplers and draw the connecting wires.
The final result is shown below (Figure Final design).
Finish by generating the waveguides
data:image/s3,"s3://crabby-images/cf5af/cf5af71aeab3b3624a5483f6bd9e93f5d0e156c8" alt="Finished design after generating the waveguides."
Finished design after generating the waveguides.
Conclusion
In this short tutorial you learned how to create a cell in L-Edit, which can be reused in other designs. This method is very powerful because it allows cell reuse and allows to manage design complexity by splitting your design in smaller chunks that are easier to understand. Note that in this case, the created MZI is a fixed cell. If you want to make parametric cells, we suggest to have a look at IPKISS PCells.