The NISQ Analyzer is a research prototype based on Salm et al.. It automatically analyzes implementations of quantum algorithms. The results indicate if a quantum algorithm can be executed on a Quantum Processing Unit (QPU) or simulator. It also enables the analysis and selection of suitable QPUs based on a specific quantum algorithm implementation. Based on Salm et al., it enables the automated comparison of available quantum compilers to support the selection of the most suitable compiled quantum circuit.
This guidance guides you through the QC Atlas UI for applying the NISQ Analyzer on given implementations of the PlanQK Platform for selecting suitable quantum computers.
To use the NISQ Analyzer on the PlanQK platform content, currenly only Qiskit-based implementations are supported. Thus the technology field is used to specify the used SDK, i.e., Qiskit, while the version field specifies the programming languages used, e.g., Qiskit or OpenQASM. Please note that currently only the first file on the platform is used by the NISQ Analyzer for analyzing and executing the implementation. A current limitation is that only fixed circuits, i.e., circuits that do not require input parameters, can be executed. The Shor implementation is such an example.
- Docker Engine - Install Guide
- Docker Compose - Install Guide
- Clone quantil-docker repository
- Required ports are listed here
- Copy docker-compose.nisq.analyzer.override.yml file
to
docker-compose.override.yml
. - Insert your Qiskit token at
QPROV_IBMQ_TOKEN: 'your-qiskit-token-here'
in the newdocker-compose.override.yml
.
Note: Currently only quantum computers of IBMQ are supported.
Open a console, navigate to the folder of the quantil-docker, and run the following commands:
docker-compose --profile nisqAnalyzer pull
docker-compose build db
docker-compose --profile nisqAnalyzer up
After a few seconds, the ecosystem is up and running and you can access it via the browser on http://localhost:80. The QC Atlas UI is visible.
To login in to the platform, click the user button on the top right and insert your PlanQK platform username and password.
Now, the list of algorithms available in the platform are displayed.
- Navigate to the desired algorithm and click on it.
- In context of the algorithm, click on Implementations and select the given implementation.
- In context of the implementation, click on the NISQ Analyzer tab.
- To start the quantum computer selection, click on New Analysis, select the vendor and insert your Qiskit token. You can also enable/disable if simulators should be included. Then, click ok to start the analysis.
- Now a new analysis job is created. When the analysis job is finished a Show analysis button occurs on the right side. While waiting, you can browse through the QC Atlas UI.
- When clicking on the Show analysis button suitable quantum computers (and simulators) are listed.
- You can also execute the implementation on the suitable quantum computers (and simulators) by clicking the Execute button. After clicking, the Show result button occurs which expands the table row and displays status and result of the execution.
- When the execution is complete, the result is displayed.
- To stop the environment go to the console window with the docker-compose running, stop the process (e.g. control+shift+C for Mac).
- To remove all volumes run
docker-compose down -v
.
Current development is supported by the Federal Ministry for Economic Affairs and Energy as part of the PlanQK project (01MK20005N) and the DFG’s Excellence Initiative project SimTech (EXC 2075 - 390740016).
Dies ist ein Forschungsprototyp. Die Haftung für entgangenen Gewinn, Produktionsausfall, Betriebsunterbrechung, entgangene Nutzungen, Verlust von Daten und Informationen, Finanzierungsaufwendungen sowie sonstige Vermögens- und Folgeschäden ist, außer in Fällen von grober Fahrlässigkeit, Vorsatz und Personenschäden, ausgeschlossen.
Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License.
SPDX-License-Identifier: Apache-2.0