Qt-based GUI for electromagnetic (EM) simulations Developed at IHP Microelectronics
EMStudio is a Qt-based desktop application for preparing, visualizing, and managing electromagnetic simulations.
It provides an integrated workflow for:
- Loading GDS layout data
- Choosing substrate stacks (dielectrics, metals, layers)
- Visualizing a 2.5D cross-section
- Configuring simulation parameters
- Generating configuration files for EM solvers (OpenEMS, Palace)
- Editing Python driver scripts with syntax highlighting
- Running simulations and streaming log output
- Cross-platform Qt GUI (Linux & Windows)
- GDS reader (
gdsreader.cpp) - Substrate & material model
- 2.5D stack visualization (
substrateview) - Python script editor with syntax highlighting & autocompletion
- Python/Palace parser with JSON configuration
- QtPropertyBrowser-based parameter editor
- Preferences dialog (paths, solver settings, Python interpreter)
- Command-line interface for automation
A ready-to-use Windows installer is produced by the CI pipeline.
You can download it from GitHub → Actions → Workflows → latest successful run.
In the workflow artifacts (job build-windows) you will find the Windows installer.
Linux users typically build EMStudio from source (see below).
cd /path/to/EMStudio
qmake EMStudio.pro
make -j$(nproc)
./EMStudiocd \path\to\EMStudio
qmake EMStudio.pro
nmake
.\release\EMStudio.exeEMStudio integrates with external electromagnetic solvers.
For full functionality, these tools must be installed separately by the user.
Please ensure the solvers are available in your PATH, or configure their locations explicitly in the EMStudio settings.
EC-FDTD electromagnetic solver.
- Project page: https://www.openems.de/
- Documentation: https://docs.openems.de/
- Source code & build instructions: https://github.com/thliebig/openEMS-Project
Parallel finite-element electromagnetic solver.
- Project page & documentation: https://awslabs.github.io/palace/
- Source code: https://github.com/awslabs/palace
You can launch EMStudio.exe directly or via terminal:
EMStudio.exe [options] [run_file.json]-
-gdsfile <path>
Path to GDS file -
-topcell <name>
Top-level GDS cell
EMStudio.exe -gdsfile "C:/Work/design.gds" -topcell "top"EMStudio can be launched directly from KLayout through the helper script:
scripts/klEmsDriver.py
- Save
klEmsDriver.pyinside your EMStudio installation directory. - (Optional) Add EMStudio directory to your system PATH.
- Launch KLayout with:
"<path>\klayout_app.exe" -e -rm "<path>\EMStudio\scripts\klEmsDriver.py"- Right-click → New → Shortcut
- Set target:
"<Path to KLayout>\klayout_app.exe" -e -rm "<Path to EMStudio>\scripts\klEmsDriver.py"
- Name it e.g. EMStudio via KLayout
- (Optional) Change the icon:
icons/logo.ico
EMStudio can be launched directly from KLayout if you start KLayout using one of the scripts provided in the EMStudio scripts directory:
KLayout.batfor WindowsKLayout.shfor Linux
This will find your KLayout installation by searching the PATH, and then start KLayout with EMStudio integration.
- EMStudio receives the currently opened GDS layout
- The top cell name is passed automatically
- If you had already created a simulation model for this layout, you can load it from the history list in File menu
EMStudio is a Qt-based desktop application for preparing, visualizing, and managing electromagnetic simulations.
EMStudio can be started stand-alone, or from the klayout layout editor.
After simulation settings and port configuration are configured, EMStudio can save a simulation model to disk, and also start simulation. The simulation model requires the solver workflow folder ('modules' for openEMS, 'gds2palace' for Palace) and the stackup file (*.XML) to be present in your target directory. This means you usually want to have one folder for each solver type (openEMS or Palace) where simulation model scripts are located together with the solver modules folder and the substrate files.
Note that the solver workflow folders are only the "bridge" to openEMS and Palace EM solvers, and you need to have these EM solvers installed, as described in the solver documentation. This is no different from using the normal Python script based IHP EM workflows.
Note for advanced users: If you want to create simulation models in different directories, and don't want to copy & paste the "modules" or "gds2palace" to each of these folders, you can also include these folders in your PYTHONPATH environment variable. For gds2palace, you can also install that using "pip install gds2palace" and update using "pip install gds2palace --upgrade".
When you start EMStudio, you first need to configure some path settings using Setup > Preferences from the main menu.
The screenshot shows the configuration of EMStudio on a Windows machine, with openEMS installed on Windows and Palace installed in Windows Subsystem for Linux (WSL).
-
MODEL_TEMPLATES_DIR EMStudio provides templates for openEMS and Palace workflows, so that you can start from scratch with no existing Python model code. The path configured here points to the template directory where
openems_model.pyandpalace_model.pyare located. -
OpenEMS Python Path
Path to the Python interpreter used for the openEMS workflow. If you installed openEMS and the IHP workflow files into a venv named "openEMS" located in your home directory "home/venv/openEMS", the python interpreter would be "home/venv/openEMS/bin/python" -
PALACE_PYTHON
Path to the Python interpreter used for the Palace workflow. If you installed the gds2palace workflow files into a venv named "palace" located in "home/venv/palace", the python interpreter would be "home/venv/palace/bin/python". If you don't want to use Palace, you can leave this empty.IMPORTANT: There is no native Palace version for Windows. When running Palace from EMStudio on Windows, you need to have gds2palace installed in a WSL virtual machine, and PALACE_PYTHON points to the venv for gds2palace in your WSL subsystem! In that case, gds2palace and the Palace solver will all run in the WSL subsystem.
-
PALACE_RUN_MODE
This setting is used to define how Palace is started after creating the model files (config.json and *.msh). "Executable" is used if Palace is installed into the "normal" file system, e.g. using spack installation. "Script" is used if you want/need more control over starting Palace, e.g. because you installed it in an apptainer container, or if you want to send jobs to remote machines. An example run script is shown in the gds2palace repository here. -
PALACE_INSTALL_PATH
This is where you have installed Palace when using the "Executable" run mode. When using EMStudio on Windows, this points to Palace in your WSL virtual machine.If you don't want to use Palace, or start Palace using script, you can leave this empty.
In this case, Palace will be started with the maximum number of cores available on your system.
-
PALACE_RUN_SCRIPT
This is the script used to start Palace when using the "Script" run mode. When using EMStudio on Windows, this points to Palace in your WSL virtual machine. If you don't want to use Palace, or start Palace using the "Executable" run mode, you can leave this empty.
The main tab is where you configure the layout input file (*.gds) and the main simulation settings.
When you start from scratch, the settings grid is almost empty. You can now load a project template using File > Load Python Model ... or you can go to the Python tab, choose the simulator that you want to use and then press Generate Default. Before leaving the tab, save your changes using File > Save or Ctrl+S
When a valid model is loaded or created from the template, the main tab will look as shown below. Scripts parameters defined using the settings[]=value syntax will be shown in the settings grid and can be modified, with bi-directional synchronization to the built-in Python script editor. If the script line provides additional information in a comment, this will be shown as "flyout help" when moving the mouse over that item in the settings grid.
Not all possible settings are included in the template. Adding an additional setting is possible using the script editor on the Python tab. For a full list of available settings[] and their meaning, please refer to the documentation of the IHP openEMS workflow: https://github.com/VolkerMuehlhaus/openems_ihp_sg13g2/blob/main/doc/Using_OpenEMS_Python_with_IHP_SG13G2_v2.pdf and IHP Palace workflow gds2palace: https://github.com/VolkerMuehlhaus/gds2palace_ihp_sg13g2/blob/main/doc/gds2palace_workflow_userguide.pdf
Before leaving any tab, save your changes using File > Save or Ctrl+S
The substrate tab is where you select the XML stackup file to be used for simulation. EMStudio shows a cross section of the substrate file, and in the background, it prepares the Ports configuration tab using the layer names found in the stackup.
Before leaving any tab, save your changes using File > Save or Ctrl+S
On the Python tab, you can see the Python model code that is used to run openEMS or Palace workflows. When you start EMStudio, you will see an empty editor window. You can now generate a default model code (Button "Generate Default") or you can load an existing model code (Menu: File > Load Python Model ...).
Python model templates are read from the scripts folder in EMStudio, with one template each for openEMS and Palace. You could modify these files if required.
The model code will be synchronized automatically with settings on the "Main" tab, where you can edit your simulation settings. Synchronization works both ways, you can apply changes in the editor on the "Python" tab or in the Settings grid on the "Main" tab.
Before leaving any tab, save your changes using File > Save or Ctrl+S
On the ports tab, you need to configure simulation ports. It is expected that ports are included in the GDSII file on special layers, one layer per port, as described in the documentation of the IHP EM workflows. The EM workflows support in-plane ports (in xy plane) and vertical via ports (z direction). The direction of current flow in the port must be set by the user: x,y,z or -x,-y,-z for reverse polarity. Port polarity matters when multiple ports are connected to the same return path.
For in-plane ports, specify only the "To Layer" field, and leave the "From Layer" field empty. This will create the correct port configuration in the Python model script.
Before leaving any tab, save your changes using File > Save or Ctrl+S
When creating ports entries from scratch, there is a checkbox "Use Substrate Layer Names" of the left bottom side of the Window. This will tell EMStudio to use layer names from the XML stackup file for the layer dropdown boxes. Of course, you need to set the XML stackup file before, so that layer mappings are available.
In the GDSII file, in-plane ports (X or Y direction) must be drawn as a rectangle for openEMS and Palace workflow. Vertical ports (Z direction) can be drawn as a zero area box (line) for Palace and openEMS. In addition, openEMS also allows via ports to have an area.
On the Simulate tab, you can run the model script to generate the EM solver input files and start the simulation model.
When you press the run button, the simulation model script will be executed, using the Python interpreter that you defined using Setup > Preferences. For openEMS, simulation only starts when setting preview_only=True in the simulation model.
--
At present, EMStudio does not allow to switch the simulator for an existing model. The simulator choice is fixed after choosing the template.
EMStudio is compatible with most publicly available example projects that demonstrate complete EM simulation flows based on IHP SG13G2 technology.
These repositories provide real-world examples for both OpenEMS and Palace, including GDS layouts, stackup files, simulation scripts, and S‑parameter extraction.
Repository:
https://github.com/VolkerMuehlhaus/openems_ihp_sg13g2
This project contains:
- SG13G2 example GDS files
- SG13G2 technology XML
- Python simulation scripts
- OpenEMS mesh and solver setup
- Post-processing utilities (S-parameters)
Load the Python script via:
File → Open Python Model…
EMStudio will:
- Parse openEMS simulation settings
- Import GDS + XML files
- Load ports and boundaries
- Provide full editing of simulation parameters
- Export updated openEMS Python script
Repository:
https://github.com/VolkerMuehlhaus/gds2palace_ihp_sg13g2
This repository shows a complete Palace EM simulation flow including:
- SG13G2 example GDS files
- SG13G2 technology XML
- Palace Python model scripts
- S‑parameter generation
Load the Palace Python script via:
File → Open Python Model…
EMStudio will:
- Parse all Palace simulation settings
- Import GDS + XML files
- Load ports and boundaries
- Provide full editing of simulation parameters
- Export updated Palace-ready Python script
These example repositories are ideal for learning EMStudio workflows and validating correct operation.
EMStudio can be used directly with both OpenEMS and Palace models for:
- Full‑wave EM simulation
- SG13G2 stack evaluation
- Port setup & S‑parameter extraction
- Automated script generation
- KLayout‑based design environment integration
EMStudio is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
See the LICENSE file for details.
This project also includes third-party components:
- QtPropertyBrowser – from the Qt Solutions package, licensed under BSD-like terms









