Activar el cliente de Boto3 de Amazon Braket - Amazon Braket

Activar el cliente de Boto3 de Amazon Braket

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

Braket es compatible con IPv6. Si utiliza una red de solo IPv6 o desea asegurarse de que su carga de trabajo utilice tráfico IPv6, utilice los puntos de conexión de doble pila tal y como se describe en la guía Puntos de conexión de doble pila 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.

Búsqueda de dispositivos

  • 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

  • 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

  • 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

  • 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

  • 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

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