QDMI v1.2.1
Quantum Device Management Interface
Loading...
Searching...
No Matches
constants.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 - 2025 Munich Quantum Software Stack Project
3 * All rights reserved.
4 *
5 * Licensed under the Apache License v2.0 with LLVM Exceptions (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * https://github.com/Munich-Quantum-Software-Stack/QDMI/blob/develop/LICENSE.md
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14 * License for the specific language governing permissions and limitations under
15 * the License.
16 *
17 * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
18 */
19
24
25#pragma once
26
27#ifdef __cplusplus
28extern "C" {
29#endif
30
31// The following clang-tidy warnings cannot be addressed because this header is
32// used from both C and C++ code.
33// NOLINTBEGIN(performance-enum-size, modernize-use-using)
34
54
142
145
201
204
267
270
430
433
452
455
665
668
815
818
843
846
1010
1013
1118
1121
1157
1160
1161// NOLINTEND(performance-enum-size, modernize-use-using)
1162
1163#ifdef __cplusplus
1164} // extern "C"
1165#endif
QDMI_JOB_STATUS_T
Enum of the status a job can have.
Definition constants.h:824
@ QDMI_JOB_STATUS_CANCELED
The job was canceled, and the result is not available.
Definition constants.h:839
@ QDMI_JOB_STATUS_CREATED
The job was created and can be configured via QDMI_job_set_parameter.
Definition constants.h:829
@ QDMI_JOB_STATUS_SUBMITTED
The job was submitted.
Definition constants.h:831
@ QDMI_JOB_STATUS_QUEUED
The job was received, and is waiting to be executed.
Definition constants.h:833
@ QDMI_JOB_STATUS_FAILED
An error occurred in the job's lifecycle.
Definition constants.h:841
@ QDMI_JOB_STATUS_RUNNING
The job is running, and the result is not yet available.
Definition constants.h:835
@ QDMI_JOB_STATUS_DONE
The job is done, and the result can be retrieved.
Definition constants.h:837
enum QDMI_DEVICE_STATUS_T QDMI_Device_Status
Device status type.
Definition constants.h:454
enum QDMI_JOB_STATUS_T QDMI_Job_Status
Job status type.
Definition constants.h:845
QDMI_PROGRAM_FORMAT_T
Enum of formats that can be submitted to the device.
Definition constants.h:850
@ QDMI_PROGRAM_FORMAT_CALIBRATION
void* A calibration program.
Definition constants.h:967
@ QDMI_PROGRAM_FORMAT_CUSTOM3
Definition constants.h:1004
@ QDMI_PROGRAM_FORMAT_QIRBASESTRING
char* (string) A text-based QIR program complying to the QIR base profile.
Definition constants.h:928
@ QDMI_PROGRAM_FORMAT_QASM3
char* (string) An OpenQASM 3 program.
Definition constants.h:898
@ QDMI_PROGRAM_FORMAT_CUSTOM4
Definition constants.h:1006
@ QDMI_PROGRAM_FORMAT_QPY
void* A QPY program.
Definition constants.h:976
@ QDMI_PROGRAM_FORMAT_QIRBASEMODULE
void* A QIR binary complying to the QIR base profile.
Definition constants.h:939
@ QDMI_PROGRAM_FORMAT_CUSTOM2
Definition constants.h:1002
@ QDMI_PROGRAM_FORMAT_CUSTOM5
Definition constants.h:1008
@ QDMI_PROGRAM_FORMAT_QIRADAPTIVESTRING
char* (string) A text-based QIR program complying to the QIR adaptive profile.
Definition constants.h:950
@ QDMI_PROGRAM_FORMAT_QIRADAPTIVEMODULE
void* A QIR binary complying to the QIR adaptive profile.
Definition constants.h:960
@ QDMI_PROGRAM_FORMAT_IQMJSON
char* (string) A program in the IQM data transfer format.
Definition constants.h:984
@ QDMI_PROGRAM_FORMAT_CUSTOM1
This enum value is reserved for a custom program format.
Definition constants.h:1000
@ QDMI_PROGRAM_FORMAT_MAX
The maximum value of the enum.
Definition constants.h:993
@ QDMI_PROGRAM_FORMAT_QASM2
char* (string) An OpenQASM 2.0 program.
Definition constants.h:876
QDMI_DEVICE_JOB_PARAMETER_T
Enum of the device job parameters that can be set via QDMI_device_job_set_parameter.
Definition constants.h:152
@ QDMI_DEVICE_JOB_PARAMETER_SHOTSNUM
size_t The number of shots to execute for a quantum circuit job.
Definition constants.h:175
@ QDMI_DEVICE_JOB_PARAMETER_MAX
The maximum value of the enum.
Definition constants.h:184
@ QDMI_DEVICE_JOB_PARAMETER_CUSTOM1
This enum value is reserved for a custom parameter.
Definition constants.h:191
@ QDMI_DEVICE_JOB_PARAMETER_PROGRAMFORMAT
QDMI_Program_Format The format of the program to be executed.
Definition constants.h:160
@ QDMI_DEVICE_JOB_PARAMETER_CUSTOM4
Definition constants.h:197
@ QDMI_DEVICE_JOB_PARAMETER_CUSTOM2
Definition constants.h:193
@ QDMI_DEVICE_JOB_PARAMETER_PROGRAM
void* The program to be executed.
Definition constants.h:170
@ QDMI_DEVICE_JOB_PARAMETER_CUSTOM5
Definition constants.h:199
@ QDMI_DEVICE_JOB_PARAMETER_CUSTOM3
Definition constants.h:195
QDMI_STATUS
Status codes returned by the API.
Definition constants.h:38
@ QDMI_ERROR_NOTFOUND
Element not found.
Definition constants.h:45
@ QDMI_ERROR_OUTOFMEM
Out of memory.
Definition constants.h:42
@ QDMI_ERROR_NOTSUPPORTED
Definition constants.h:49
@ QDMI_WARN_GENERAL
A general warning.
Definition constants.h:39
@ QDMI_ERROR_INVALIDARGUMENT
Invalid argument.
Definition constants.h:47
@ QDMI_ERROR_FATAL
A fatal error.
Definition constants.h:41
@ QDMI_SUCCESS
The operation was successful.
Definition constants.h:40
@ QDMI_ERROR_BADSTATE
Resource is in the wrong state for the operation.
Definition constants.h:51
@ QDMI_ERROR_OUTOFRANGE
Out of range.
Definition constants.h:46
@ QDMI_ERROR_NOTIMPLEMENTED
Not implemented.
Definition constants.h:43
@ QDMI_ERROR_PERMISSIONDENIED
Permission denied.
Definition constants.h:48
@ QDMI_ERROR_TIMEOUT
Operation timed out.
Definition constants.h:52
@ QDMI_ERROR_LIBNOTFOUND
Library not found.
Definition constants.h:44
enum QDMI_PROGRAM_FORMAT_T QDMI_Program_Format
Program format type.
Definition constants.h:1012
QDMI_DEVICE_PULSE_SUPPORT_LEVEL_T
Enum to indicate the level of pulse support a device has.
Definition constants.h:1125
@ QDMI_DEVICE_PULSE_SUPPORT_LEVEL_CHANNEL
The device supports pulse-level control at an abstraction level of QDMI_Pulse_Channel.
Definition constants.h:1148
@ QDMI_DEVICE_PULSE_SUPPORT_LEVEL_NONE
The device does not support pulse-level control.
Definition constants.h:1127
@ QDMI_DEVICE_PULSE_SUPPORT_LEVEL_SITEANDCHANNEL
The device supports pulse-level control at an abstraction level of QDMI_Site and QDMI_Pulse_Channel.
Definition constants.h:1155
@ QDMI_DEVICE_PULSE_SUPPORT_LEVEL_SITE
The device supports pulse-level control at an abstraction level of QDMI_Site.
Definition constants.h:1138
enum QDMI_JOB_RESULT_T QDMI_Job_Result
Job result type.
Definition constants.h:1120
enum QDMI_DEVICE_JOB_PARAMETER_T QDMI_Device_Job_Parameter
Device job parameter type.
Definition constants.h:203
enum QDMI_SITE_PROPERTY_T QDMI_Site_Property
Site property type.
Definition constants.h:667
QDMI_SITE_PROPERTY_T
Definition constants.h:460
@ QDMI_SITE_PROPERTY_INDEX
size_t The unique index (or ID) to identify the site in a program.
Definition constants.h:472
@ QDMI_SITE_PROPERTY_XCOORDINATE
int64_t The raw, unscaled X-coordinate of the site.
Definition constants.h:519
@ QDMI_SITE_PROPERTY_ZEXTENT
uint64_t The raw, unscaled extent of a zone along the Z-axis.
Definition constants.h:624
@ QDMI_SITE_PROPERTY_CUSTOM1
This enum value is reserved for a custom property.
Definition constants.h:655
@ QDMI_SITE_PROPERTY_CUSTOM4
Definition constants.h:661
@ QDMI_SITE_PROPERTY_XEXTENT
uint64_t The raw, unscaled extent of a zone along the X-axis.
Definition constants.h:592
@ QDMI_SITE_PROPERTY_CUSTOM2
Definition constants.h:657
@ QDMI_SITE_PROPERTY_CUSTOM3
Definition constants.h:659
@ QDMI_SITE_PROPERTY_T1
uint64_t The raw, unscaled T1 time of a site.
Definition constants.h:483
@ QDMI_SITE_PROPERTY_ISZONE
bool Whether the site is a zone.
Definition constants.h:576
@ QDMI_SITE_PROPERTY_T2
uint64_t The raw, unscaled T2 time of a site.
Definition constants.h:494
@ QDMI_SITE_PROPERTY_YEXTENT
uint64_t The raw, unscaled extent of a zone along the Y-axis.
Definition constants.h:608
@ QDMI_SITE_PROPERTY_MODULEINDEX
uint64_t an unsigned integer that uniquely identifies the module.
Definition constants.h:630
@ QDMI_SITE_PROPERTY_SUBMODULEINDEX
uint64_t an unsigned integer uniquely identifying the submodule within a module.
Definition constants.h:639
@ QDMI_SITE_PROPERTY_YCOORDINATE
int64_t The raw, unscaled Y-coordinate of the site.
Definition constants.h:539
@ QDMI_SITE_PROPERTY_ZCOORDINATE
int64_t The raw, unscaled Z-coordinate of the site.
Definition constants.h:559
@ QDMI_SITE_PROPERTY_NAME
Definition constants.h:499
@ QDMI_SITE_PROPERTY_MAX
The maximum value of the enum.
Definition constants.h:648
@ QDMI_SITE_PROPERTY_CUSTOM5
Definition constants.h:663
QDMI_DEVICE_JOB_PROPERTY_T
Enum of the device job properties that can be queried via QDMI_device_job_query_property as part of t...
Definition constants.h:212
@ QDMI_DEVICE_JOB_PROPERTY_CUSTOM5
Definition constants.h:265
@ QDMI_DEVICE_JOB_PROPERTY_PROGRAM
void* The program to be executed.
Definition constants.h:235
@ QDMI_DEVICE_JOB_PROPERTY_CUSTOM1
This enum value is reserved for a custom parameter.
Definition constants.h:257
@ QDMI_DEVICE_JOB_PROPERTY_PROGRAMFORMAT
QDMI_Program_Format The format of the program to be executed.
Definition constants.h:229
@ QDMI_DEVICE_JOB_PROPERTY_CUSTOM4
Definition constants.h:263
@ QDMI_DEVICE_JOB_PROPERTY_CUSTOM3
Definition constants.h:261
@ QDMI_DEVICE_JOB_PROPERTY_SHOTSNUM
size_t The number of shots to execute for a quantum circuit job.
Definition constants.h:241
@ QDMI_DEVICE_JOB_PROPERTY_MAX
The maximum value of the enum.
Definition constants.h:250
@ QDMI_DEVICE_JOB_PROPERTY_CUSTOM2
Definition constants.h:259
@ QDMI_DEVICE_JOB_PROPERTY_ID
char* (string) The job's ID.
Definition constants.h:223
enum QDMI_DEVICE_JOB_PROPERTY_T QDMI_Device_Job_Property
Device job property type.
Definition constants.h:269
QDMI_DEVICE_SESSION_PARAMETER_T
Enum of the device session parameters that can be set via QDMI_device_session_set_parameter.
Definition constants.h:61
@ QDMI_DEVICE_SESSION_PARAMETER_MAX
The maximum value of the enum.
Definition constants.h:125
@ QDMI_DEVICE_SESSION_PARAMETER_PASSWORD
char* (string) The password to use for the session.
Definition constants.h:116
@ QDMI_DEVICE_SESSION_PARAMETER_CUSTOM4
Definition constants.h:138
@ QDMI_DEVICE_SESSION_PARAMETER_TOKEN
char* (string) A token to be used in the session initialization for authenticating with the device.
Definition constants.h:79
@ QDMI_DEVICE_SESSION_PARAMETER_CUSTOM5
Definition constants.h:140
@ QDMI_DEVICE_SESSION_PARAMETER_USERNAME
char* (string) The username to use for the device session.
Definition constants.h:109
@ QDMI_DEVICE_SESSION_PARAMETER_CUSTOM2
Definition constants.h:134
@ QDMI_DEVICE_SESSION_PARAMETER_CUSTOM3
Definition constants.h:136
@ QDMI_DEVICE_SESSION_PARAMETER_BASEURL
char* (string) The baseURL or API endpoint to be used for accessing the device within the session.
Definition constants.h:70
@ QDMI_DEVICE_SESSION_PARAMETER_CUSTOM1
This enum value is reserved for a custom parameter.
Definition constants.h:132
@ QDMI_DEVICE_SESSION_PARAMETER_AUTHURL
char* (string) The URL to an authentication server used as part of the authentication procedure.
Definition constants.h:102
@ QDMI_DEVICE_SESSION_PARAMETER_AUTHFILE
char* (string) A file path to a file containing authentication information.
Definition constants.h:88
QDMI_DEVICE_STATUS_T
Enum of different status the device can be in.
Definition constants.h:435
@ QDMI_DEVICE_STATUS_IDLE
The device is idle.
Definition constants.h:437
@ QDMI_DEVICE_STATUS_OFFLINE
The device is offline.
Definition constants.h:436
@ QDMI_DEVICE_STATUS_ERROR
The device is in an error state.
Definition constants.h:439
@ QDMI_DEVICE_STATUS_MAX
The maximum value of the enum.
Definition constants.h:450
@ QDMI_DEVICE_STATUS_CALIBRATION
The device is in calibration.
Definition constants.h:441
@ QDMI_DEVICE_STATUS_MAINTENANCE
The device is in maintenance.
Definition constants.h:440
@ QDMI_DEVICE_STATUS_BUSY
The device is busy.
Definition constants.h:438
QDMI_JOB_RESULT_T
Enum of the formats the results can be returned in.
Definition constants.h:1017
@ QDMI_JOB_RESULT_PROBABILITIES_DENSE
double* (double list) The probabilities of the result.
Definition constants.h:1057
@ QDMI_JOB_RESULT_MAX
The maximum value of the enum.
Definition constants.h:1101
@ QDMI_JOB_RESULT_STATEVECTOR_DENSE
double* (double list) The state vector of the result.
Definition constants.h:1049
@ QDMI_JOB_RESULT_HIST_KEYS
char* (string) The keys for the histogram of the results.
Definition constants.h:1034
@ QDMI_JOB_RESULT_PROBABILITIES_SPARSE_VALUES
double* (double list) The values for the sparse probabilities of the result.
Definition constants.h:1092
@ QDMI_JOB_RESULT_HIST_VALUES
size_t* (size_t list) The values for the histogram of the results.
Definition constants.h:1040
@ QDMI_JOB_RESULT_STATEVECTOR_SPARSE_VALUES
double* (double list) The values for the sparse state vector of the result.
Definition constants.h:1074
@ QDMI_JOB_RESULT_CUSTOM1
This enum value is reserved for a custom result.
Definition constants.h:1108
@ QDMI_JOB_RESULT_CUSTOM5
Definition constants.h:1116
@ QDMI_JOB_RESULT_CUSTOM2
Definition constants.h:1110
@ QDMI_JOB_RESULT_STATEVECTOR_SPARSE_KEYS
char* (string) The keys for the sparse state vector of the result.
Definition constants.h:1065
@ QDMI_JOB_RESULT_SHOTS
char* (string) The results of the individual shots as a comma-separated list, for example,...
Definition constants.h:1023
@ QDMI_JOB_RESULT_CUSTOM4
Definition constants.h:1114
@ QDMI_JOB_RESULT_CUSTOM3
Definition constants.h:1112
@ QDMI_JOB_RESULT_PROBABILITIES_SPARSE_KEYS
char* (string) The keys for the sparse probabilities of the result.
Definition constants.h:1083
QDMI_OPERATION_PROPERTY_T
Definition constants.h:674
@ QDMI_OPERATION_PROPERTY_CUSTOM2
Definition constants.h:807
@ QDMI_OPERATION_PROPERTY_MAX
The maximum value of the enum.
Definition constants.h:798
@ QDMI_OPERATION_PROPERTY_BLOCKINGRADIUS
uint64_t The raw, unscaled blocking radius of the operation.
Definition constants.h:731
@ QDMI_OPERATION_PROPERTY_ISZONED
bool Whether the operation is a zoned (global) operation.
Definition constants.h:758
@ QDMI_OPERATION_PROPERTY_QUBITSNUM
size_t The number of qubits involved in the operation.
Definition constants.h:678
@ QDMI_OPERATION_PROPERTY_NAME
char* (string) The string identifier of the operation.
Definition constants.h:676
@ QDMI_OPERATION_PROPERTY_PARAMETERSNUM
size_t The number of floating point parameters the operation takes.
Definition constants.h:680
@ QDMI_OPERATION_PROPERTY_INTERACTIONRADIUS
uint64_t The raw, unscaled interaction radius of the operation.
Definition constants.h:712
@ QDMI_OPERATION_PROPERTY_CUSTOM1
This enum value is reserved for a custom property.
Definition constants.h:805
@ QDMI_OPERATION_PROPERTY_CUSTOM3
Definition constants.h:809
@ QDMI_OPERATION_PROPERTY_DURATION
uint64_t The raw, unscaled duration of an operation.
Definition constants.h:691
@ QDMI_OPERATION_PROPERTY_MEANSHUTTLINGSPEED
uint64_t The raw, unscaled mean shuttling speed of an operation.
Definition constants.h:789
@ QDMI_OPERATION_PROPERTY_CUSTOM5
Definition constants.h:813
@ QDMI_OPERATION_PROPERTY_IDLINGFIDELITY
double Fidelity of qubits idling during a global operation.
Definition constants.h:744
@ QDMI_OPERATION_PROPERTY_FIDELITY
double The fidelity of an operation.
Definition constants.h:693
@ QDMI_OPERATION_PROPERTY_SITES
QDMI_Site* (list) The sites to which the operation is applicable.
Definition constants.h:771
@ QDMI_OPERATION_PROPERTY_CUSTOM4
Definition constants.h:811
enum QDMI_DEVICE_SESSION_PARAMETER_T QDMI_Device_Session_Parameter
Device session parameter type.
Definition constants.h:144
enum QDMI_OPERATION_PROPERTY_T QDMI_Operation_Property
Operation property type.
Definition constants.h:817
QDMI_DEVICE_PROPERTY_T
Definition constants.h:278
@ QDMI_DEVICE_PROPERTY_MINATOMDISTANCE
uint64_t The raw, unscaled minimum required distance between qubits during quantum computation.
Definition constants.h:396
@ QDMI_DEVICE_PROPERTY_NAME
char* (string) The name of the device.
Definition constants.h:280
@ QDMI_DEVICE_PROPERTY_LENGTHSCALEFACTOR
double A scale factor for all length values.
Definition constants.h:358
@ QDMI_DEVICE_PROPERTY_CUSTOM3
Definition constants.h:424
@ QDMI_DEVICE_PROPERTY_CUSTOM2
Definition constants.h:422
@ QDMI_DEVICE_PROPERTY_LENGTHUNIT
char* (string) The length unit reported by the device.
Definition constants.h:348
@ QDMI_DEVICE_PROPERTY_NEEDSCALIBRATION
size_t Whether the device needs calibration.
Definition constants.h:331
@ QDMI_DEVICE_PROPERTY_STATUS
QDMI_Device_Status The status of the device.
Definition constants.h:284
@ QDMI_DEVICE_PROPERTY_VERSION
char* (string) The version of the device.
Definition constants.h:282
@ QDMI_DEVICE_PROPERTY_LIBRARYVERSION
char* (string) The implemented version of QDMI.
Definition constants.h:286
@ QDMI_DEVICE_PROPERTY_PULSESUPPORT
QDMI_Device_Pulse_Support_Level Whether the device supports pulse-level control.
Definition constants.h:339
@ QDMI_DEVICE_PROPERTY_SUPPORTEDPROGRAMFORMATS
QDMI_Program_Format* (QDMI_Program_Format list) The program formats supported by the device.
Definition constants.h:404
@ QDMI_DEVICE_PROPERTY_QUBITSNUM
size_t The number of qubits in the device.
Definition constants.h:288
@ QDMI_DEVICE_PROPERTY_COUPLINGMAP
QDMI_Site* (QDMI_Site list) The coupling map of the device.
Definition constants.h:319
@ QDMI_DEVICE_PROPERTY_DURATIONSCALEFACTOR
double A scale factor for all duration values.
Definition constants.h:377
@ QDMI_DEVICE_PROPERTY_OPERATIONS
QDMI_Operation* (QDMI_Operation list) The operations supported by the device.
Definition constants.h:307
@ QDMI_DEVICE_PROPERTY_DURATIONUNIT
char* (string) The duration unit reported by the device.
Definition constants.h:367
@ QDMI_DEVICE_PROPERTY_CUSTOM1
This enum value is reserved for a custom property.
Definition constants.h:420
@ QDMI_DEVICE_PROPERTY_CUSTOM4
Definition constants.h:426
@ QDMI_DEVICE_PROPERTY_CUSTOM5
Definition constants.h:428
@ QDMI_DEVICE_PROPERTY_SITES
QDMI_Site* (QDMI_Site list) The sites of the device.
Definition constants.h:300
@ QDMI_DEVICE_PROPERTY_MAX
The maximum value of the enum.
Definition constants.h:413
enum QDMI_DEVICE_PULSE_SUPPORT_LEVEL_T QDMI_Device_Pulse_Support_Level
Pulse support level type.
Definition constants.h:1159
enum QDMI_DEVICE_PROPERTY_T QDMI_Device_Property
Device property type.
Definition constants.h:432