Skip to main content

Quantum Simulation Suite with VQE, QPE, and QITE modules (PennyLane-based)

Project description

Quantum Simulation Suite

PyPI Version Python Versions Tests License Sponsor

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:

  • vqe for ground-state and excited-state solvers
  • qpe for phase-estimation workflows
  • qite for projected variational dynamics (VarQITE, VarQRTE)
  • common for shared chemistry, Hamiltonians, caching, and plotting

Table of Contents

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:

  1. run VQE to get a ground-state reference
  2. run post-VQE or excited-state solvers if needed
  3. compare against exact small-system references where possible

For dynamics:

  1. prepare a state with VQE, VarQITE, or an excited-state workflow
  2. use VarQRTE for real-time dynamics
  3. benchmark against exact evolution on small systems when possible

Package Overview

vqe

Includes:

  • run_vqe
  • run_vqe_low_qubit_benchmark
  • run_adapt_vqe
  • run_lr_vqe
  • run_eom_vqe
  • run_qse
  • run_eom_qse
  • run_ssvqe
  • run_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=4
  • t=1.0
  • trotter_steps=2
  • shots=1000

They are intended as good small-molecule starting values, not globally optimized settings for every molecule.

qite

Includes:

  • run_qite
  • run_qrte

Use it for:

  • imaginary-time relaxation with VarQITE
  • real-time dynamics with VarQRTE
  • prepared-state quench workflows

Important:

  • VarQITE is a state-finding / relaxation method
  • VarQRTE is a dynamics method, not an eigensolver
  • for time-independent Hamiltonians, VarQRTE should 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.py
  • common/geometry.py
  • common/hamiltonian.py
  • common/problem.py
  • common/persist.py
  • common/plotting.py
  • common/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+, H6
  • He, He+, He2, HeH+
  • Li, Li+, LiH
  • Be, Be+, BeH2
  • B, B+, C, C+, N, N+, O, O+, F, F+, Ne
  • H2O

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 both hamiltonian and hf_state
  • chemistry-specific ansatzes like UCCSD still require chemistry metadata; for generic model Hamiltonians prefer ansatzes like RY-CZ, Minimal, or StronglyEntanglingLayers

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
  • --force recomputes 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 demos
  • notebooks/benchmarks/ for exact-reference, comparison, and scan workflows

Recommended starting points:

Documentation

Use these in order:

  1. README.md for orientation and quickstart
  2. USAGE.md for CLI and Python entrypoints
  3. THEORY.md for algorithmic background
  4. notebooks/README_notebooks.md for notebook navigation

Deeper implementation notes:

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

License

MIT. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vqe_pennylane-0.3.19.tar.gz (152.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vqe_pennylane-0.3.19-py3-none-any.whl (130.3 kB view details)

Uploaded Python 3

File details

Details for the file vqe_pennylane-0.3.19.tar.gz.

File metadata

  • Download URL: vqe_pennylane-0.3.19.tar.gz
  • Upload date:
  • Size: 152.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vqe_pennylane-0.3.19.tar.gz
Algorithm Hash digest
SHA256 79959b31a3f3827b5e521ab3d54b15a1bb23780410b44f7babaa6747b17f58ef
MD5 021ef24ed5ab18e31fba31c031e9efaf
BLAKE2b-256 d56d636f6014686da86455a0a7784f7b4f5bfd9587d527cc0ee98c501ecb67fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for vqe_pennylane-0.3.19.tar.gz:

Publisher: publish.yml on SidRichardsQuantum/Variational_Quantum_Eigensolver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vqe_pennylane-0.3.19-py3-none-any.whl.

File metadata

  • Download URL: vqe_pennylane-0.3.19-py3-none-any.whl
  • Upload date:
  • Size: 130.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vqe_pennylane-0.3.19-py3-none-any.whl
Algorithm Hash digest
SHA256 f72e771a4d6908c4bfe9dccd8cf6704b08a40eed1d82b27b248ab79256892bf6
MD5 8ffde87d444acb950510fba3e4aeb800
BLAKE2b-256 2c0683604d0a68b941d5ef03152d5f500462a823f12196ce0c0cbc5cc0d93d9b

See more details on using hashes here.

Provenance

The following attestation bundles were made for vqe_pennylane-0.3.19-py3-none-any.whl:

Publisher: publish.yml on SidRichardsQuantum/Variational_Quantum_Eigensolver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page