Ativar o cliente Amazon Braket Boto3 - Amazon Braket

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

Ativar o cliente Amazon Braket Boto3

Para usar o Boto3 com o Amazon Braket, você deve importar o Boto3 e definir um cliente que você usa para se conectar ao Braket. Amazon API No exemplo a seguir, o cliente Boto3 é nomeado. braket

nota

Para compatibilidade com versões anteriores do BraketSchemas, as informações do OpenQASM são omitidas das chamadas. GetDevice API Para obter essas informações, o agente de usuário precisa apresentar uma versão recente do BraketSchemas (1.8.0 ou posterior). O SDK do Braket relata isso automaticamente para você. Se você não vê resultados do OpenQASM na GetDevice resposta ao usar um SDK do Braket, talvez seja necessário definir a variável de AWS_EXECUTION_ENV ambiente para configurar o agente de usuário. Consulte os exemplos de código fornecidos no tópico de erro GetDevice não retorna resultados do OpenQASM para saber como fazer isso com os AWS CLI SDKs Boto3 e Go, Java e//. JavaScript TypeScript

import boto3 import botocore braket = boto3.client("braket", config=botocore.client.Config(user_agent_extra="BraketSchemas/1.8.0"))

Agora que você tem um braket cliente estabelecido, você pode fazer solicitações e processar respostas do serviço Amazon Braket. Você pode obter mais detalhes sobre os dados de solicitação e resposta na Referência da API.

Pesquise dispositivos

  • search_devices(**kwargs)

Pesquise dispositivos usando os 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'])

Recuperar um dispositivo

  • get_device(deviceArn)

Recupere os dispositivos disponíveis no 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']}")

Crie uma tarefa quântica

  • create_quantum_task(**kwargs)

Crie uma tarefa quâ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")

Recupere uma tarefa quântica

  • get_quantum_task(quantumTaskArn)

Recupere a tarefa quâ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'])

Pesquise tarefas quânticas

  • search_quantum_tasks(**kwargs)

Pesquise tarefas quânticas que correspondam aos 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']}")

Cancelar tarefa quântica

  • cancel_quantum_task(quantumTaskArn)

Cancele a tarefa quâ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']}")