A framework for analyzing and validating quantum code execution quality on quantum processing units (QPUs)
Project description
QWARD - Quantum Circuit Analysis and Runtime Development
QWARD is a comprehensive framework for analyzing quantum circuits and validating quantum code execution quality on quantum processing units (QPUs). It provides tools to analyze circuit complexity, measure performance metrics, and visualize quantum algorithm behavior.
🚀 Quick Start
from qiskit import QuantumCircuit
from qward import Scanner
# Create a quantum circuit
circuit = QuantumCircuit(2)
circuit.h(0)
circuit.cx(0, 1)
# Analyze with all metrics in one line
Scanner(circuit).scan().summary()
Full Control
from qward import Scanner
from qward.metrics import QiskitMetrics, ComplexityMetrics
from qward.visualization import Visualizer
# Build scanner and visualizer explicitly
scanner = Scanner(circuit=circuit, strategies=[QiskitMetrics, ComplexityMetrics])
metrics = scanner.calculate_metrics()
visualizer = Visualizer(scanner=scanner)
dashboards = visualizer.create_dashboard(save=True)
📚 Documentation
For Users
- Project Overview - Learn about QWARD's goals and capabilities
- Installation Guide - Get QWARD up and running
- Beginner's Guide - Start here if you're new to QWARD
- Quickstart Guide - Jump right into using QWARD
- Architecture Overview - Understand QWARD's design and components
- Visualization Guide - Learn about QWARD's visualization capabilities
For Developers
- Developer Guide - Development setup and code quality standards
- Technical Documentation - Deep dive into QWARD's implementation
- Contribution Guidelines - How to contribute to QWARD
- API Documentation - Complete API reference
🎯 Key Features
- Circuit Analysis: Comprehensive metrics for quantum circuit complexity and structure
- Performance Monitoring: Track success rates, fidelity, and execution statistics
- Visualization: Rich, interactive plots and dashboards for metric analysis
- Schema Validation: Type-safe metrics with Pydantic-based validation
- Extensible Architecture: Plugin-based system for custom metrics and visualizations
- Multi-Backend Support: Works with Qiskit Aer, IBM Quantum, and other providers
🛠️ Installation
# Install from PyPI (when available)
pip install qward
# Or install from source
git clone https://github.com/your-org/qiskit-qward.git
cd qiskit-qward
pip install -e .
📖 Examples
Explore comprehensive examples in the qward/examples/ directory:
- Basic Usage - Complete workflow examples
- Circuit Performance - Performance analysis
- Visualization Demo - Visualization capabilities
- Aer Integration - Using QWARD with Qiskit Aer
🧪 Development & Linting
Quick Local Check
Use verify.sh for a fast local validation against your active Python environment:
./verify.sh
Replicating CI Exactly
CI runs tox -elint with Python 3.10 in an isolated environment. To replicate this locally:
# Requires Python 3.10 available via pyenv
PYENV_VERSION=3.10.4 pyenv exec tox -elint
This creates the same isolated environment as CI (same Python version, same pinned tool versions, no extra packages like IPython) and runs:
black --check .- Code formattingpylint -rn --ignore-paths=qward/examples qward tests- Lintingmypy --exclude qward/examples qward tests- Type checking
Running Tests
# Quick local test run
python -m pytest tests/ -v
# Full CI-equivalent test run with tox
PYENV_VERSION=3.10.4 pyenv exec tox -epy310
🤝 Contributing
We welcome contributions! Please see our Contribution Guidelines for details on:
- Setting up the development environment
- Code style and quality standards
- Testing requirements
- Submitting pull requests
📄 License
This project is licensed under the Apache License 2.0.
🔗 Links
- Documentation: docs/
- Examples: qward/examples/
- Issues: GitHub Issues
- Discussions: GitHub Discussions
QWARD is designed to help quantum developers and researchers understand and optimize their quantum algorithms through comprehensive analysis and visualization tools.
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 qiskit_qward-0.17.0.tar.gz.
File metadata
- Download URL: qiskit_qward-0.17.0.tar.gz
- Upload date:
- Size: 351.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
566486316a557aaa1c3ff34c49a0a15f56ba0c6788f7c491692594db7d629c3e
|
|
| MD5 |
067fde7e81e7d9c569ec857abd163c66
|
|
| BLAKE2b-256 |
7b2dd236ecbf0b3f01cfa2398a09238df91690d151746ff8e50cd4c885040bc0
|
File details
Details for the file qiskit_qward-0.17.0-py3-none-any.whl.
File metadata
- Download URL: qiskit_qward-0.17.0-py3-none-any.whl
- Upload date:
- Size: 289.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5d52bc2582f93fc1e20287ec581751f7b1452b4a14d3c2d364627fd28c7872c
|
|
| MD5 |
69d9e3eb35bc165dc86c113f52088a70
|
|
| BLAKE2b-256 |
5b18176f434bf612bf24efc58c8c03e8f9cb8ebab9d3a1f7c05fa06759a8430a
|