

本文為英文版的機器翻譯版本，如內容有任何歧義或不一致之處，概以英文版為準。

# 開啟 Amazon Braket Boto3 用戶端
<a name="braket-using-boto3-client"></a>

若要搭配 Amazon Braket 使用 Boto3，您必須匯入 Boto3，然後定義用來連線至 Amazon Braket 的用戶端API。在下列範例中，Boto3 用戶端名為 `braket`。

```
import boto3
import botocore

braket = boto3.client("braket")
```

**注意**  
[Braket 支援 IPv6](https://docs.aws.amazon.com/vpc/latest/userguide/aws-ipv6-support.html)。如果您使用IPv6-only的網路，或希望確保工作負載使用 IPv6 流量，請使用雙堆疊端點，如[雙堆疊和 FIPS 端點](https://docs.aws.amazon.com/sdkref/latest/guide/feature-endpoints.html)指南中所述。

現在您已建立`braket`用戶端，您可以從 Amazon Braket 服務提出請求和處理回應。您可以在 [API 參考](https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/braket.html)中取得請求和回應資料的詳細資訊。

**Topics**
+ [搜尋裝置](#braket-using-boto3-example-search-devices)
+ [擷取裝置](#braket-using-boto3-example-retrieve-devices)
+ [建立量子任務](#braket-using-boto3-example-create-task)
+ [擷取量子任務](#braket-using-boto3-example-retrieve-task)
+ [搜尋量子任務](#braket-using-boto3-example-search-tasks)
+ [取消量子任務](#braket-using-boto3-example-cancel-task)

## 搜尋裝置
<a name="braket-using-boto3-example-search-devices"></a>
+  `search_devices(**kwargs)` 

使用指定的篩選條件搜尋裝置。

```
# Pass search filters and optional parameters when sending the
# request and capture the response
response = braket.search_devices(filters=[{
    'name': 'deviceArn',
    'values': ['arn:aws:braket:::device/quantum-simulator/amazon/sv1']
}], maxResults=10)

print(f"Found {len(response['devices'])} devices")

for i in range(len(response['devices'])):
    device = response['devices'][i]
    print(device['deviceArn'])
```

## 擷取裝置
<a name="braket-using-boto3-example-retrieve-devices"></a>
+  `get_device(deviceArn)` 

擷取 Amazon Braket 中可用的裝置。

```
# Pass the device ARN when sending the request and capture the repsonse
response = braket.get_device(deviceArn='arn:aws:braket:::device/quantum-simulator/amazon/sv1')

print(f"Device {response['deviceName']} is {response['deviceStatus']}")
```

## 建立量子任務
<a name="braket-using-boto3-example-create-task"></a>
+  `create_quantum_task(**kwargs)` 

建立量子任務。

```
# Create parameters to pass into create_quantum_task()
kwargs = {
    # Create a Bell pair
    'action': '{"braketSchemaHeader": {"name": "braket.ir.jaqcd.program", "version": "1"}, "results": [], "basis_rotation_instructions": [], "instructions": [{"type": "h", "target": 0}, {"type": "cnot", "control": 0, "target": 1}]}',
    # Specify the SV1 Device ARN
    'deviceArn': 'arn:aws:braket:::device/quantum-simulator/amazon/sv1',
    # Specify 2 qubits for the Bell pair
    'deviceParameters': '{"braketSchemaHeader": {"name": "braket.device_schema.simulators.gate_model_simulator_device_parameters", "version": "1"}, "paradigmParameters": {"braketSchemaHeader": {"name": "braket.device_schema.gate_model_parameters", "version": "1"}, "qubitCount": 2}}',
    # Specify where results should be placed when the quantum task completes.
    # You must ensure the S3 Bucket exists before calling create_quantum_task()
    'outputS3Bucket': 'amazon-braket-examples',
    'outputS3KeyPrefix': 'boto-examples',
    # Specify number of shots for the quantum task
    'shots': 100
}

# Send the request and capture the response
response = braket.create_quantum_task(**kwargs)

print(f"Quantum task {response['quantumTaskArn']} created")
```

## 擷取量子任務
<a name="braket-using-boto3-example-retrieve-task"></a>
+  `get_quantum_task(quantumTaskArn)` 

擷取指定的量子任務。

```
# Pass the quantum task ARN when sending the request and capture the response
response = braket.get_quantum_task(quantumTaskArn='arn:aws:braket:us-west-1:123456789012:quantum-task/ce78c429-cef5-45f2-88da-123456789012')

print(response['status'])
```

## 搜尋量子任務
<a name="braket-using-boto3-example-search-tasks"></a>
+  `search_quantum_tasks(**kwargs)` 

搜尋符合指定篩選條件值的量子任務。

```
# Pass search filters and optional parameters when sending the
# request and capture the response
response = braket.search_quantum_tasks(filters=[{
    'name': 'deviceArn',
    'operator': 'EQUAL',
    'values': ['arn:aws:braket:::device/quantum-simulator/amazon/sv1']
}], maxResults=25)

print(f"Found {len(response['quantumTasks'])} quantum tasks")

for n in range(len(response['quantumTasks'])):
    task = response['quantumTasks'][n]
    print(f"Quantum task {task['quantumTaskArn']} for {task['deviceArn']} is {task['status']}")
```

## 取消量子任務
<a name="braket-using-boto3-example-cancel-task"></a>
+  `cancel_quantum_task(quantumTaskArn)` 

取消指定的量子任務。

```
# Pass the quantum task ARN when sending the request and capture the response
response = braket.cancel_quantum_task(quantumTaskArn='arn:aws:braket:us-west-1:123456789012:quantum-task/ce78c429-cef5-45f2-88da-123456789012')

print(f"Quantum task {response['quantumTaskArn']} is {response['cancellationStatus']}")
```