-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add @aq.hybrid_job decorator implementation
- Loading branch information
Showing
6 changed files
with
713 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
# AutoQASM with Amazon Braket Hybrid Jobs | ||
|
||
Amazon Braket Hybrid Jobs provides a solution for executing hybrid quantum-classical algorithms that utilize both classical computing resources and Quantum Processing Units (QPUs). This service efficiently manages allocating classical compute resources, executing your algorithm, and then freeing up those resources upon completion, ensuring cost-effectiveness by charging only for the resources used. It's perfectly suited for iterative algorithms that span lengthy durations and require the integration of classical and quantum computing. | ||
|
||
## Using `AwsQuantumJob.create` | ||
|
||
This [documentation page](https://docs.aws.amazon.com/braket/latest/developerguide/braket-jobs-first.html#braket-jobs-first-create) shows you how to create a hybrid job with `AwsQuantumJob.create`. To use a hybrid job with AutoQASM, simply use AutoQASM in your algorithm script. Because AutoQASM is currently not installed in the default job container, be sure to include the AutoQASM feature branch in the requirements.txt of your source module, or add AutoQASM as a dependency when you build your own container. Below is an example algorithm script to get you started. | ||
``` | ||
import os | ||
from braket.devices import LocalSimulator | ||
from braket.circuits import Circuit | ||
import autoqasm as aq | ||
from autoqasm.instructions import measure, h, cnot | ||
def start_here(): | ||
print("Test job started!") | ||
# Use the device declared in the job script | ||
device = LocalSimulator("autoqasm") | ||
@aq.main | ||
def bell(): | ||
h(0) | ||
cnot(0, 1) | ||
c = measure([0, 1]) | ||
for count in range(5): | ||
task = device.run(bell, shots=100) | ||
print(task.result().measurements) | ||
print("Test job completed!") | ||
``` | ||
|
||
Save this algorithm script as "algorithm_script.py" and run this code snippet below to create your first hybrid job with AutoQASM! | ||
``` | ||
from braket.aws import AwsQuantumJob | ||
job = AwsQuantumJob.create( | ||
device="local:braket_simulator", | ||
dependencies=["autoqasm"], | ||
source_module="algorithm_script.py", | ||
entry_point="algorithm_script:start_here", | ||
wait_until_complete=True | ||
) | ||
``` | ||
|
||
## Using the `@aq.hybrid_job` decorator | ||
|
||
Alternatively, you can use the `@aq.hybrid_job` decorator to create a hybrid job with AutoQASM. Because AutoQASM is currently not installed in the default job container, be sure to include AutoQASM in the `dependencies` keyword of the `@aq.hybrid_job` decorator, or add AutoQASM as a dependency when you build your own container. | ||
|
||
One of the core mechanisms of AutoQASM is source code analysis. When calling an AutoQASM decorated function, the source code of the function is analyzed and converted into a transformed Python function by AutoGraph. The source code of a function defined inside the `@aq.hybrid_job` decorated function is then separately saved as input data to the job. When [AutoQASM decorators](decorators.md) wrap these functions, the source code is retrieved from the input data. Because of this, if you use an AutoQASM decorator to convert a function that is defined outside of the `@aq.hybrid_job` decorated function, it may not work properly. If your application requires AutoQASM decorated functions to be defined outside of the `@aq.hybrid_job` decorated function, we recommend that you use the option described in "Using `AwsQuantumJob.create`" to create the hybrid job. | ||
|
||
Below is a working example to create an AutoQASM job with the `@aq.hybrid_job` decorator. | ||
``` | ||
from braket.jobs import hybrid_job | ||
from braket.devices import LocalSimulator | ||
import autoqasm as aq | ||
from autoqasm.instructions import measure, h, cnot | ||
@aq.hybrid_job( | ||
device="local:braket_simulator", | ||
dependencies=["autoqasm"], | ||
) | ||
def bell_circuit_job(): | ||
@aq.main | ||
def bell(): | ||
h(0) | ||
cnot(0, 1) | ||
c = measure([0, 1]) | ||
device = LocalSimulator("autoqasm") | ||
for count in range(5): | ||
task = device.run(bell, shots=100) | ||
print(task.result().measurements) | ||
bell_circuit_job() | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.