Q1RAM Python client for interacting with the Quantum RAM API
Project description
Q1RAM Client API Methods
This document explains the main methods provided by the Q1RAM client API for quantum random access memory operations. These methods allow you to manipulate quantum memory in both single and superposition states.
1. read
Purpose:
Reads data from the Q1RAM at a specified address or in superposition.
Signature:
read(address_register=None, data_register=None, address_value=None, data_value=None)
Parameters:
address_register: Optional. QuantumRegister or list specifying the address qubits.data_register: Optional. QuantumRegister or list specifying the data qubits.address_value: Optional. List of integers specifying the classical address to read from. If omitted, reads in superposition.data_value: Optional. List of integers specifying the classical data to match (rarely used for read).
Usage Examples:
- Read from a superposition address states:
qram.read(address_value=[0, 1])
2. write
Purpose:
Writes data to the Q1RAM at a single or superposition address states.
Signature:
write(address_register=None, data_register=None, address_value=None, data_value=None)
Parameters:
address_register: Optional. QuantumRegister or list specifying the address qubits.data_register: Optional. QuantumRegister or list specifying the data qubits.address_value: Optional. List of integers specifying the classical address to write to. If omitted, writes in superposition.data_value: Required. List of integers specifying the data to write.
Usage Examples:
- Write to a specific address:
qram.write(address_value=[0, 1], data_value=[5])
3. read_all
Purpose:
Reads all data from Q1RAM, typically used to retrieve the full memory contents.
Signature:
read_all()
Usage Example:
qram.read_all()
Authentication
Before using any method, authenticate with the API:
from q1ram import authenticate
authenticate()
Example Workflow
from q1ram_client.q1ram.circuit import Q1RAM, authenticate
from qiskit import QuantumCircuit
authenticate()
qc = QuantumCircuit()
qram = Q1RAM(qc, number_address_qubits=2, number_data_qubits=2)
# Write data to address [0, 1]
qram.write(address_value=[0, 1], data_value=[1, 0])
# Read data from address [0, 1]
qram.read(address_value=[0, 1])
# Write data in superposition
qram.write(data_value=[1, 1])
# Read all data in superposition
qram.read()
Notes
- All API calls require valid authentication credentials, by registering on https://q1ram.com.
- The methods interact with the Q1RAM backend via HTTP requests and update the local quantum circuit accordingly.
- For advanced usage, you can provide custom quantum registers for address and data.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file q1ram-0.1.5.tar.gz.
File metadata
- Download URL: q1ram-0.1.5.tar.gz
- Upload date:
- Size: 3.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
02d6e6905d43d48515da564a0276b124e84c0c650c052a831add171eb0914d86
|
|
| MD5 |
1b359b930a74406996f797759d122858
|
|
| BLAKE2b-256 |
04b1b92f4ddae1f3467b206ea3069293111533ea9f65d501b863326aeb7e4170
|
File details
Details for the file q1ram-0.1.5-py3-none-any.whl.
File metadata
- Download URL: q1ram-0.1.5-py3-none-any.whl
- Upload date:
- Size: 7.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
52fa293987b37793064dd6e915baa19641df7eb52ae0c9b0dff1b1bed9054d19
|
|
| MD5 |
fedf6749d65cc0f58af6f93f8b0d2ea5
|
|
| BLAKE2b-256 |
e2aafb24459023eb60800b3ed5d24569e66a6b08370868165da4cf419681f819
|