Installation
There are three distinct ways of installing KQCircuits suitable for different use cases.
The simplest way is installing the latest KQCircuits Salt Package with KLayout’s package manager. This gives the user instant access to KQCircuits from KLayout GUI but in a slightly limited read-only way. See Getting started (Salt package).
Developers should rather install git, clone the source code of KQCircuits and link it to the KLayout application. See the Developer GUI Setup. This way the KQCircuits extension in the KLayout GUI application will use the exact codebase present in the cloned, version-controlled local repository.
For GUI-less features developers should also install KQCircuits as a standalone KLayout Python module, for that see
Developer Standalone module Setup. This allows developers to make use of KQCircuits features in their own
python code by importing the kqcircuits
module. This also enables terminal commands such as:
kqc sim <simulation_script> # to export simulation data and then to process it with a third-party simulator
kqc mask <mask_script> # to export mask layout files for fabrication
KLayout
Download and install KLayout from https://www.klayout.de/build.html. Builds should exist there for most common operating systems, choose the correct one for your OS. Otherwise you need to build KLayout yourself. We recommend installing KLayout without changing the installation directory location from default, as many KQCircuits features assume that KLayout specific files can be found there.
Note
For mac users:
KLayout can also be installed using the HomeBrew package manager,
using terminal command brew install --cask klayout
.
There might be issues on first time launch of KLayout with window:
"klayout" cannot be opened because the developer cannot be verified
.
To fix this, find KLayout app using Finder, control+click KLayout,
click Open, then in the warning window there should be option to Open.
KLayout is an actively maintained project with regular feature updates, bugfixes and stability improvements. We recommend using the latest version. KQCircuits is automatically tested using KLayout versions:
0.27.13
0.28.17
latest version of 0.29
on the following platforms:
Linux: Ubuntu 22.04 LTS, 64-bit
MacOS: latest github image
Microsoft Windows Server 2022, OS version 10
Note
KQC documentation uses Linux conventions and examples unless explicitly talking about Windows or
MacOS. For example a Windows user should mentally translate path separator /
to \
,
klayout executable klayout
to %APPDATA%\KLayout\klayout_app.exe
or the KLayout
environment directory ~/.klayout
to %HOMEPATH%\KLayout
.
Known installation issues
For some specific KLayout builds there can be problems with KQCircuits installation that require some extra steps:
Standard KLayout installation package for MacOS (
ST-klayout-*
) is compiled to use the system Python dynamic library, which for Sonoma version still has Python version 3.9.networkx
dependency is only supported on Python version 3.10 and higher. We recommend using heavyweight KLayout package (HW-klayout-*
) that uses compatible Python, but if that is not an option, you can comment out thenetworkx
entry in gui-requirements.txt to proceed with installation. Currently this only prevents using the netlist_as_graph.py script.For some macOS BigSur KLayout builds (at least for KLayout v0.27.x), KQC might not work due to a problem with the KLayout included
setuptools
package. The KQC libraries will not be visible and one might see the error message"No module named '_distutils_hack'"
when trying to run macros. This can be fixed by installing manually thesetuptools
package into KLayout (at leastsetuptools
v52.0.0 and v57.4.0 should work, probably also some other versions). See Installing different Python package versions to KLayout manually for instructions on how to install a specific package version to KLayout.
Installing different Python package versions to KLayout manually
Sometimes there are issues with specific package versions in the KLayout Python environment. To install a different version of some package, use:
pip install <PACKAGE>==<VERSION> --target=<KLAYOUT-PACKAGE-DIR> --python-version <KLAYOUT-PYTHON-VERSION> --platform <KLAYOUT-PLATFORM> --only-binary=:all: --upgrade
The KLAYOUT-PACKAGE-DIR should be the path to the site-packages directory
used by KLayout. If you don’t know where that is, you can find it by opening
the KLayout macro editor and writing import setuptools
and then setuptools.__path__
in the console.
KLAYOUT-PYTHON-VERSION may expect a different version than the Python version you use in the terminal,
so it’s best to query that from KLayout macro editor: import sys
, sys.version_info
.
On other operating systems than MacOS the --platform
argument can be omitted.
However Mac distributions of KLayout are compiled on x86_64
CPU architecture,
while many modern macbooks have M2
or other CPU architecture. Hence some dependencies
like numpy
and scipy
need to be compiled for platform macosx_10_9_x86_64
,
even when pip
will by default fetch distributions compiled for macosx_10_9_arm64
.
Notice that this only affects the GUI installation of KQCircuits. The standalone, GUI-less KQCircuits installation will use whatever Python environment where it was explicitly installed in, which is most likely separate from the Python environment used by KLayout. It is even recommended to install standalone KQCircuits into a virtual environment.