## ECE 546 HOMEWORK No 9 Due Wednesday, April 17, 2024

In this homework you are going to build a simple inverter based transmitter, simulate it with the provided channel s4p file and analyze its response.

1. Get a *FastX* client (version 1) from webstore and follow the installation instruction to login to your designated server.

2. After login, go to the ECE546 folder in your home directory from a terminal and type 'virtuoso &'. Then Cadence Virtuoso will start. Notice that the top window in Figure 1 will be referred to as 'Library manager' and the bottom window will be referred as 'CIW'

| Library Manager: WorkArea: /home/dawei1/ECE546                                                                                                                                                                                                   | _                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| <u>E</u> ile <u>E</u> dit <u>V</u> iew <u>D</u> esign Manager <u>H</u> elp                                                                                                                                                                       | cadence                    |
| Show Categories Show Files  View  NCSU_Analog_Parts NCSU_Digital_Parts NCSU_TechLib_ami06 NCSU_TechLib_ami16 NCSU_TechLib_tsmc02 NCSU_TechLib_tsmc02 NCSU_TechLib_tsmc03  NCSU_TechLib_tsmc03  Log file is "/home/dawei1/ECE546/libManager.log". |                            |
| Virtuoso® 6.1.6-64b - Log: /home/dawei1/CDS.log                                                                                                                                                                                                  | _ = ×                      |
| Eile Tools Options Help                                                                                                                                                                                                                          | c <mark>a</mark> d e n c e |
| loading vars from ~/.cdsenv for tool license<br>Loading NCSU SKILL routines<br>Done loading NCSU_CDK customizations.                                                                                                                             |                            |
|                                                                                                                                                                                                                                                  |                            |
| Immouse L: M:                                                                                                                                                                                                                                    | R:                         |
|                                                                                                                                                                                                                                                  |                            |

Figure 1. Window view for steps 1 and 2

3. Now you are going to create a library. First, identify the CIW window shown in Figure

1, then go to 'Tools->library manager' a new window will pop up as shown in Figure 2.

4. In the library manager window go to 'file->new->library' and type 'ECE546' in the 'name' field and click the "OK" button.

| Library Manager: WorkArea: /l                                                                                                                                                                                                                             | nome/dawei1/ECE546 _ 🗆 × |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| <u>File Edit View D</u> esign Manager <u>H</u> elp                                                                                                                                                                                                        | cadence                  |
| New     Library       Open     Ctrl+O       Open (Bead-Only)     Ctrl+R       Open Wittj     Ctrl+R       Load Defaults     Save Defaults       Ogen Shell Window     Ctrl+P       Explore Shell Window     Ctrl+X       NCSU TechLib Istmc03d     Ctrl+X |                          |
| Messages<br>Log file is "/home/dawei1/ECE546/libManager.log".                                                                                                                                                                                             |                          |

Figure 2. Window view for step 4.

|                                                        |                                                                       | New Li | brary |       |        |       |
|--------------------------------------------------------|-----------------------------------------------------------------------|--------|-------|-------|--------|-------|
| Library —                                              |                                                                       |        |       |       |        |       |
| Name                                                   | ECE546                                                                |        |       |       |        |       |
| Directory                                              | home/dawei1/ECE54                                                     | 6/     |       |       | - 1 -  | ## ## |
| Cds.li<br>Cds.li<br>Cds.li<br>CdsLi<br>displa<br>libMa | b<br>ib-<br>ibEditor.log<br>ay.drf<br>anager.log<br>anager.log.cdslck |        |       |       |        |       |
| ,<br>File <u>t</u> ype:                                | Directories                                                           |        |       |       |        | -     |
| Design M                                               | lanager                                                               |        |       |       |        |       |
| 🖲 Use No                                               | DNE                                                                   |        |       |       |        |       |
| ) Use No                                               | DM                                                                    |        |       |       |        |       |
| Compres                                                | ssion enabled                                                         |        |       |       |        |       |
|                                                        |                                                                       |        | ОК    | Apply | Cancel | Help  |
|                                                        |                                                                       |        | -     | Carro |        | Contr |

Figure 3. Window view for step 4.

5. A new pop up window as in Figure 5 'attach to an existing technology library'. Choose 'NCSU\_TechLib\_tsmc02d'.

6. Go back to the library manager and choose library ECE546 (you just created it), when it is highlighted, go to 'File->new->Cell View' a new window like figure will pop up. Type 'Inv' in the 'Cell' field and click 'OK'. The cell named 'Inv' is created and the schematics editor will open it in editing mode automatically.

| New Library        | ECE546               |     |
|--------------------|----------------------|-----|
| Fechnology Library | NCSU TechLib ami16   | 1   |
|                    | NCSU TechLib hp06    | 0   |
|                    | NCSU_TechLib_tsmc02  | I   |
|                    | NCSU_TechLib_tsmc02d |     |
|                    | NCSU_TechLib_tsmc03  |     |
|                    | NCSU TechLib tsmc03d | 5.7 |

Figure 4. Window view for step 5

|                                                                                                                                    | Library Manager: Wor                                 | kArea: /home/dawei1/ECE546 | _ = × 🗖                                            | New File ×         |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------|----------------------------------------------------|--------------------|
| <u>File Edit V</u> iew <u>D</u> e                                                                                                  | sign Manager <u>H</u> elp                            |                            | cādence File                                       | ECE546             |
| Show Categories                                                                                                                    | Show Files                                           |                            | Cell                                               | Inv                |
| Library                                                                                                                            | Cell                                                 | View                       | View                                               | schematic          |
| ECE546                                                                                                                             |                                                      |                            | Туре                                               | schematic 🔽        |
| ECE546<br>NCSU_Analog_Parts<br>NCSU_Digital_Parts<br>NCSU_TechLib_ami(<br>NCSU_TechLib_ami<br>NCSU_TechLib_hp0<br>NCSU_TechLib_hp0 |                                                      | View ~ Lock                | Size Applicatio<br>Open with Always<br>Library pal | Schematics L       |
| Messages                                                                                                                           |                                                      |                            |                                                    | C11/202340/003.110 |
| Deleting I library<br>Deleting library "ece<br>Deleted library 'ece<br>Deleted library 'ece                                        | 546_2".<br>546_2'.Delete of library "ece546_2" :<br> | ucceeded.                  |                                                    |                    |
|                                                                                                                                    |                                                      | Lib: E                     | ECE546 Free: 1.40T                                 | OK Cancel Hel      |

Figure 5. Window view for step 6.

7. Now you are going to add transistors to the schematic. Press the key 'I' and the 'add instance' window will pop up. You can also go to the pull-down menu 'Create->Instance' from the schematic editor to create an instance in the schematic.

8. On the 'Add Instance' window, click 'Browse' and a new window will pop up as shown in Figure 6. Choose "NCSU\_Analog\_Parts" as the library and 'nmos' as the cell, 'symbol' as the view. Next, go back to the schematic window and click anywhere of the empty space; an nmos transistor symbol will be added. You can press 'ESC' to cancel the add instance command. Please use the same method to add a pmos transistor with minimal length and width.

9. Now you are going to make some connections. In the schematic editor press 'w'. This will allow you to add wires. You can alternatively go to the pull-down menu 'Create->wire(narrow)' from the schematic editor. Single click will define a start point

and double click will define the end point of the connection. Next, connect the pmos and nmos devices created in step 8 to build an inverter circuit.



Figure 6. Window view for step 8

10. You will now create the I/O ports. Press '**p**' and enter the pin creation window as shown in the figure. You can also enter this mode by going to '**Create->pin'**. Type '**in'** in the '**name**' text box and choose '**input**' as the direction. Then click on any empty space in the schematic editor to place a port '**in**'. Create port '**out**' as output, '**VDD**' and '**gnd**' as **InputOutput** and connect them to the inverter you just built. The final circuit is shown in Figure 7.



Figure 7. Window view for step 10.

11. The last step is to create a symbol for the inverter so that you can instantiate it in other blocks. Before that, you need to check and save the schematic. Please go to 'File->Check and Save'.



There should be no warning nor error. If there is one, go to the CIW window for the logs and information to debug your schematic. Once the schematic is clean, go to **'Create->cellview->from cellview'**, keep the default setting and click '**OK**'. Next, you need to define the pin locations. Usually we want '**VDD**' on top, '**gnd**' at the bottom, inputs on the left and outputs on the right.

|                 | Sy                 | mbol Gene | eration Op  | tions |                   | ×  |
|-----------------|--------------------|-----------|-------------|-------|-------------------|----|
| Library Name    |                    | Cell Name |             | View  | Name              |    |
| ECE546          |                    | Inv       |             | symbo | 1                 |    |
| Pin Specificati | ons                |           |             |       | Attributes        |    |
| Left Pins       | in                 |           |             |       | List              |    |
| Right Pins      | out                |           |             |       | List              |    |
| Top Pins        | ADD                |           |             |       | List              |    |
| Bottom Pins     | gnd                |           |             |       | List              |    |
| Exclude Inherit | ted Connection Pin | s:        |             |       |                   |    |
| 🖲 None 🔾        | All 🔾 Only these   | 9:        |             |       |                   |    |
| Load/Save 🗌     | Edit Attrib        | utes 🔲    | Edit Labels |       | Edit Properties 🔲 |    |
|                 |                    |           |             | ОК    | Cancel Apply He   | lp |

Figure 9. Window view for step 11.

Once you have adjusted your pin locations click the '**OK**' button, the symbol editor with the automatically created symbol for your inverter will appear. Check and save the symbol and the inverter is successfully created.



Figure 10. Window view for step 11.

12. Now you are going to create the testbench for your inverter. Create a new cellview in the ECE546 library and instantiate the inverter from library 'ECE 546' just as you instantiated the pmos and nmos transistors. Then from library 'analogLib' instantiate the dc source vdc and set the DC voltage to 1.8V. Connect the positive port of the DC voltage source to the VDD port of the inverter. Connect the ground port, 'gnd' to the global ground. Next, from library 'analogLib' instantiate the voltage step generator vpwl. This will be your input. Please set the 'number of voltage time pair' to 3 and enter the following voltage/time pair information:

This will create a unit step function u(t-10n) with rising time 0f and 20ps. Add a capacitor of 10fF from analogLib (part name: cap) between the output and ground and create an output pin, then check and save your testbench. The final circuit should be as shown in Figure 11.

|             |     |     |  | 1Ø |       |      |     |
|-------------|-----|-----|--|----|-------|------|-----|
|             |     |     |  |    |       |      |     |
| <br>        |     |     |  |    |       |      |     |
| <br>· · · · |     | In  |  |    |       |      | out |
|             |     |     |  |    |       |      |     |
| V1          | к н |     |  |    | · · · | CØ . |     |
| )<br>v1:Ø   |     |     |  |    |       |      |     |
| tvpairs=3   |     |     |  |    |       |      |     |
|             |     | gnd |  |    | · ·   |      |     |
|             | <   |     |  |    |       |      |     |

Figure 11. Window view for step 12.

13. The next step is to run a transient simulation with the newly built testbench. From the schematic of the testbench, go to 'Launch->ADE L'. The ADE L window will appear as shown in Figure 12.

| ADE L (1) -                  | ECE546 Inv_testbench                        | schematic                                  | _ O X              |
|------------------------------|---------------------------------------------|--------------------------------------------|--------------------|
| Window Menu Setup Analyses V | ariables <u>O</u> utputs <u>S</u> imulation | <u>R</u> esults <u>T</u> ools <u>H</u> elp | cādence            |
| 🛃 🔊   🦵 25.0   👌 🎾           | ê 🗹 🖻                                       | _                                          |                    |
| Design Variables             | Analyses                                    |                                            | ? 5 ×              |
| Name Value                   | Type Enable                                 | Arguments                                  | O DC<br>O Trans    |
| Nume Value                   |                                             |                                            | 4                  |
|                              |                                             |                                            |                    |
|                              |                                             |                                            | ~                  |
|                              |                                             |                                            | ~                  |
|                              |                                             |                                            |                    |
|                              | Outputs                                     |                                            | ? 🗗 🗙 🙆            |
|                              | Name/Signal/Expr                            | Value Plot Save Sa                         | ave Options        |
|                              |                                             |                                            | 80                 |
|                              |                                             |                                            |                    |
|                              |                                             |                                            |                    |
|                              |                                             |                                            |                    |
|                              |                                             | _                                          |                    |
| >                            | Plot after simulation: Auto                 | Plotting mode: Rep                         | olace              |
| m                            |                                             |                                            |                    |
| 4(7) Plot Outputs            | Sta                                         | atus: Ready   T=25.0 C   S                 | Simulator: hspiceD |

Figure 12. Window view for step 13.

14. First go to 'setup->Simulator/Directory/Host', on the newly popped window. Change Simulator from 'hspiceD' to 'spectre'. You can also specify the simulation file folder in the 'Project Directory' field. Next, click the 'Choose Analysis' icon to choose the simulation type.



Figure 13. Window view for step 14.

There, you need to choose '**tran'** with a stop time '**20n**', and '**conservative**' as the accuracy. You can also click '**option**' to fine tune the simulation parameters but the defaults are good enough for this homework. Click '**OK**' when you are done.

15. You will next add the signals to be displayed after simulation. Click the 'Setup Output' icon.



Figure 14. Window view for step 15

The signal selection window will pop up. Click **'From Schematic'** and click on the testbench schematic to select the signals you want. Here we want the output and the input of the inverter. After choosing all the signals, press **'ESC'** to quit command mode and get back to the ADE window.

16. Go back to the ADE L window and choose 'output->Save all'. In the field 'Select signal to output(save)' choose 'selected'. This is important since the default selection will save all the signals (most of which are useless for our purpose), which would generate too large a dataset and would dramatically reduce HDD performance.

17. On the ADE L window, choose 'Setup-> Model Libraries', in 'Model Library Setup' window add the pmos and nmos model files as shown in Figure 15.

| spectre5: Model Library Se                                                                                                                              | tup            | ×      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| Model File<br>⊡- Global Model Files<br>⊡ ✔/EEAPPS/ncsu-cdk-1.6.0.beta/models/models_ece546<br>↓ ▼ <click add="" file="" here="" model="" to=""></click> | Section        |        |
|                                                                                                                                                         | OK Cancel Appl | y Help |

Figure 15. Window view for step 17.

17. Click the "**Run**" green button to start simulation. The program will run and generate some plots. Include the results and provide your comments.



Figure 16. Window view for step 17

18. Change the load capacitor to 100fF and re-run the simulation. Include the resulting plot and compare with the plot from step 17.

19. Use '**nport**' from '**analogLib**' (detailed setup on next page, Figure 18) to simulate the inverter based transmitter with the four-port channel from the S-parameter file TYCO.s4p (http://emlab.illinois.edu/ece546/tools/TYCO.s4p). You need to add another inverter to generate a differential input of the channel. The channel needs to be terminated as shown in Figure 17. Plot the results of the differential input of the inverter based transmitter, differential input of the channel and differential output of the channel. Comment on the results.



Figure 17. Channel termination diagram

|                           | Edit Object Properties        | ×       |
|---------------------------|-------------------------------|---------|
| Apply To Only cur         | rrent 🔽 instance 🔽            |         |
| Show 🗌 syste              | em 🗹 user 🗹 CDF               |         |
| Browse                    | Reset Instance Labels Display |         |
| Property                  | Value                         | Display |
| Library Name              | analogLib                     | off 🔽   |
| Cell Name                 | nport                         | off 🔽   |
| View Name                 | symbol                        | off 🔽   |
| Instance Name             | NPORTO                        | off 🔽   |
|                           | Add Delete Modif              | y )     |
| CDF Parameter             | Value                         | Display |
| Common reference          | ⊻                             | off 🔽   |
| Number of ports           | 4                             | off 🔽   |
| Browse and select s-data  | file 🗌                        | off 🔽   |
| S-parameter data file     | Path to s4p file              | off 🔽   |
| Passivity                 | enforce                       | off 🔽   |
| Interpolation method      | spline                        | off 🔽   |
| Tran convolution paramete | ers 🗹                         | off 🔽   |
| Accuracy                  | 🔾 default 🧕 conservative      | off 🔽   |
| Advanced transient param  | eters ⊻                       | off 🔽   |
| Max sampling points       |                               | off 🔽   |
| Max frequency of intere   | st                            | off 🔽   |
| Impulse response trunca   | tion 1.0e-6                   | off 🔽   |
| Causality correction      | fmax 🔽                        | off 🔽   |
| DC extrapolation          | unwrap 🔽                      | off 🔽   |
| Noise parameters          |                               | off 🔽   |
| Rarely used parameters    |                               | off 🔽   |

Figure 18. Window view for step 19