Monitoraggio delle attività quantistiche dall'SDK Amazon Braket - Amazon Braket

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

Monitoraggio delle attività quantistiche dall'SDK Amazon Braket

Il comando device.run(…​) definisce un'attività quantistica con un ID di attività quantistica univoco. È possibile interrogare e tenere traccia dello stato con task.state() come illustrato nell'esempio seguente.

Nota: task = device.run() è un'operazione asincrona, il che significa che potete continuare a lavorare mentre il sistema elabora il vostro compito quantistico in background.

Recupera un risultato

Quando chiamitask.result(), l'SDK inizia a interrogare Amazon Braket per vedere se l'attività quantistica è completa. L'SDK utilizza i parametri di polling definiti in. .run() Una volta completata l'attività quantistica, l'SDK recupera il risultato dal bucket S3 e lo restituisce come oggetto. QuantumTaskResult

# create a circuit, specify the device and run the circuit circ = Circuit().rx(0, 0.15).ry(1, 0.2).cnot(0,2) device = AwsDevice("arn:aws:braket:::device/quantum-simulator/amazon/sv1") task = device.run(circ, s3_location, shots=1000) # get ID and status of submitted task task_id = task.id status = task.state() print('ID of task:', task_id) print('Status of task:', status) # wait for job to complete while status != 'COMPLETED': status = task.state() print('Status:', status)
ID of task: arn:aws:braket:us-west-2:123412341234:quantum-task/b68ae94b-1547-4d1d-aa92-1500b82c300d Status of task: QUEUED Status: QUEUED Status: QUEUED Status: QUEUED Status: QUEUED Status: QUEUED Status: QUEUED Status: QUEUED Status: RUNNING Status: RUNNING Status: COMPLETED

Annulla un'attività quantistica

Per annullare un'operazione quantistica, chiamate il cancel() metodo, come illustrato nell'esempio seguente.

# cancel quantum task task.cancel() status = task.state() print('Status of task:', status)
Status of task: CANCELLING

Controllate i metadati

È possibile controllare i metadati dell'operazione quantistica completata, come mostrato nell'esempio seguente.

# get the metadata of the quantum task metadata = task.metadata() # example of metadata shots = metadata['shots'] date = metadata['ResponseMetadata']['HTTPHeaders']['date'] # print example metadata print("{} shots taken on {}.".format(shots, date)) # print name of the s3 bucket where the result is saved results_bucket = metadata['outputS3Bucket'] print('Bucket where results are stored:', results_bucket) # print the s3 object key (folder name) results_object_key = metadata['outputS3Directory'] print('S3 object key:', results_object_key) # the entire look-up string of the saved result data look_up = 's3://'+results_bucket+'/'+results_object_key print('S3 URI:', look_up)
1000 shots taken on Wed, 05 Aug 2020 14:44:22 GMT. Bucket where results are stored: amazon-braket-123412341234 S3 object key: simulation-output/b68ae94b-1547-4d1d-aa92-1500b82c300d S3 URI: s3://amazon-braket-123412341234/simulation-output/b68ae94b-1547-4d1d-aa92-1500b82c300d

Recuperate un'attività o un risultato quantistico

Se il kernel muore dopo aver inviato il task quantistico o se chiudi il notebook o il computer, puoi ricostruire l'taskoggetto con il suo ARN (quantum task ID) univoco. Quindi puoi chiamare task.result() per ottenere il risultato dal bucket S3 in cui è memorizzato.

from braket.aws import AwsSession, AwsQuantumTask # restore task with unique arn task_load = AwsQuantumTask(arn=task_id) # retrieve the result of the task result = task_load.result()