## Schematic Capture and Spice Simulation Tutorial

## Introduction:

Welcome to C2S2's Analog Sub-Team! The intent of this tutorial is for you to familiarize yourself with the *xschem* schematic editor as well as *Ngspice*, a Spice circuit simulator - both of which are open-source tools. By the end of this tutorial, you will have successfully captured the schematic of an inverter and performed transient analysis.

Before you dive into this tutorial, please familiarize yourself with how to navigate a Linux operating system. Your work on this team will primarily be done on our team's *ecelinux* server. If you need a refresher on Linux commands or a crash course on Linux, please refer to the excellent tutorial developed for ECE 2400 and ECE 4750 students:

https://cornell-ece4750.github.io/ece4750-sec01-linux/

Once you have done so, please SSH into our server:

c2s2-dev.ece.cornell.edu

Now that you have logged into our server, enter the following command on the command line to source the set-up script:

source setup-c2s2.sh

Please note that you should source this set-up script each time you log into the C2S2 server. For the sake of convenience, you may want to consider placing the above command within your *.bashrc* file. Furthermore, you should remove any pre-existing source set-up commands from your *.bashrc* (upon removal, exit the server, log back in, and source the C2S2 set-up script).

Now you can simply enter the following command to launch xschem: xschem

Once you have launched *xschem*, navigate to the top-lefthand corner of the window and click *file*, then *New Schematic*. You should save this file (click *file*, then *Save as*) within a personal directory of your choice; for now, make a directory within your user-specific folder and save the schematic within this directory. I highly suggest frequently saving your work in the case the server or the program itself crashes.

Now, we will populate the schematic with the components necessary for building and simulating the converter. First, press *Shift+i* on your keyboard to pull up a window that shows you your selection of available components (you can also click *Tools* then *Insert symbol*). The window should look like this:

| X Choose symbol                                                                                                                                                         |                                                                                                                                                      | — [    | ) X    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|
| /xschem/xschem_library/devices<br>/doc/xschem/examples<br>/doc/xschem/logic<br>/doc/xschem/logic<br>/doc/xschem/schem_simulator<br>/doc/xschem/pcb<br>/doc/xschem/rom8k | asrc.sym<br>assign.sym<br>attributes.sym<br>bsource.sym<br>bus_connect_nolab.sym<br>capa-2.sym<br>capa.sym<br>cccs.sym<br>code.sym<br>code_shown.sym |        |        |
| Home Up Current d                                                                                                                                                       | ir New dir:                                                                                                                                          | Create | Delete |
| ● All ○ .sym ○ .sch File/Sea                                                                                                                                            | arch:                                                                                                                                                | Cancel | ОК     |

Once this window has appeared, navigate to the following directory, and select *nfet\_01v8*, which is a 1.8V NMOS device:

| X Choose symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -      | - X    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|
| Choose symbol<br>Classes/c2s2/pdks/sky130A/libs.tech/xschem/sky130_fd_pr<br>nfet3_g5v0d10v5.sym<br>nfet3_g5v0d10v5.sym<br>nfet_01v8_sym<br>nfet_01v8_esd.sym<br>nfet_01v8_lvt.sym<br>nfet_01v8_lvt.nf.sym<br>nfet_03v3_nvt.sym<br>nfet_03v3_nvt.sym<br>nfet_05v0_nvt.sym<br>Nfet_05v0_nvt.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym<br>Nfet_05v0_nvt_nf.sym |        | X E    |
| @name_D® @model<br>@ name_D® @model<br>a contract of the contract                                                                                     |        | Delete |
| All C .sym C .sch File/Search: nfet_01v8.sym                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Cancel | OK     |

Once you have done so, press OK and place the component on your schematic. Repeat this process and place a pfet\_01v8 on the schematic as well (a 1.8V PMOS device from the same library). If you want to move components around, click on the component to select it and then press M on your keyboard; finally, left click on the location where you wish to place the component. You can select multiple components at once by pressing down on your mouse's left-click button whilst dragging your cursor across the region of the screen that contains the components of interest. Your schematic should now look something like this:



Now you will populate the schematic with a DC voltage source as well as a square-wave voltage source (one will act as VDD for your inverter and the other will act as the input to your circuit): *vsource.sym* and *sqwsource.sym* respectively. To find these components, click on *Home* and then the first path available (the text color should be red). This library contains ideal sources and symbols that will hold your Spice directives, which are necessary for simulation:



Your schematic should now look something like this:



Next, we will connect the devices using wires. Specifically, we will tie the gates of the transistors together as well as their drains. We will also create wire stubs that will eventually be labelled with net labels. We will also connect the gates of both devices to the square-wave voltage source. Lastly, we will tie the bulk terminals of the transistors to their respective source terminals. The bulk terminals can be tied to other locations to change the threshold voltage of the MOSFETs, but for now, we will stick the aforementioned instructions.

To create a wire, press W where you wish to begin drawing your wire and left click at the location where you wish to end the wire; if you want your wire to change directions, continue to press W at the locations where you want your wire to turn and only left click where you want to end the wire. If you mess up and wish to delete a wire or a component, simply select the object of interest and press the delete key. Your schematic should look like this now:



Now, we will add *ground* connections, *VDD* symbols (which will act as labels for your *VDD* supply voltage), code block symbols, and net labels to the circuit (for the inverter's *Vin* and *Vout*). Search for the respective symbols in the same library as before: *gnd.sym*, *vdd.sym*, *code.sym*, *codeshown.sym*, and *lab\_pin.sym*. To copy a component, click the component and press C; finally, click where you wish to place the copied component. To associate a wire with a net label, click on the wire of interest when placing your *lab\_pin* symbol. To flip a symbol, press *Alt+F*. To rotate a symbol, press *Alt+R*. Your schematic should now look something like this:



We are only a few steps away from being able to simulate our circuit! Now, we will turn our attention to configuring the voltage sources and code block properly. To edit the properties of a component, double click on the component or click it once, and press Q (just like in Cadence Virtuoso). First, let us set the DC voltage of the VDD supply. Double click on the V1 voltage source and edit the value to be 1.8 (which corresponds to 1.8 volts).



Next, we will configure the square input voltage source that will be fed into the inverter. Set vhi (which stands for voltage high) to 1.8. This means that the square wave will oscillate between 0 and 1.8V. Next, set the frequency to 10 (this corresponds to 10Hz).

| X Edit Properties                                  |            |            |               | _        |          | ×       |
|----------------------------------------------------|------------|------------|---------------|----------|----------|---------|
| Path: /classes/c2s2/install/stow-pkgs/x86_64-rhel7 | /pkgs/xsch | em-3.1.0/s | hare/xschem   | /xschem_ | library/ | levices |
| Symbol sqwsource.sym                               | ОК         | Cancel     | Load          | Del      | Bro      | wse     |
| □ No change properties □ Preserve unchanged        | props 🗆 🕻  | Copy cell  | Edit Attr: <4 | LL>      |          | -       |
| name=V2 vhi=1.8 freq=10                            |            |            |               |          |          |         |
| 4                                                  |            |            |               |          |          |         |

For the net labels, label the input to the inverter Vin and the output of the inverter Vout.

| X Edit Properties                                 |         | _      |        | ×           |
|---------------------------------------------------|---------|--------|--------|-------------|
| Path: /classes/c2s2/install/stow-pkgs/x86_64-rhel | 7/pkgs  | /xsche | em-3.1 | .0/share    |
| Symbol lab_pin.sym                                | ОК      | Car    | ncel   | Load        |
| 🗆 No change properties 🗖 Preserve unchange        | d props | s 🗆 C  | Сору с | ell Edit At |
| name=l1 sig_type=std_logic lab=Vin                |         |        |        |             |
|                                                   |         |        |        | 21          |

Now, double click the *s1* code block and modify its parameters to match what is shown in the following image. Essentially what the code is doing is providing a path to the PDK's Spice library. The *tt* at the end of the path simply means that the devices in the schematic will operate nominally. We can adjust *tt* in order to use other models; this will prove helpful when we will wish to the test the circuit under different corner conditions (for example, process variation and temperature variation). The path has been provided below for your convenience:

/classes/c2s2/pdks/volare/sky130/versions/fa87f8f4bbcc7255b6f0c0fb506960f531ae2392/sky130 A/libs.tech/ngspice/sky130.lib.spice

| X Edit Properties       - □ ×         Path: /classes/c2s2/install/stow-pkgs/x86_64-rhel7/pkgs/xschem-3.1.0/share/xschem_library/devices       -         Symbol       code.sym       OK       Cancel       Load       Del       Browse         No change properties       Preserve unchanged props       Copy cell       Edit Attr: <all>       _      </all>                                                                |                                                   |                                                     |                |                       |                     |                     |                   |       |        |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------|----------------|-----------------------|---------------------|---------------------|-------------------|-------|--------|---|
| Path: //classes/c2s2/install/stow-pkgs/x86_64-rhel7/pkgs/xschem-3.1.0/share/xschem_library/devices<br>Symbol code.sym OK Cancel Load Del Browse<br>No change properties Preserve unchanged props Copy cell Edit Attr: <all> ↓<br/>name=TT only_toplevel=false value="<br/>.lib /classes/c2s2/pdks/volare/sky130/versions/fa87f8f4bbcc7255b6f0c0fb506960f531ae2392/sky130A/libs.tech/ngspice/sky130.lib.spice tt<br/>*</all> | X Edit Properties                                 |                                                     |                |                       |                     |                     |                   | _     |        | × |
| Symbol       code.sym       OK       Cancel       Load       Del       Browse         No change properties       Preserve unchanged props       Copy cell       Edit Attr: <all> </all>                                                                                                                                                                                                                                     | Path: /classes/c2s2/ins                           | tall/stow-pkgs/x86_64-rhel7/pkgs/xso                | hem-3.1.0/shar | re/xschem/xscl        | nem_library/devices |                     |                   |       |        |   |
| <pre>No change properties □ Preserve unchanged props □ Copy cell Edit Attr: <all> ↓ name=TT only_toplevel=false value=" .lib /classes/c2s2/pdks/volare/sky130/versions/fa87f8f4bbcc7255b6f0c0fb506960f531ae2392/sky130A/libs.tech/ngspice/sky130.lib.spice tt "</all></pre>                                                                                                                                                 | Symbol                                            | code.sym                                            |                | ОК                    | Cancel              | Load                | Del               |       | Browse |   |
| name=TT only_toplevel=false value="<br>.lib /classes/c2s2/pdks/volare/sky130/versions/fa87f8f4bbcc7255b6f0c0fb506960f531ae2392/sky130A/libs.tech/ngspice/sky130.lib.spice tt<br>"                                                                                                                                                                                                                                           | 🗆 No change properti                              | es 🗆 Preserve unchanged props                       | Copy cell Ed   | lit Attr: <all></all> |                     |                     |                   |       |        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                             | name=TT only_topleva<br>.lib /classes/c2s2/;<br>" | ≀l=false value="<br>dks/volare/sky130/versions/fa87 | f8f4bbcc7255b  | 6f0c0fb506966         | f531ae2392/sky130   | A/libs.tech/ngspice | ∶/sky130.lib.spid | ce tt | :      |   |

Lastly, we need to enter the Spice directives into the *s2* code block to perform the transient analysis as well as to capture the raw data so that we can display waveforms. Modify the parameters of the code block to match what is shown in the following image. Essentially, the *.control* and *.endc* demarcate the beginning and end of your Spice directives. The *save all* saves the data from the simulation. The *tran 0.1 2* means that a transient simulation will be performed for 2 second in 0.1 second increments. Lastly, the final write command places the data into a raw file that can be used to generate a waveform. Make sure the name of the raw file matches the name of your schematic.

| Path: /classes/c2s2/install/stow-pkgs/x86_64-rhel7/pkgs/xschem-3.1.0/share/xschem_library/devices<br>Symbol code_shown.sym OK Cancel Load Del Browse<br>No change properties Preserve unchanged props Copy cell Edit Attr: <all><br/>name-Spice only_toplevel=false value="<br/>.control<br/>save all<br/>tran 0.12<br/>write inverter_tutorial.raw<br/>.endd<br/>"</all> | X Edit Properties                                                                         |                                               |                        |                   |      |     | _ |        | Х   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------|------------------------|-------------------|------|-----|---|--------|-----|
| Symbol     code_shown.sym     OK     Cancel     Load     Del     Browse       No change properties     Preserve unchanged props     Copy cell     Edit Attr:         name=Spice     only_toplevel=false     value="     .     .       .control     save all     tran 0.12     .     .       .endd     "     .     .     .                                                 | Path: /classes/c2s2/inst                                                                  | all/stow-pkgs/x86_64-rhel7/pkgs/xschem-3.1.0/ | /share/xschem/xscher   | n_library/devices |      |     |   |        |     |
| <pre>No change properties Preserve unchanged props Copy cell Edit Attr: <all> name=Spice only_toplevel=false value=" .control save all tran 0.1 2 write inverter_tutorial.raw .endd "</all></pre>                                                                                                                                                                         | Symbol                                                                                    | code_shown.sym                                | ОК                     | Cancel            | Load | Del |   | Browse |     |
| <pre>name=Spice only_toplevel=false value=" .control save all tran 0.1 2 write inverter_tutorial.raw .endd "</pre>                                                                                                                                                                                                                                                        | □ No change propertie                                                                     | es 🗆 Preserve unchanged props 🗂 Copy cell     | Edit Attr: <all></all> | <b>_</b>          |      |     |   |        | - 1 |
|                                                                                                                                                                                                                                                                                                                                                                           | name=Spice only_topl<br>.control<br>save all<br>tran 0.1 2<br>write inverter_tut<br>.endd | evel=false value="<br>orial.raw               |                        |                   |      |     |   |        |     |

Next, go to the toolbar at the top of your screen and click Add waveform graph. Place the graph in an appropriate location that does not obscure or cover your schematic. Your schematic should look like this now:



We are now in the home stretch! Click *Netlist* in the top-right corner to generate a netlist that will be used by *Ngspice* to run your simulation. If you want to view the netlist that has been generated, click *Simulation* (in your toolbar) and then *Edit Netlist*. Finally, click *Simulate*!

To view your waveforms, click on your graph to select it. Afterwards, click on the wire of interest and press Alt+G. You can repeat this process multiple times on the same graph if you wish to superimpose waveforms or you can simply add more graphs. Your screen should look something like this:



Next, click *Simulation* and then *Load/Unload ngspice .raw file*. This will load the data from the simulation (which we stored in a raw file) so that we can view it as a waveform. Now click on the graph itself and press F to fit the waveforms on the screen. You should see the input signal and its inverted counterpart!

