This project represents a Camunda BPMN 2.0-based business process that executes Grover's algorithm to search an item in an unsorted list of 𝑁 items.
The model presented here is a conversion of the following process model that uses the QuantME extension:
In contrast to the implementations of Simon's algorithm and the Bernstein-Vazirani algorithm, the provided base circuit contains multiple placeholders for oracles that have to be replaced before the circuit execution. Thus, the OracleExpansionTask is configured with multiple IDs.
The transformed BPMN 2.0 process model (in xml format) can be found here. The model can be visualized and edited using bpmn.io, the Camunda Modeler or the QuantME Modeling and Transformation Framework.
A visualization of the transformed BPMN 2.0-compliant model is presented below (please click on the figure to zoom in):
A configuration file is used to specify the following values:
- The endpoint URL of the Camunda Engine (please use your IP address if you run the services using Docker)
- The endpoint URL of the Oracle Replacement Service
- The endpoint URL of the Circuit Execution Service
- The endpoint URL of the Provenance Service
This configuration file can be found here. However, if using the Docker-Compose setup on the same host where the Camunda Platform runs, the default configuration can be kept, except using your IP in the Camunda Engine URL, as the Docker Containers can not access it via localhost.
The project uses Java 8 and can be built and packaged using Maven. Please use the following command to built the WAR file:
mvn clean package
The project is packaged into a WAR file which can be found in the folloing path:
target/grover-algorithm-0.0.1-SNAPSHOT.war
This WAR file contains the process model as well as the used java classes and their dependencies.
Follow these steps to deploy the process model to the Camunda engine:
-
Build and package the project into a WAR file (see above).
-
Install the standalone Camunda Community Platform (please follow the instructions on this website). We call the path where you unzipped the Camunda distribution $CAMUNDA_HOME$.
-
Camunda has an embedded Apache Tomcat server. Deploy the project you built in step 1 to this server by copying the WAR file to the following folder:
$CAMUNDA_HOME$/server/apache-tomcat-XXX/webapps
You can now see the deployed process model in the various Camunda applications (Admin, Tasklist, and Cockpit): Go to the Welcome application and use "demo/demo" as a username and password.
Using the Tasklist Camunda application, initiate the process by logging in (demo/demo) and then clicking on the button "Start process" and finally choosing "Grover's Algorithm".
Thereby, two input parameters have to be passed:
- IBM Access Token: The access token for IBMs cloud offering IBM Quantum Experience to execute the quantum computation on a real quantum computer.
- IBMQ QPU Name: The name of a quantum computer (or simulator) available via IBM Quantum Experience. Please have a look at the currently available QPUs and copy the name of one with at least 5 qubits.
- Oracle URL: The URL where the oracle that should be used for Grover's algorithm is located. Three example oracles can be found here. Please have a look at the python files which contain a comment with the expected result. However, any other oracle operating on max. five qubits can be used as the base circuit is intended for five qubits.
After the termination of the calculation, the searched bit string representing the searched item for Grover's algorithm is returned.
Notes:
- The result as well as errors from other message end events are printed to the console of the Camunda engine. Therefore, have a look at this console if the Camunda Cockpit does not display a running instance any more, as the free version does not display terminated instances.
- When executing the first quantum circuit on a certain quantum computer, the provenance service has to build a new calibration matrix. This requires to run lots of calibration circuits, and thus, takes some time. Please have a look in the logs of the services to track the progress.