Skip to main content

A tool for Quantum Circuit Mapping

Project description

PyPI OS License: MIT CI Bindings codecov

MQT QMAP - A tool for Quantum Circuit Mapping written in C++

A tool for quantum circuit mapping developed by the Chair for Design Automation at the Technical University of Munich based on methods proposed in [1] , [2] , [3] , [4].

[1] A. Zulehner, A. Paler, and R. Wille. An Efficient Methodology for Mapping Quantum Circuits to the IBM QX Architectures. IEEE Transactions on Computer Aided Design of Integrated Circuits and Systems (TCAD), 2018.

[2] R. Wille, L. Burgholzer, and A. Zulehner. Mapping Quantum Circuits to IBM QX Architectures Using the Minimal Number of SWAP and H Operations. In Design Automation Conference (DAC), 2019.

[3] S. Hillmich, A. Zulehner, and R. Wille. Exploiting Quantum Teleportation in Quantum Circuit Mapping. In Asia and South Pacific Design Automation Conference (ASP-DAC), 2021.

[4] L. Burgholzer, S. Schneider, and R. Wille. Limiting the Search Space in Optimal Quantum Circuit Mapping. In Asia and South Pacific Design Automation Conference (ASP-DAC), 2022.

QMAP is part of the Munich Quantum Toolkit (MQT; formerly known as JKQ and developed by the Institute for Integrated Circuits at the Johannes Kepler University Linz). It builds upon our quantum functionality representation (QFR) and can be used for mapping quantum circuits in any of the following formats:

to any given architecture, e.g., the 5-qubit, T-shaped IBMQ London architecture, which is specified by the coupling map

5
0 1
1 0
1 2
2 1
1 3
3 1
3 4
4 3

with the following available methods:

  • Heuristic Mapper: Heuristic solution based on A* search. For details see [1] and [3].
  • Exact Mapper: Exact solution utilizing the SMT Solver Z3. For details see [2] and [4].

Note that, at the moment, circuits to be mapped are assumed to be already decomposed into elementary gates supported by the targeted device. More specifically, circuits must not contain gates acting on more than two qubits.

For more information, please visit cda.cit.tum.de/research/ibm_qx_mapping/.

If you have any questions, feel free to contact us via quantum.cda@xcit.tum.de or by creating an issue on GitHub.

Usage

MQT QMAP is developed as a C++ library with an easy to use Python interface.

  • In order to make the library as easy to use as possible (without compilation), we provide pre-built wheels for most common platforms (64-bit Linux, MacOS, Windows). These can be installed using
    pip install mqt.qmap
    
    However, in order to get the best performance out of QMAP, it is recommended to build it locally from the source distribution (see system requirements) via
    pip install  mqt.qmap --no-binary mqt.qmap
    
    This enables platform specific compiler optimizations that cannot be enabled on portable wheels.
  • Once installed, start using it in Python:
    from mqt.qmap import *
    results = compile(circ, arch)
    

where circ is either a Qiskit QuantumCircuit object or the path to an input file (in any of the formats listed above) and arch is either one of the pre-defined architectures (see below) or the path to a file containing the number of qubits and a line-by-line enumeration of the qubit connections.

Architectures that are available per default (either as strings or under qmap.Arch.<...>) include (corresponding files are available in extern/architectures/):

  • IBM_QX4 (5 qubit, directed bow tie layout)
  • IBM_QX5 (16 qubit, directed ladder layout)
  • IBMQ_Yorktown (5 qubit, undirected bow tie layout)
  • IBMQ_London (5 qubit, undirected T-shape layout)
  • IBMQ_Bogota (5 qubit, undirected linear chain layout)
  • IBMQ_Tokyo (20 qubit, undirected brick-like layout)

Whether the heuristic (default) or the exact mapper is used can be controlled by passing method="heuristic" or method="exact" to the compile function.

There are several configuration options that can be passed to the compile function:

  • The heuristic mapper offers the initial_layout option, which allows to choose one of the following strategies for choosing an initial layout:

    • identity: map logical qubit q_i to physical qubit Q_i,
    • static: determine fixed initial layout statically at the start of mapping,
    • dynamic (default): determine initial layout on demand during the mapping (this is the only one compatible with teleportation).
  • Both, the exact and the heuristic mapper also offer the layering option, which allows to choose one of the following strategies for partitioning the circuit:

    • individual_gates (default): consider each gate separately,
    • disjoint_qubits: consider gates acting on disjoint qubits as a layer,
    • odd_gates: group pairs of gates. (Note that this strategy was only tested for IBM QX4 with the exact mapping tool and may not work on different architectures)
    • qubit_triangle: add gates to a layer, as long as no more than three qubits are involved. (Note that this strategy only works if the architecture's coupling map contains a triangle, e.g. IBM QX4, and was only tested using the exact mapping tool)
  • The exact mapper offers the encoding option, which allows to choose a different encoding for at-most-one and exactly-one constraints:

    • naive (default): use naive encoding for constraints
    • commander: use commander encoding for at-most-one and exactly-one constraints
    • bimander: use bimander encoding for at-most-one and commander for exactly-one constraints

    As the commander encoding can use different strategies to group the variables, there are different commander_grouping options:

    • halves (default): each group contains half of the total variables
    • logarithm: each group contains at most log2 of the total variables
    • fixed2: each group contains exactly two variables
    • fixed3: each group contains exactly three variables
  • Per default, the exact mapper searches for a suitable mapping by considering every possible (connected) subset of qubits instead of the whole architecture at once. This can be disabled by setting use_subsets=False.

  • The exact mapper also offers the swap_reduction option to enable limiting the number of swaps considered per layer (as proposed in [4] , which offers the following options:

    • none: consider whole search space
    • coupling_limit (default): calculate the max swaps per layer based on the longest path of current choice of qubits, or if use_subsets is disabled considers the whole architecture
    • increasing: start with 0 swaps and geometrically increase the number of swaps per layer
    • custom: set a custom limit, needs the swap_limit option to set the limit

    Using the use_bdd option, the mapping utilizes BDDs instead of simply removing the permutations from the core routine. This option is not generally advised, as it is more resource intensive in most cases, but is something to try in cases of timeout.

Command-line Executable

QMAP also provides two standalone executables with command-line interface called qmap_heuristic and qmap_exact. They provide the same options as the Python module as flags. Per default, this produces JSON formatted output. In general, we recommend to use the Python approach described above, as these commandline executables might not be maintained in the future.

System Requirements

Building (and running) is continuously tested under Linux, MacOS, and Windows using the latest available system versions for GitHub Actions. However, the implementation should be compatible with any current C++ compiler supporting C++17 and a minimum CMake version of 3.14.

boost/program_options >= 1.50 is required for building the commandline applications of the mapping tool.

In order to build the exact mapping tool and for the Python bindings to work, the SMT Solver Z3 >= 4.8.3 has to be installed and the dynamic linker has to be able to find the library. This can be accomplished in a multitude of ways:

  • Under Ubuntu 20.04 and newer: sudo apt-get install libz3-dev
  • Under macOS: brew install z3
  • Alternatively: pip install z3-solver and then append the corresponding path to the library path (LD_LIBRARY_PATH under Linux, DYLD_LIBRARY_PATH under macOS), e.g. via
    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$(python -c "import z3; print(z3.__path__[0]+'/lib')")
    
  • Download pre-built binaries from https://github.com/Z3Prover/z3/releases and copy the files to the respective system directories
  • Build Z3 from source and install it to the system

Library Organisation

Internally the MQT QMAP library works in the following way

  • Import input file into a qc::QuantumComputation object
    qc::QuantumComputation qc{};
    std::string circ = "<PATH_TO_CIRCUIT_FILE>";
    qc.import(circ);
    
  • Import architecture file into a Architecture object
    Architecture arch{};
    std::string cm = "<PATH_TO_ARCH_FILE>";
    arch.loadCouplingMap(cm);
    
  • (Optional) Import calibration file into arch object
    std::string cal = "<PATH_TO_CAL_FILE>";
    arch.loadCalibrationData(cal);
    
  • Depending on Method, instantiate a HeuristicMapper or ExactMapper object with the circuit and the architecture
    HeuristicMapper mapper(qc, arch);
    
    or
    ExactMapper mapper(qc, arch);
    
  • Set configuration options, e.g.,
    Configuration config{};
    config.layeringStrategy = Layering::DisjointQubits;
    
  • Perform the actual mapping
    mapper.map(config);
    
  • Dump the mapped circuit
    mapper.dumpResult("<PATH_TO_OUTPUT_FILE>");
    
  • Print the results
    mapper.printResult(std::cout);
    

Configure, Build, and Install

To start off, clone this repository using

git clone --recurse-submodules -j8 https://github.com/cda-tum/qmap 

Note the --recurse-submodules flag. It is required to also clone all the required submodules. If you happen to forget passing the flag on your initial clone, you can initialize all the submodules by executing git submodule update --init --recursive in the main project directory.

Our projects use CMake as the main build configuration tool. Building a project using CMake is a two-stage process. First, CMake needs to be configured by calling

cmake -S . -B build -DCMAKE_BUILD_TYPE=Release

This tells CMake to search the current directory . (passed via -S) for a CMakeLists.txt file and process it into a directory build (passed via -B). The flag -DCMAKE_BUILD_TYPE=Release tells CMake to configure a Release build (as opposed to, e.g., a Debug build).

After configuring with CMake, the project can be built by calling

cmake --build build --config Release

This tries to build the project in the build directory (passed via --build). Some operating systems and developer environments explicitly require a configuration to be set, which is why the --config flag is also passed to the build command. The flag --parallel <NUMBER_OF_THREADS> may be added to trigger a parallel build.

Building the project this way generates

  • the heuristic library libqmap_heuristic_lib.a (Unix) / qmap_heuristic_lib.lib (Windows) in the build/src directory
  • the heuristic mapper commandline executable qmap_heuristic in the build/apps directory (only available if Boost is found)
  • a test executable qmap_heuristic_test containing a small set of unit tests for the heuristic mapper in the build/test directory
  • the exact library libqmap_exact_lib.a (Unix) / qmap_exact_lib.lib (Windows) in the build/src directory (only available if Z3 is found)
  • the exact mapper commandline executable qmap_exact in the build/apps directory (only available if Boost and Z3 is found)
  • a test executable qmap_exact_test containing a small set of unit tests for the exact mapper in the build/test directory (only available if Z3 is found)

Extending the Python Bindings

To extend the Python bindings you can locally install the package in edit mode, so that changes in the Python code are instantly available. The following example assumes you have a virtual environment set up and activated.

(venv) $ pip install cmake
(venv) $ pip install --editable .

If you change parts of the C++ code, you have to run the second line to make the changes visible in Python.

Reference

If you use our tool for your research, we will be thankful if you refer to it by citing the appropriate publications.

For the heuristic mapping, please cite

@article{DBLP:journals/tcad/ZulehnerPW19,
  author    = {Alwin Zulehner and Alexandru Paler and Robert Wille},
  title     = {An Efficient Methodology for Mapping Quantum Circuits to the {IBM QX} Architectures},
  journal   = {{IEEE} Transactions on Computer-Aided Design of Integrated Circuits and Systems},
  volume    = {38},
  number    = {7},
  pages     = {1226--1236},
  year      = {2019}
}

For the teleportation in the heuristic mapping, please cite

@inproceedings{DBLP:conf/aspdac/HillmichZW21,
  author    = {Stefan Hillmich and Alwin Zulehner and Robert Wille},
  title     = {Exploiting Quantum Teleportation in Quantum Circuit Mapping},
  booktitle = {Asia and South Pacific Design Automation Conference},
  pages     = {792--797},
  publisher = {{ACM}},
  year      = {2021}
}

For the exact mapping, please cite

@inproceedings{DBLP:conf/dac/WilleBZ19,
  author    = {Robert Wille and Lukas Burgholzer and Alwin Zulehner},
  title     = {Mapping Quantum Circuits to {IBM QX} Architectures Using the Minimal Number of {SWAP} and {H} Operations},
  booktitle = {Design Automation Conference},
  publisher = {{ACM}},
  year      = {2019}
}

For the search space limitation in the exact mapping, please cite

@inproceedings{burgholzer2022limitingSearchSpace,
  author    = {Lukas Burgholzer and Sarah Schneider and Robert Wille},
  title     = {Limiting the Search Space in Optimal Quantum Circuit Mapping},
  booktitle = {Asia and South Pacific Design Automation Conference},
  year      = {2022}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mqt.qmap-1.7.0.tar.gz (1.7 MB view details)

Uploaded Source

Built Distributions

mqt.qmap-1.7.0-cp310-cp310-win_amd64.whl (6.6 MB view details)

Uploaded CPython 3.10 Windows x86-64

mqt.qmap-1.7.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.4 MB view details)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

mqt.qmap-1.7.0-cp310-cp310-macosx_11_0_arm64.whl (6.9 MB view details)

Uploaded CPython 3.10 macOS 11.0+ ARM64

mqt.qmap-1.7.0-cp310-cp310-macosx_10_15_x86_64.whl (7.4 MB view details)

Uploaded CPython 3.10 macOS 10.15+ x86-64

mqt.qmap-1.7.0-cp39-cp39-win_amd64.whl (6.6 MB view details)

Uploaded CPython 3.9 Windows x86-64

mqt.qmap-1.7.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.4 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

mqt.qmap-1.7.0-cp39-cp39-macosx_11_0_arm64.whl (6.9 MB view details)

Uploaded CPython 3.9 macOS 11.0+ ARM64

mqt.qmap-1.7.0-cp39-cp39-macosx_10_15_x86_64.whl (7.4 MB view details)

Uploaded CPython 3.9 macOS 10.15+ x86-64

mqt.qmap-1.7.0-cp38-cp38-win_amd64.whl (6.6 MB view details)

Uploaded CPython 3.8 Windows x86-64

mqt.qmap-1.7.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.4 MB view details)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

mqt.qmap-1.7.0-cp38-cp38-macosx_11_0_arm64.whl (6.9 MB view details)

Uploaded CPython 3.8 macOS 11.0+ ARM64

mqt.qmap-1.7.0-cp38-cp38-macosx_10_15_x86_64.whl (7.4 MB view details)

Uploaded CPython 3.8 macOS 10.15+ x86-64

mqt.qmap-1.7.0-cp37-cp37m-win_amd64.whl (6.6 MB view details)

Uploaded CPython 3.7m Windows x86-64

mqt.qmap-1.7.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.4 MB view details)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

mqt.qmap-1.7.0-cp37-cp37m-macosx_10_15_x86_64.whl (7.4 MB view details)

Uploaded CPython 3.7m macOS 10.15+ x86-64

mqt.qmap-1.7.0-cp36-cp36m-win_amd64.whl (6.6 MB view details)

Uploaded CPython 3.6m Windows x86-64

mqt.qmap-1.7.0-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.4 MB view details)

Uploaded CPython 3.6m manylinux: glibc 2.17+ x86-64

mqt.qmap-1.7.0-cp36-cp36m-macosx_10_15_x86_64.whl (7.4 MB view details)

Uploaded CPython 3.6m macOS 10.15+ x86-64

File details

Details for the file mqt.qmap-1.7.0.tar.gz.

File metadata

  • Download URL: mqt.qmap-1.7.0.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for mqt.qmap-1.7.0.tar.gz
Algorithm Hash digest
SHA256 028598ddebcc07c1216a3d26ee1dcaa36d1b7d6c5768bb90a391b41175ed204c
MD5 9bf2bcd4fb080dffbffab1970413f1ac
BLAKE2b-256 5c6e7b61df7bfd965579749d24037595690feda2d5b4a76a0467d6a95e69ddfe

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 ad9338661e7d28b9df3e73b60ffaf55a12da8d562cdf73378611257ec7fec376
MD5 c247cef5a509ac0fc335381f6c325d6f
BLAKE2b-256 35996b903ac9ad17030a4d2ba9f5abc8d0adedb8205b30cb1b81f2230c928f6b

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6790c8dd0c98b4f9884d666925aaa310761c8de08f1066b1bc1be64804d56d70
MD5 3053efc8769b92a41feda40683db56a2
BLAKE2b-256 7959458dd819f088d20f75a5cc3f8a14f564641ed7b863c2d87395208342ad3e

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 3d0a01ad5481d1e78fd7a037b4275c2dce5681c7d9160ba5bdbc25b0b25db4fe
MD5 05394244066a8b2bd60081039ec8042d
BLAKE2b-256 97b00fef4fd2f4fef2d85ead1aec95d2c27b3bfe8f5ebc913db5b33bf4eafd8d

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp310-cp310-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp310-cp310-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 491a1425fdc1865979da476244b1705c3eff689bf2dadf6b4266bc5eb7578f11
MD5 bd3a2c9a8531287d0a6800156867011a
BLAKE2b-256 dde11aa5dd57622f79ad56721743e7d29af69d8b85d4fc74f999c4c7e9f2b0e4

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: mqt.qmap-1.7.0-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 6.6 MB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for mqt.qmap-1.7.0-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 222dcca0c21abbb2b399fa396637b9134514e50a94e478c5f6e12a6474169f8e
MD5 048ee06afba50915527000deaa5ed98b
BLAKE2b-256 e8080ba17df26981c9f23aa1912bbde5c3a04553015ff6c48f4e2c72d0b88316

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6c70409c527fd1c178740ce3a6a1ed884b21d5da27f366185a75d25e2348c889
MD5 b38e5d002cae7fa78d0cafe82e8329e2
BLAKE2b-256 d6714ad4538b4269ab8659420a8630de05c060a8f7fff5dcaaed0f3e07c910f3

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp39-cp39-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp39-cp39-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 4d33da6acf4f53e91de432648cd4945869c18f10aafda7116ca56dc5e1444be8
MD5 819be2498a685731c2dc5674751e6cee
BLAKE2b-256 1a6d93b18b3907374f1bbdf4f5b162df12d5b4995302c3b5f3bc43a1c09bea4c

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp39-cp39-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp39-cp39-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 bed25c07313d8e2d31b8c681a306646bc6291ab44b1d631c3afb43fe8ef47d11
MD5 9543d60dbb3e3080101cebd4a3f79198
BLAKE2b-256 765a312d945ca375faca9bc2a312e3e211f2e339f7e76b17c56238b8ed87273b

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: mqt.qmap-1.7.0-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 6.6 MB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for mqt.qmap-1.7.0-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 e98cd02d7ad83e1ef3da605f5523817e59047b26274396ed9e4d7b009fb0f6a0
MD5 7c22cb4f6be501fbd8f6ab385deec653
BLAKE2b-256 9369de46ef4e0531eec156c7bcea390efd4a4c215e5b0c337e8ffb880da16905

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4e5e9982e1c7513b4e025a35bd44fdb76a873458c02b1be1aeaccef2a0e8a40a
MD5 8779495a3c95cc3b97e8c3cd3b3aa091
BLAKE2b-256 59923a57b5d879af4952a59898bb29b0305e8c9efac08e3c90fa006708f69c23

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp38-cp38-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp38-cp38-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ff5d8503182c3f1e8f21750826c352d0507cafba19ddfa93d5e0d866b1d1ba4f
MD5 8704c66f115358e40f160c1db88c5834
BLAKE2b-256 5b836c464e3f489ab9271a078b1261385742f9032455e373d24455987683c73f

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp38-cp38-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp38-cp38-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 4100db693df876d35b32dfbf6437b428f8c4e10157fbf1e2277eb0827e4e37b5
MD5 1ef4cdbb8693798c83124a66fab6d28e
BLAKE2b-256 b14bf96910344d118749adb664c56fdd3184dd1547d763b300a1ea3994e520d7

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: mqt.qmap-1.7.0-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 6.6 MB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for mqt.qmap-1.7.0-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 b77c94f863602f136770e07000797e32d32edb20debb4b8cea52bdb0cf94f4f4
MD5 2ed2d5dccf541f8423fe4d1d935ee860
BLAKE2b-256 97cfe07206c8c0acc0e6015edf43550e21eaad3a12da485952ca0e91b238b7b3

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 ece4a2d85bcbb92792254e03f23ff2e5d522f0739f0d892f945b418d7c1821b7
MD5 086827ce2dd5e0bac02e06dead64b21f
BLAKE2b-256 365f387618ee35c1cd3e05c97818747c5ea2ccbda8d97b724d885b3b056b1a42

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp37-cp37m-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp37-cp37m-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 ea63be8eaa3921f3299359a0a172a5831ea36b3f1f3c0178631b11ff14ce0092
MD5 4b0691d52747a69432cbad2747adb6b3
BLAKE2b-256 f9842a17b0d1fbf1278fa3ce19b0d4729054e73f87a9e6bf7e0bc954e1ee6694

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: mqt.qmap-1.7.0-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 6.6 MB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for mqt.qmap-1.7.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 cdb1b5a989da9af7961c4b5e0816eeacf674847d20c4d52d21a76579483cbeb3
MD5 766c0883f2a4801d952c0c493cb714ba
BLAKE2b-256 7244b7aec2a559f9e90893034e481c1f718e995a376ca4c681e321e3db83e5c1

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 71279f00edd1bcadb4ebdc758abbefa925734c82403e6866e1f1a8bdcb5c9409
MD5 a80c26839532f0d7d22c7bd9874092b4
BLAKE2b-256 39c8fb7532482e81a5e7bbdaa4609e28e5962b70faf00940c2ff3f03cfb68a44

See more details on using hashes here.

File details

Details for the file mqt.qmap-1.7.0-cp36-cp36m-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for mqt.qmap-1.7.0-cp36-cp36m-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 c8b9bd368137156015551f570089773276aef90d1da05e1a2a73881ed3ecbf6b
MD5 5557c65d7de23f03a05e6f891af04eaa
BLAKE2b-256 0cfba8e67b5b4f7abe9d3b7f3cd3ad4678e4a901018f0dbaf382edd492e20bcd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page