|
QDMI v1.2.1
Quantum Device Management Interface
|
Together with QDMI, we provide a template meant to kick-start the implementation of a new device. The following sections describe how to set up and use the template.
The code for the template is contained in the template/ directory of the QDMI repository. To start a new project based on the template, configure QDMI once to define the prefix and output path, then explicitly build the qdmi-template target that writes the files.
If the option TEMPLATE_PATH is not given it will be placed in PREFIX_qdmi_device relative to the parent directory where QDMI was cloned in.
If you want to regenerate into an existing directory, use:
After this step you can directly start implementing your device in C++. Example implementations are provided in the examples/ directory. See Examples for more information.
For stability, we recommend pinning the version of QDMI that you are using for your implementation. You can use any valid git tag, branch, or commit hash for that. To this end, adjust the QDMI_REV variable in cmake/ExternalDependecies.cmake as follows:
When you want to change the prefix after the creation of the template, you need to change the prefix in a couple of places. We want to give you some hints where you have to change it, but depending on your personal project setup, they might be different or there might be more than the ones listed. All paths are given relative to the root of the template project directory.
The template is structured into five directories. The top-level CMakeLists.txt contains settings for the entire project. Some additional CMake code that imports required dependencies is outsourced into cmake/.
The most important directory for your implementation is src/ and the .cpp file located in that directory. Here you find stubs for all functions that have to be implemented by a device. For every function the return QDMI_ERROR_NOTIMPLEMENTED; should be replaced by a proper implementation of the function. In particular, there should not be any computation path at the end that returns QDMI_ERROR_NOTIMPLEMENTED. Instead, some other error code from QDMI_STATUS should be returned in case of an erroneous state.
The implementation in the src/ directory is complemented with a testing framework in test/. The .cpp source file already contains some examples for tests. They are meant to serve as an inspiration, and more tests should be implemented to cover everything in your device implementation.
The python directory in combination with the pyproject.toml file contains some basic packaging setup for distributing the device implementation as a Python package.
The docs/ directory contains the documentation for the template. This is intended to be used as a starting point for your own documentation.
Some more files are present in the root directory of the template, such as LICENSE, README.md, and .gitignore.
All following commands are meant to be executed from the root directory of the template. After configuring your project (see Configuring the Template), you can build your project with the following command:
If you only want to build a specific target, you can append, for example, --target prefix_device_test to the command above, which will build the tests. If you only want to build the device implementation, you can use --target prefix_qdmi.
To run the tests, perform the following command:
For more details on the development process, also check out the Development Guide.