SCCircuits is a Python package for numerical superconducting-circuit analysis. It focuses on matrix-based black-box quantization, dense Hamiltonian construction, spectroscopy workflows, and small research utilities for superconducting quantum circuits.
The user-facing documentation is published at:
https://joanjcaceres.github.io/sccircuits/
Recommended starting points:
- BBQ Overview explains the practical workflow from cQEDraw or circuit matrices to
BBQresults. - BBQ Quickstart gives a runnable matrix example with frequencies and phase ZPFs.
- BBQ Examples collects worked examples and the planned cQEDraw project-download example.
- BBQ Validation explains the code-backed checks behind the matrix reductions and branch conventions.
- BBQ Implementation Notes maps the mathematical derivation to the current
BBQimplementation stages. - BBQ API shows how to call
sccircuits.BBQ, read frequencies and phase ZPFs, and build Hamiltonians. - Circuit Matrix Quantization documents the matrix reductions, mode normalization, units, and branch phase zero-point fluctuations.
The site is intentionally incremental. BBQ is the first fully documented
research workflow because it is currently the most mature path between cQEDraw
and SCCircuits. The rest of the package should be documented through the same
site as those workflows stabilize.
The Markdown source for the website lives in docs/. Build it locally with:
pixi run -e sccircuits docs-buildcQEDraw is the companion web app for drawing and
analyzing superconducting circuit graphs. A typical workflow is:
- Draw the circuit in cQEDraw.
- Export or copy the generated capacitance matrix, inverse-inductance matrix, and Josephson junction records.
- Pass those matrices and records to
sccircuits.BBQ. - Inspect mode frequencies, branch phase ZPFs, and Hamiltonian spectra in Python.
Researchers should install SCCircuits from PyPI:
python -m pip install sccircuitsThis installs the pure-Python SCCircuits package plus NumPy, SciPy, Matplotlib, SymPy, and PyYAML from normal Python wheels. Pixi is not required to use the package.
Optional extras are available for notebook widgets, development, and docs:
python -m pip install "sccircuits[interactive]"
python -m pip install "sccircuits[dev]"
python -m pip install "sccircuits[docs]"Pixi remains the recommended contributor environment because it keeps the NumPy/SciPy stack reproducible while developing and testing the repository.
git clone https://github.com/joanjcaceres/sccircuits.git
cd sccircuits
pixi run -e sccircuits install-dev
pixi run -e sccircuits testFor local editable development without Pixi:
python -m venv .venv
source .venv/bin/activate
python -m pip install -e ".[dev,interactive,docs]"SCCircuits relies on NumPy and SciPy wheels for cross-platform BLAS/LAPACK linear algebra. The first public package does not compile native extensions or require GPU-specific backends.
To record a quick local diagonalization baseline:
python benchmarks/diagonalization_smoke.pyimport numpy as np
from sccircuits import BBQ
capacitance_matrix = np.array(
[
[40e-15, -32.9e-15],
[-32.9e-15, 40e-15],
]
)
inverse_inductance_matrix = np.array(
[
[1 / 1.23e-9, 0.0],
[0.0, 1 / 1.23e-9],
]
)
bbq = BBQ(
capacitance_matrix,
inverse_inductance_matrix,
nonlinear_branches=(0, 1),
)
print("Mode frequencies in GHz:", bbq.frequencies_ghz)
print("Branch phase ZPFs:", bbq.branch_phase_zpfs)For cQEDraw exports with Josephson junction records, pass the records directly:
bbq = BBQ(
capacitance_matrix,
inverse_inductance_matrix,
junctions=junctions,
)BBQ keeps the junction row order when reporting branch_phase_zpfs and
josephson_energies_ghz, so drawing tools can map results back to the original
branches.
sccircuits.BBQ: black-box quantization from capacitance and inverse-inductance matrices.sccircuits.Circuit: dense superconducting-circuit Hamiltonian construction and diagonalization.sccircuits.TransitionFitter: transition-frequency fitting utilities.sccircuits.PointPicker: interactive point selection for data analysis.
Run the main checks with:
pixi run -e sccircuits test
pixi run -e sccircuits lint
pixi run -e sccircuits docs-buildCheck the pip package path with:
python -m build
python -m twine check dist/*
python -m pip install dist/sccircuits-0.1.0-py3-none-any.whl
python -m pip check
python tests/pip_smoke.pyIf dependency resolution becomes inconsistent, recreate the Pixi environment:
pixi clean
pixi run -e sccircuits install-devThis project is licensed under the MIT License. See LICENSE for details.
Joan Caceres - contact@joanjcaceres.com
Project link: https://github.com/joanjcaceres/sccircuits