Skip to main content

A comprehensive Python package for simulating quantum walks in various dimensions and on complex networks

Project description

# Quantum Walks

A comprehensive Python package for simulating quantum walks in various dimensions and on complex networks.

## Features

- **Multi-dimensional quantum walks**: 1D, 2D, and 3D discrete-time quantum walks
- **Graph-based quantum walks**: Quantum walks on arbitrary graphs using various coin operators
- **Szegedy quantum walks**: Advanced quantum walks for complex network analysis
- **Quantum ranking algorithms**: Quantum PageRank and node ranking for network analysis
- **Comprehensive visualization**: Built-in plotting utilities for all walk types
- **Performance analysis**: Convergence analysis and comparison tools

## Installation

```bash
pip install quantumwalks

Quick Start

import numpy as np
import networkx as nx
from quantumwalks import DTQW1D, GraphDTQW, QuantumPageRank

# 1D quantum walk
qw1d = DTQW1D(N=100, coin_type='hadamard')
qw1d.initialize_state(init_pos=0)
qw1d.evolve(50)
qw1d.plot()

# Graph quantum walk
graph = nx.karate_club_graph()
gqw = GraphDTQW(graph, coin_type='grover', initial_node=0)
gqw.evolve(10)
gqw.plot()

# Quantum PageRank
qpr = QuantumPageRank(graph)
ranking = qpr.get_ranking()
qpr.plot(plot_type='bar')

Documentation

Full documentation is available at quantumwalks.readthedocs.io

Examples

Check the examples/ directory for comprehensive usage examples:

  • basic_usage.py: Basic quantum walk simulations
  • network_analysis.py: Network analysis with quantum walks
  • visualization_demo.py: Advanced visualization techniques

Basic 1D Walk Example

from quantumwalks import DTQW1D
import numpy as np

# Initialize 1D quantum walk
qw = DTQW1D(N=100, coin_type='hadamard')
qw.initialize_state(init_pos=0, init_coin=np.array([1, 1j])/np.sqrt(2))

# Evolve and plot
qw.evolve(100)
qw.plot()

Network Analysis Example

import networkx as nx
from quantumwalks import GraphDTQW, QuantumPageRank

# Create complex network
graph = nx.connected_watts_strogatz_graph(20, 4, 0.3)

# Quantum walk on graph
gqw = GraphDTQW(graph, coin_type='grover', initial_node=0)
gqw.evolve(10)
gqw.plot()

# Quantum PageRank analysis
qpr = QuantumPageRank(graph)
ranking = qpr.get_sorted_ranking()
print("Top nodes:", ranking[:5])

Supported Quantum Walk Types

Discrete-Time Quantum Walks

  • 1D Walks: Line graphs with various coin operators
  • 2D Walks: Lattice graphs with 4-direction movement
  • 3D Walks: Cubic lattices with 6-direction movement

Graph-Based Walks

  • GraphDTQW: Quantum walks on arbitrary graphs
  • SzegedyQW: Szegedy quantum walks for complex networks
  • DTQWPageRank: Discrete-time quantum walk for node ranking
  • QuantumPageRank: Quantum PageRank using Szegedy formalism

Coin Operators

  • Hadamard coin
  • Grover coin
  • Fourier coin
  • SU(n) coin

Advanced Usage

Convergence Analysis

from quantumwalks import analyze_convergence, plot_convergence_analysis

graph = nx.barabasi_albert_graph(30, 2)
gqw = GraphDTQW(graph, coin_type='grover', initial_node=0)

# Analyze convergence behavior
convergence_data = analyze_convergence(gqw, max_steps=50)
plot_convergence_analysis(convergence_data)

Quantum vs Classical Comparison

from quantumwalks import compare_classical_quantum

graph = nx.connected_caveman_graph(3, 8)
comparison = compare_classical_quantum(graph)

print(f"Correlation: {comparison['correlation']:.4f}")
print(f"KL Divergence: {comparison['kl_divergence']:.4f}")

API Overview

Core Classes

  • DTQW1D, DTQW2D, DTQW3D: Multi-dimensional quantum walks
  • GraphDTQW: Quantum walks on arbitrary graphs
  • SzegedyQW: Szegedy quantum walks
  • DTQWPageRank, QuantumPageRank: Quantum ranking algorithms

Key Methods

  • evolve(num_steps): Evolve quantum walk for specified steps
  • get_probabilities(): Get current probability distribution
  • plot(): Visualize results
  • get_ranking(): Compute node ranking scores

Dependencies

  • Python >= 3.8
  • NumPy >= 1.21.0
  • SciPy >= 1.7.0
  • Matplotlib >= 3.5.0
  • NetworkX >= 2.6.0

Development

To contribute to this project:

# Clone repository
git clone https://github.com/TDSKS-123/quantumwalks
cd quantumwalks

# Install in development mode
pip install -e .

# Install development dependencies
pip install -e ".[dev]"

# Run tests
pytest tests/

Citation

If you use this package in your research, please cite:

@software{quantumwalks2025,
  title = {Quantum Walks: A Python package for quantum walk simulations},
  author = {LiangWen},
  year = {2025},
  url = {https://github.com/TDSKS-123/quantumwalks}
}

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the project
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Support

If you encounter any problems or have questions:

Changelog

Version 1.0.1

  • Initial release with comprehensive quantum walk implementations
  • Support for 1D, 2D, and 3D quantum walks
  • Graph-based quantum walks and ranking algorithms
  • Advanced visualization and analysis tools
  • Fixed some issues that prevented operation, and now all examples can run.

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

quantumwalks-1.0.1.tar.gz (22.6 kB view details)

Uploaded Source

Built Distribution

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

quantumwalks-1.0.1-py3-none-any.whl (19.4 kB view details)

Uploaded Python 3

File details

Details for the file quantumwalks-1.0.1.tar.gz.

File metadata

  • Download URL: quantumwalks-1.0.1.tar.gz
  • Upload date:
  • Size: 22.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for quantumwalks-1.0.1.tar.gz
Algorithm Hash digest
SHA256 cf162cebe20eb542579493be37d8711573d367ef87abcb918736969ae7d1ede7
MD5 a3be83b1145adb1cb654c672f1ebc7d2
BLAKE2b-256 edc0b044c41a003a75b9fa6d58064354769d62a75e5457ac87cf73945ddcea6d

See more details on using hashes here.

File details

Details for the file quantumwalks-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: quantumwalks-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 19.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for quantumwalks-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 16892e4e8cf989b4cd525417df5bcba4a10e5da03ff7b160896c7e670f96b01a
MD5 5f12e000cb70755ab96ad9c961d8c98a
BLAKE2b-256 eaf4cf161e3431d621122d9f54b8a8fc7f4e50397fb48f003c69f6b52185ef8b

See more details on using hashes here.

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