Azure Quantum Jobs client library for Java - version 1.0.0-beta.1
Azure Quantum is a Microsoft Azure service that you can use to run quantum computing programs or solve optimization problems in the cloud. Using the Azure Quantum tools and SDKs, you can create quantum programs and run them against different quantum simulators and machines. You can use the Azure.Quantum.Jobs client library to:
- Create, enumerate, and cancel quantum jobs
- Enumerate provider status and quotas
Source code | API reference documentation | Product documentation
Getting started
This section should include everything a developer needs to do to install and create their first client connection very quickly.
Install the package
Install the Azure Quantum Jobs client library for Java by adding the following to your pom.xml file:
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-quantum-jobs</artifactId>
<version>1.0.0-beta.1</version>
</dependency>
Prerequisites: You must have an Azure subscription, Azure Quantum workspace, Azure storage account, and a Java Development Kit (JDK) of version 8 or later.
Authenticate the client
To authenticate with the service, you will have to pass a TokenCredential
to the client builder as described below.
TokenCredential
is the default Authentication mechanism used by Azure SDKs.
Key concepts
QuantumJobClient
is the root class to be used to authenticate and create, enumerate, and cancel jobs.
JobDetails
contains all the properties of a job.
ProviderStatus
contains status information for a provider.
QuantumJobQuota
contains quota properties.
Examples
Create the client
Create an instance of the client of your choice by passing the following values to QuantumClientBuilder
and then calling the appropriate build method.
- Subscription - looks like XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX and can be found in your list of subscriptions on azure
- Resource Group - a container that holds related resources for an Azure solution
- Workspace - a collection of assets associated with running quantum or optimization applications
- Host - the host endpoint is "https://{location}.quantum.azure.com". Choose the best data center location by geographical region
- StorageContainerName - your blob storage
- Credential - used to authenticate
JobsClient jobsClient = new QuantumClientBuilder()
.credential(new DefaultAzureCredentialBuilder().build())
.host("{endpoint}")
.subscriptionId("{subscriptionId}")
.resourceGroupName("{resourceGroup}")
.workspaceName("{workspaceName}")
.buildJobsClient();
StorageClient storageClient = new QuantumClientBuilder()
.credential(new DefaultAzureCredentialBuilder().build())
.host("{endpoint}")
.subscriptionId("{subscriptionId}")
.resourceGroupName("{resourceGroup}")
.workspaceName("{workspaceName}")
.buildStorageClient();
Get Container SAS URI
Create a storage container to put your data in.
// Get container URI with SAS key
String containerName = "{storageContainerName}";
// Create container if it doesn't already exist
BlobContainerClient containerClient = new BlobContainerClientBuilder()
.containerName(containerName)
.endpoint(containerUri)
.buildClient();
if (!containerClient.exists()) {
containerClient.create();
}
// Get connection string to the container
String containerUri = storageClient.sasUri(
new BlobDetails().setContainerName(containerName)
).getSasUri();
Upload Input Data
Using the SAS URI, upload the json input data to the blob client. This contains the parameters to be used with Quantum Inspired Optimizations
// Get input data blob Uri with SAS key
String blobName = "{blobName}";
BlobDetails blobDetails = new BlobDetails()
.setContainerName(containerName)
.setBlobName(blobName);
String inputDataUri = storageClient.sasUri(blobDetails).getSasUri();
// Upload input data to blob
BlobClient blobClient = new BlobClientBuilder()
.endpoint(inputDataUri)
.buildClient();
String problemFilePath = FileSystems.getDefault().getPath("src/samples/resources/problem.json").toString();
blobClient.uploadFromFile(problemFilePath);
Create The Job
Now that you've uploaded your problem definition to Azure Storage, you can use the create()
method in JobsClient
or JobsAsyncClient
, or the createWithResponse()
method in JobsAsyncClient
to define an Azure Quantum job.
String jobId = String.format("job-%s", UUID.randomUUID());
JobDetails createJobDetails = new JobDetails()
.setContainerUri(containerUri)
.setId(jobId)
.setInputDataFormat("microsoft.qio.v2")
.setOutputDataFormat("microsoft.qio-results.v2")
.setProviderId("microsoft")
.setTarget("microsoft.paralleltempering-parameterfree.cpu")
.setName("{jobName}");
JobDetails jobDetails = jobsClient.create(jobId, createJobDetails);
Get Job
To retrieve a specific job by its ID, you can use get()
from JobsClient
or JobsAsyncClient
, or getWithResponse()
in JobsAsyncClient
.
// Get the job that we've just created based on its jobId
JobDetails myJob = jobsClient.get(jobId);
List Jobs
To enumerate all the jobs in the workspace, use the list()
method from JobClient
or JobAsyncClient
, or from JobAsyncClient
use listSinglePage()
or listNextPage()
.
PagedIterable<JobDetails> jobs = jobsClient.list();
jobs.forEach(job -> {
System.out.println(job.getName());
});
Troubleshooting
All Quantum Jobs service operations will throw a RequestFailedException on failure with helpful ErrorCodes. Many of these errors are recoverable.
Next steps
- Visit our Product documentation to learn more about Azure Quantum.
Contributing
See the CONTRIBUTING.md for details on building, testing, and contributing to this library.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit [cla.microsoft.com][cla].
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.