

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

# Activar el cliente de Boto3 de Amazon Braket
<a name="braket-using-boto3-client"></a>

Para utilizar Boto3 con Amazon Braket, debe importar Boto3 y, a continuación, definir un cliente que utilice para conectarse a la API de Amazon Braket. En el siguiente ejemplo, el cliente de Boto3 se denomina `braket`.

```
import boto3
import botocore

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

**nota**  
[Soportes para Braket. IPv6](https://docs.aws.amazon.com/vpc/latest/userguide/aws-ipv6-support.html) Si utiliza una red IPv6 exclusiva o desea asegurarse de que su carga de trabajo utilice IPv6 tráfico, utilice los terminales de doble pila tal y como se describe en la guía de terminales de [doble pila](https://docs.aws.amazon.com/sdkref/latest/guide/feature-endpoints.html) y FIPS.

Ahora que tiene un cliente de `braket` establecido, puede realizar solicitudes y procesar respuestas desde el servicio Amazon Braket. Puede obtener más detalles sobre los datos de solicitud y respuesta en la [referencia de la API](https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/braket.html).

**Topics**
+ [Búsqueda de dispositivos](#braket-using-boto3-example-search-devices)
+ [Recuperación de un dispositivo](#braket-using-boto3-example-retrieve-devices)
+ [Creación de una tarea cuántica](#braket-using-boto3-example-create-task)
+ [Recuperación de una tarea cuántica](#braket-using-boto3-example-retrieve-task)
+ [Búsqueda de tareas cuánticas](#braket-using-boto3-example-search-tasks)
+ [Cancelación de tarea cuántica](#braket-using-boto3-example-cancel-task)

## Búsqueda de dispositivos
<a name="braket-using-boto3-example-search-devices"></a>
+  `search_devices(**kwargs)` 

Buscar los dispositivos mediante los filtros especificados.

```
# 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'])
```

## Recuperación de un dispositivo
<a name="braket-using-boto3-example-retrieve-devices"></a>
+  `get_device(deviceArn)` 

Recuperar los dispositivos disponibles en 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']}")
```

## Creación de una tarea cuántica
<a name="braket-using-boto3-example-create-task"></a>
+  `create_quantum_task(**kwargs)` 

Crear una tarea cuántica.

```
# 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")
```

## Recuperación de una tarea cuántica
<a name="braket-using-boto3-example-retrieve-task"></a>
+  `get_quantum_task(quantumTaskArn)` 

Recuperar la tarea cuántica especificada.

```
# 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'])
```

## Búsqueda de tareas cuánticas
<a name="braket-using-boto3-example-search-tasks"></a>
+  `search_quantum_tasks(**kwargs)` 

Buscar tareas cuánticas que coincidan con los valores de filtro especificados.

```
# 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']}")
```

## Cancelación de tarea cuántica
<a name="braket-using-boto3-example-cancel-task"></a>
+  `cancel_quantum_task(quantumTaskArn)` 

Cancelar la tarea cuántica especificada.

```
# 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']}")
```