First read the overall project contributing guidelines. These are all included in the qiskit documentation:
https://qiskit.org/documentation/contributing_to_qiskit.html
In addition to the general guidelines there are specific details for contributing to aer, these are documented below.
When submitting a pull request and you feel it is ready for review, please ensure that:
- The code follows the code style of the project and successfully
passes the tests. For convenience, you can execute
tox
locally, which will run these checks and report any issues. - The documentation has been updated accordingly. In particular, if a function or class has been modified during the PR, please update the docstring accordingly.
- If it makes sense for your change that you have added new tests that cover the changes.
- Ensure that if your change has an end user facing impact (new feature, deprecation, removal etc) that you have added a reno release note for that change and that the PR is tagged for the changelog.
The changelog is automatically generated as part of the release process
automation. This works through a combination of the git log and the pull
request. When a release is tagged and pushed to github the release automation
bot looks at all commit messages from the git log for the release. It takes the
PR numbers from the git log (assuming a squash merge) and checks if that PR had
a Changelog:
label on it. If there is a label it will add the git commit
message summary line from the git log for the release to the changelog.
If there are multiple Changelog:
tags on a PR the git commit message summary
line from the git log will be used for each changelog category tagged.
The current categories for each label are as follows:
PR Label | Changelog Category |
---|---|
Changelog: Deprecation | Deprecated |
Changelog: New Feature | Added |
Changelog: API Change | Changed |
Changelog: Removal | Removed |
Changelog: Bugfix | Fixed |
When making any end user facing changes in a contribution we have to make sure we document that when we release a new version of qiskit-aer. The expectation is that if your code contribution has user facing changes that you will write the release documentation for these changes. This documentation must explain what was changed, why it was changed, and how users can either use or adapt to the change. The idea behind release documentation is that when a naive user with limited internal knowledge of the project is upgrading from the previous release to the new one, they should be able to read the release notes, understand if they need to update their program which uses qiskit, and how they would go about doing that. It ideally should explain why they need to make this change too, to provide the necessary context.
To make sure we don't forget a release note or if the details of user facing changes over a release cycle we require that all user facing changes include documentation at the same time as the code. To accomplish this we use the reno tool which enables a git based workflow for writing and compiling release notes.
Making a new release note is quite straightforward. Ensure that you have reno installed with::
pip install -U reno
Once you have reno installed you can make a new release note by running in your local repository checkout's root::
reno new short-description-string
where short-description-string is a brief string (with no spaces) that describes what's in the release note. This will become the prefix for the release note file. Once that is run it will create a new yaml file in releasenotes/notes. Then open that yaml file in a text editor and write the release note. The basic structure of a release note is restructured text in yaml lists under category keys. You add individual items under each category and they will be grouped automatically by release when the release notes are compiled. A single file can have as many entries in it as needed, but to avoid potential conflicts you'll want to create a new file for each pull request that has user facing changes. When you open the newly created file it will be a full template of the different categories with a description of a category as a single entry in each category. You'll want to delete all the sections you aren't using and update the contents for those you are. For example, the end result should look something like::
features:
- |
Introduced a new feature foo, that adds support for doing something to
``QuantumCircuit`` objects. It can be used by using the foo function,
for example::
from qiskit import foo
from qiskit import QuantumCircuit
foo(QuantumCircuit())
- |
The ``qiskit.QuantumCircuit`` module has a new method ``foo()``. This is
the equivalent of calling the ``qiskit.foo()`` to do something to your
QuantumCircuit. This is the equivalent of running ``qiskit.foo()`` on
your circuit, but provides the convenience of running it natively on
an object. For example::
from qiskit import QuantumCircuit
circ = QuantumCircuit()
circ.foo()
deprecations:
- |
The ``qiskit.bar`` module has been deprecated and will be removed in a
future release. Its sole function, ``foobar()`` has been superseded by the
``qiskit.foo()`` function which provides similar functionality but with
more accurate results and better performance. You should update your calls
``qiskit.bar.foobar()`` calls to ``qiskit.foo()``.
You can also look at other release notes for other examples.
You can use any restructured text feature in them (code sections, tables, enumerated lists, bulleted list, etc) to express what is being changed as needed. In general you want the release notes to include as much detail as needed so that users will understand what has changed, why it changed, and how they'll have to update their code.
After you've finished writing your release notes you'll want to add the note
file to your commit with git add
and commit them to your PR branch to make
sure they're included with the code in your PR.
If you need to link to an issue or other github artifact as part of the release note this should be done using an inline link with the text being the issue number. For example you would write a release note with a link to issue 12345 as:
fixes:
- |
Fixes a race condition in the function ``foo()``. Refer to
`#12345 <https://github.com/Qiskit/qiskit-aer/issues/12345>` for more
details.
After release notes have been added if you want to see what the full output of
the release notes. In general the output from reno that we'll get is a rst
(ReStructuredText) file that can be compiled by
sphinx. To generate the rst file you
use the reno report
command. If you want to generate the full aer release
notes for all releases (since we started using reno during 0.9) you just run::
reno report
but you can also use the --version
argument to view a single release (after
it has been tagged::
reno report --version 0.5.0
At release time reno report
is used to generate the release notes for the
release and the output will be submitted as a pull request to the documentation
repository's release notes file
Building The release notes are part of the standard qiskit-aer documentation
builds. To check what the rendered html output of the release notes will look
like for the current state of the repo you can run: tox -edocs
which will
build all the documentation into docs/_build/html
and the release notes in
particular will be located at docs/_build/html/release_notes.html
The development cycle for qiskit-aer is all handled in the open using the project boards in Github for project management. We use milestones in Github to track work for specific releases. The features or other changes that we want to include in a release will be tagged and discussed in Github. As we're preparing a new release we'll document what has changed since the previous version in the release notes.
master
:
The master branch is used for development of the next version of qiskit-aer. It will be updated frequently and should not be considered stable. The API can and will change on master as we introduce and refine new features.
stable/*
branches: Branches understable/*
are used to maintain released versions of qiskit-aer. It contains the version of the code corresponding to the latest release for that minor version on pypi. For example, stable/0.4 contains the code for the 0.4.0 release on pypi. The API on these branches are stable and the only changes merged to it are bugfixes.
When it is time to release a new minor version of qiskit-aer we will:
- Create a new tag with the version number and push it to github
- Change the
master
version to the next release version.
The release automation processes will be triggered by the new tag and perform the following steps:
- Create a stable branch for the new minor version from the release tag
on the
master
branch - Build and upload binary wheels to pypi
- Create a github release page with a generated changelog
- Generate a PR on the meta-repository to bump the Aer version and meta-package version.
The stable/*
branches should only receive changes in the form of bug
fixes.
Note: The following are prerequisites for all operating systems
We recommend using Python virtual environments to cleanly separate Qiskit from other applications and improve your experience.
- The simplest way to use environments is by using Anaconda in a terminal window
$ conda create -y -n QiskitDevEnv python=3
$ conda activate QiskitDevEnv
- Clone the
Qiskit Aer
repo via git.
$ git clone https://github.com/Qiskit/qiskit-aer
-
Next, install the platform-specific dependencies for your operating system Linux | macOS | Windows.
-
The common dependencies can then be installed via pip, using the
requirements-dev.txt
file, e.g.:
$ cd qiskit-aer
$ pip install -r requirements-dev.txt
This will also install Conan, a C/C++ package manager written in Python. This tool will handle most of the dependencies needed by the C++ source code. Internet connection may be needed for the first build or when dependencies are added/updated, in order to download the required packages if they are not in your Conan local repository.
If we are only building the standalone version and do not want to install all Python requirements you can just install Conan:
$ pip install conan
You're now ready to build from source! Follow the instructions for your platform: Linux | macOS | Windows
Qiskit is officially supported on Red Hat, CentOS, Fedora and Ubuntu distributions, as long as you can install a GCC version that is C++14 compatible and the few dependencies we need.
To get most of the necessary compilers and libraries, install the development environment tools from your Linux distribution by running
CentOS/Red Hat
$ yum groupinstall "Development Tools"
Fedora
$ dnf install @development-tools
Ubuntu
$ sudo apt install build-essential
And of course, git
is required in order to build from repositories
CentOS/Red Hat
$ yum install git
Fedora
$ dnf install git
Ubuntu
$ apt-get install git
There are two ways of building Aer
simulators, depending on your goal:
- Build a python extension that works with Terra.
- Build a standalone executable.
Python extension
As any other python package, we can install from source code by just running:
qiskit-aer$ pip install .
This will build and install Aer
with the default options which is probably suitable for most of the users.
There's another pythonic approach to build and install software: build the wheels distributable file.
qiskit-aer$ python ./setup.py bdist_wheel
This is also the way we will choose to change default Aer
behavior by passing parameters to the build system.
Advanced options
As Aer
is meant to be executed in many configurations and platforms, there is a complex underlying build system that offers a lot of options you can tune by setting some parameters.
We are using scikit-build as a substitute for setuptools. This is basically the glue between setuptools and CMake, so there are various options to pass variables to CMake, and the underlying build system (depending on your platform). The way to pass variables is:
qiskit-aer$ python ./setup.py bdist_wheel [skbuild_opts] \
[-- [cmake_opts] [-- build_tool_opts]]
where the elements within square brackets []
are optional, and
skbuild_opts
, cmake_opts
, build_tool_opts
are to be replaced by
flags of your choice. A list of CMake options is available
here. For
example,
qiskit-aer$ python ./setup.py bdist_wheel --build-type=Debug -- -DCMAKE_CXX_COMPILER=g++-9 -- -j8
This is passing the --build-type
option with Debug
parameter to scikit-build, so we are telling it to perform a debug build. The -DCMAKE_CXX_COMPILER=g++-9
option is being passed to CMake
so it forces the use of g++-9
compiler, and the -j8
flag is telling the underlying build system, which in this case is Makefile, to build in parallel using 8 processes.
After this command is executed successfully, we will have a wheel package into
the dist/
directory, so next step is installing it:
qiskit-aer/dist$ pip install -U dist/qiskit_aer*.whl
Standalone Executable
If we want to build a standalone executable, we have to use CMake directly. The preferred way CMake is meant to be used, is by setting up an "out of source" build. So in order to build our standalone executable, we have to follow these steps:
qiskit-aer$ mkdir out
qiskit-aer$ cd out
qiskit-aer/out$ cmake ..
qiskit-aer/out$ cmake --build . --config Release -- -j4
Once built, you will have your standalone executable into the Release/
or
Debug/
directory (depending on the type of building chosen with the --config
option):
qiskit-aer/out$ cd Release
qiskit-aer/out/Release/$ ls
qasm_simulator
Advanced options
Because the standalone version of Aer
doesn't need Python at all, the build system is
based on CMake, just like most of other C++ projects. So in order to pass all the different
options we have on Aer
to CMake we use it's native mechanism:
qiskit-aer/out$ cmake -DCMAKE_CXX_COMPILER=g++-9 -DAER_BLAS_LIB_PATH=/path/to/my/blas ..
There are various methods depending on the compiler we want to use. If we want to use the Clang compiler, we need to install an extra library for supporting OpenMP: libomp. The CMake build system will warn you otherwise. To install it manually, in a terminal window, run:
$ brew install libomp
You further need to have Xcode Command Line Tools installed on macOS:
$ xcode-select --install
There are two ways of building Aer
simulators, depending on your goal:
- Build a python extension that works with Terra;
- Build a standalone executable.
Python extension
As any other python package, we can install from source code by just running:
qiskit-aer$ pip install .
This will build and install Aer
with the default options which is probably suitable for most of the users.
There's another pythonic approach to build and install software: build the wheels distributable file.
qiskit-aer$ python ./setup.py bdist_wheel
This is also the way we will choose to change default Aer
behavior by passing parameters to the build system.
Advanced options
As Aer
is meant to be executed in many configurations and platforms, there is a complex underlying build system that offers a lot of options you can tune by setting some parameters.
We are using scikit-build as a substitute for setuptools. This is basically the glue between setuptools and CMake, so there are various options to pass variables to CMake, and the underlying build system (depending on your platform). The way to pass variables is:
qiskit-aer$ python ./setup.py bdist_wheel [skbuild_opts] [-- [cmake_opts] [-- build_tool_opts]]
where the elements within square brackets []
are optional, and
skbuild_opts
, cmake_opts
, build_tool_opts
are to be replaced by
flags of your choice. A list of CMake options is available
here. For
example,
qiskit-aer$ python ./setup.py bdist_wheel --build-type=Debug -- -DCMAKE_CXX_COMPILER=g++-9 -- -j8
This is passing the --build-type
option with Debug
parameter to scikit-build, so we are telling it to perform a debug build. The -DCMAKE_CXX_COMPILER=g++-9
option is being passed to CMake
so it forces the use of g++-9
compiler, and the -j8
flag is telling the underlying build system, which in this case is Makefile, to build in parallel using 8 processes.
After this command is executed successfully, we will have a wheel package into
the dist/
directory, so next step is installing it:
qiskit-aer/dist$ pip install -U dist/qiskit_aer*.whl
Standalone Executable
If we want to build a standalone executable, we have to use CMake directly. The preferred way CMake is meant to be used, is by setting up an "out of source" build. So in order to build our standalone executable, we have to follow these steps:
qiskit-aer$ mkdir out
qiskit-aer$ cd out
qiskit-aer/out$ cmake ..
qiskit-aer/out$ cmake --build . --config Release -- -j4
Once built, you will have your standalone executable into the Release/
or
Debug/
directory (depending on the type of building chosen with the --config
option):
qiskit-aer/out$ cd Release
qiskit-aer/out/Release/$ ls
qasm_simulator
Advanced options
Because the standalone version of Aer
doesn't need Python at all, the build system is
based on CMake, just like most of other C++ projects. So in order to pass all the different
options we have on Aer
to CMake we use it's native mechanism:
qiskit-aer/out$ cmake -DCMAKE_CXX_COMPILER=g++-9 -DAER_BLAS_LIB_PATH=/path/to/my/blas ..
On Windows, you must have Anaconda3 installed. We recommend also installing Visual Studio 2017 Community Edition or Visual Studio 2019 Community Edition.
Anaconda 3 can be installed from their web: https://www.anaconda.com/distribution/#download-section
Visual Studio 2017/2019 Community Edition can be installed from: https://visualstudio.microsoft.com/vs/community/
Once you have Anaconda3 and Visual Studio Community Edition installed, you have to open a new cmd terminal and create an Anaconda virtual environment or activate it if you already have created one:
> conda create -y -n QiskitDevEnv python=3
> conda activate QiskitDevEnv
(QiskitDevEnv) >_
We only support Visual Studio compilers on Windows, so if you have others installed in your machine (MinGW, TurboC)
you have to make sure that the path to the Visual Studio tools has precedence over others so that the build system
can get the correct one.
There's a (recommended) way to force the build system to use the one you want by using CMake -G
parameter. Will talk
about this and other parameters later.
Python extension
As any other python package, we can install from source code by just running:
(QiskitDevEnv) qiskit-aer > pip install .
This will build and install Aer
with the default options which is probably suitable for most of the users.
There's another pythonic approach to build and install software: build the wheels distributable file.
(QiskitDevEnv) qiskit-aer > python ./setup.py bdist_wheel
This is also the way we will choose to change default Aer
behavior by passing parameters to the build system.
Advanced options
As Aer
is meant to be executed in many configurations and platforms, there is a complex underlying build system that offers a lot of options you can tune by setting some parameters.
We are using scikit-build as a substitute for setuptools. This is basically the glue between setuptools and CMake, so there are various options to pass variables to CMake, and the underlying build system (depending on your platform). The way to pass variables is:
qiskit-aer > python ./setup.py bdist_wheel [skbuild_opts] [-- [cmake_opts] [-- build_tool_opts]]
where the elements within square brackets []
are optional, and
skbuild_opts
, cmake_opts
, build_tool_opts
are to be replaced by
flags of your choice. A list of CMake options is available
here. For
example,
(QiskitDevEnv) qiskit-aer > python ./setup.py bdist_wheel --build-type=Debug -- -G "Visual Studio 15 2017"
This is passing the --build-type
option with Debug
parameter to scikit-build, so we are telling it to perform a debug build. The -G "Visual Studio 15 2017"
option is being passed to CMake
so it forces the use of Visual Studio 2017
C++ compiler to drive the build.
After this command is executed successfully, we will have a wheel package into
the dist/
directory, so next step is installing it:
(QiskitDevEnv) qiskit-aer\dist$ pip install -U dist\qiskit_aer*.whl
Standalone Executable
If we want to build a standalone executable, we have to use CMake directly. The preferred way CMake is meant to be used, is by setting up an "out of source" build. So in order to build our standalone executable, we have to follow these steps:
(QiskitDevEnv) qiskit-aer> mkdir out
(QiskitDevEnv) qiskit-aer> cd out
(QiskitDevEnv) qiskit-aer\out> cmake ..
(QiskitDevEnv) qiskit-aer\out> cmake --build . --config Release -- -j4
Once built, you will have your standalone executable into the Release/
or
Debug/
directory (depending on the type of building chosen with the --config
option):
(QiskitDevEnv) qiskit-aer\out> cd Release
(QiskitDevEnv) qiskit-aer\out\Release> dir
qasm_simulator
Advanced options
Because the standalone version of Aer
doesn't need Python at all, the build system is
based on CMake, just like most of other C++ projects. So in order to pass all the different
options we have on Aer
to CMake we use it's native mechanism:
(QiskitDevEnv) qiskit-aer\out> cmake -G "Visual Studio 15 2017" -DAER_BLAS_LIB_PATH=c:\path\to\my\blas ..
Qiskit Aer can exploit GPU's horsepower to accelerate some simulations, specially the larger ones. GPU access is supported via CUDA® (NVIDIA® chipset), so in order to build with GPU support we need to have CUDA® >= 10.1 preinstalled. See install instructions here Please note that we only support GPU acceleration on Linux platforms at the moment.
Once CUDA® is properly installed, we only need to set a flag so the build system knows what to do:
AER_THRUST_BACKEND=CUDA
For example,
qiskit-aer$ python ./setup.py bdist_wheel -- -DAER_THRUST_BACKEND=CUDA
If we want to specify the CUDA® architecture instead of letting the build system auto detect it, we can use the AER_CUDA_ARCH flag (can also be set as an ENV variable with the same name, although the flag takes precedence). For example:
qiskit-aer$ python ./setup.py bdist_wheel -- -DAER_THRUST_BACKEND=CUDA -DAER_CUDA_ARCH="5.2"
or
qiskit-aer$ export AER_CUDA_ARCH="5.2"
qiskit-aer$ python ./setup.py bdist_wheel -- -DAER_THRUST_BACKEND=CUDA
This will reduce the amount of compilation time when, for example, the architecture auto detection fails and the build system compiles all common architectures.
Few notes on GPU builds:
- Building takes considerable more time than non-GPU build, so be patient :)
- CUDA® >= 10.1 imposes the restriction of building with g++ version not newer than 8
- We don't need NVIDIA® drivers for building, but we need them for running simulations
- Only Linux platforms are supported
There are some useful flags that can be set during CMake command invocation and
will help you change some default behavior. To make use of them, you just need to
pass them right after -D
CMake argument. Example:
qiskit-aer/out$ cmake -DUSEFUL_FLAG=Value ..
In the case of building the Qiskit python extension, you have to pass these flags after writing
--
at the end of the python command line, eg:
qiskit-aer$ python ./setup.py bdist_wheel -- -DUSEFUL_FLAG=Value
These are the flags:
-
USER_LIB_PATH
This flag tells CMake to look for libraries that are needed by some of the native components to be built, but they are not in a common place where CMake could find it automatically.
Values: An absolute path. Default: No value. Example:
python ./setup.py bdist_wheel -- -DUSER_LIB_PATH=C:\path\to\openblas\libopenblas.so
-
AER_BLAS_LIB_PATH
Tells CMake the directory to look for the BLAS library instead of the usual paths. If no BLAS library is found under that directory, CMake will raise an error and stop.
It can also be set as an ENV variable with the same name, although the flag takes precedence.
Values: An absolute path. Default: No value. Example:
python ./setup.py bdist_wheel -- -DAER_BLAS_LIB_PATH=/path/to/look/for/blas/
-
BUILD_TESTS
It will tell the build system to build C++ tests along with the simulator.
Values: True|False Default: False Example:
python ./setup.py bdist_wheel -- -DBUILD_TESTS=True
-
CMAKE_CXX_COMPILER
This is an internal CMake flag. It forces CMake to use the provided toolchain to build everything. If it's not set, CMake system will use one of the toolchains installed in system.
Values: g++|clang++|g++-8 Default: Depends on the running platform and the toolchains installed Example:
python ./setup.py bdist_wheel -- -DCMAKE_CXX_COMPILER=g++
-
AER_THRUST_BACKEND
We use Thrust library for GPU support through CUDA. If we want to build a version of
Aer
with GPU acceleration, we need to install CUDA and set this variable to the value: "CUDA". There are other values that will use different CPU methods depending on the kind of backend we want to use:- "OMP": For OpenMP support
- "TBB": For Intel Threading Building Blocks
Values: CUDA|OMP|TBB Default: No value Example:
python ./setup.py bdist_wheel -- -DAER_THRUST_BACKEND=CUDA
-
AER_CUDA_ARCH
This flag allows us we to specify the CUDA architecture instead of letting the build system auto detect it. It can also be set as an ENV variable with the same name, although the flag takes precedence.
Values: Auto | Common | All | List of valid CUDA architecture(s). Default: Auto Example:
python ./setup.py bdist_wheel -- -DAER_THRUST_BACKEND=CUDA -DAER_CUDA_ARCH="5.2; 5.3"
Code contribution are expected to include tests that provide coverage for the changes being made.
We have two types of tests in the codebase: Qiskit Terra integration tests and Standalone integration tests.
For Qiskit Terra integration tests, you first need to build and install the Qiskit python extension, and then run unittest
Python framework.
qiskit-aer$ pip install .
qiskit-aer$ stestr run
Manual for stestr
can be found here.
The integration tests for Qiskit python extension are included in: test/terra
.
Bear in mind that every new feature/change needs to be compatible with all our supported platforms: Win64, MacOS (API Level >= 19) and Linux-x86_64. The Continuous Integration (CI) systems will run builds and pass all the corresponding tests to verify this compatibility.
We have to build in debug mode if we want to start a debugging session with tools like gdb
or lldb
.
In order to create a Debug build for all platforms, we just need to pass a parameter while invoking the build to
create the wheel file:
qiskit-aer$> python ./setup.py bdist_wheel --build-type=Debug
If you want to debug the standalone executable, then the parameter changes to:
qiskit-aer/out$> cmake -DCMAKE_BUILD_TYPE=Debug
There are three different build configurations: Release
, Debug
, and Release with Debug Symbols
, which parameters are:
Release
, Debug
, RelWithDebInfo
respectively.
We recommend building in verbose mode and dump all the output to a file so it's easier to inspect possible build issues:
On Linux and Mac:
qiskit-aer$ VERBOSE=1 python ./setup.py bdist_wheel --build-type=Debug 2>&1|tee build.log
On Windows:
qisikt-aer> set VERBOSE=1
qiskit-aer> python ./setup.py bdist_wheel --build-type=Debug 1> build.log 2>&1
We encourage to always send the whole build.log
file when reporting a build issue, otherwise we will ask for it :)
Stepping through the code
Standalone version doesn't require anything special, just use your debugger like always:
qiskit-aer/out/Debug$ gdb qasm_simulator
Stepping through the code of a Python extension is another story, trickier, but possible. This is because Python interpreters usually load Python extensions dynamically, so we need to start debugging the python interpreter and set our breakpoints ahead of time, before any of our python extension symbols are loaded into the process.
Once built and installed we have to run the debugger with the python interpreter:
$ lldb python
That will get us into the debugger (lldb in our case) interactive shell:
(lldb) target create "python"
Current executable set to 'python' (x86_64).
(lldb)
Then we have to set our breakpoints:
(lldb) b AER::controller_execute
Breakpoint 1: no locations (pending).
WARNING: Unable to resolve breakpoint to any actual locations.
Here the message is clear, it can't find the function: AER::controller_execute
because our python extension hasn't been loaded yet
by the python interpreter, so it's "on-hold" hoping to find the function later in the execution.
Now we can run the python interpreter and pass the arguments (the python file to execute):
(lldb) r test_qiskit_program.py
Process 24896 launched: '/opt/anaconda3/envs/aer37/bin/python' (x86_64)
3 locations added to breakpoint 1
Executing on QasmSimulator for nq=16
Process 24896 stopped
* thread #12, stop reason = breakpoint 1.1
frame #0: 0x000000012f834c10 controller_wrappers.cpython-37m-darwin.so`AER::Result AER::controller_execute<AER::Simulator::QasmController>(qobj_js=0x00007000032716b0) at controller_execute.hpp:48:16
45
46 template <class controller_t>
47 Result controller_execute(const json_t &qobj_js) {
-> 48 controller_t controller;
49
50 // Fix for MacOS and OpenMP library double initialization crash.
51 // Issue: https://github.com/Qiskit/qiskit-aer/issues/1
Target 0: (python) stopped.
After this, you can step through the code and continue with your debug session as always.