

# CONMLS

# Institut für Theoretische Elektrotechnik

Technische Universität Hamburg (TUHH)





Copyright © 2014-2017 Institut für Theoretische Elektrotechnik, Technische Universität Hamburg, Harburger Schloss Str 20, D-21079 Hamburg, Germany For question and concerns regarding this document, please consult Torsten Reuschel (email: torsten.reuschel@tuhh.de).

WWW.TET.TUHH.DE

This book refers to CONMLS rev1096 with TETlib rev651. Features available in other versions may not be covered. Likewise, not all of the described features may be available in former revisions. The following authors contributed to this documentation: David Dahl, Sebastian Müller, Torsten Reuschel, and Renato Rimolo-Donadio.

Hamburg, Germany, September 6, 2017

# Contents

les l'e

| 1              |                                                                          | . 5      |
|----------------|--------------------------------------------------------------------------|----------|
| 2              | Installation                                                             | . 7      |
| 2.1            | Windows                                                                  | 7        |
| 2.1.1          | Installation of the CONCEPT-II MLS module under Windows operating system | s 7      |
| 2.1.2          | Installation of auxiliary software                                       |          |
| 2.1.3          | Test of the installation                                                 | . 8      |
| 3              | Getting Started                                                          | . 9      |
| 3.1            | Graphical User Interface                                                 | 9        |
| 3.1.1          | Example 1: Via-to-Via Link                                               | 10       |
| 3.1.2          | Example 2: Multilayer Thru Vias                                          | 20       |
| 3.1.3          | Example 3: Pin Field with 64 Vias                                        | 21       |
| 3.2            | Running from Command Line                                                | 22       |
| 4              | Technical Reference                                                      | 23       |
| 4.1            | Simulation Setup                                                         | 23       |
| 4.1.1          | Model Parameterization                                                   | 24       |
| 4.1.2          | Parameter Sweeping                                                       | 25       |
| 4.1.3          | Algorithm Configuration                                                  | 27       |
| 4.1.4          |                                                                          | 30       |
| 4.1.5<br>4.1.6 |                                                                          | 31<br>31 |
|                | Selection of Output Data                                                 |          |
| 4.2            | Specification of Board Geometry (2D) and Components                      | 32       |
| 4.2.1          |                                                                          | 34       |
| 4.2.2<br>4.2.3 | Via Geometry and Modeling                                                | 35<br>39 |
| 4.2.3          |                                                                          | 39<br>40 |
| 4.2.4          | Microstrip Transmission Lines (untested)                                 | 40       |
| 4.2.6          | Multiconductor Transmission Lines                                        | 41       |
| 4.2.7          |                                                                          | 45       |
| 4.2.8          | Pads (untested)                                                          | 45       |
| 4.2.9          | Ports                                                                    | 45       |

Cap de

6

| 4.3 | 3 Stackup Geometry     |    |  |  |  |
|-----|------------------------|----|--|--|--|
| 4.4 | Material Specification | 48 |  |  |  |
| 5   |                        | 49 |  |  |  |
|     | Bibliography           | 51 |  |  |  |

# 1 — Introduction

The CONMLS code is the improved Fortran [1] implementation of the Matlab [2] Via Pin Simulator (VPF) code [3]. It makes use of the models discussed in [4, 5, 6, 7, 8] to simulate multilayer substrates enclosed by solid reference planes. This document explains the syntax, structure and functionality.

'e', 'e', 'e'

Figure 1.1 illustrates the program functionality and main building blocks. An interpreter reads the input files, which are a high-level description of the structure to be simulated. These files are then decoded. A second code component gets the variables created by the interpreter and identifies the cavities and their related interconnect elements. Then, the calculator computes the parallel-plate impedance per cavity, generates or imports the transmission line models for traces, and calculates or reads the via-to-plane capacitances to approximate the near fields in the antipad region. The calculator combines the plane and trace model by applying modal decomposition, and creates the interconnection matrices for via capacitances and lumped elements. Finally, the partial results are concatenated, for instance, using segmentation techniques. Post-processing functions and utilities are available to store (e.g. as lydite- or touchstone files [9]) and visualize the results. This version of the program is based on previous code developments [3, 10, 11, 12]. It has been interfaced with a revised CIM package [13] which allows the computation of arbitrary-shaped planes by applying the contour integral method. Another previously external algorithm for the computation of MTL systems with an hybrid 2D approach for arbitrary cross sections [14, 15] is included in the CONMLS code.



Figure 1.1: Flow chart of input/output and code functionalities in CONMLS.



Figure 1.2: Input files for the high-level description of multilayer substrates in CONMLS are based on the widely used INI-format. Asterisks mark mandatory files. Other files may be required depending on the configuration of the algorithm.

Figure 1.2 shows the required input files and their dependencies. The fundamental configuration is provided through the simulation setup (.sim-file). The choice of algorithms and their respective parameters is contained in this file. Moreover, models may be freely parameterized with regard to variables and parameter sweeps, all of which are to be defined in the simulation setup. Additional files such as the geometry specification are linked. Geometry definition of PCB layout, stackup, vias, and multi-conductor transmission lines (MTLs) are to be provided through .geo-files. These files may utilize physical material definitions that are located in .matr-files.

# Notation

Parts of this user guide are enriched by one or more of the following elements:

- Remarks provide additional information for advanced users.
- Notes give hint to specifics in configuration and behavior of CONMLS.

Short examples of code and syntax are provided in the following way:

mlss.2.exe --help



The CONMLS code is available for Linux and Windows operating systems.

# 2.1 Windows

The following guide describes the installation process of CONMLS under MS Windows 64-bit and the steps required to get started:

# 2.1.1 Installation of the CONCEPT-II MLS module under Windows operating systems

- 1. Run *conmls-[xx]-setup.exe* to install the CONMLS binaries, where *[xx]* denotes the version.
- 2. Extend the system path by C:\CONMLS-1.0\bin or wherever the package has been installed, here referred to as \$CONMLS.

|                                                             | Hardware        | Erweitert                                                 | Completenskitz                                                         | Demetr                                    |       |
|-------------------------------------------------------------|-----------------|-----------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------|-------|
| nputername                                                  | Hardware        | Liwellen                                                  | Computerschutz                                                         | Remote                                    |       |
| mgebungsv                                                   | /ariablen       |                                                           |                                                                        |                                           | Σ     |
|                                                             |                 |                                                           |                                                                        |                                           |       |
| <u> </u>                                                    |                 |                                                           |                                                                        |                                           | _     |
| Benutzer                                                    | variable be     | arbeiten                                                  |                                                                        |                                           | ×     |
|                                                             |                 |                                                           |                                                                        |                                           |       |
| Name de                                                     | r Variablen:    | PATH                                                      |                                                                        |                                           |       |
|                                                             |                 |                                                           |                                                                        |                                           |       |
| Wert der Variablen: in;C:\CONMTLI-1.0\bin;C:\CONMLS-1.0\bin |                 |                                                           |                                                                        |                                           |       |
| OK Abbrechen                                                |                 |                                                           |                                                                        |                                           |       |
|                                                             |                 |                                                           | OK                                                                     | Abbre                                     | chen  |
|                                                             |                 |                                                           | ОК                                                                     | Abbre                                     | chen  |
|                                                             |                 |                                                           | ОК                                                                     | Abbre                                     | chen  |
| Systemvari                                                  | ablen           |                                                           | ОК                                                                     | Abbre                                     | chen  |
| Systemvari<br>Variable                                      |                 | Wert                                                      | OK                                                                     | Abbre                                     | chen  |
| Variable                                                    |                 |                                                           |                                                                        | ,                                         | chen  |
|                                                             |                 |                                                           | s\system32\cmd.ex                                                      | ,                                         | chen  |
| Variable<br>ComSpec<br>CONCEPT                              | : 1             | C: \Windows                                               | s\system32\cmd.ex                                                      | ie ie                                     |       |
| Variable<br>ComSpec<br>CONCEPT<br>F_EM64T                   | :<br>T<br>_REDI | C: \Windows<br>c: \concept-3<br>C: \Program               | s\system32\cmd.ex<br>II-12.0                                           | ie<br>n Files\In                          |       |
| Variable<br>ComSpec<br>CONCEPT<br>F_EM64T                   | :<br>T<br>_REDI | C: \Windows<br>c: \concept-<br>C: \Program<br>C: \Program | s\system32\cmd.ex<br>II-12.0<br>Files (x86)\Commo<br>Files (x86)\Commo | ie<br>on Files\In<br>on Files\In          | · · · |
| Variable<br>ComSpec<br>CONCEPT<br>F_EM64T                   | :<br>T<br>_REDI | C: \Windows<br>c: \concept-3<br>C: \Program               | s\system32\cmd.ex<br>II-12.0<br>Files (x86)\Commo                      | ie<br>n Files\In                          | · · · |
| Variable<br>ComSpec<br>CONCEPT<br>F_EM64T                   | :<br>T<br>_REDI | C: \Windows<br>c: \concept-<br>C: \Program<br>C: \Program | s\system32\cmd.ex<br>II-12.0<br>Files (x86)\Commo<br>Files (x86)\Commo | ie<br>on Files\In<br>on Files\In          | · · · |
| Variable<br>ComSpec<br>CONCEPT<br>F_EM64T                   | :<br>T<br>_REDI | C: \Windows<br>c: \concept-<br>C: \Program<br>C: \Program | s\system32\cmd.ex<br>II-12.0<br>Files (x86)\Commo<br>Files (x86)\Commo | ie<br>in Files\In<br>in Files\In<br>Lösch | · •   |

Figure 2.1: Setting the path to the CONMLS executables (System variables/Name of variables).

To do so, open the System applet in the Control panel (Systemsteuerung). Choose the

register Advanced (Erweitert). Click on Environment variables (Umgebungsvariable).

Select the entry *Path* of *System variables* (Systemvariablen) and press *Edit* (Bearbeiten). A window according to Fig. 2.1 opens where *Path* can be completed. Note: *Path* has to be extended by a semicolon followed by the CONMLS path. For details see Fig. 2.1.

The installation works only properly if all programs that are contained in the directory \$CONMLS/bin can be called without specifying the complete path. Please do not execute programs under \$CONMLS/bin. Copying of executables is not necessary and should not be done!

#### 2.1.2 Installation of auxiliary software

Gnuplot is necessary for the graphical representation of curves. To install it, download the binaries from http://www.gnuplot.info.

CONMLS uses the program gnuplot.exe. Please extend the variable PATH by the corresponding path, e.g., *C:\Programs\gnuplot\bin* or wherever gnuplot.exe is installed. The program must be callable from any working directory.

# 2.1.3 Test of the installation

Using a command line window, the following two steps can be used to validate that the path variables and binaries are configured and installed properly.

- (a) Type conmls.exe <Enter>. The GUI of CONMLS appears. If not, the Path has not been specified properly.
- (b) Type gnuplot.exe <Enter> at the command line. The gnuplot window appears. If not, the Path has not been specified properly.



This chapter gives some aid to those who are new to the CONMLS code.

# 3.1 Graphical User Interface

Starting the graphical user interface CONMLS for the first time, the various design views and monitors are empty as shown in Fig. 3.1.



Figure 3.1: Graphical user interface CONMLS after first startup.

The depicted views and monitors are:

Project View A tree-structured list of all components, models, and configurations.

**Board View** A bird's view of the PCB.

Stackup View The stackup of the PCB.

**Variables** A list of variables used in the current project. Variables can be utilized for parameter sweeping.

Status View The output of the backend is piped to this monitor.

**Toolbar** Direct access to repeatedly used functions such as loading and saving a project as well as running a simulation.

The following sections provide details on functionality and usage of the graphical user interface based on specific examples.

## 3.1.1 Example 1: Via-to-Via Link

The first example features two vias that are interconnected by a transmission line on layer *signal1*. One of the vias ranges through the entire stackup and features a via stub. The second via is back-drilled and ends on layer *signal1*.

Loading a previously stored project can be done using the *File* menu or using the *Open file*.. button in the toolbar, cf. Fig. 3.2.



Figure 3.2: Graphical user interface CONMLS after loading example Via-to-Via Link.

All properties and settings of the project are accessible through the project tree on the left of the screen. Typically, materials need imported or defined prior to setting up the stackup, cf. Fig. 3.3. The shape of the board and the layers of the stackup can be configured as depicted in Figs. 3.4 and 3.5. Next, the via models can be defined as shown in Fig. 3.6. Once defined, vias can be placed as shown in Fig. 3.7.

Note how the via *via1* ranges from top to bottom of the board. The graphical preview of the geometry offers two more perspectives. Clicking on the white antipad area of a via opens the cross-sectional view as shown in Fig. 3.8. Second, the currently displayed layer can be selected in the stackup view on the right, cf. Fig. 3.9. Selecting the layer plate2 reveals how only *via1* pinches through this metallic layer.

Ideal transmission lines as well as generic multiconductor transmission lines can be used to interconnect vias. Figures 3.10 and 3.11 depict the latter. Again, selecting the corresponding layer, here: *signal2*, reveals the routing of transmission lines, cf. Fig. 3.12.

Once the geometry is set up, the algorithms, models, and boundary conditions that are to be used for the simulation can be configured as depicted in Fig. 3.13. Sweeping parameters such as the frequency can be selected from the project tree, cf. Fig. 3.14. Finally, ports should be placed as shown in Fig. 3.15 in order to probe the geometry which is to be simulated.

Finally, the simulation can be started after selecting the number of processors to be used.

| File Options About                                                                           | + 🔍 🔍 Current layer: 1 🗘                                                                                                                                                                                                                |                                                                                  |
|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| Project View © 🗹<br>Simulation Setup<br>Ports<br>Output data<br>Post Processing<br>Materials | CONMLS - Material Description 🔶 🗆 X<br>Material Specification                                                                                                                                                                           | Stackup View<br>Simulation: via_to_via_link<br>→ plate1 GND<br>diel1a<br>signal1 |
| Plots<br>Variables:                                                                          | Material name: FR-4 <br>Material type: dielectric V                                                                                                                                                                                     | diel1b<br>plate2 GND                                                             |
| Name     Value     Cor       1     freq     1e+008                                           | Conductivity:<br>Relative permeability:<br>Relative permittivity:<br>Dielectric loss tangent:<br>Dielectric loss tangent:<br>Dielectric loss tangent:<br>Dielectric loss tangent:<br>Dielectric loss tangent:<br>Cose<br>Close<br>Close | diel2<br>plate3 GND<br>diel3<br>plate4 GND<br>diel4<br>plate5 GND<br>diel5       |
| Add variable                                                                                 |                                                                                                                                                                                                                                         | plate6 GND<br>diel6                                                              |
|                                                                                              |                                                                                                                                                                                                                                         |                                                                                  |

Figure 3.3: Editing a material definition.

CONMLS offers parallelization based on OpenMP (shared memory parallelization). Completion of the simulation is indicated by a blue *Program finished!* at the bottom of the project status view. For quick sanity checks of the results, the graphical user interface offers selecting input and output ports and viewing the magnitude of their respective transfer function, cf. Figs. 3.17 through 3.19.

| File   | Options About          |            | CO         | NMLS           |                     |       |                    | ↑ _ □ ×   |
|--------|------------------------|------------|------------|----------------|---------------------|-------|--------------------|-----------|
|        | 🗶 CPUs: 1 🗘 🗋          | 🚔 📕 🕂      | 🔍 🔍 Curr   | ent layer: 1   | \$                  |       |                    |           |
| Projec | t View                 |            |            |                |                     |       | Stackup View       | ØX        |
|        | Stackup [stackup_board |            | CONMLS - S | hape Descripti | on                  | ↑ □ × |                    | Â         |
|        | Board Shape<br>Stackup |            | Shap       | pe Description | n                   |       | Simulation: via_to | _via_link |
| e      | Components             | rect       |            |                |                     | ~     |                    | GND       |
|        | Vias<br>Pads           | Maniaianum | N          | March Inc.     | Ar an an discussion |       | diel1a             |           |
|        | Lumped Elements        | X minimum  | X maximum  | Y minimum      | Y maximum           |       |                    |           |
| Varia  | TL (ideal)             | 1 0        | 200        | 0              | 200                 |       | diel1b             |           |
| varia  | Name Value             |            |            |                |                     |       | plate2 💻<br>diel2  | GND       |
| 1 fre  |                        |            |            |                |                     |       |                    | GND       |
| 1 10   | ed Te+008              |            |            |                |                     |       | diel3              | GND       |
|        |                        |            |            |                |                     |       |                    | GND       |
|        |                        |            |            |                |                     |       | diel4              | GND       |
|        |                        |            |            |                |                     |       |                    | GND       |
|        |                        |            |            |                |                     |       | diel5              |           |
|        |                        |            |            |                |                     |       |                    | GND       |
|        | l variable             |            |            |                |                     |       | diel6              |           |
| Add    | I Variable             | و لم       | Set values |                | 🗶 Close             |       | <                  | >         |
| Projec | t Status View          |            |            |                |                     |       |                    | 0 X       |
|        |                        |            |            |                |                     |       |                    |           |

Figure 3.4: Editing the shape of the printed circuit board.

|                                                              | ð X |                 |                        | _                              | _         |            | Stackup View      | ß          |
|--------------------------------------------------------------|-----|-----------------|------------------------|--------------------------------|-----------|------------|-------------------|------------|
| ∃ via_to_via_link<br>⊡ Files<br>Board [via_to_via_link_bo    |     |                 | CONMLS - Sta<br>Stacku | ckup Descript<br>up Descriptic |           | + = ×      | Simulation: via_t | o_via_link |
| Stackup [stackup_board.<br>MTL file [tl1.geo]<br>Beard Shape |     | ts for stackup: | mil                    | <b>v</b>                       |           |            | diella            | GNE        |
| Stackup                                                      |     | Label           | Connectivity           | Material                       | Thickness | Тур        | signal1           |            |
| <ul> <li>Components</li> <li>Vias</li> </ul>                 | 1   | plate1          | GND                    | PEC                            | 1         | plane      | diel1b            |            |
| ariables:                                                    | 2   | diella          |                        | FR-4                           | 5.5       | dielectric | plate2 💻          | GNE        |
| Name Value                                                   | 3   | signal 1        | SL1                    | PEC                            | 1         | signal     | diel2             |            |
| freq 1e+008                                                  | 4   | diel1b          |                        | FR-4                           | 5.5       | dielectric | plate3 💻<br>diel3 | GN         |
|                                                              | 5   | plate2          | GND                    | PEC                            | 1         | plane      |                   | GNI        |
|                                                              | < ( |                 |                        |                                |           |            | diel4             |            |
|                                                              |     |                 |                        |                                |           |            | plate5 💻          | GN         |
|                                                              | A   | ppend 🗸 Tota    | I numbers              | *                              | 0         | 🗸 Ok       | diel5             |            |
|                                                              |     |                 |                        |                                |           |            | plate6 💻          | GNE        |
| Add variable                                                 |     | s له            | iet values             |                                | 🗙 Close   |            | diel6             |            |
|                                                              | 252 |                 |                        |                                |           |            |                   | <br>[7     |

Figure 3.5: Editing the layers of the stackup.



Figure 3.6: Definition of a via model.

| File (    | Opti | ions About                       |            |               | CON          | MLS            |            |             |             | ÷.                   | ×                 |
|-----------|------|----------------------------------|------------|---------------|--------------|----------------|------------|-------------|-------------|----------------------|-------------------|
|           | ×    | CPUs: 1                          | 🗋 🗋 🚔      | <b>  </b> + ( | 🔍 🔍 Currer   | nt layer: 1    |            |             |             |                      |                   |
| Project \ | √iev | v                                | 6          | ×             |              |                |            |             | Stackup Vie | w                    | ß×                |
|           | ζ    | ckup<br>up nents<br>Vias<br>au b | nte l      |               |              |                |            |             | Simulation  | via_to_via_<br>• • × |                   |
|           |      |                                  |            |               |              | ia Description |            |             |             | TUA                  | н                 |
| -         |      |                                  |            |               |              |                |            |             |             |                      |                   |
| Variab    |      | Label                            | Туре       | Model         | Connectivity | X position     | Y position | Start layer | End layer   | Start dej            | GND               |
|           | 1    | vial                             | blind      | ✓ st_model    | SL1          | 40             | 100        | plate1      | platell     |                      | ы                 |
| 1 fre     | 2    | via2                             | blind      | ✓ st_model    | SL1          | 160            | 100        | plate1      | signal1     |                      | GND               |
|           |      |                                  |            |               |              |                |            |             |             |                      | <u>3ND</u><br>3ND |
| ۲ مطا     | <    | Append                           | ► Total nu | Imbers        | 1            | ~              | 0          |             | × ×         | »<br>Dk              | 3ND<br>           |
| Project   |      |                                  | به         | Set values    |              |                |            | 🗶 Close     |             |                      | 0 8               |
|           |      |                                  |            |               |              |                |            |             |             | -                    |                   |

Figure 3.7: Placement of vias.

|              | MLSS - Model                                          | ↑ _ □ × |
|--------------|-------------------------------------------------------|---------|
| <u>F</u> ile |                                                       |         |
|              |                                                       |         |
|              | via1, model: st_model                                 |         |
|              |                                                       |         |
|              | plate1_size: 1 mil                                    |         |
|              | diella size: 5,5 mil<br>signal1_size: 1 mil           |         |
|              | di <u>ěl 1b. size: 5.5 mil</u><br>plate2. size: 1 mil |         |
|              | diel2 size: 12 mil                                    |         |
|              | plate3 size: 1 mil                                    |         |
|              | diel3 size: 12 mil                                    |         |
|              | plate4 size: 1 mil                                    |         |
|              | diel4 size: 12 mil                                    |         |
|              | plate5 size: 1 mil                                    |         |
|              | diel5 size: 12 mil                                    |         |
|              | plate6 size: 1 mil                                    |         |
|              | diel6 size: 12 mil                                    |         |
|              | plate7 size: 1 mil                                    |         |
|              | diel7 size: 12 mil                                    |         |
|              | plate8 size: 1 mil                                    |         |
|              | diel8 size: 12 mil                                    |         |
|              | plate9 size: 1 mil                                    |         |
|              | diel9 size: 12 mil                                    |         |
|              | plate10 size: 1 mil                                   |         |
|              | diel10 size: 12 mil                                   |         |
|              | plateri size: i mi                                    |         |
|              |                                                       |         |
|              |                                                       |         |
|              |                                                       |         |

Figure 3.8: Cross-sectional view of via via1.

| <ul> <li>via_to_via_link</li> <li>Files</li> <li>Board (via_to_via_link_bc)</li> <li>Stackup (stackup_board)</li> <li>Board Shape</li> <li>Stackup 2</li> <li>Components</li> <li>Vias</li> <li>Variables:</li> <li>Name Value Coi</li> <li>I freq 1e+008</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CONMLS + _ 🗆 X                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| Project View                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                      |
| • via to, via link       • Files       Simulation: via_to_via_link         Board (via_to_via_link_bo)       • Simulation: via_to_via_link         • Mth.file(11.geo)       • Board Shape         • Board Shape       • If the signal is in the s | 🚰 📕 🕂 🔍 Current layer: 5 🛟                           |
| Files       Board (via to_via link bo)         Stackup [stackup board       Image: stackup board         Mrt file (l1.geo)       Board Shape         Board Shape       Simulation: via_to_via_link         Stackup       Components         Variables:       Image: stackup         Image: freq       1e+008         Image: freq       1e+008                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ම 🕱 Stackup View ම ව                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Cor<br>Cor<br>Cor<br>Cor<br>Cor<br>Cor<br>Cor<br>Cor |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                      |

Figure 3.9: Selecting and viewing the layout of layers in the stackup.

| Project View<br>MTLs<br>MTL Description | CONMLS                                                                                                                                                                                                                                                                   |                                                                                                                                                         | Stackup View 🕑 🗷                                                                                                                |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| MT_ Global Values                       | CONMLS - MTL GLOBA<br>Values for Multiconductor<br>MTL name:<br>Choice of algorithm:<br>Reference to material of conductor:<br>Reference to material of dielectric:<br>Coupling factor, lower limit:<br>Minimum relative deviation of two geometry points<br>Line names: | Transmission Lines          [t]1         [Classical 2D-MTL algorithm, optimized]         [PEC        v]         [FR-4        v]         [0.01       [v] | plate 1 GND<br>diel 1a<br>signal 1 GND<br>diel 2 GND<br>diel 2<br>plate 3 GND<br>diel 3<br>plate 4 GND<br>diel 4<br>plate 5 GND |
| Add variable<br>Project Status View     | <b>₽</b> Save                                                                                                                                                                                                                                                            | 🗶 Close                                                                                                                                                 | diel5<br>plate6 GND<br>diel6 8                                                                                                  |

Figure 3.10: Definition of a multiconductor transmission line (MTL) object.

| C.                                                             | CONML                          | S - MTL Line VALUES              | ↑ □ × | ŕ                      | ×     |
|----------------------------------------------------------------|--------------------------------|----------------------------------|-------|------------------------|-------|
| File Options About                                             | Description of a               | multiconductor transmission line |       |                        |       |
| Project View                                                   | Identifier of line:            | line 1                           |       | Stackup View           | ð×    |
| MTLs                                                           | Units:                         | mil                              | ~     |                        | î     |
| <ul> <li>MTL Description</li> <li>MTL Global Values</li> </ul> | Width of trace:                | 4                                |       | Simulation: via_to_via | _link |
| tl1<br>- MT- times                                             | Thickness of trace:            | 1                                |       | plate1                 | GND   |
| line1                                                          | Height of dielectric at top:   | 5.5                              |       | diel1a                 | _     |
| st_model                                                       | Height of dielectric at bottom |                                  |       | signal1 📼              |       |
| Algorithm Configuration                                        | -                              |                                  |       | diel1b                 |       |
|                                                                | Trace position:                | up                               | ~     | plate2                 | GND   |
|                                                                | Trace coordinates:             |                                  |       | diel2                  |       |
| 1 freq 1e+008                                                  | X Y                            |                                  |       | plate3 diel3           | GND   |
|                                                                | 1 40 100                       |                                  |       | plate4                 |       |
|                                                                | 2 160 100                      |                                  |       | diel4                  | GND   |
|                                                                |                                |                                  |       | plate5                 |       |
|                                                                |                                |                                  |       | diel5                  | GND   |
|                                                                |                                |                                  |       | plate6                 |       |
|                                                                |                                |                                  |       | diel6                  | GND   |
| Add variable                                                   |                                |                                  |       | dielo                  | v     |
| Project Status View                                            |                                |                                  |       |                        | ØX    |
|                                                                | Append V Total numbers         |                                  | Ok    |                        |       |
|                                                                |                                |                                  |       |                        |       |
|                                                                | 🖊 Save                         | 🗶 Close                          |       |                        |       |
|                                                                |                                |                                  |       |                        |       |
|                                                                |                                |                                  |       |                        |       |

Figure 3.11: Editing the traces ('lines') of a multiconductor transmission line object.

|                                                                                                                                                                                                                    |           | CONMLS                 | ↑ _ □ ×                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------------|------------------------------------------------------------------------------------------|
| File Options About                                                                                                                                                                                                 |           |                        |                                                                                          |
| 🔴 💥 CPUs: 1                                                                                                                                                                                                        | े 🗅 😅 📕   | 🕂 🔍 Current layer: 3 🛟 |                                                                                          |
| Project View                                                                                                                                                                                                       | o x       |                        | Stackup View 🛛 🕅                                                                         |
| <ul> <li>via_to_via_link</li> <li>Files</li> <li>Board [via_to_<br/>Stackup [stac</li> <li>MTL file [tll.ge</li> <li>Board Shape</li> <li>Stackup</li> <li>Components</li> <li>Vias</li> <li>Variables:</li> </ul> | kup_board |                        | Simulation: via_to_via_link<br>plate1 GND<br>diel1a<br>diel1b<br>plate2 GND              |
| Name                                                                                                                                                                                                               | Value Coi |                        | diel2                                                                                    |
| 1 freq 1e+0                                                                                                                                                                                                        |           |                        | plate3 GND<br>diel3<br>plate4 GND<br>diel4<br>plate5 GND<br>diel5<br>plate6 GND<br>diel6 |
| Project Status View                                                                                                                                                                                                |           |                        | S 8                                                                                      |

Figure 3.12: Signal layers can be selected from the stackup view to view the routing of traces.

| Project View                                                                   | ð X | _    |                                 |             |       | Stackup View       | ØX         |
|--------------------------------------------------------------------------------|-----|------|---------------------------------|-------------|-------|--------------------|------------|
| Via Models  Algorithm Configuration Completion Configuration Ports Output data |     | F    | CONMLS - Algor<br>Algorithm Cor |             | ↑ □ X | Simulation: via_to | o_via_link |
| Post Processing                                                                |     |      | Name                            | Value       | -     |                    |            |
| <ul> <li>Materials</li> <li>PEC</li> </ul>                                     |     | 1    | airap_top_bot                   | no          |       | diel1b             |            |
| Variables:                                                                     |     | 2    | autoseg_parameter               | S-parameter | ~     | plate2 💻           | GND        |
| Name Value                                                                     | Coi | 3    | bc                              | РМС         | ~     | diel2              |            |
| 1 freq le+008                                                                  |     | 4    | boundary parameter              | S-parameter |       |                    | GND        |
|                                                                                |     |      |                                 |             |       | diel3              |            |
|                                                                                |     | 5    | coax_ext                        | 0.          | _     |                    | GND        |
|                                                                                |     | 6    | rnax ext all                    | VAS         | v v   | diel4              |            |
|                                                                                |     | De   | efault values                   |             |       |                    | GND        |
|                                                                                |     |      |                                 |             |       | diel5              |            |
| <                                                                              | 2   |      | ✓ Save                          | 🗶 Close     |       |                    | GND        |
| Add variable                                                                   | x=  | 27.3 |                                 |             |       | <br>diel6          |            |
|                                                                                |     |      |                                 |             |       |                    |            |
| Project Status View                                                            |     |      |                                 |             |       |                    | đ×         |
|                                                                                |     |      |                                 |             |       |                    |            |

Figure 3.13: Selecting and configuring algorithms, e.g., semi-analytical models.

| File Options About                         |         | CON    | MLS          |                 |          |              | ↑ _ □ X  |
|--------------------------------------------|---------|--------|--------------|-----------------|----------|--------------|----------|
| 🔴 🗶 CPUs: 1 🗘 🎦                            | ጅ 📳 🕂 🔍 | Currer | nt layer: 1  |                 |          |              |          |
| Project View                               | 0 *     |        |              |                 | _        | Stackup View | 0 ×      |
| 🗆 Via Models                               | ^       |        |              |                 |          |              | - î      |
| st_model                                   |         |        | CONML        | S - Parameter S | Sweeping | <b>•</b>     | 🗆 🗙 link |
| Simulation Setup                           |         |        | I            | Parameter Sw    | veeping  |              | GND      |
| Output data<br>Post Processing             |         | Name   | Start        | Stop            | Steps    | Type         |          |
| Materials     PEC                          |         | 1 freq | le+008       | 2e+010          | 200      | linear 🗸     |          |
| Variables:                                 | Col     |        |              |                 |          |              | GND      |
| Name     Value       1     freq     1e+008 |         |        |              |                 |          |              | GND      |
|                                            |         |        |              |                 |          |              | GND      |
|                                            |         | freq   | <b>v</b> ]   | Refresh         |          | Add Sweep    | GND      |
| <                                          | 2       |        | ✔ Set values |                 | ,        | Close        | GND      |
| Add variable                               |         |        |              |                 |          |              | v        |
| Project Status View                        |         |        |              |                 |          |              | 0 ×      |
|                                            |         |        |              |                 |          |              |          |
|                                            |         |        |              |                 |          |              |          |
|                                            |         |        |              |                 |          |              |          |
| Add variable                               | 3       |        | Set values   |                 | 3        | ( Close      | v        |

Figure 3.14: Definition of parameter sweeps.

|                           |               | 01 |             |                |                    |    |       |           | Stackup View      | Ø          |
|---------------------------|---------------|----|-------------|----------------|--------------------|----|-------|-----------|-------------------|------------|
| ⊡ Via Models<br>st mod    |               |    |             | CONMLS         | - Port Description | on |       | ÷         | □ ×               |            |
| Algorithm (<br>Cimulation | Configuration |    |             | P              | ort descriptior    | ١  |       |           | lation: via_t     | o_via_link |
| Ports<br>Output dat       |               | Г  | Port label  | ∨ia label      | Type               |    | Side  | Impedance | diel1a            |            |
| Post Proce<br>Materials   | ssing         | 1  | pl          | vial           | single ende 🗸      | up | V     | 50        | signal1           |            |
| PEC                       |               | 2  | p2          | via2           | single ende 🗸      | up |       | 50        | diel 1b           |            |
| ariables:                 |               | F  | -           |                | []                 |    |       | J,        |                   | GN         |
| Name                      | Value         |    |             |                |                    |    |       |           | diel2             |            |
| freq                      | le+008        |    |             |                |                    |    |       |           |                   | GN         |
|                           |               |    |             |                |                    |    |       |           | diel3             |            |
|                           |               |    |             |                |                    |    |       |           |                   | GN         |
|                           |               |    |             |                |                    |    |       |           | diel4             |            |
|                           |               | ł  | Append 🗸 To | otal numbers 1 | <b>^</b>           |    | 0     | 🔹 🗸 Ok    | plate5 💻<br>diel5 | GN         |
|                           |               |    |             |                |                    |    |       |           |                   |            |
|                           | _             |    |             | Set values     |                    |    | 🗶 Clo | se        | plate6 💻<br>diel6 | GN         |
| Add variable              |               |    |             |                |                    |    |       |           | dielo             | _          |
| ject Status View          |               |    |             |                |                    |    |       |           |                   | (i         |

Figure 3.15: Definition of ports, e.g., via ports and stripline ports.



Figure 3.16: Setting the number of processors to be used (shared memory parallelization).

| File Options About                                                     | CONMLS Post Processing                                 | ↑ _ □ X                                    |
|------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------|
| 🔵 🗶 CPUs: 1 🛟 🗋 😂 📕                                                    | Select values for view with gnuplot                    |                                            |
| Project View                                                           | Sweep Selection                                        | Stackup View 🛛 🖉                           |
| Simulation Setup<br>Ports<br>Potput data                               | Sweep name     eep/Step num       1     freq     sweep | Simulation: via_to_via_link                |
| Post Processing<br>Materials<br>PEC<br>FR-4                            |                                                        | →plate1 → GND<br>diel1a<br>signal1 →       |
| Plots<br>Variables:                                                    |                                                        | diel1b<br>plate2 GND                       |
| Name         Value         Col           1         freq         1e+008 | Gnuplot file: via_to_via_link_out.asc                  | diel2<br>plate3 GND<br>diel3<br>plate4 GND |
|                                                                        | Input port     Output port       1     1               | diel4<br>plate5 GND<br>diel5               |
| Add variable                                                           |                                                        | diel6                                      |
| Project Status View                                                    |                                                        | 0 8                                        |
| Progress [===================================                          | ☐ S parameter in dB<br>Select values ★ Close           | Û                                          |
| Program finished!                                                      |                                                        |                                            |

Figure 3.17: Selection of input and output ports for plotting.

| Gnuplot front-end<br>File Options Ratapprox |        | me/tetr/Softwa | re/mlss- | v2-dev/examp    | les/archive/SIMPLE/Via | _to_via_link | Ϋ́ΟΧ    |
|---------------------------------------------|--------|----------------|----------|-----------------|------------------------|--------------|---------|
|                                             |        | GNUPLOT        | FRONT    | FEND FOR C      | ONCEPT-II              |              |         |
| Title: via_to_via_link                      |        |                |          |                 |                        |              |         |
| X label: freq                               |        |                |          |                 |                        |              |         |
| Y label:                                    |        |                |          |                 |                        |              |         |
| Z label:                                    |        |                |          |                 |                        |              |         |
| Legend position:                            |        | right top      |          |                 |                        | <b>\</b>     |         |
| Number of files                             |        | 1              | Get data | file(s) 🗆 🗆 U   | Jse rel. path Refresh  | n info(s)    |         |
| File name                                   | Take   | Style          | Width    | Color           | Legend title           | Using        | Delet   |
| 1 via_to_via_link_out                       |        | Lines 🗸        |          | red 🗸           | s12, magnitude         | 1:4          | Delete  |
|                                             |        |                | 1        |                 | 1                      |              |         |
|                                             |        |                |          |                 |                        |              |         |
|                                             |        |                |          |                 |                        |              |         |
|                                             |        |                |          |                 |                        |              |         |
| Output to: Gnuplot View                     |        | Settings       | Output   | t file D File p | ame:                   |              | ø<br>g∨ |
| Output to. Onuplot view                     | 1.     | Settings       | outpu    |                 |                        |              | gv      |
| P                                           | ın gnı | uplot          |          |                 | 🚫 Cancel               |              |         |
|                                             | argni  | aproc          |          |                 | Gancer                 |              |         |
|                                             |        |                |          |                 |                        |              |         |

Figure 3.18: The plotting interface. Data may be imported from CONMLS as well as external files. Plots such as Fig. 3.19 can be displayed by clicking on *Run gnuplot*.



Figure 3.19: Transmission of the via-to-via link. The stub causes resonances near 9 GHz and 18 GHz.

# 3.1.2 Example 2: Multilayer Thru Vias

This example features two adjacent vias and can be used to investigate the crosstalk behavior in a multilayer board environment.



Figure 3.20: Main window view of demo scenario 2: two adjacent vias in a multilayer environment.



Figure 3.21: Crosstalk of two adjacent vias in a multilayer environment.

# 3.1.3 Example 3: Pin Field with 64 Vias

To demonstrate the efficiency of the CONMLS code, this example features a via pin field with 64 vias. On a standard office computer, this



Figure 3.22: Main window view of demo scenario 3: a pin field with 64 vias.



Figure 3.23: Crosstalk between the edge via and a central via of the pin field.

# **3.2** Running from Command Line

CONMLS allows for parallelization of computations based on *OpenMP*, a shared memory parallelization scheme. To utilize it, run CONMLS using the command

OMP\_NUM\_THREADS=[num] mlss.2 path/to/config.sim

where *num* sets the number of parallel threads during runtime. A corresponding input argument is available to set the desired number of threads:

```
mlss.2 -n [NUM_THREADS] path/to/config.sim
```

Note that this argument will override the conventional setting through the environment variable *OMP\_NUM\_THREADS*.

If parallelization is to be disabled, CONMLS needs to be explicitly configured to use only one process, e.g.

OMP\_NUM\_THREADS=1 mlss.2 path/to/config.sim

or

```
mlss.2 -n 1 path/to/config.sim
```

22



This chapter introduces the syntax used to configure CONMLS and build models. All files are based on the INI-format implementation available from *TETlib*. The INI-format arranges *attributes* and their respective *values* by means of *sections*:

```
1 [section]
2 #comment
3 attribute = value
```

() While the maximum line length is limited to 1024 characters as of TETlib rev589, whitespaces are automatically discarded and can be used for formatting purposes. Nevertheless, tabs are known to cause issues during processing by the Fortran code and should be avoided.

The input of CONMLS is structured into a algorithm configuration (.sim) and a physical description of the problem consisting of geometry (.geo) and material (.matr) definition, cf. Fig. 1.1. The details and contents of these files are discussed in the following.

# 4.1 Simulation Setup

The simulation setup file (file-extension .sim) is the principal file which is processed by CONMLS. Selection and configuration of algorithms as well as other global runtime options is achieved through this file. If an option is not defined, the program will used a default value. A warning is be issued and printed in the simulation log regarding the selection of a default value. The general structure of a simulation setup is given in Listing 4.1.

The identifier in the *global* section is required for ease of clarity as this type of file may be processed by other software packages that are being developed at the Institute of Electromagnetic Theory. The other sections are (in alphabetical order):

cim\_config This section is specific to the CIM [16] algorithm.

files Referencing of other project files, e.g. geometry definitions. One section only.

global System commands, to be used for control of software environment only. One section.

**output** Configuration of desired output, e.g. output filename and numerical precision of results. One section only.

parameter Selection and configuration of algorithm options. One section only.

sweep Definition of parameter sweep. Multiple instances of this section are allowed.

variables Definition of variables. One section only.

The actual positioning and order of results and attribute definitions in the file is irrelevant to the output of CONMLS and can be chosen ad libitum. However, note that the relative order of

```
Listing 4.1: Generic Simulation Setup File (.sim)
1 [global]
2 # simulation configuration file for mlss.2
3 identifier = mlss.2
4
5 [variables]
• myvar
7 my_2nd_Var
*
                      = 30e-9 * sin(pi/5)
                      = .5 * $myVar$
8
9 [sweep]
10 # name of the variable to be swept
11 name = freq
12 start
                     = 1e8
                     = 4e10
13 stop
= 400
15 # possible sweep types: linear, log
                     = linear
16 type
17
18 [files]
19 geometry
20 stackup
                     = 2d_board_definition.geo
                     = stackup_definition.geo
21 mtl
                     = mtl_definition.geo
22
23 [parameter]
24 autoseg_parameter = 1
25 boundary_parameter = 1
26bc= PMC27frequency= $freq$28method_zpp= crm_single29modesm000
28 meest
                      = 300
                      = 300
31
32 [output]
33 append
                      = 1
34 format
                     = lydite
35 # Output filename. If append==0, this is used as prefix and "_###"
36 # is added to the individual filenames where "###" denotes the
37 # simset index.
38 filename
                      = output_basename
39 precision
                      = double
```

multiple parameter sweep definitions will impact their delineation through CONMLS and as such will impact the automatic indexing on output.



All input will be turned to lower-case letters. This is particularly worth noting, because actual filenames need to be spelled using lower-case letters.

# 4.1.1 Model Parameterization

CONMLS allows for model parameterization by means of variables that can be used as placeholder for constant values as well as parameter sweeps, cf. subsequent section. Declaration and initialization of variables is achieved by means of simple attribute-value pairs in the *variables* section: Variables are available and may be used for the assignment of values throughout

```
1 [variables]
2 # declare a frequency value of 20GHz
3 freq = 20e9
4 # yet another arbitrary value
5 pitch_new = 10
```

the entire simulation setup as well as geometry and material definitions. They are evaluated as complex-valued mathematical expressions, which are not limited to basic operations such as addition, subtraction, multiplication and division. Expressions may contain mathematical functions such as polynomials, exponentials with arbitrary base  $(a^b)$ , exp, sin, cos, tan, and log.

The following example is to demonstrate the utilization of variables by means of frequencydependent material characteristics. Consider the linearly interpolated permittivity

$$\varepsilon_r(f) = 3.6 + 0.2 \frac{40 \,\mathrm{GHz} - f}{40 \,\mathrm{GHz} - 1 \,\mathrm{GHz}}$$

where the frequency f is given in Hertz. The following listing shows the corresponding notation for input to CONMLS:

1 epsilon\_r = 3.6 + .2\*(40e9-\$freq\$)/(40e9-1e9)

Variables are enclosed by dollar symbols. Here, *\$freq\$* denotes the frequency which is subject to a parameter sweep. The permittivity of the given dielectric is linearly interpolated between two known samples  $\varepsilon_r$  (1GHz) = 3.8 and  $\varepsilon_r$  (40GHz) = 3.6.

### 4.1.2 Parameter Sweeping

Listing 4.1 includes a generic parameter sweep. While this example defines only one sweep, multiple instances may be declared. Sweeps declare a variable *name*, start and stop values, the number of steps, as well as the type of steps (linear, log) as shown in the following listing:

```
1 [sweep]
2 # name of the variable to be swept
3 name = freq
4 start = 1e8
5 stop = 4e10
6 steps = 400
7 # possible sweep types: linear, log
8 type = linear
```

Note: the relative order of declaration of sweeps impacts the processing through CONMLS. Ultimately, this affects the indexes that are assigned to the result sets. Given three sweeps A, B, and C with three steps each, Table 4.1 denotes the outcome for two different orderings of declaration.

| Order of Sweep Declaration | Index Pattern                                                                                            |
|----------------------------|----------------------------------------------------------------------------------------------------------|
| A, B, C                    | <b>#1:</b> A1/B1/C1, <b>#2:</b> A1/B1/C2, <b>#3:</b> A1/B1/C3, <b>#4:</b> A1/B2/C1, <b>#5:</b> A1/B2/C2, |
|                            | # <b>27:</b> A3/B3/C3                                                                                    |
| С, В, А                    | <b>#1:</b> C1/B1/A1, <b>#2:</b> C1/B1/A2, <b>#3:</b> C1/B1/A3, <b>#4:</b> C1/B2/A1, <b>#5:</b> C1/B2/A2, |
|                            | #27: C3/B3/A3                                                                                            |

Table 4.1: Numbering of partial results according to interleaving parameter sweeps.

The syntax of the INI-format that CONMLS utilizes allows for number formatting. This may be utilized for discrete selection and thus sweeping of numbered items in the geometry specification. The following example sweeps the variable *plateIdx* over the values 1, 2, 3, and 4. The parameter sweep definition is given in Listing 4.2.

Consider the stackup in Listing 4.3 and the blind vias defined in Listing 4.4. The PCB consists of four cavities which are confined by the metallic layers *pl00* through *pl04*. Via v1 reaches through the first cavity only, i.e. between layer *pl00* and *pl01*. Via v2, on the other hand, ranges down to a variable layer. In order to reproduce the label of the layer in the last argument of the specification, the variable is printed as two-digit integer.

```
Listing 4.2: Advanced parameter sweeping, definition of parameter sweep.

1 [sweep]

2 name = plateIdx

3 start = 1

4 stop = 4

5 steps = 4

6 type = linear
```

| Listing 4.3: Advanced parameter sweeping, geometry definition of stackup: four cavities, the upper most cavity includes a signal layer. |
|-----------------------------------------------------------------------------------------------------------------------------------------|
| 1 [stack]                                                                                                                               |

| 1  | [stack] |   |          |
|----|---------|---|----------|
| 2  | layer1  | = | p100     |
| 3  | layer2  | = | diel01a  |
| 4  | layer3  | = | signal01 |
| 5  | layer4  | = | diel01b  |
| 6  | layer5  | = | pl01     |
| 7  | layer6  | = | diel02   |
| 8  | layer7  | = | p102     |
| 9  | layer8  | = | diel03   |
| 10 | layer9  | = | p103     |
| 11 | layer10 | = | diel04   |
| 12 | layer11 | = | p104     |
|    |         |   |          |

Listing 4.4: Advanced parameter sweeping, geometry definition of vias in board file.

 1
 [vias]

 2
 v1={blind, std, n1, 40, 100, pl00, pl01}

 3
 v2={blind, std, n1, 120, 100, pl00, pl\$plateIdx,i2.2,x\$}

# 4.1.3 Algorithm Configuration

The following options select and configure the algorithms to be used for simulation. The attributes are to be placed in the *parameter* section of the .sim-file.

| <b>airap_top_bot</b> — " <b>airy</b> " <b>antipads</b><br>Assume that antipads in the top and bottom metal layer of a board are filled with air instead of<br>the dielectric material of the respective cavity. This property often applies to manufactured<br>PCBs. Option for research purposes, has not been tested thoroughly. |                                                                                                                                                                                                            |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 1                                                                                                                                                                                                                                                                                                                                  | yes                                                                                                                                                                                                        |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                  | no (default)                                                                                                                                                                                               |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                    | rameter — network parameter representation during cavity segmentation<br>twork parameters to be used for the segmentation of cavities.<br>S-parameter, original formulation, which may be more numerically |  |  |  |  |  |  |
| -                                                                                                                                                                                                                                                                                                                                  | stable (annot. of editor: not sufficiently proven) (default)                                                                                                                                               |  |  |  |  |  |  |
| 3                                                                                                                                                                                                                                                                                                                                  | Y-parameter, faster than S-parameter since no additional parameter conversion (inversion) needs to be conducted                                                                                            |  |  |  |  |  |  |

Boundary conditions to be used at dielectric board edges.

| PEC | perfectly electrically conducting surface at boundary                                      |
|-----|--------------------------------------------------------------------------------------------|
| РМС | perfectly magnetically conducting surface at boundary ( <i>default, for all cavities</i> ) |
| PML | perfectly matched layer surface at boundary                                                |

#### **boundary\_parameter** — network parameter representation for cavity bounds

Choice of network parameters to be used for boundary layer generation. This parameter should be chosen in alignment with *autoseg\_parameter* to avoid unnecessary parameter conversion. Benchmark testing is carried out only for a selection that aligns with *autoseg\_parameter*.

- 1 S-parameter (*default*)
- 3 Y-parameter

## coax\_ext\_all — flag for coaxial port extensions

Select whether to add coaxial extensions to all ports (or only first half of ports, e.g. upper side only) after the simulation.

| 1 | all (default)   |
|---|-----------------|
| 0 | first half only |

#### coax\_ext\_len — length of coaxial port extensions

Length of coaxial extensions to be added to all ports after the simulation (length in mil). This feature may be useful when correlating to results obtained from CST Microwave Studio [17].

[numeric] length of extension (default: 0 mil)

# direct\_ypp — direct calculation of Z<sup>pp</sup>

Instead of calculating the parallel plate impedance  $Z_{pp}$  and subsequently converting the network parameters in order to obtain the parallel plate admittance  $Y^{pp}$ ,  $Y^{pp}$ , the admittances are calculated directly. This spares an inversion and is thus more efficient. Dependencies: only relevant if method = cim\_pml.

| 1 | yes          |
|---|--------------|
| 0 | no (default) |

#### **frequency** — frequency to of operation

Numerical value of operating frequency at which the given geometry is to be considered.

| [mumonia] | fraguanay | of | onoration | for | simulated PCB |
|-----------|-----------|----|-----------|-----|---------------|
| [numeric] | nequency  | 01 | operation | 101 | Simulated FCD |

# gnd\_reduction — reduce gnd vias using Schur's complement (2D)

Vias that are connected to both reference planes of a cavity are eliminated from the  $Z_t ext pp$  matrix of that cavity in an early step of the calculation using the Schur's complement. This is the most efficient option, since it reduces the matrix size for all following operations.

| 1 | yes (default) |
|---|---------------|
| 0 | no            |

#### mem\_reduction — interchange computational steps to save memory

Instead of collecting the data for all cavities and performing the segmentation as a final step, the cavity results are combined as soon as they are available. While this option is deactivated by default (original implementation), it may enforce an early release of allocated memory and reduces the overall memory requirements.

1 yes

0 no (default)

| <b>method_zpp</b> — <b>method for determination of</b> $Z_{pp}$<br>The specified method is used for the calculation of the parallel-plate impedance $Z_{pp}$ . |                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| cim                                                                                                                                                            | Contour integral method for regularly and irregularly shaped PCBs [16]. The boundary conditions may be freely chosen $\in$ {PEC, PMC, PML}.                                                                                                                                                                                                                                      |  |  |
| cim_pml                                                                                                                                                        | Analytical formulation of contour integral method for infinite planes [18]. Solves passivity violations observed with the <i>rwg</i> for via arrays with a small pitch. Numerical effort increases by a factor of about 2 (with <i>direct_ypp</i> option) or a factor of about 3 (without <i>direct_ypp</i> option) in comparison to the <i>rwg</i> . Dependencies: $bc = PML$ . |  |  |
| crm_double                                                                                                                                                     | Cavity resonator model, double summation [19, ch. 2]. Dependencies: $bc \in \{PEC, PMC\}$ .                                                                                                                                                                                                                                                                                      |  |  |
| rwg                                                                                                                                                            | Radial waveguide method [20]. Neglects the size of the second port. Dependencies: $bc = PML$ .                                                                                                                                                                                                                                                                                   |  |  |
| rwg2                                                                                                                                                           | [not implemented yet] – radial waveguide method, including Bessel function for finite size of second port [21] Dependencies: $bc = PML$ .                                                                                                                                                                                                                                        |  |  |

#### modesm — number of modes m for crm\_single and crm\_double

Sets the number of modes *m* to be employed in the cavity resonator method calculation. The required number depends on factors such as the board size and the frequency range. If a high accuracy is required, the convergence should be tested with at least two different values for m. Dependencies: only relevant if method  $\in \{\text{crm}_{double}, \text{crm}_{single}\}$ .

| [numeric]        | number of modes (default: 200)                                            |
|------------------|---------------------------------------------------------------------------|
| modesn — num     | ber of modes n for crm_double                                             |
| Sets the number  | r of modes $n$ to be employed in the cavity resonator method calculation, |
| cf. option modes | <i>m</i> . Dependencies: only relevant if method = crm_double.            |

[numeric] number of modes (default: 200)

# nmodes\_cap — number of modes for via-to-plate capacitance calculation

Sets the number of modes to be during calculation of via-to-plate capacitances. The required number depends on factors such as the antipad and via radius and the frequency range. If a high accuracy is required, the convergence should be tested with at least two different values.

[numeric] number of modes (default: 20)

# nmodes\_pad — number of modes for pad-to-plate calculations

Sets the number of modes to be during calculation of pad-to-plate capacitances. The required number depends on factors such as the pad and via radius and the frequency range. If a high accuracy is required, the convergence should be tested with at least two different values.

[numeric] number of modes (default: 20)

# subtract\_tlc — subtract coaxial capacitance from imported capacitance

Subtract the coaxial capacitance (calculated by CONMLS) from the imported, fixed capacitance values. This is useful if transmission line models are employed to model the coaxial sections of vias, since the transmission line models already take the coaxial capacitance into account. Note: a subtraction is only necessary, if the imported capacitances include the coaxial sections in the first place.

Dependencies:  $tl\_coax = 1$ 

| 1 | yes (default) |
|---|---------------|
| 0 | no            |
|   |               |

# tlcoax —

use transmission line segments to describe coaxial region of vias

| 1 | yes (default) |
|---|---------------|
| 0 | no            |

# **zpp\_red** — reuse the $Z_{pp}$ matrix

All cavities feature the same geometrical via arrangement and have the same height. Recycle the  $Z^{pp}$  of the first cavity for all of the other cavities. Different connectivities of the vias in the respective cavities are accounted for separately.

| 1 | yes                   |
|---|-----------------------|
| 0 | no ( <i>default</i> ) |

# **zpp\_red\_gnd** — reuse the Z<sub>pp</sub> matrix after ground reduction

The prerequisites of the option  $zpp\_red$  are extended by means of same via connectivity in all cavities. The reduced  $Z_{pp}$  is computed only once for all cavities. Dependencies:  $zpp\_red = 1$ .

| 1 | yes                   |
|---|-----------------------|
| 0 | no ( <i>default</i> ) |

# 4.1.4 Configuration of CIM Algorithm

The following options are to be placed in the *cim\_config* section of the .sim-file.

| <b>bc_ho_via</b> — <b>termination of higher order circular modes at vias</b><br>Boundary condition to terminate higher order circular modes at vias. |                                      |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|
| PEC                                                                                                                                                  | perfect electric conductor (default) |  |
| PML                                                                                                                                                  | perfectly matched layer              |  |

# max\_elem\_len — maximum length of a segment

Maximum length of a segment (unit: mm).

[numeric] length value (default: 10)

#### **nmode** — number of higher order circular modes

Specifies the highest order of circular modes that is to be to considered in determining  $Z_{pp}$ .

[numeric] length value (default: 0)

## seg\_per\_wavelen — minimum number of segments per wavelength

Defines the minimum number of segments per wavelength. The algorithm tries to set the number of segments to the given value and increases the amount of segments if subdivision fails.

[numeric] length value (default: 10)

# 4.1.5 Linking Geometry Specifications

The descriptions of the PCB and the stackup are mandatory. The geometrical description of MTLs is subject to choice of transmission line modeling and thus optional.

geometry — name of PCB .geo-file

References a file for the two-dimensional description of a PCB.

[character string] Name of .geo-file (with file-extension).

# stackup — name of stackup .geo-file

References a file for the description of a stackup.

[character string] Name of .geo-file (including file-extension).

#### mtl — name of MTL .geo-file

References a file for the description of the multiconductor transmission lines (MTLs).

[character string] Name of .geo-file (including file-extension).

## 4.1.6 Selection of Output Data

The following options are to be placed in the *output* section of the .sim-file.

#### append — flag for output file multiplicity

no

This flag determines whether all data is to be stored in one file or separate files, i.e. one file per configuration in case of parameter sweeping.

1 yes (default)

0

### format — output file format

Choice of output file format. Results may be stored using the HDF5-based [22] lydite-format, i.e. binary .lyd.h5-files. These files contain additional meta-data, including the entire analysissetup. This format is recommended whenever processing ten or more ports. The file-size is about 30 % of a touchstone(R)-file and less.

lydite (default)

touchstone (to be available as of June 2016)

#### filename — file-/basename of output file

Sets output filename. If *append*==0, this string is used as prefix and "\_###" is added to the individual filenames where "###" denotes the index of the simulation set during parameter sweep operation.

[character string] file-/basename of output file

**precision** — **floating point precision of resulting network parameters** Selection the preferred floating point precision of resulting network parameters.

| double | use double precision floating point numbers |
|--------|---------------------------------------------|
| single | use single precision floating point numbers |

# 4.2 Specification of Board Geometry (2D) and Components

The geometry of the printed circuit board (PCB) under consideration are provided by means of a .geo-file. It contains the units used for the geometrical parameters, the two-dimensional PCB description and as well as the description of components such as vias and transmission lines. Finally, ports are placed in this file.

This file is referenced from the main .sim-file. An illustrative board description is given in Listing 4.5. Valid sections are:

global contains the general header and information for file sanity checks.

ideal\_tls for the placement of ideal transmission lines.

lumped specifies lumped RLC elements.

mstls refers to microstrip transmission lines. Warning: this is an untested feature.

mtls references to separately defined multiconductor transmission lines.

pads places via pads. Warning: this is an untested feature.

**ports** lists all external ports of the system which are to be accessible by means of resulting S-parameters.

shape defines the shape of the PCB under test.

viamodel declares details of via geometry and modeling. Multiple instances of this sections are allowed, e.g. to declare different types of vias.

vias for the geometrical placement and auxiliary specification of vias.

If not stated otherwise, all of these sections may only be placed once in the .geo-file.

```
Listing 4.5: Syntax of a PCB description as .geo-file
1 [global]
2 identifier = mlss.2
3 type = board
4 units
            = mil
5
6 [shape]
7 type = rect
8 \text{ xmin} = 0
9 xmax = 600
10 \ ymin = 0
11 ymax = 2000
12
13 [viamodel]
14 name
                     = std_vmod
  ### via-geometry
15

      16
      via_radius
      = 5

      17
      inner_radius
      = 4

18 #..note that there are n_cavities+1 planes
19 antipad_radius = 15
20 pad_radius_plane = \{10, 0, 0, 0, 10\}
21 pad_radius_signal = 0
22 material
              = copper
23 ### capdef
24 cap_type = auto
25 #..frequency dependency (yes or no)
26 cap_fd = yes
27 #..definition of upper value of via fringing capacitance
_{28} cap_cfu = 0
  #..definition of lower value of via fringing capacitance
29
30 \text{ cap_cfl} = 0
31
32 [mtls]
33 #label={id, layer,netparam,k, nPort,v1_lbl,v2_lbl,...,vN_lbl}
34 mtll ={tll, sig1, y, -0.5, 2, via1, via2}
35
36 [vias]
  #label = {type, model,
37
                              net, Xpos, Ypos}
  vial = {thru, std_vmod, s1, 250, 250}
38
39 via2 = {thru, std_vmod, s1, 350, 250}
40
41 [ports]
42 #label = {via_id, type, side, ref-impedance (w/o function)}
43 via1_up = {via1, se, up,
                                    50}
44 via2_up = {via2, se, up,
                                     50}
45 via1_low = {via1, se, low, 50}
46 via2_low = {via2, se,
                              10w, 50
```

Similar to the .sim-file, a *global* section is mandated for explicitly dedicate this file for use with CONMLS. Furthermore, the type of the geometry description is explicitly stated as well as the units which are to be applied to all geometrical dimensions:

Details of the remaining sections and all supported (as well as some proposed) attributes are

# units — unit for geometry specification

The unit of geometrical specification of the module may be used globally. Several components will use this definition, if not specified otherwise.

[*character string*] Abbreviation of geometrical unit  $\in \{mm, cm, m, mil, inch\}$ .

given in the following sections.

# 4.2.1 Shape

The *shape* section specifies the two-dimensional outline of the PCB.

# type — outline of a printed circuit board

Selects the type of shape for the printed circuit board and its cavities.

| rect | Set board to be rectangular. Additionally, the arguments <i>xmin</i> , <i>xmax</i> , <i>ymin</i> and <i>ymax</i> are required to define the boundary of the board.                                                                                                                                                                                                                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| poly | Irregular/arbitrary plane stack: definition of arbitrarily shaped planes (identical for all cavities). This feature is used in conjunction with the CIM algorithm. Additionally, the arguments <i>xlist</i> and <i>ylist</i> are required to define the x- and y-coordinates of a polyline that curtails the board. Note: the coordinates need to be ordered and listed in mathematical positive direction of rotation, i.e. counter-clockwise. |
| gmsh | Choose to provide a gmsh-file which defines a discretized polyline. This feature is used in conjunction with the CIM algorithm. Additionally, the argument <i>filename_gmsh</i> is required to link the corresponding file. The file is read in and processed within the CIM algorithm, the <i>units</i> setting is subject to consideration therein.                                                                                           |

filename\_gmsh — filename for discretized gmsh-polyline Links a gmsh-file which defines a discretized polyline.

[character string] filename

# gmsh\_entity — contour index that refers to gmsh input file

Physical entity as provided by gmsh, used to select from multiple contours that may be provided in one file.

[numeric] integer value

### **xlist** — **x** reference points

This attribute is used to enter the x-values of the reference coordinates that span the printed circuit board and its cavities:

{val\_1, val\_2, ..., val\_N}

[character string] array of values

#### xmax — upper bound for PCB size in x-direction

Part of a rectangular board definition, cf. type:rect. Should be larger than xmin.

[numeric] double-precision floating point value  $\in (-10^{300}, 10^{300})$ 

# xmin — lower bound for PCB size in x-direction

Part of a rectangular board definition, cf. type:rect. Should be smaller than xmax.

[numeric] double-precision floating point value  $\in (-10^{300}, 10^{300})$ 

# ylist — y reference points

This attribute is used to enter the y-values of the reference coordinates that span the printed circuit board and its cavities:

{val\_1, val\_2, ..., val\_N}

[character string] array of values

#### ymax — upper bound for PCB size in y-direction

Part of a rectangular board definition, cf. type:rect. Should be larger than ymax.

[numeric] double-precision floating point value  $\in (-10^{300}, 10^{300})$ 

### ymin — upper bound for PCB size in y-direction

Part of a rectangular board definition, cf. type:rect. Should be smaller than ymax.

[numeric] double-precision floating point value  $\in (-10^{300}, 10^{300})$ 

## 4.2.2 Via Geometry and Modeling

A via model describes the via geometry, its material, and configures the calculation of via-toplane capacitances. One model may be used multiple times throughout a board description. On the other hand, multiple *viamodel* sections may be defined in order to allow for different vias on a PCB.

The syntax of a *viamodel* section is illustrated in Listing 4.6. Details on valid attributes and respective values are provided in the subsequent list. The geometric parameters are illustrated in Fig. 4.1.



The number of planes  $N_{\text{pl}}$  is the number of cavities plus one  $(N_{\text{cav}} + 1)$ , since the cavities are by means of confining metallic planes.

```
Listing 4.6: Illustrative Via Model
```

```
1 [viamodel]
2 ### general specification
                    = my_via_model
3 name
  material
                    = copper
4
  ### geometry
5
6 via_radius
                    = 5
                    = 4
7 inner_radius
8 #..stating equal antipad radius for all layers, ..
9 antipad_radius
                   = 15
10 #..plane pad radius > 0 only at top and bottom (5 layers), ...
n pad_radius_plane = {10, 0, 0, 0, 10}
  #..and the same (no) signal pad radius for all signal layers
12
13 pad_radius_signal = 0
14 ### parameters that concern the capacitance calculation
15 cap_type = auto
16 #frequency dependency (yes or no)
17 cap_fd
                    = yes
18 #definition of upper value of via fringing capacitance
                    = 0
19 cap_cfu
20 #definition of lower value of via fringing capacitance
21 cap_cfl
                    = 0
```



Figure 4.1: Geometry of a via model, cross-sectional view.

An essential part of via models are via-to-plane capacitances that are used to represent the interaction between via barrel and reference planes, cf. Figure 4.2. Attributes with prefix *cap\_* concern the algorithms to be used for determining the via-to-plane capacitances.



Figure 4.2: Via-to-plane capacitances in a via model. The capacitance  $C_{VPC}$  refers to the via-to-plane capacitance.

| Geometry para | <b>s</b> — radius of dielectric antipad<br>meter as specified in Fig. 4.1. A range of $N_{pl}$ values may be given to set<br>for each plane that is pierced. If only one value is given, it is used for all                                                                                                     |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [numeric]     | Set value(s) with regard to chosen <i>unit</i> specified in .geo-file of board geometry.                                                                                                                                                                                                                        |
|               | uency dependency<br>ndency of analytical values                                                                                                                                                                                                                                                                 |
| yes           | Do account for frequency dependent behavior of the via-to-plane ca-<br>pacitances.                                                                                                                                                                                                                              |
| no            | No frequency dependence, use the value determined at <i>fmin</i> for all frequencies. Experience showed, that the capacitances hardly change in the considered frequency ranges. On the other hand, the frequency dependency may be included at almost no cost (calculated once per capacitance-specification). |

## cap\_cfl — lower fringing capacitance

The lower fringing capacitance is the capacitance due to electric field lines through air (outside the PCB) at a lower via end. It may be required to accurately model open terminations in some cases, especially for thin PCBs (only one or a few layers). It is given as a fixed value for all capacitance types and is added to the respective computed or given values.

*[numeric]* Set value of lower via fringing capacitances.

#### cap\_cfu — upper fringing capacitance

The upper fringing capacitance is the capacitance due to electric field lines through air (outside the PCB) at a lower via end. It may be required to accurately model open terminations in some cases, especially for thin PCBs (only one or a few layers). It is given as a fixed value for all capacitance types and is added to the respective computed or given values.

| <b>cap_type</b> — sou<br>Selection of calc | urce for values<br>sulation method for the via near-field model.                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| auto                                       | Use via barrel-to-plane capacitances calculated from analytical formulas available in the CONMLS code based on [23]. Possibly specified fixed values will be ignored.                                                                                                                                                                                                                                                                                  |
| auto2                                      | This option is based on the coaxial to radial waveguide junction model<br>described in [24], using only the elements which correspond to the via<br>barrel-to-plane capacitances. This option may be interesting for studies<br>in a research context. For practical investigations, the option <i>wg_junc</i><br>should be preferred, which uses the more accurate full waveguide<br>junction model. Possibly specified fixed values will be ignored. |
| fix                                        | Use fixed values as defined in the .cap-file. Values may be given as<br>samples with regard to frequency to account for a frequency-dependent<br>behavior. This option can be used to import capacitance values extracted<br>with an external tool.                                                                                                                                                                                                    |
| semiauto                                   | Automatic computation (similar to <i>auto</i> ) for entries assigned with 1, others assumed as fixed values. Used e.g. for buried via models Number of capacitances given should be consistent with the stackup definition.                                                                                                                                                                                                                            |
| wg_junct                                   | Coaxial to radial waveguide junction model based on [24]. The mode<br>uses additional elements (frequency dependent admittances and an idea<br>transformer) to model the via near-field more accurately. This model<br>gives the most accurate results, without (noticeably) increasing the<br>computation time.                                                                                                                                       |

[numeric] Set value with regard to chosen *unit* specified in .geo-file of board geometry.

### material — name of .matr-file

References a files for the definition of the conducting material which the via is made of.

[character string] Name of .matr-file (without file-extension).

#### name — identifier of via model

Name of via model for ease of referencing in other parts of the problem description.

[character string] name of via model.

#### pad\_radius\_plane — radius of pad via within reference planes

Geometry parameter as specified in Fig. 4.1. A range  $N_{pl}$  of values may be given to set different radii for each plane that is pierced. If only one value is given, it is used for all cavities.

[numeric] Set value with regard to chosen *unit* specified in .geo-file of board geometry.

#### pad\_radius\_signal — radius of pad via within signal layers

Geometry parameter as specified in Fig. 4.1. A range of  $N_{\rm pl}$  values may be given to set different radii for each plane that is pierced. If only one value is given, it is used for all cavities. Note: except for special cases, signal pads will be ignored in the calculation!

[numeric] Set value with regard to chosen *unit* specified in .geo-file of board geometry.

#### via\_radius — outer radius of via barrel

Geometry parameter as specified in Fig. 4.1. A range of  $N_{cav}$  values may be given to set different radii within each cavity. If only one value is given, it is used for all cavities.

[*numeric*] Set value with regard to chosen *unit* specified in .geo-file of board geometry.

### 4.2.3 Via Placement

Vias are placed using a *vias* section of the board description (.geo-file). The general syntax for the array that specifies a via is {[type], [model], [connectivity/net], [xpos], [ypos], [start\_layer]<sup>1</sup>, [end\_layer]<sup>1</sup>, [start\_depth]<sup>2</sup>, [end\_depth]<sup>2</sup>}, where

<sup>1</sup> applies to buried, blind, and stripline probes only, and

 $^2$  applies to buried vias only. The values specify the penetration depth for the first and last layer, respectively (e.g. 0.5).

```
1 [vias]
2 #label = {type, model, net, Xpos, Ypos[, pFrom, pTo, d0, d1]}
3 via_thru = {thru, vmod, s1, 0, 0}
4 via_blind = {blind, vmod, s1, 40, 0, pFrom, pTo}
5 via_buried = {buried, vmod, s1, 40, 40, pFrom, pTo, d0, d1}
6 via_slprobe = {slprobe, generic, 0, 40, pFrom, pTo}
```

Valid types of vias are:

thru A via that range from the upper most layer down to the bottom of the stackup. Syntax:

1 label={thru, model, net, xpos, ypos}

**blind** A backdrilled via, that does not range down to the bottom of the stackup. Syntax:

1 label={blind, model net, xpos, ypos, start\_layer, end\_layer}

**buried** Vias that are enclosed within the stackup, i.e. do not necessarily reach top or bottom of the stackup. Syntax:

1 label={buried, model, net, xpos, ypos, start\_layer, end\_layer, start\_depth, end\_depth}

**slprobe** Available as of rev560 for S-parameter-based segmentation [7, 8]. This type is not a physical via. It terminates a stripline without the need of placing an actual via. This type currently does not require a model (the model can be anything, the string is currenly ignored).

Syntax:

```
1 label={slprobe, generic, xpos, ypos, start_layer, end_layer}
```

Application notes: Stripline probes (probe-vias) are located at the end of a single stripline and exist only within one cavity. Thus, the description by means of  $Z_{pp}$  is not the same for all cavities. Functionality for the reduction of memory (e.g. Zpp\_reduction) are not available if this type of via is used. Furthermore, a network description and handling by means ABCD-parameter has not been tested for the segmentation of cavity/ $Z_{pp}$  and transmission lines.

Due to legacy reasons, stripline ports (slports) do not make use of the conventional current/voltage definition near ports, i.e. current flowing *into* the network. Instead, the current features a phase shift of 180°. This needs to be considered if the obtained S-parameter are to be used in subsequent simulations, e.g. using TiDE.

## 4.2.4 Ideal Transmission Lines

Ideal transmission lines between two vias, with dielectric losses but without conductor loss. This type of transmission line is the fastest during calculation because it is based on analytical expressions. They may be specified in the *ideal\_tls* section of the board description (.geo-file) according to the syntax

```
1 [ideal_tls]
2 label={type, layer, startVia, endVia, width, lenght, k, Z0}
```

Valid types include

Single ended Single ended transmission lines

Type: se

where *k* denotes the coupling factor for the modal decomposition [25, 26, 27] and  $Z_0$  is the characteristic impedance of the transmission line

The *layer* corresponds to the label in the stackup layer as opposed to the implementation in its predecessor VPF, in which it corresponds to the interconnect identifier.

#### 4.2.5 Microstrip Transmission Lines (untested)

Microstrip lines may be specified in the *mstls* section of the board description (.geo-file) according to the syntax

```
1 [mstls]
2 label={type, side, origin, end, width, lenght, L}
```

This feature is currently not subject to code testing and validation. For more details refer to the latest source code from the subversion repository.

40

## 4.2.6 Multiconductor Transmission Lines

Multiconductor (coupled) transmission lines (MTLs) are specified in a separate .geo-file as discussed below. They are referenced in the *mtls* section of the board description (.geo-file) according to the syntax

```
1 [mtls]
2 #label={id, layer, netparam, k, nPort, vial_lbl, ..., viaN_lbl}
3 my_mtl={id, signal3, y, -0.5, 4, vial, via2, via3, via4}
```

where the value of *id* refers to the unique identifier that is given to the geometry specification in the separate .geo-file. By this, repeating transmission lines and their corresponding network parameters are reused during time of simulation. Each MTL is characterized only once using the code 2D-MTL of Concept-II which is included as external module.

The *layer* specifier refers to the stackup to obtain the geometry and material of the considered cavity, cf. 4.3. The value of *netparam* is currently expected to equal "y" and is a placeholder for future extension. The modal decomposition factor k depends on the relative positioning of the trace within the substrate, cf. [25, 26, 27]. While k is implicitly given by the stackup, it can be entered separately due to historic reasons.

Finally, the number *nPort* indicates the number of single-ended ports of the considered MTL, followed by the corresponding amount of references to vias that are to be connected to the MTL, cf. Figure 4.3.



Figure 4.3: MTL geometry specification and simple MTL example with four vias/ports.

#### MTL Specification in Separate .geo-file

All MTL-systems are defined in one .geo-file of type *mtl*. This file is linked to the project by means of the attribute *mtl* in the *files* section of the configuration in the .sim-file:

1 [files]
2 mtl = mtl\_filename.geo

The MTL .geo-file of may contains the description of all multiconductor transmission lines in scope that are to be simulated using the 2D-MTL algorithm. The description allows to define irregular traces with mixed coupled and uncoupled segments, which are interpreted and treated in the mtl\_seg module (see [12]). Listing 4.7 provides an illustrative example for the syntax with regard to the system depicted in Figure 4.3.

As before, a *global* section provides sanity information regarding the content of the file, cf. illustrative example in Listing 4.7. The file may contain one or more *mtl* sections and one or more linked *line* sections, which are used to specify independent MTL-systems. The *mtl* sections contain the following information:

#### kc — coupling factor, lower limit

Lower limit for estimation of minimum coupling considered among adjacent conductors. Must be below 0.1.

[numeric] sets the lower limit for  $k_c$ 

## line — identifier of traces (lines) that are part of the MTL

Multiple attributes may be used to reference multiple traces that are to be considered during the same simulation, e.g. to consider coupling.

[character string] identifier

## matr\_cond — reference to material specification of conductor Reference to conductor material specification.

[character string] name of the conducting material

## matr\_diel — reference to material specification of dielectric Reference to dielectric material specification.

name of the dielectric [character string]

### mode — choice of algorithm

Determines the algorithm to be used.

| 1 | classical 2D-MTL algorithm, optimized                                                               |
|---|-----------------------------------------------------------------------------------------------------|
| 2 | non-optimized 2D-MTL (untested)                                                                     |
| 3 | Runge-Kutta (untested)                                                                              |
| 4 | reuse identical cross-sections (using look-up table), can speed up simulation by 30 $\%$ to 50 $\%$ |

## name — identifier of MTL system

This identifier is used to reference the MTL system from the board description.

[character string] identifier

## rfactor — minimum relative deviation of two geometry points

Sets the minimal trace length to be considered.

sets the resolution [numeric]

Note that the *mtl* section may link to one or more *line* sections that define the geometry of the TLs. Each *line* sections contains the following attributes and values:

height\_diel\_bot — height of dielectric between trace center and lower reference plane This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

height\_diel\_top — height of dielectric between trace center and upper reference plane This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

## name — identifier of line

This identifier is used to reference the line system from the MTL description.

[character string] identifier

#### **p** — reference point

This attribute is used to enter the 2D coordinates of the trace center. As least two reference points are required to define a trace. Points are connected in order of their respective index:

{index, xpos, ypos}

[character string] array of values

#### thickness\_l — left-hand thickness of trace

This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

#### thickness\_r — right-hand thickness of trace

This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

#### units — unit for geometry specification

The unit of geometrical specification of a model are given explicitly.

[*character string*] Abbreviation of used unit  $\in \{mm, cm, m, mil, inch\}$ .

## width\_bot — bottom width of trace

This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

## width\_top — top width of trace

This value specifies a geometrical parameter of the trace, cf. Figure 4.3.

[numeric] dimension: length

|    |                             | a .geo-file for MTL description. |
|----|-----------------------------|----------------------------------|
| 1  | [global]                    |                                  |
| 2  | <pre>identifier = ml;</pre> | ss.2                             |
| 3  | type = mt                   | 1                                |
| 4  | [mtl]                       |                                  |
| 5  | name =                      | mtl_seg_test2                    |
| 6  | mode =                      | 1                                |
| 7  | <pre>matr_cond =</pre>      | copper                           |
| 8  | <pre>matr_diel =</pre>      | meg                              |
| 9  | kc =                        | 0.001                            |
| 10 | rfactor =                   | 0.01                             |
| 11 | line =                      | line1                            |
| 12 | line =                      | line2                            |
| 13 | [line]                      |                                  |
| 14 | name                        | = line1                          |
| 15 | units                       | = mil                            |
| 16 | width_top                   | = 4                              |
| 17 | width_bot                   | = 4                              |
| 18 | height_diel_top             |                                  |
|    | height_diel_bot             | = 6                              |
|    | thickness_1                 | = 1                              |
| 21 | thickness_r                 | = 1                              |
| 22 | P                           | $= \{1, 0, 0\}$                  |
| 23 | P                           | $= \{2, 46, 46\}$                |
| 24 | P                           | = {3, 46, 1454}                  |
| 25 | P                           | = {4, 0, 1500}                   |
| 26 | [line]                      |                                  |
| 27 | name                        | = line2                          |
| 28 | units                       | = mil                            |
| 29 | width_top                   | = 4                              |
| 30 | width_bot                   | = 4                              |
| 31 | height_diel_top             |                                  |
| 32 | height_diel_bot             |                                  |
|    | thickness_1                 | = 1                              |
| 34 | thickness_r                 | = 1                              |
| 35 | P                           | $= \{1, 100, 0\}$                |
| 36 | P                           | $= \{2, 54, 46\}$                |
| 37 | P                           | $= \{3, 54, 1454\}$              |
| 38 | P                           | $= \{4, 100, 1500\}$             |

44

## 4.2.7 Lumped Elements

Lumped elements, that is, 1-port RLC series or parallel networks, may be specified in the *lumped* section of the board description (.geo-file) by means of the syntax

```
1 [lumped]
2 label={type, layer, via, R_value, L_value, C_value}
```

Types: RLCser, RLCpar fixed values given for R,L, C elements connected to one via port in series or parallel, respectively. Useful to define e.g. terminations and decoupling capacitors.

**R** Lumped elements are placed between a via and the corresponding layer at which they are placed. A short circuit can be defined using the parallel-type lumped elements with R = L = 0 and  $C = 1 \neq 0$ , e.g.

```
short = {RLCpar, myLayer, myViaPort, 0, 0, 1}
```

Only one lumped element, that is, one set of R, L, and C is supported per location. The algorithm does not issue a warning in case there is more than one set of lumped elements connected. It is not clear, if only the first or all sets of elements are included in the simulation.

## 4.2.8 Pads (untested)

Pads may be specified in the *pads* section of the board description (.geo-file) by means of the syntax

```
1 [pads]
2 label={type, layer, via, pshape, size, cup, clow}
```



This feature is currently not subject to code testing and validation. For more details refer to the latest source code from the subversion repository.

## 4.2.9 Ports

Ports may be specified in the *pads* section of the board description (.geo-file) by means of the syntax

```
1 [ports]
2 label = {viaref, type, side, impedance}
```

In case the results are written to the HDF5-based lydite-format, the label is stored as well for ease of reference.

Valid types of ports are:

Single ended Single ended ports

Type: se

Valid sides for ports are:

**Upper side** Ports located on the upper side of the stackup. Note stripline-ports are always located at the upper side. Type: *up*  Lower side Ports located on the lower side of the stackup.

Type: low

As of the current revision, the reference impedance is without impact. The algorithm assumes a reference impedance of  $50\Omega$  during network parameter conversion.



Stripline ports that terminate microstrip lines are feasible in general. However, this feature has not been tested or validated until now and is considered to be experimental.

## 4.3 Stackup Geometry

The stackup is defined in a .geo-file of type *stackup* and is linked from the configuration .sim-file. As illustrated in Listing 4.8, the *global* section includes sanity check information as well as the unit of the length dimensions throughout the file:

## units — unit for geometry specification

The unit of geometrical specification of a model are given explicitly.

[*character string*] Abbreviation of used unit  $\in \{mm, cm, m, mil, inch\}$ .

The *stack* section lists all layers. A continuous index is appended to the keyword *label* to specify the relative location of a layer in the stack, cf. Listing 4.8. Each layer is subsequently specified in a separate *layer* section. Some attributes may depending on the type the layer (dielectric, plane, signal):

#### connectivity — identifier of connecting net

Reference to the net to which the plane or signal layer is connected. This attribute is without function in case of a dielectric layer.

*[character string]* name of the material

## material — reference to material specification

Reference to conductor or dielectric material specification.

[character string] name of the material

### name — identifier of layer

This identifier is used to reference the layer in the *stack* section of the stackup description.

[character string] identifier

### thickness — layer thickness

This value defines the thickness of the layer in accordance with the unit that is defined in the *global* section of the stackup .geo-file.

[numeric] dimension of length

| <b>type — functionality of layer in stackup</b><br>Select the functionality of the layer within the given stackup. The value may be one of the following: |                                                                                                                                         |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| dielectric                                                                                                                                                | Dielectric layer.                                                                                                                       |  |
| plane                                                                                                                                                     | Conducting reference plane.                                                                                                             |  |
| signal                                                                                                                                                    | This is a placeholder for a signal layer. The thickness of this layer is filled using the dielectric of the adjacent dielectric layers. |  |

```
Listing 4.8: Illustrative stackup description using a .geo-file
1 [global]
2 identifier = mlss.2
3 units = mil
4 type
            = stackup
5
6 [stack]
7 layer1 = power1
8 layer2 = diella
9 layer3 = signal1
10 layer4 = diel1b
11 layer5 = power2
12
13 [layer]
         = diel1a
= dielectric
14 name
15 type
16 material = meg
17 thickness = 5.5
18 [layer]
19name= diel1b20type= dielectric
21 material = meg
22 thickness = 5.5
23
24 [layer]
        = power1
= plane
25 name
26 type
27 connectivity = gnd
28 thickness = 1
                = copper
29 material
30 [layer]
31 name
                 = power2
              = plane
32 type
33 connectivity = gnd
34 thickness = 1
35 material = copper
36
37 [layer]
38 name
                = signal1
         = signal
= signal
39 type
40 connectivity = sl1
41 thickness = 1
42 material = copper
```

## 4.4 Material Specification

The .matr-files are used to define material parameters and may be frequency dependent, cf. remark below. The syntax behaves according to the generic examples given in Listings 4.9 and 4.10. The filenames are referenced from stackup, via models, as well as external MTL algorithm. They need be spelled lower case.

```
Listing 4.9: Generic Conductor Description in a .matr-file.

      1
      [global]

      2
      identifier = mlss.2

      3
      type = conductor

      4
      # Material definition for Copper (frequency independent)

      5
      [properties]

      6
      conductivity = 5.8e7

      7
      mu_r = 1
```

```
Listing 4.10: Generic Dielectric Description in a .matr-file.

      [global]

      identifier = mlss.2

      type = dielectric

      # Material definition for Megtron (frequency independent)

      [properties]

      tand = 0.02

      epsilon_r = 3.8

      mu_r = 1
```

**R** Variables are enclosed by dollar symbols. In the following example, *\$freq\$* denotes the frequency which is subject to a parameter sweep. The permittivity of the given dielectric is linearly interpolated between two known samples  $\varepsilon_r$  (1 GHz) = 3.8 and  $\varepsilon_r$  (40 GHz) = 3.6.

48



Interested in working with the full version of CONMLS? To request a Windows license file from the contact person, you will need to name the MAC-address and the C: drive volume number of the computer to be used. This information can be obtained from the command prompt using the commands:

```
pconfig /all
```

and

vol c:

Alternatively, the script mlss\_cpuinfo.exe in the CONMLS binary directory can be used to automatically generate a text file containing this information.

## **3rd-Party Packages**

CONMLS uses the following 3rd-Party packages:

- Qt 4.8.6
  - LGPL
  - https://www.qt.io/download-open-source/#section-2
  - The usage of the software is according to the GPL and the LGPL (see below).
- HDF5 1.8.12
  - BSD
  - http://www.hdfgroup.org/products/licenses.html
- Inno Setup Compiler 5.5.5
  - http://www.jrsoftware.org/isinfo.php

For details on the respective licenses/copyrights see the files in the directory *\$INSTALLA-TION\_DIRECTORY/licenses*. Text files of the GPL and the LGPL are included (gpl.txt, lgpl.txt).

## Contact

For license generation, assistance, or questions please contact:

Technische Universität Hamburg (TUHH) Institut für Theoretische Elektrotechnik c/o Dr.-Ing. Heinz-D. Brüns (bruens@tuhh.de) Harburger Schloss Str 20 21079 Hamburg

# Germany

WWW.TET.TUHH.DE



- [1] S. Chapman, *Fortran 95/2003 for scientists & engineers*, 3rd ed. New York, USA: McGraw-Hill, 2008.
- [2] Mathworks Corporation. (2009) Matlab ver. 2009. Natick, MA. [Online]. Available: http://www.mathworks.com
- [3] R. Rimolo-Donadio, *Via Pin Field (VPF)-Tool Documentation*, Institut of Electromagnetic Theory, Hamburg University of Technology, Hamburg, Germany, 2010, internal document.
- [4] R. Rimolo-Donadio, "Development, validation, and application of semi-analytical interconnect models for efficient modeling of multilayer substrates," Ph.D. dissertation, Hamburg University of Technology, Hamburg, Germany, 2010.
- [5] R. Rimolo-Donadio, X. Gu, Y. Kwark, M. Ritter, B. Archambeault, F. de Paulis, Y. Zhang, J. Fan, H.-D. Brüns, and C. Schuster, "Physics-based via and trace models for efficient link simulation on multilayer structures up to 40 GHz," *IEEE Transactions on Microwave Theory and Techniques*, vol. 57, no. 8, pp. 2072–2083, Aug. 2009.
- [6] R. Rimolo-Donadio, A. Stepan, H.-D. Brüns, J. Drewniak, and C. Schuster, "Simulation of via interconnects using physics-based models and microwave network parameters," in *Signal Propagation on Interconnects (SPI)*, 12th IEEE Workshop, May 2008.
- [7] T. Reuschel, S. Müller, and C. Schuster, "Segmented physics-based modeling of multilayer printed circuit boards using stripline ports," *IEEE Transactions on Electromagnetic Compatibility*, vol. 58, no. 1, pp. 197–206, Feb. 2016.
- [8] T. Reuschel, M. Kotzev, D. Dahl, and C. Schuster, "Modeling of differential striplines in segmented simulation of printed circuit board links," in *IEEE Int. Symp. Electromagn. Compat. (EMC)*, Ottawa, ON, Canada, Jul. 2016.
- [9] EIA/IBIS Open Forum, "Touchstone (.SnP) file format specification. Rev 1.1," http://vhdl.org/ibis/connector/touchstone\_spec11.pdf, Mar. 2014.
- [10] A. J. Stepan, "Implementation of a matlab-code for high-frequency via pin field simulation in printed circuit boards," Bachelorarbeit, TUHH, 2008.
- [11] D. Timmermann, "Implementation of efficient algorithms for parallel-plate impedance calculation," Studienarbeit, TUHH, 2009.
- [12] C. Schuster, "STL-Toolbox: A collection of Matlab functions for S-Parameters, T-Lines and Links," Aug. 2006.

- [13] X. Duan, R. Rimolo-Donadio, H.-D. Brüns, and C. Schuster, "A combined method for fast analysis of signal propagation, ground noise, and radiated emission of multilayer printed circuit boards," *IEEE Transactions on Electromagnetic Compatibility*, vol. 52, no. 2, pp. 487–495, May 2010.
- [14] H. Färber, "Segmentierte Modellierung gekoppelter Mehrfachstreifenleitungen auf Leiterplatten," Bachelorarbeit, TUHH, 2011.
- [15] S. Müller, "Including multiconductor transmission lines in a quasi-analytical model for multilayer structures," Diplomarbeit, TUHH, 2009.
- [16] Xiaomin Duan, R. Rimolo-Donadio, H.-D. Brüns, and C. Schuster, "Circular ports in parallel-plate waveguide analysis with isotropic excitations," *IEEE Transactions on Electromagnetic Compatibility*, vol. 54, no. 3, pp. 603–612, Jun. 2012.
- [17] CST. Microwave studio. Darmstadt, Germany. [Online]. Available: http://www.cst.com
- [18] X. Duan, R. Rimolo-Donadio, S. Müller, K. J. Han, X. Gu, Y. H. Kwark, H.-D. Brüns, and C. Schuster, "Impact of multiple scattering on passivity of equivalent-circuit via models," in 2011 IEEE Electrical Design of Advanced Packaging and Systems Symposium (EDAPS), Hanzhou, China, Dec. 12–14, 2011.
- [19] T. Okoshi, *Planar Circuits for Microwaves and Lightwaves*, ser. Springer Series in Electrophysics. Berlin and Heidelberg: Springer Berlin Heidelberg, 1985, vol. 18.
- [20] J. Parker, "Via coupling within parallel rectangular planes," *IEEE Transactions on Electro-magnetic Compatibility*, vol. 39, no. 1, pp. 17–23, Feb. 1997.
- [21] A. R. Chada, Y. Zhang, G. Feng, J. L. Drewniak, and J. Fan, "Impedance of an infinitely large parallel-plane pair and its applications in engineering modeling," in 2009 IEEE International Symposium on Electromagnetic Compatibility - EMC 2009, Austin, TX, USA, Aug. 17–21, 2009, pp. 78–82.
- [22] *HDF5 Reference Manual*, Release 1.8.8 ed., The HDF Group, Nov. 2011. [Online]. Available: http://www.hdfgroup.org/HDF5/doc/PSandPDF/HDF5\_RefManual.PDF
- [23] Yaojiang Zhang, J. Fan, G. Selli, M. Cocchini, and F. d. Paulis, "Analytical evaluation of viaplate capacitance for multilayer printed circuit boards and packages," *IEEE Transactions* on *Microwave Theory and Techniques*, vol. 56, no. 9, pp. 2118–2128, Sep. 2008.
- [24] A. G. WILLIAMSON, "Radial-line/coaxial-line junctions: analysis and equivalent circuits," *International Journal of Electronics*, vol. 58, no. 1, pp. 91–104, 1985.
- [25] E. Engin, W. John, G. Sommer, W. Mathis, and H. Reichl, "Modeling of striplines between a power and a ground plane," *IEEE Transactions on Advanced Packaging*, vol. 29, no. 3, pp. 415–426, Aug. 2006.
- [26] A. Ege Engin, K. Bharath, K. Srinivasan, and M. Swaminathan, "Modeling of multilayered packages and boards using modal decomposition and finite difference methods," in *IEEE Int. Symp. Electromagn. Compat. (EMC)*, vol. 3, Portland, OR, USA, Aug. 2006, pp. 646–650.
- [27] R. Rimolo-Donadio, H.-D. Brüns, and C. Schuster, "Including stripline connections into network parameter based via models for fast simulation of interconnects," in *Int. Zurich Symp. Electromagnetic Compatibility*, Zurich, Switzerland, Jan. 2009.

- [28] A. Arsenovic et al. (2014) scikit-rf. [Online]. Available: http://www.scikit-rf.org
- [29] S. Zhang and J.-M. Jin, *Computation of Special Functions*, 1st ed. New York, NY, USA: John Wiley & Sons, Inc., 1996.