LogicQubit is a simple library for quantum computing simulation.
Project description
Features
- Numerical and symbolic simulation of quantum algorithms
- Plot state and current operation, density matrix and measurement graphs
- The state values can be represented as angles, which helps in the analysis of the fourrier quantum transform.
- Operations can be performed directly on the instantiated qubit object or using qubit indices.
- Support GPU
Table of Contents
Installation
pip install logicqubit
Startup
logicQuBit = LogicQuBit(n_qubits, symbolic = True)
Where n_qubits is the number of qubits, and symbolic defines whether the values a and b of the qubits will be symbolic or not, if the symbolic input is omitted the calculation will be numeric.
To instantiate a qubit
q = Qubit()
To instantiate a qubit register
reg = QubitRegister(num_qubits)
Operations
Operations on one qubit
The operation can be performed as q.Gate(parameters) or logicQuBit.Gate(id_qubit, parameters).
Operations on two qubits
In this case, the operation can be performed as q.Gate(control_qubit, parameters) or logicQuBit.Gate(control_qubit, target_qubit, parameters).
*The need for parameters depends on the type of gate.
List of available gates
Single-qubit gates: X, Y, Z, V, S, T, H, RX, RY, RZ, U, U1, U2, U3.
Two-qubits gates: CX or CNOT, CY, CZ, CV, CS, CT, CRX, CRY, CRZ, CU, CU1, CU2, CU3, SWAP.
Three-qubits gates: CCX or Toffoli, Fredkin.
Measure
Measure the expected value of one or more qubits
result = logicQuBit.Measure([q1,q2,..,qn])
Measure one shot on a qubit
value = logicQuBit.Measure_One(qubit)
Plot graphs and print state
Plot expected values
logicQuBit.plot()
Generate a graph of the values obtained by the Measure([...]).
Plot the density matrix
logicQuBit.PlotDensityMatrix()
Print the current state
logicQuBit.PrintState()
Print the current state as angles
logicQuBit.getPsiAtAngles(degree=True)
The degree variable defines whether the result will be displayed in degrees or radians.
Code sample
from logicqubit.logic import *
logicQuBit = LogicQuBit(3)
a = Qubit()
b = Qubit()
c = Qubit()
a.H()
b.H()
c.CCX(a,b) # and operation
logicQuBit.Measure([c])
logicQuBit.Plot()
Other code samples
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
File details
Details for the file logicqubit-1.6.1.tar.gz
.
File metadata
- Download URL: logicqubit-1.6.1.tar.gz
- Upload date:
- Size: 18.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 02c478c866e9c2c1dca8836fea549db2f2776e3592d658cd52b4ffe0a38488a3 |
|
MD5 | fea44f1c750c0c6af74aa19e3a5ebe3d |
|
BLAKE2b-256 | 4dfb5ba875b40ccf43103c6002e534a924ea4485e8777c57ca21483ee887cc1a |
File details
Details for the file logicqubit-1.6.1-py3-none-any.whl
.
File metadata
- Download URL: logicqubit-1.6.1-py3-none-any.whl
- Upload date:
- Size: 20.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e0e594a90d2fa506e014386aa8d030790f377898fd3ea77f0b25a94278806660 |
|
MD5 | 35b9812269a11bb7b7a58668b424b2c6 |
|
BLAKE2b-256 | 67aec26f278c9539d78d7e24a624c03cdcd6c06be04f6bc1d6dfc98f8d3ade18 |