# Schematic Driven Silicon Photonics Design (Invited)

Lukas Chrostowski<sup>a</sup>, Zeqin Lu<sup>a</sup>, Jonas Flueckiger<sup>a</sup>, James Pond<sup>b</sup>, Jackson Klein<sup>b</sup>, Xu Wang<sup>b</sup>, Sarah Li<sup>a</sup>, Wei Tai <sup>a</sup>, En Yao Hsu<sup>a</sup>, Chan Kim<sup>a</sup>, John Ferguson<sup>c</sup>, Chris Cone<sup>c</sup>

<sup>a</sup>Department of Electrical and Computer Engineering,
 University of British Columbia, Vancouver, British Columbia, Canada
 <sup>b</sup>Lumerical Solutions Inc., Vancouver, British Columbia, Canada
 <sup>c</sup>Mentor Graphics Corporation, Portland, Oregon, USA

# **ABSTRACT**

Electronic circuit designers commonly start their design process with a schematic, namely an abstract representation of the physical circuit. In integrated photonics on the other hand, it is very common for the design to begin at the physical component level. In order to build large integrated photonic systems, it is crucial to design using a schematic-driven approach. This includes simulations based on schematics, schematic-driven layout, layout versus schematic verification, and post-layout simulations. This paper describes such a design framework implemented using Mentor Graphics and Lumerical Solutions design tools. In addition, we describe challenges in silicon photonics related to manufacturing, and how these can taken into account in simulations and how these impact circuit performance.

**Keywords:** silicon photonics design, photonic integrated circuits design, design methodologies, electronic design automation (EDA), manufacturing variability, corner analysis

# 1. INTRODUCTION

In electronic circuit design, the complexity and scale of designs necessitated multi-user collaboration. Namely, a team of designers with different roles, such concept and system architect, simulation expert, and layout designer, is required to implement a chip design. In addition, there is another team, associated with the foundry that fabricates the designs, that includes device designers and process design kit developers. The typical electronic design process begins with a schematic, namely an abstract representation of the circuit. This requires that the foundry provides device models and layouts, embedded in a "Process Design Kit" (PDK) that can be used by circuit designers for their circuit simulations and to create their layout. This partitioning of tasks is illustrated in Figure 1.

In integrated photonics design on the other hand, it is often one person who is responsible for all stages of the design. Furthermore, the design process is usually "bottom-up", where the design begins with the physical components, and gradually builds up into a system. In order to build large integrated photonic systems, it is crucial to 1) have a design methodology that allows for teams of designers with various roles to collaborate, and 2) have a capability that includes abstract representations (e.g., schematics) with a link to the physical implementation (layout).

The proposed methodology is based on the electronic IC ecosystem. This includes simulations based on schematics, schematic-driven layout, layout versus schematic verification, and post-layout simulations. We have implemented a design framework using Mentor Graphics and Lumerical Solutions design tools that implements the above requirements, as described Refs. 1, 2.



Figure 1: The partitioning of tasks between the foundry and the circuit designer.

This paper expands upon the design methodology described previously by adding:

- 1. Post-layout simulations
- 2. A choice in design style Schematic-Driven Design versus Layout-Driven Design
- 3. Manufacturing variability simulations (Monte Carlo)

In particular, this paper emphasizes the importance of post-layout simulations. We describe challenges in silicon photonics related to manufacturing, how manufacturing variability can be taken into account in post-layout simulations, and how these simulations can predict the impact of variability on circuit performance.

## 2. SCHEMATIC-DRIVEN DESIGN

First, we review the schematic-driven design approach described in Refs. 1,2. This design flow is aimed at highly-complex silicon photonic circuits, analogous to how they are designed in the electronics industry. Here, the design flow starts with an abstract representation, i.e., a circuit schematic. We begin with symbols for the components, place them on a schematic, and connect them. This allows us immediately simulate the circuit by providing the desired stimulus. Behind the scenes, there are component models. The designer does not need to develop them, since they are provided in the design kit. Advanced PDKs will include active optical components, and electronics.

In this flow, the layout is created on the basis of the schematic. The software aids the designer in creating the layout by reading the schematic as the layout is generated; specifically component placement can be inferred from the schematic, and the connectivity between components is maintained to aid in the routing.

The verification step involves two parts: 1) manufacturing verification (minimum features size, etc), known as Design Rule Check (DRC), and 2) functional verification, known as Layout Versus Schematic (LVS). The latter is critical for large circuits. Since we have a schematic and a layout, we have the opportunity to compare them. The LVS tool uses a set of rules to recognize the components and their connectivity in the layout, known as netlist extraction, and then compares the components and connectivity with the original schematic. This verification step can identify incorrect connectivity, such as disconnected wires and waveguides, and component errors such as incorrect components or incorrect parameters.

Once the layout of the circuit is deemed to be correct, the LVS tool can extract the parameters from the layout and update the schematic. For photonics, the lengths of your waveguides, as drawn, is often critical in determining the performance. For example, the lengths of the waveguides in an interferometer need to be calculated so that we can obtain an accurate estimation and simulation of the free spectral range (FSR). After the schematic is updated, the designer can re-simulate the circuit to verify that it operates as expected once the details (such as waveguide length in photonics, or parasitics in electronics) are included.

In contrast to the traditional photonics design approach, this design flow has a much more well established design kit, and enables rapid design of complex circuits, without having to spend time on modelling individual components. This type of design has been critical to the success of the electronics industry where circuits have thousands to billions of components.

An evolution that is expected for integrated photonics design is that we are moving towards a methodology similar to CMOS design leading to a distinct skill sets. For example, circuit designers will need to know the minimum of information about how a directional coupler works, but will not need to design them. For example, the main knowledge required is that it's function is similar to a beam splitter. However, the circuit designer will be highly attune to the performance criteria of the splitter (e.g., wavelength dependance of the splitting ratio, insertion loss, power splitting balance, sensitivity to manufacturing variations) and how these impact the circuit performance (e.g., extinction ratio, crosstalk). This enables the circuit designer to focus on design at a higher level, including system implementation.

# 2.1 Post-Layout Simulation

Post-layout simulation refers to circuit simulations that are performed after the layout is created. In the schematic-driven design flow, this involves extracting parameters from the layout, and updating the schematic. However, this is another use case for post-layout simulations. Namely, we desire the capability to simulate directly from a layout without requiring a schematic (e.g., created by a different designer, created using different software, and in general if the schematic is not available).

In this case, the LVS tool can be used to create a netlist representation of the circuit. This is in fact easier to perform than the layout versus schematic operation described above, as it only requires the netlist extraction step. The requirement for this functionality is that each component is supported by the library / PDK. This is necessary so that the LVS tool can recognize the devices correctly, and label them with the appropriate component model. Typically, the components have added marking layers that identify the components, perhaps their names, where the input / output ports are, and provide port names.

After the layout extraction done, the circuit simulator tool is used as before to perform simulations, based on the netlist.

#### 3. LAYOUT-DRIVEN DESIGN

The capabilities developed for post-layout simulation allow us to consider another design methodology, namely layout-driven design. This second approach begins with the layout, as shown in Figure 2. First the designer creates a layout, then simulates it directly from the layout. The simulation is performed by two steps: a) netlist extraction and b) circuit simulations.

This approach may be appealing to traditional photonics designers who have independent design stages: device modelling, circuit design, and layout. In this traditional flow, there is no communication between these stages, hence verification and post-layout simulation is challenging. In the case of separate tools, the need for schematics may not even be obvious or required. For these designers, the benefit of including post-layout simulations in the layout-driven design flow is that accurate simulations can be generated based on the design. An inspection of the simulation results, and comparison with expectations, is an excellent verification step.

Another advantage of the layout-first approach is that it provides insight into what is physically realistic, prior to doing abstract circuit design in a schematic. For example, creating a layout first gives the designer insight into how large the library components are, how long the waveguides will need to be, how far apart the components will need to be, how many waveguide crossings will be required, etc.

Another design option is to create a draft layout with arbitrary component parameters and use the post-layout simulation functionality to create the files necessary circuit modelling. Once the project is setup with all components and stimulus found in the layout, the designer can proceed to optimize the design within the circuit modelling tool. For example, in a WDM ring modulator transceiver, the choice in ring resonator parameters can be performed in the circuit modelling tool, using the realistic simulation environment created from the layout extraction tool. In such a design flow, it is also important to have the capability for the component parameters to be synchronized between the circuit simulation and the physical layout.

Clearly, there are several design flows that are enabled by the capability of extracting the netlist from the physical layout. The layout-driven design approach is likely to be attractive for small circuit designs.

Both of these design flows (schematic-driven and layout-driven) require that there is a connection between the layout and the schematic, and in both directions. Both need a library of components, containing component models, component layouts, and component layout recognition rules (called an LVS rule deck). The biggest challenge for the designer is to obtain access to all the necessary pieces, namely to have access to a state-of-the art PDK similar to those available in the electronics industry.

# 4. LAYOUT EXTRACTION

In this section, we provide further details on the layout extraction and netlist generation procedure. As discussed above, extracting the netlist from the layout is important for two reasons: 1) to verify the layout, with respect to the abstract (schematic) representation, 2) to simulate the as-drawn layout, which will include the precise waveguide lengths and



Figure 2: Design methodology based either on 1) Schematic-Driven Design, or 2) Layout-Driven Design.

component position information. The post-layout simulation is an important verification step to ensure that no errors were introduced during the layout (e.g., disconnected waveguides leading to back-reflections).

In this section, we describe an example layout – a Mach-Zehnder Interferometer circuit as shown in Figure 3. It consists of two fibre grating couplers, two broad-band splitters<sup>3</sup>, and numerous waveguides and waveguide bends. The netlist is extracted from the layout, either using Mentor Graphics Calibre Layout Versus Schematic (LVS), or using the open-source KLayout<sup>4</sup> tool with the SiEPIC-EBeam-PDK add-on<sup>5</sup>. The extracted netlist is shown in Listing 1. Although this is a simple circuit, the listing is quite long and involves 18 components. Each component includes the following information:

- The nets to which each component pin is connected to (e.g., N\$2)
- The library which contains the component's compact model to be used for simulations (e.g., "Design kits/ebeam\_v1.2")
- The component position in the layout (lay\_x, lay\_y)
- Optionally, a position for the component to be used in drawing the schematic (sch\_x, sch\_y)
- Component parameters, for components that are parameterized. For the waveguides, the parameters are the waveguide width and length. For bends, the parameters are the radius and the waveguide width.

In the above circuit, the waveguide is broken up into straight sections and waveguide bends. The advantage of separately listing these components is that it allows the circuit simulation to be as detailed as possible. For example, the circuit simulation can include:

- An accurate model for the waveguide bend, including the insertion loss, the optical phase through the device, and the reflections from the mode-mismatch from the straight-to-bend region.
- Position information for all these components can be used for thermal modelling and for Monte Carlo simulations, as described below.

Such an approach is particularly useful if the designer has a choice of waveguide bend radius, and the impact of the bends is not known a priori. A simulation with that includes numerous waveguide bends with a too-small bend radius would predict the Fabry-Perot cavities introduced by the small reflections at all interfaces.



Figure 3: Example layout of a Mach-Zehnder Interferometer circuit.

However, in many cases, the bend has already been optimized, analyzed and chosen so that it has little impact on the circuit performance. In that case, precise knowledge of the bend location is not necessary to include in the circuit model, nor is the bend itself. An alternative representation of the above circuit is one where the waveguides and bends are merged into a single waveguide object. This approach reduces the size of the netlist, and improves on the performance of the circuit simulations. One modification is made to the waveguide object as follows:

- The waveguide length includes the straight sections, and the waveguide bends. The length of the waveguide bends is taken as  $L = \pi r/2$ , where r is the radius taken at the centre of the waveguide.
- The waveguide has an additional parameter, namely a vector of points, e.g., points="((-59050, 5000), (-45690, 5000), (-45690, -117300), (-59050, -117300))" [units of nanometers]. These are used in the Monte Carlo analysis described below.

```
.subckt MZI circuit N$0 N$1
 ebeam bdc te1550 0 N$2 N$3 N$4 N$5 ebeam bdc te1550 library="Design kits/ebeam v1.2" lav x=-94.35E-6
           lay_y=7.35E-6 sch_x=-4.7175E0 sch_y=367.5E-3
 ebeam_gc_te1550_1 N$0 N$6 ebeam_gc_te1550 library="Design kits/ebeam_v1.2" lay_x=-149.8E-6 lay_y=-117.3E-6
           sch_x=-7.49E0 sch_y=-5.865E0
 ebeam_gc_te1550_2 N$1 N$7 ebeam_gc_te1550 library="Design kits/ebeam_v1.2" lay_x=-149.8E-6 lay_y=9.7E-6
           sch_x=-7.49E0 sch_y=485.0E-3
 ebeam_bdc_te1550_3 N$8 N$9 N$10 N$11 ebeam_bdc_te1550 library="Design kits/ebeam_v1.2" lay_x=-94.35E-6
           lay_y=-119.65E-6 sch_x=-4.7175E0 sch_y=-5.9825E0
 lay_y=5.0E-6 sch_x=-6.49E0 sch_y=250.0E-3
 ebeam_terminator_te1550_5 N$9 ebeam_terminator_te1550 library="Design kits/ebeam_v1.2" lay_x=-129.8E-6
           lay_y=-122.0E-6 sch_x=-6.49E0 sch_y=-6.1E0
 {\tt ebeam\_bend\_1550\_6~N\$12~N\$13~ebeam\_bend\_1550~library="Design~kits/ebeam\_v1.2"~radius=5.000u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.500u~wg\_width=0.5000u~wg\_width=0.5000u~wg\_width=0.5000u~wg\_width=0.5000u~wg\_width=0.5000u~wg\_width=0.5000u~wg\_width
           lay_x=-45.69E-6 lay_y=5.0E-6 sch_x=-2.2845E0 sch_y=250.0E-3 sch_r=180 sch_f=true
 ebeam_bend_1550_7 N$14 N$15 ebeam_bend_1550 library="Design kits/ebeam_v1.2" radius=5.000u wg_width=0.500u
           \texttt{lay\_x} = -45.69 \\ \texttt{E} - 6 \ \texttt{lay\_y} = -117.3 \\ \texttt{E} - 6 \ \texttt{sch\_x} = -2.2845 \\ \texttt{E} 0 \ \texttt{sch\_y} = -5.865 \\ \texttt{E} 0 \ \texttt{sch\_r} = 270
 {\tt ebeam\_wg\_integral\_1550\_8~N\$13~N\$14~ebeam\_wg\_integral\_1550~library="Design~kits/ebeam\_v1.2"~wg\_width=0.500u}
           wg_length=112.300u lay_x=-45.69E-6 lay_y=-56.15E-6 sch_x=-2.2845E0 sch_y=-2.8075E0 sch_r=90
 ebeam_wg_integral_1550_9 N$5 N$12 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
           wg_length=8.360u lay_x=-54.87E-6 lay_y=5.0E-6 sch_x=-2.7435E0 sch_y=250.0E-3
  ebeam_wg_integral_1550_10 N$15 N$10 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
           wg_length=8.360u lay_x=-54.87E-6 lay_y=-117.3E-6 sch_x=-2.7435E0 sch_y=-5.865E0 sch_r=180
  ebeam_bend_1550_11 N$16 N$17 ebeam_bend_1550 library="Design kits/ebeam_v1.2" radius=5.000u wg_width=0.500u
           lay_x=-41.34E-6 lay_y=-122.0E-6 sch_x=-2.067E0 sch_y=-6.1E0
```

```
ebeam_bend_1550_12 N$18 N$19 ebeam_bend_1550 library="Design kits/ebeam_v1.2" radius=5.000u wg_width=0.500u
              lay_x=-41.34E-6 lay_y=9.7E-6 sch_x=-2.067E0 sch_y=485.0E-3 sch_r=270
   ebeam_wg_integral_1550_13 N$17 N$18 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
              wg_length=121.700u lay_x=-41.34E-6 lay_y=-56.15E-6 sch_x=-2.067E0 sch_y=-2.8075E0 sch_r=270
   \verb|ebeam_wg_integral_1550_14 N\$11 N\$16 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u library="Design kits/ebeam_v1.2" wg_width=0.5000 library="Design kits/eb
              wg\_length=12.710u \ lay\_x=-52.695E-6 \ lay\_y=-122.0E-6 \ sch\_x=-2.63475E0 \ sch\_y=-6.1E0
   ebeam_wg_integral_1550_15 N$19 N$4 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
              wg_length=12.710u lay_x=-52.695E-6 lay_y=9.7E-6 sch_x=-2.63475E0 sch_y=485.0E-3 sch_r=180
   ebeam_wg_integral_1550_16 N$7 N$2 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
              wg_length=20.000u lay_x=-139.8E-6 lay_y=9.7E-6 sch_x=-6.99E0 sch_y=485.0E-3
   ebeam_wg_integral_1550_17 N$6 N$8 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_width=0.500u
              wg_length=20.000u lay_x=-139.8E-6 lay_y=-117.3E-6 sch_x=-6.99E0 sch_y=-5.865E0
.ends {\tt MZI\_circuit}
* Optical Network Analyzer:
.ona input_unit=wavelength input_parameter=start_and_stop
   + minimum_loss=50
   + analysis_type=scattering_data
   + multithreading=user\_defined number\_of\_threads=1
   + start=1500.000e-9
   + stop=1600.000e-9
   + number_of_points=2000
   + input(1)=MZI_circuit,N$0
   + output=MZI_circuit,N$1
MZI_circuit N$0 N$1 MZI_circuit sch_x=-1 sch_y=-1
```

Listing 1: Netlist, in SPICE format, for a Mach-Zehnder Interferometer circuit. This netlist includes all bends as separate components.

```
.subckt MZI_circuit N$0 N$1
 ebeam_bdc_te1550_0 N$2 N$3 N$4 N$5 ebeam_bdc_te1550 library="Design kits/ebeam_v1.2" lay_x=-94.35E-6
      lay_y=7.35E-6 sch_x=-4.7175E0 sch_y=367.5E-3
 ebeam_gc_te1550_1 N$0 N$6 ebeam_gc_te1550 library="Design kits/ebeam_v1.2" lay_x=-149.8E-6 lay_y=-117.3E-6
      sch_x=-7.49E0 sch_y=-5.865E0
 ebeam_gc_te1550_2 N$1 N$7 ebeam_gc_te1550 library="Design kits/ebeam_v1.2" lay_x=-149.8E-6 lay_y=9.7E-6
      sch_x=-7.49E0 sch_y=485.0E-3
 ebeam_bdc_te1550_3 N$8 N$9 N$10 N$11 ebeam_bdc_te1550 library="Design kits/ebeam_v1.2" lay_x=-94.35E-6
      lay_y=-119.65E-6 sch_x=-4.7175E0 sch_y=-5.9825E0
 ebeam_terminator_te1550_4 N$3 ebeam_terminator_te1550 library="Design kits/ebeam_v1.2" lay_x=-129.8E-6
      lay_y=5.0E-6 sch_x=-6.49E0 sch_y=250.0E-3
 ebeam_terminator_te1550_5 N$9 ebeam_terminator_te1550 library="Design kits/ebeam_v1.2" lay_x=-129.8E-6
      lay_y=-122.0E-6 sch_x=-6.49E0 sch_y=-6.1E0
 wg0 N$5 N$10 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_length=144.727E-6 wg_width=500.0E-9
      sch_x=-2.6185E0 sch_y=-2.8075E0 points="((-59050, 5000), (-45690, 5000), (-45690, -117300), (-59050,
       -117300))
 wg1 N$11 N$4 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_length=162.827E-6 wg_width=500.0E-9
      sch_x=-2.50975E0 sch_y=-2.8075E0 points="((-59050, -122000), (-41340, -122000), (-41340, 9700), (-59050,
      9700))"
 wq2 N$7 N$2 ebeam_wq_integral_1550 library="Design kits/ebeam_v1.2" wq_length=20.0E-6 wq_width=500.0E-9
      sch_x=-6.99E0 sch_y=485.0E-3 points="((-149800, 9700), (-139800, 9700), (-139800, 9700), (-129800, 9700))"
 wg3 N$6 N$8 ebeam_wg_integral_1550 library="Design kits/ebeam_v1.2" wg_length=20.0E-6 wg_width=500.0E-9
      sch_x=-6.99125E0 sch_y=-5.865E0 points="((-149800, -117300), (-139850, -117300), (-139850, -117300),
      (-129800, -117300))
.ends MZI circuit
* Optical Network Analyzer:
.ona input_unit=wavelength input_parameter=start_and_stop
 + minimum loss=50
 + analysis_type=scattering_data
 + multithreading=user\_defined number\_of\_threads=1
 + start=1500.000e-9
 + stop=1600.000e-9
 + number_of_points=2000
 + input(1)=MZI circuit, N$0
 + output=MZI circuit, N$1
MZI_circuit N$0 N$1 MZI_circuit sch_x=-1 sch_y=-1
```

Listing 2: Netlist, in SPICE format, for a Mach-Zehnder Interferometer circuit. This is a simplified netlist where the waveguides and bends are grouped into a single waveguide object.





(b) Zoom of the Bragg cavity, showing a portion of the Bragg grating and the taper.



(c) Circuit simulation of the Bragg grating test structure. Figure 4: Layout and simulations of a Bragg grating cavity.

5. CIRCUIT SIMULATIONS

We previously described how to perform circuit simulations of photonic circuits using compact models created from S-parameters <sup>1,2</sup>. This is a powerful technique since it allows any passive device to be represented, without having to establish expressions that describe the behaviour of the component. Efficient circuit simulations can be by achieved by using S-parameters directly, in particular for frequency (wavelength) domain simulations, as the S-parameters are already wavelength dependant. For time domain simulations, the circuit modelling tool internally converts the S-parameters into a time-domain representation.

We provide an example of a Bragg grating cavity test structure layout in Figure 4, together with the simulations from the extracted netlist. The response of the circuit deviates from the ideal Bragg grating cavity response, due: 1) the grating coupler insertion loss, 2) the back-reflections from the grating couplers, and 3) the insertion loss and back-reflections from the tapers. Ripples are observed in both the transmission and reflection spectra, that are not present in the ideal model. Furthermore, the shapes, positions, and oscillation frequencies of the ripples are dependant on the optical phases introduced by the various components, such as the waveguides. Hence it is important to extract the lengths and device parameters for an accurate simulation.

# 6. MANUFACTURING VARIABILITY

The high refractive index contrast of SOI permits sharp waveguide bends and ultra-small device sizes, making it promising for the development of densely integrated photonic circuits. However, silicon photonic devices face serious manufacturability challenges. Fabrication errors on either the waveguide width or waveguide thickness have a significant effect on the



Figure 5: Monte Carlo simulation of the Mach-Zehnder Interferometer layout in Figure 3.

propagation constant of light, and, thus, circuits such as interferometers are highly sensitive to manufacturing, as shown in Figure 5.

Thus, taking manufacturing variability into account in order to predict yield is critical for photonic integrated circuits. In the electronics community, corner analysis and Monte Carlo simulations are typically used to analyze fabrication variability; the former of predicts the worst-case performance of the circuit, while the later creates histograms and distributions, and is typically based on process variations applied to the entire circuit. In the simplest Monte Carlo approach, the same variations are applied to all components in the circuit, thus the simulation considers common-mode variability only (i.e., all devices are slightly thicker).

#### 6.1 Component models taking into account variability

In order to perform Monte Carlo simulations, we require parameterized component models that are continuous with the variables of interest (e.g., thickness, width). Although one approach is to simulate each component on a fine mesh (e.g., 0.1 nm steps in each deviation variable), this may be computationally prohibitive. We developed more efficient approaches, as follows.

## **6.1.1 S-Parameter component models**

For components that are described by S-parameters, we begin by generating S-parameters for the corner cases (e.g., components with waveguide geometries of 225 x 505 nm, 215 x 505 nm, 225 x 495 nm, 215 x 495 nm). For each Monte Carlo iteration, we interpolate the S-parameters for the desired thickness and width variation.

This can be applied to components such as directional couplers, where the phase through the device is dependant on the thickness and width of the waveguide. Two directional couplers can be connected to create a ring resonator sub-circuit, and the performance of the ring resonator (resonance frequency, free spectral range, extinction ratio) will vary with the thickness and width variability introduced into the directional coupler model.

The model can include multiple modes (e.g., TE and TM polarization).

\*\*\*\* add something intelligent here: challenges in interpolation? \*\*\*\*\*

## 6.1.2 Waveguides

2D case. easiest is to simply parameterize the effective index as a function of the thickness and width.

\*\*\*\* add something intelligent here \*\*\*\*

## 6.1.3 Perturbation approach

For the case of the Bragg grating, for example, we can assume that the manufacturing only affects the central Bragg wavelength. If all other parameters remain the same (grating coupling coefficient) than a small perturbation to the nominal effective index can be applied. This can be expressed as two independent linear parameters,  $\frac{\partial n_{\text{eff}}}{\partial w}$ , and  $\frac{\partial n_{\text{eff}}}{\partial h}$ , which are added to the nominal value.

## **6.2 Enhanced Monte Carlo**

The challenge in these simulations is to capture the die-to-die, device-to-device, and intra-device variations, which have position-dependant correlations. Correlated yield analysis is attracting increasing attention, and there have been studies investigating the statistical on-chip correlations <sup>6,7</sup>, and models for dealing with the uncertainty of devices <sup>8</sup>. From this past work, what is clear is if only common-mode variability is considered (corner analysis, Monte Carlo described above), the simulations do not capture an important type variability – differential. Namely, two nominally identical devices side-by-side on a chip will have slightly difference performance. This difference can have significant impact on system performance (e.g., WDM ring resonators, optical switches) and it cannot be simply compensated by thermally tuning the entire chip.

In this work, we propose, for the first time, a methodology that takes correlation between devices into account by using the physical layout in order to perform a manufacturing variability analysis of on-chip photonic integrated circuits. Beginning with the physical layout, and performing to enhanced Monte Carlo simulations, our methodology provides insight into the significance of compact layouts for photonic designs, and offers a useful tool for post-layout verification and power trimming estimation.



Figure 6: (a) Flow chart of the proposed methodology; (b) simulated waveguide linewidth deviations across a wafer; (c) simulated waveguide thickness deviations across a wafer.

Figure 6(a) shows the flow chart of our proposed methodology. The procedure includes:



Figure 7: Box scatter plot of the phase error of a balanced Mach-Zehnder Interferometer versus waveguide spacing, generated using the Enhanced Monte Carlo simulations.

- First, the layout for silicon photonic circuits and/or devices under test are created. In the example presented here, they are designed using KLayout<sup>4</sup>.
- The netlist is extracted from the layout, either using Mentor Graphics LVS or the SiEPIC-EBeam-PDK add-on<sup>5</sup> to KLayout<sup>4</sup>. The netlist provides a list of the primitive components in the library and the connectivity between components. The netlist is imported into Lumerical INTERCONNECT for circuit simulations.
- The third step is a wafer simulation. In INTERCONNECT, silicon waveguide width deviations,  $\Delta w(x,y)$ , and wafer thickness deviations,  $\Delta h(x,y)$ , are simulated across the whole wafer, as illustrated in the maps in Figures 6(b) and 6(c), respectively. Both deviations are characterized by a sigma RMS amplitude and a correlation length, and both are based on experimental results <sup>6,7</sup>. In each run of the Monte Carlo simulation, different deviation maps are be generated.
- According to the spatially-dependent waveguide width and thickness deviations, the optical S-parameters of primitive elements and the optical propagation constants of connecting waveguides are calculated. This is performed using interpolation in INTERCONNECT.
- The circuit with components updated based on their position is simulated. This is repeated several times, and the results can be visualized, as in Figure 5. Histograms and statistical analysis can be performed, as in Figure 7.

The scatter plot in Figure 7 shows the simulated phase error of a balanced Mach-Zehnder Interferometer versus the waveguide spacing between two arms, in a 248 nm silicon photonics process. In the Monte Carlo simulations, the horizontal length of the phase arms, L, is 200  $\mu m$ . The phase error is defined as the absolute optical phase difference between the

two phase arms. Ideally, the phase error should be 0 when there are no fabrication variations. However, this figure clearly shows that the mean of the phase error for an ensemble of MZIs is approximately linearly proportional to the waveguide spacing, emphasizing the importance of very compact layout designs, particularly where phase matching is required. This simulation is similar to the proportionality observed experimentally in ring resonators<sup>6</sup>. The simulated phase error can be used to estimate the trimming power required for MZI-based photonic switches.

# 7. CONCLUSION

The objective of this work is "first-time-right" design, where circuits function correctly the first time they are fabricated; this can be achieved only if the designer takes manufacturing challenges into consideration and applies effective mitigation strategies in order to build circuits that are immune to these variations.

#### ACKNOWLEDGMENTS

The authors would like to thank CMC Microsystems for enabling the fabrication of numerous chips via imec-ePIXfab and IME. Funding for this research was provided by NSERC, particularly the NSERC CREATE Silicon Electronic Photonic Integrated Circuits (SiEPIC) training program, http://www.siepic.ubc.ca.

## References

- [1] Chrostowski, L., Flueckiger, J., Lin, C., Hochberg, M., Pond, J., Klein, J., Ferguson, J., and Cone, C., "Design methodologies for silicon photonic integrated circuits," *Proc. SPIE, Smart Photonic and Optoelectronic Integrated Circuits XVI* **8989**, 8989–15 (Feb. 2014).
- [2] Chrostowski, L. and Hochberg, M., [Silicon Photonics Design: From Devices to Systems], Cambridge University Press (2015).
- [3] Lu, Z., Yun, H., Wang, Y., Chen, Z., Zhang, F., Jaeger, N. A. F., and Chrostowski, L., "Broadband silicon photonic directional coupler using asymmetric-waveguide based phase control," *Opt. Express* 23, 3795–3808 (Feb 2015).
- [4] Köfferlein, M., "KLayout," http://www.klayout.de.
- [5] Chrostowski, L., "SiEPIC EBeam PDK & Library for KLayout," http://github.com/lukasc-ubc/ SiEPIC EBeam PDK.
- [6] Chrostowski, L., Wang, X., Flueckiger, J., Wu, Y., Wang, Y., and Fard, S. T., "Impact of fabrication non-uniformity on chip-scale silicon photonic integrated circuits," in [Optical Fiber Communication Conference], Optical Fiber Communication Conference, Th2A.37, Optical Society of America (2014).
- [7] Yang, Y., Ma, Y., Guan, H., Liu, Y., Danziger, S., Ocheltree, S., Bergman, K., Baehr-Jones, T., and Hochberg, M., "Phase coherence length in silicon photonic platform," *Opt. Express* **23**, 16890–16902 (Jun 2015).
- [8] Weng, T.-W., Zhang, Z., Su, Z., Marzouk, Y., Melloni, A., and Daniel, L., "Uncertainty quantification of silicon photonic devices with correlated and non-gaussian random parameters," *Opt. Express* 23, 4242–4254 (Feb 2015).