QDMI v1.3.0
Quantum Device Management Interface
Loading...
Searching...
No Matches
client.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 - 2026 QDMI Maintainers
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://llvm.org/LICENSE.txt
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
23
24#pragma once
25
26#include "qdmi/constants.h" // IWYU pragma: export
27#include "qdmi/types.h" // IWYU pragma: export
28
29#ifdef __cplusplus
30#include <cstddef>
31
32extern "C" {
33#else
34#include <stddef.h>
35#endif
36
37// The following clang-tidy warning cannot be addressed because this header is
38// used from both C and C++ code.
39// NOLINTBEGIN(performance-enum-size, modernize-use-using)
40
57
64typedef struct QDMI_Device_impl_d *QDMI_Device;
65
83
89typedef struct QDMI_Session_impl_d *QDMI_Session;
90
108
193
196
247 QDMI_Session_Parameter param, size_t size,
248 const void *value);
249
271
308
311
367 QDMI_Session_Property prop, size_t size,
368 void *value, size_t *size_ret);
369
378 // end of client_session_interface
380
390
438 QDMI_Device_Property prop, size_t size,
439 void *value, size_t *size_ret);
440
493 QDMI_Site_Property prop, size_t size,
494 void *value, size_t *size_ret);
495
579 QDMI_Device device, QDMI_Operation operation, size_t num_sites,
580 const QDMI_Site *sites, size_t num_params, const double *params,
581 QDMI_Operation_Property prop, size_t size, void *value, size_t *size_ret);
582 // end of client_query_interface
584
602
612typedef struct QDMI_Job_impl_d *QDMI_Job;
613
631
685
688
741 const void *value);
742
803
806
858 void *value, size_t *size_ret);
859
876
891
907
927int QDMI_job_wait(QDMI_Job job, size_t timeout);
928
979int QDMI_job_get_results(QDMI_Job job, QDMI_Job_Result result, size_t size,
980 void *data, size_t *size_ret);
981
989 // end of client_job_interface
991 // end of client_interface
993
994// NOLINTEND(performance-enum-size, modernize-use-using)
995
996#ifdef __cplusplus
997} // extern "C"
998#endif
Defines all enums used within QDMI across the QDMI Client Interface and the QDMI Device Interface.
enum QDMI_JOB_STATUS_T QDMI_Job_Status
Job status type.
Definition constants.h:846
enum QDMI_JOB_RESULT_T QDMI_Job_Result
Job result type.
Definition constants.h:1121
enum QDMI_SITE_PROPERTY_T QDMI_Site_Property
Site property type.
Definition constants.h:668
enum QDMI_OPERATION_PROPERTY_T QDMI_Operation_Property
Operation property type.
Definition constants.h:818
enum QDMI_DEVICE_PROPERTY_T QDMI_Device_Property
Device property type.
Definition constants.h:433
struct QDMI_Device_impl_d * QDMI_Device
A handle for a device implementing the QDMI Device Interface.
Definition client.h:64
enum QDMI_JOB_PROPERTY_T QDMI_Job_Property
Job property type.
Definition client.h:805
int QDMI_job_submit(QDMI_Job job)
Submit a job to the device.
QDMI_JOB_PARAMETER_T
Enum of the job parameters that can be set.
Definition client.h:637
enum QDMI_JOB_PARAMETER_T QDMI_Job_Parameter
Job parameter type.
Definition client.h:687
int QDMI_job_wait(QDMI_Job job, size_t timeout)
Wait for a job to finish.
QDMI_JOB_PROPERTY_T
Enum of the job properties that can be queried via QDMI_job_query_property as part of the client inte...
Definition client.h:750
int QDMI_job_set_parameter(QDMI_Job job, QDMI_Job_Parameter param, size_t size, const void *value)
Set a parameter for a job.
void QDMI_job_free(QDMI_Job job)
Free a job.
int QDMI_device_create_job(QDMI_Device device, QDMI_Job *job)
Create a job.
struct QDMI_Job_impl_d * QDMI_Job
A handle for a client-side job.
Definition client.h:612
int QDMI_job_get_results(QDMI_Job job, QDMI_Job_Result result, size_t size, void *data, size_t *size_ret)
Retrieve the results of a job.
int QDMI_job_cancel(QDMI_Job job)
Cancel an already submitted job.
int QDMI_job_check(QDMI_Job job, QDMI_Job_Status *status)
Check the status of a job.
int QDMI_job_query_property(QDMI_Job job, QDMI_Job_Property prop, size_t size, void *value, size_t *size_ret)
Query a job property.
@ QDMI_JOB_PARAMETER_CUSTOM1
This enum value is reserved for a custom parameter.
Definition client.h:675
@ QDMI_JOB_PARAMETER_CUSTOM4
Definition client.h:681
@ QDMI_JOB_PARAMETER_SHOTSNUM
size_t The number of shots to execute for a quantum circuit job.
Definition client.h:660
@ QDMI_JOB_PARAMETER_CUSTOM3
Definition client.h:679
@ QDMI_JOB_PARAMETER_CUSTOM5
Definition client.h:683
@ QDMI_JOB_PARAMETER_CUSTOM2
Definition client.h:677
@ QDMI_JOB_PARAMETER_MAX
The maximum value of the enum.
Definition client.h:668
@ QDMI_JOB_PARAMETER_PROGRAM
void* The program to be executed.
Definition client.h:655
@ QDMI_JOB_PARAMETER_PROGRAMFORMAT
QDMI_Program_Format The format of the program to be executed.
Definition client.h:645
@ QDMI_JOB_PROPERTY_CUSTOM5
Definition client.h:801
@ QDMI_JOB_PROPERTY_CUSTOM1
This enum value is reserved for a custom parameter.
Definition client.h:793
@ QDMI_JOB_PROPERTY_MAX
The maximum value of the enum.
Definition client.h:786
@ QDMI_JOB_PROPERTY_PROGRAM
void* The program to be executed.
Definition client.h:771
@ QDMI_JOB_PROPERTY_SHOTSNUM
size_t The number of shots to execute for a quantum circuit job.
Definition client.h:777
@ QDMI_JOB_PROPERTY_ID
char* (string) The job's ID.
Definition client.h:759
@ QDMI_JOB_PROPERTY_PROGRAMFORMAT
QDMI_Program_Format The format of the program to be executed.
Definition client.h:765
@ QDMI_JOB_PROPERTY_CUSTOM2
Definition client.h:795
@ QDMI_JOB_PROPERTY_CUSTOM3
Definition client.h:797
@ QDMI_JOB_PROPERTY_CUSTOM4
Definition client.h:799
int QDMI_device_query_device_property(QDMI_Device device, QDMI_Device_Property prop, size_t size, void *value, size_t *size_ret)
Query a device property.
int QDMI_device_query_operation_property(QDMI_Device device, QDMI_Operation operation, size_t num_sites, const QDMI_Site *sites, size_t num_params, const double *params, QDMI_Operation_Property prop, size_t size, void *value, size_t *size_ret)
Query an operation property.
int QDMI_device_query_site_property(QDMI_Device device, QDMI_Site site, QDMI_Site_Property prop, size_t size, void *value, size_t *size_ret)
Query a site property.
void QDMI_session_free(QDMI_Session session)
Free a session.
int QDMI_session_set_parameter(QDMI_Session session, QDMI_Session_Parameter param, size_t size, const void *value)
Set a parameter for a session.
struct QDMI_Session_impl_d * QDMI_Session
A handle for a session.
Definition client.h:89
int QDMI_session_query_session_property(QDMI_Session session, QDMI_Session_Property prop, size_t size, void *value, size_t *size_ret)
Query a property of a session.
QDMI_SESSION_PROPERTY_T
Enum of the session properties that can be queried via QDMI_session_query_session_property.
Definition client.h:278
int QDMI_session_alloc(QDMI_Session *session)
Allocate a new session.
QDMI_SESSION_PARAMETER_T
Enum of the session parameters that can be set via QDMI_session_set_parameter.
Definition client.h:115
enum QDMI_SESSION_PARAMETER_T QDMI_Session_Parameter
Session parameter type.
Definition client.h:195
enum QDMI_SESSION_PROPERTY_T QDMI_Session_Property
Session property type.
Definition client.h:310
int QDMI_session_init(QDMI_Session session)
Initialize a session.
@ QDMI_SESSION_PROPERTY_CUSTOM3
Definition client.h:302
@ QDMI_SESSION_PROPERTY_CUSTOM2
Definition client.h:300
@ QDMI_SESSION_PROPERTY_CUSTOM1
This enum value is reserved for a custom property.
Definition client.h:298
@ QDMI_SESSION_PROPERTY_CUSTOM5
Definition client.h:306
@ QDMI_SESSION_PROPERTY_MAX
The maximum value of the enum.
Definition client.h:291
@ QDMI_SESSION_PROPERTY_DEVICES
QDMI_Device* (QDMI_Device list) The devices the client has access to.
Definition client.h:283
@ QDMI_SESSION_PROPERTY_CUSTOM4
Definition client.h:304
@ QDMI_SESSION_PARAMETER_CUSTOM1
This enum value is reserved for a custom parameter.
Definition client.h:183
@ QDMI_SESSION_PARAMETER_AUTHURL
char* (string) The URL to an authentication server used as part of the authentication procedure.
Definition client.h:146
@ QDMI_SESSION_PARAMETER_CUSTOM3
Definition client.h:187
@ QDMI_SESSION_PARAMETER_PASSWORD
char* (string) The password to use for the session.
Definition client.h:160
@ QDMI_SESSION_PARAMETER_MAX
The maximum value of the enum.
Definition client.h:176
@ QDMI_SESSION_PARAMETER_CUSTOM5
Definition client.h:191
@ QDMI_SESSION_PARAMETER_CUSTOM2
Definition client.h:185
@ QDMI_SESSION_PARAMETER_CUSTOM4
Definition client.h:189
@ QDMI_SESSION_PARAMETER_USERNAME
char* (string) The username to use for the session.
Definition client.h:153
@ QDMI_SESSION_PARAMETER_TOKEN
char* (string) The token to use for the session.
Definition client.h:122
@ QDMI_SESSION_PARAMETER_PROJECTID
char* (string) The project ID to use for the session.
Definition client.h:167
@ QDMI_SESSION_PARAMETER_AUTHFILE
char* (string) A file path to a file containing authentication information.
Definition client.h:132
Defines all types used within QDMI across the QDMI Client Interface and the QDMI Device Interface.
struct QDMI_Site_impl_d * QDMI_Site
A handle for a site.
Definition types.h:54
struct QDMI_Operation_impl_d * QDMI_Operation
A handle for an operation.
Definition types.h:73