Quantum Simulation Suite with VQE, QPE, and QITE modules (PennyLane-based)
Project description
Quantum Simulation Suite
PyPI: https://pypi.org/project/vqe-pennylane/
PennyLane-based workflows for:
- ground-state VQE
- excited-state methods
- quantum phase estimation
- variational imaginary-time evolution
- variational real-time evolution
Implemented packages:
vqefor ground-state and excited-state solversqpefor phase-estimation workflowsqitefor projected variational dynamics (VarQITE,VarQRTE)commonfor shared chemistry, Hamiltonians, caching, and plotting
Table of Contents
- What This Repo Is Good For
- Choose A Method
- Install
- Quickstart
- Typical Workflow
- Package Overview
- Shared Infrastructure
- Supported Molecule Inputs
- Non-Molecule Mode
- Outputs And Reproducibility
- Notebooks
- Documentation
- Repository Layout
- Testing
- Support Development
- Author
- License
What This Repo Is Good For
Use this repo if you want:
- one Hamiltonian pipeline shared across VQE, QPE, and QITE/QRTE
- one shared problem-resolution layer for molecule, explicit-geometry, and expert-mode inputs
- reproducible runs with stable cache keys and JSON outputs
- both Python APIs and CLI workflows
- notebooks that separate demos from benchmarks
It is optimized for small-molecule algorithm development and comparison, not large-scale production chemistry.
Choose A Method
Use VQE when you want a ground-state energy or a good reference state.
Use ADAPT-VQE when you want an adaptive ansatz rather than a fixed one.
Use QSE, EOM-QSE, LR-VQE, or EOM-VQE when you already have a converged VQE reference and want excited-state information.
Use SSVQE or VQD when you want variational excited-state solvers directly.
Use QPE when you want spectral / phase information rather than a compact variational state.
Use VarQITE when you want imaginary-time relaxation toward a low-energy state.
Use VarQRTE when you already have a relevant state and want to evolve it in real time and analyze observables.
Use expert-mode Hamiltonian inputs when you want to benchmark algorithms on non-chemistry qubit models without going through the molecule / geometry pipeline.
Install
From PyPI:
pip install vqe-pennylane
From source:
git clone https://github.com/SidRichardsQuantum/Variational_Quantum_Eigensolver.git
cd Variational_Quantum_Eigensolver
pip install -e .
Verify:
python -c "import vqe, qpe, qite, common; print('Quantum stacks imported successfully')"
Quickstart
Python:
import pennylane as qml
from vqe import run_vqe
from qite import run_qite, run_qrte
vqe_res = run_vqe(molecule="H2")
print("VQE:", vqe_res["energy"])
qite_res = run_qite(molecule="H2", steps=75, dtau=0.2)
print("VarQITE:", qite_res["energy"])
qrte_res = run_qrte(molecule="H2", steps=20, dt=0.05)
print("VarQRTE final energy:", qrte_res["energy"])
H_model = qml.Hamiltonian([1.0, 0.5], [qml.PauliZ(0), qml.PauliX(0)])
model_res = run_vqe(
hamiltonian=H_model,
num_qubits=1,
reference_state=[1],
ansatz_name="RY-CZ",
steps=10,
plot=False,
)
print("Model VQE:", model_res["energy"])
run_vqe() uses the calibrated default stepsize for the selected optimizer when stepsize is omitted.
The vqe CLI does the same when --stepsize is omitted.
CLI:
python -m vqe -m H2
python -m qpe --molecule H2 --ancillas 4 --shots 1000 --trotter-steps 2
python -m qite run --molecule H2 --steps 75 --dtau 0.2
python -m qite run-qrte --molecule H2 --steps 20 --dt 0.05
Typical Workflow
For stationary-state work:
- run
VQEto get a ground-state reference - run post-VQE or excited-state solvers if needed
- compare against exact small-system references where possible
For dynamics:
- prepare a state with
VQE,VarQITE, or an excited-state workflow - use
VarQRTEfor real-time dynamics - benchmark against exact evolution on small systems when possible
Package Overview
vqe
Includes:
run_vqerun_vqe_low_qubit_benchmarkrun_adapt_vqerun_lr_vqerun_eom_vqerun_qserun_eom_qserun_ssvqerun_vqd
Use it for:
- ground-state optimization
- low-qubit multi-molecule benchmarking
- excited-state studies
- ansatz / optimizer / mapping comparisons
- geometry scans
- noisy VQE experiments
qpe
Includes:
run_qpe
Use it for:
- phase-to-energy estimation
- ancilla / shot studies
- controlled time-evolution experiments
Default QPE settings are H2-calibrated baseline defaults:
n_ancilla=4t=1.0trotter_steps=2shots=1000
They are intended as good small-molecule starting values, not globally optimized settings for every molecule.
qite
Includes:
run_qiterun_qrte
Use it for:
- imaginary-time relaxation with
VarQITE - real-time dynamics with
VarQRTE - prepared-state quench workflows
Important:
VarQITEis a state-finding / relaxation methodVarQRTEis a dynamics method, not an eigensolver- for time-independent Hamiltonians,
VarQRTEshould usually conserve energy up to numerical error
Shared Infrastructure
All solver packages use the same chemistry layer in common/.
That gives you:
- consistent Hamiltonians across algorithms
- comparable outputs across methods
- shared run signatures and cache reuse
- standardized result and image paths
Main shared modules:
common/molecules.pycommon/geometry.pycommon/hamiltonian.pycommon/problem.pycommon/persist.pycommon/plotting.pycommon/paths.py
Useful shared helpers:
build_hamiltonian(...)get_exact_spectrum(...)summarize_registry_coverage(...)
Supported Molecule Inputs
For standard chemistry workflows, prefer the shared molecule pipeline over expert-mode Hamiltonian inputs.
Built-in registry molecules currently include:
H,H-,H2,H2+,H2-,H3,H3+,H4,H4+,H5+,H6He,He+,He2,HeH+Li,Li+,LiHBe,Be+,BeH2B,B+,C,C+,N,N+,O,O+,F,F+,NeH2O
If a target system is not in the registry, use explicit geometry inputs such as
symbols=..., coordinates=..., charge=..., multiplicity=..., and basis=....
That keeps the run on the standard chemistry path and avoids expert mode unless you
already have a prebuilt qubit Hamiltonian.
For a ready-made inventory of the built-in registry, use:
from common import summarize_registry_coverage
rows = summarize_registry_coverage()
Non-Molecule Mode
The Python APIs also support a direct qubit-Hamiltonian mode for algorithm benchmarking outside chemistry.
Currently supported:
run_vqe(..., hamiltonian=H, num_qubits=..., reference_state=...)run_qite(..., hamiltonian=H, num_qubits=..., reference_state=...)run_qrte(..., hamiltonian=H, num_qubits=..., reference_state=...)run_qpe(..., hamiltonian=H, hf_state=..., system_qubits=...)
Notes:
- this is a Python expert-mode API, not a CLI feature
- arbitrary qubit wire labels are normalized internally
run_qpe(...)expert mode requires bothhamiltonianandhf_state- chemistry-specific ansatzes like
UCCSDstill require chemistry metadata; for generic model Hamiltonians prefer ansatzes likeRY-CZ,Minimal, orStronglyEntanglingLayers
Outputs And Reproducibility
Generated outputs are written under:
results/vqe/
results/qpe/
results/qite/
images/vqe/
images/qpe/
images/qite/
General behavior:
- run configurations are hashed deterministically
- matching runs reuse cached JSON records
- cached records missing runtime metadata are treated as stale and recomputed automatically
--forcerecomputes instead of loading cache
For sampled QPE runs with finite shots, seed still matters because the measured bitstring distribution is stochastic. In analytic mode (shots=None), the seed is effectively irrelevant.
Notebooks
Notebook guide:
Layout:
notebooks/getting_started/for usage-oriented demosnotebooks/benchmarks/for exact-reference, comparison, and scan workflows
Recommended starting points:
notebooks/getting_started/01_vqe_vs_qpe_from_scratch_h2.ipynbnotebooks/getting_started/07_getting_started_qite_h2.ipynbnotebooks/getting_started/11_getting_started_qrte_h2.ipynbnotebooks/benchmarks/qite/H2/Exact_QRTE_Benchmark.ipynb
Documentation
Use these in order:
README.mdfor orientation and quickstartUSAGE.mdfor CLI and Python entrypointsTHEORY.mdfor algorithmic backgroundnotebooks/README_notebooks.mdfor notebook navigation
Deeper implementation notes:
more_docs/architecture.mdmore_docs/vqe/more_docs/qpe/more_docs/qite/
Repository Layout
Variational_Quantum_Eigensolver/
├── vqe/
├── qpe/
├── qite/
├── common/
├── notebooks/
│ ├── getting_started/
│ └── benchmarks/
├── results/
├── images/
├── README.md
├── USAGE.md
├── THEORY.md
└── pyproject.toml
Testing
pytest -q
Support development
If this repository is useful for research, learning, or experimentation, you can support continued development via GitHub Sponsors:
https://github.com/sponsors/SidRichardsQuantum
Sponsorship helps support ongoing work on open-source implementations of quantum algorithms, including improvements to documentation, reproducible workflows, and example notebooks.
Support helps maintain and expand practical tooling for variational quantum methods, quantum simulation workflows, and related experimentation.
Citation
Sid Richards (2026)
Unified Variational and Phase-Estimation Quantum Simulation Suite
Author
Sid Richards
- LinkedIn: sid-richards-21374b30b
- GitHub: SidRichardsQuantum
License
MIT. See LICENSE.
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 vqe_pennylane-0.3.18.tar.gz.
File metadata
- Download URL: vqe_pennylane-0.3.18.tar.gz
- Upload date:
- Size: 151.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c6eb4e6e310b5b9d2cbe871e17e88706a6ec0719ec4654b8a47ad4732f3c6b4b
|
|
| MD5 |
015bdb352aaf6486fb770710c1b132f6
|
|
| BLAKE2b-256 |
727d4c29094663bc90cfdd3b33322bc5a63349fff17bef5b5ecddbb7d28a2804
|
Provenance
The following attestation bundles were made for vqe_pennylane-0.3.18.tar.gz:
Publisher:
publish.yml on SidRichardsQuantum/Variational_Quantum_Eigensolver
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vqe_pennylane-0.3.18.tar.gz -
Subject digest:
c6eb4e6e310b5b9d2cbe871e17e88706a6ec0719ec4654b8a47ad4732f3c6b4b - Sigstore transparency entry: 1341620954
- Sigstore integration time:
-
Permalink:
SidRichardsQuantum/Variational_Quantum_Eigensolver@b07f57b490129d3b318c9624ba2384a14668be34 -
Branch / Tag:
refs/tags/v0.3.18 - Owner: https://github.com/SidRichardsQuantum
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b07f57b490129d3b318c9624ba2384a14668be34 -
Trigger Event:
push
-
Statement type:
File details
Details for the file vqe_pennylane-0.3.18-py3-none-any.whl.
File metadata
- Download URL: vqe_pennylane-0.3.18-py3-none-any.whl
- Upload date:
- Size: 130.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f8743823a4fa39bf19f600d18db6335b7649f85fea1c32981da9ebc88c4666ab
|
|
| MD5 |
dbf2d576adbe325ea39a6cd69d4d0ed1
|
|
| BLAKE2b-256 |
850014d861e5917be721fc82782ab87fdfff51b6e080370fe939f341e7ab25c0
|
Provenance
The following attestation bundles were made for vqe_pennylane-0.3.18-py3-none-any.whl:
Publisher:
publish.yml on SidRichardsQuantum/Variational_Quantum_Eigensolver
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vqe_pennylane-0.3.18-py3-none-any.whl -
Subject digest:
f8743823a4fa39bf19f600d18db6335b7649f85fea1c32981da9ebc88c4666ab - Sigstore transparency entry: 1341620956
- Sigstore integration time:
-
Permalink:
SidRichardsQuantum/Variational_Quantum_Eigensolver@b07f57b490129d3b318c9624ba2384a14668be34 -
Branch / Tag:
refs/tags/v0.3.18 - Owner: https://github.com/SidRichardsQuantum
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b07f57b490129d3b318c9624ba2384a14668be34 -
Trigger Event:
push
-
Statement type: