Metadata-Version: 2.4
Name: agentbible
Version: 0.2.1
Summary: Production-grade infrastructure for AI-assisted research software
Project-URL: Homepage, https://github.com/rylanmalarchick/research-code-principles
Project-URL: Documentation, https://github.com/rylanmalarchick/research-code-principles#readme
Project-URL: Repository, https://github.com/rylanmalarchick/research-code-principles.git
Project-URL: Issues, https://github.com/rylanmalarchick/research-code-principles/issues
Project-URL: Changelog, https://github.com/rylanmalarchick/research-code-principles/blob/main/CHANGELOG.md
Author-email: Rylan Malarchick <rylan1012@gmail.com>
Maintainer-email: Rylan Malarchick <rylan1012@gmail.com>
License-Expression: MIT
License-File: LICENSE
Keywords: ai-coding,developer-tools,physics,quantum,research,scientific-computing,validation
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Scientific/Engineering
Classifier: Topic :: Scientific/Engineering :: Physics
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Software Development :: Quality Assurance
Classifier: Typing :: Typed
Requires-Python: >=3.9
Requires-Dist: click>=8.0
Requires-Dist: numpy>=1.20
Requires-Dist: pyyaml>=6.0
Requires-Dist: rich>=13.0
Provides-Extra: all
Requires-Dist: chromadb>=0.4; extra == 'all'
Requires-Dist: h5py>=3.0; extra == 'all'
Requires-Dist: hypothesis>=6.0; extra == 'all'
Requires-Dist: mypy>=1.0; extra == 'all'
Requires-Dist: openai>=1.0; extra == 'all'
Requires-Dist: pre-commit>=3.0; extra == 'all'
Requires-Dist: pytest-cov>=4.0; extra == 'all'
Requires-Dist: pytest-xdist>=3.0; extra == 'all'
Requires-Dist: pytest>=7.0; extra == 'all'
Requires-Dist: ruff>=0.1; extra == 'all'
Requires-Dist: tiktoken>=0.5; extra == 'all'
Provides-Extra: dev
Requires-Dist: hypothesis>=6.0; extra == 'dev'
Requires-Dist: mypy>=1.0; extra == 'dev'
Requires-Dist: pre-commit>=3.0; extra == 'dev'
Requires-Dist: pytest-cov>=4.0; extra == 'dev'
Requires-Dist: pytest-xdist>=3.0; extra == 'dev'
Requires-Dist: pytest>=7.0; extra == 'dev'
Requires-Dist: ruff>=0.1; extra == 'dev'
Provides-Extra: hdf5
Requires-Dist: h5py>=3.0; extra == 'hdf5'
Provides-Extra: vector
Requires-Dist: chromadb>=0.4; extra == 'vector'
Requires-Dist: openai>=1.0; extra == 'vector'
Requires-Dist: tiktoken>=0.5; extra == 'vector'
Description-Content-Type: text/markdown

# AgentBible

[![CI](https://github.com/rylanmalarchick/research-code-principles/actions/workflows/ci.yml/badge.svg)](https://github.com/rylanmalarchick/research-code-principles/actions/workflows/ci.yml)
[![Docs](https://github.com/rylanmalarchick/research-code-principles/actions/workflows/docs.yml/badge.svg)](https://rylanmalarchick.github.io/research-code-principles/)
[![PyPI version](https://badge.fury.io/py/agentbible.svg)](https://pypi.org/project/agentbible/)
[![Python 3.9+](https://img.shields.io/badge/python-3.9+-blue.svg)](https://www.python.org/downloads/)
[![codecov](https://codecov.io/gh/rylanmalarchick/research-code-principles/branch/main/graph/badge.svg)](https://codecov.io/gh/rylanmalarchick/research-code-principles)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

## Why AgentBible Exists

When Copilot or Claude generates quantum computing code, how do you know it's physically correct?
When you run an experiment, how do you reproduce it 6 months later?

**AgentBible solves both problems:**

- **Physics validators** catch invalid code at runtime (`@validate_unitary`, `@validate_density_matrix`, etc.)
- **Automatic provenance** captures everything needed for reproducibility (git SHA, random seeds, package versions, hardware info)

**Result:** Research code you can trust and reproduce.

## Install Now

```bash
pip install agentbible
```

```bash
# With HDF5 provenance support
pip install agentbible[hdf5]

# Full development install
pip install agentbible[all]
```

## The Problem AgentBible Solves

```python
# WITHOUT AgentBible - silent bug, hours of debugging
def create_hadamard():
    return np.array([[1, 1], [1, 0]]) / np.sqrt(2)  # Bug: should be [1, -1]
    # This is NOT unitary. You won't catch it until your quantum simulation
    # produces nonsense results and you spend hours debugging.

H = create_hadamard()  # No error - bug silently propagates
```

```python
# WITH AgentBible - catches it immediately
from agentbible import validate_unitary

@validate_unitary
def create_hadamard():
    return np.array([[1, 1], [1, 0]]) / np.sqrt(2)  # Same bug

H = create_hadamard()
# UnitarityError: Matrix is not unitary
#   Expected: U@U.H = I (conjugate transpose times matrix equals identity)
#   Got: max|U@U - I| = 5.00e-01
#   Function: create_hadamard
#
#   Reference: Nielsen & Chuang, 'Quantum Computation and Quantum Information'
#   Guidance: Your quantum gate is not reversible. Common causes:
#       - Missing normalization factor (e.g., 1/sqrt(2) for Hadamard)
#       - Incorrect matrix elements or signs
```

**The bug is caught immediately, with an educational error message.**

## Quick Start

### Create a New Project

```bash
bible init my-quantum-sim --template python-scientific
cd my-quantum-sim
source .venv/bin/activate
pip install -e ".[dev]"
pytest  # 28 tests pass immediately
```

### Use Physics Validators

```python
from agentbible import validate_unitary, validate_density_matrix
import numpy as np

@validate_unitary
def create_hadamard():
    """Returns Hadamard gate - validated as unitary."""
    return np.array([[1, 1], [1, -1]], dtype=complex) / np.sqrt(2)

@validate_density_matrix
def create_mixed_state():
    """Returns maximally mixed state - validated as density matrix."""
    return np.eye(2, dtype=complex) / 2

# Validation happens automatically on return
H = create_hadamard()      # OK - unitary
rho = create_mixed_state() # OK - trace=1, Hermitian, positive semi-definite
```

### Validate Data Files

```bash
# Validate a numpy matrix
bible validate state.npy --check unitarity

# Validate HDF5 with all checks
bible validate results.h5 --check all

# Multiple specific checks
bible validate matrix.npy -c hermiticity -c trace -c positivity
```

### Save Data with Provenance

```python
from agentbible.provenance import save_with_metadata, load_with_metadata
import numpy as np

# Save with full reproducibility metadata
save_with_metadata(
    "results.h5",
    {"density_matrix": rho, "eigenvalues": np.linalg.eigvalsh(rho)},
    description="Ground state calculation",
)

# Load with metadata
data, metadata = load_with_metadata("results.h5")
print(metadata["git_sha"])      # "a1b2c3d..."
print(metadata["timestamp"])    # "2026-01-01T12:00:00+00:00"
print(metadata["packages"])     # {"numpy": "1.26.0", ...}
print(metadata["pip_freeze"])   # Full pip freeze for exact reproduction
print(metadata["hardware"])     # CPU model, GPU info, memory
```

### Physics-Aware Testing

```python
from agentbible.testing import physics_test, deterministic_seed
import numpy as np

@physics_test(checks=["unitarity", "hermiticity"])
def test_pauli_x():
    """Automatically validates return value."""
    return np.array([[0, 1], [1, 0]], dtype=complex)

def test_reproducible(deterministic_seed):
    """Seeds are set to 42 for reproducibility."""
    random_value = np.random.rand()
    assert random_value == 0.3745401188473625  # Always the same
```

## Who This Is For

**AgentBible is for:**

- Researchers using AI agents (Claude, Copilot, Cursor) to write scientific code
- Quantum computing developers who need correctness guarantees
- ML/Physics/HPC developers who care about reproducibility
- PhD students who want rigorous software from day one
- Anyone who has lost hours debugging a subtle numerical bug

**AgentBible is NOT for:**

- Enterprise web applications
- Frontend/GUI projects
- Code that doesn't involve numerical computation

## Features

### Validators

| Decorator | Validates |
|-----------|-----------|
| `@validate_unitary` | U @ U.H = I |
| `@validate_hermitian` | A = A.H |
| `@validate_density_matrix` | Hermitian, trace=1, positive semi-definite |
| `@validate_probability` | Value in [0, 1] |
| `@validate_probabilities` | Array of probabilities |
| `@validate_normalized` | Sum or norm = 1 |
| `@validate_positive` | Value > 0 |
| `@validate_non_negative` | Value >= 0 |
| `@validate_range(min, max)` | Value in [min, max] |
| `@validate_finite` | No NaN or Inf |

All validators:
- Check for NaN/Inf **before** physics checks (catches numerical instability first)
- Support both `rtol` and `atol` tolerances
- Provide educational error messages with academic references

### CLI Commands

```bash
bible init <name>           # Create project from template
bible validate <file>       # Validate physics constraints
bible context               # Generate AI context
bible info                  # Show installation info
```

### Provenance Metadata

`save_with_metadata()` automatically captures:

- Git SHA, branch, dirty status, and diff (if uncommitted changes)
- UTC timestamp (ISO 8601)
- Random seeds (numpy, python, torch)
- Hostname, platform, Python version
- Package versions (numpy, scipy, h5py, torch, etc.)
- Full `pip freeze` output for exact environment reproduction
- Hardware info (CPU model, core count, memory, GPU details)

### Testing Fixtures

| Fixture | Purpose |
|---------|---------|
| `deterministic_seed` | Sets numpy/random to seed 42 |
| `tolerance` | Returns `{"rtol": 1e-10, "atol": 1e-12}` |
| `quantum_tolerance` | Returns `{"rtol": 1e-6, "atol": 1e-8}` |

## Project Templates

### Python Scientific (`python-scientific`)

Pre-configured with:
- **ruff** for linting (strict rules)
- **mypy** in strict mode
- **pytest** with 70% coverage minimum
- Physics validation helpers
- `.cursorrules` for AI agents

```bash
bible init my-project --template python-scientific
```

### C++ HPC/CUDA (`cpp-hpc-cuda`)

Pre-configured with:
- **CMake** with zero-warning policy
- **GoogleTest** for testing
- **CUDA** support (optional)
- Physical validation functions

```bash
bible init my-project --template cpp-hpc-cuda
```

## The 5 Principles

1. **Correctness First** - Physical accuracy is non-negotiable
2. **Specification Before Code** - Tests define the contract
3. **Fail Fast with Clarity** - Validate inputs, descriptive errors
4. **Simplicity by Design** - Functions <= 50 lines, single responsibility
5. **Infrastructure Enables Speed** - CI, tests, linting from day one

## Status

**v0.1.1** (Alpha) - Core validators working, API stable, ready for real use.

See the full [ROADMAP.md](ROADMAP.md) for what's coming next.

## Documentation

Full documentation: [rylanmalarchick.github.io/research-code-principles](https://rylanmalarchick.github.io/research-code-principles/)

- [Getting Started](https://rylanmalarchick.github.io/research-code-principles/getting-started/installation/)
- [Validators Guide](https://rylanmalarchick.github.io/research-code-principles/guide/validators/)
- [Provenance Guide](https://rylanmalarchick.github.io/research-code-principles/guide/provenance/)
- [API Reference](https://rylanmalarchick.github.io/research-code-principles/api/validators/)
- [Philosophy](docs/philosophy.md) - Why good code matters
- [Style Guide](docs/style-guide-reference.md) - Coding conventions
- [CHANGELOG](CHANGELOG.md) - Release history

## Getting Help

- **Questions?** [Open a GitHub Issue](https://github.com/rylanmalarchick/research-code-principles/issues)
- **Found a bug?** [Report it here](https://github.com/rylanmalarchick/research-code-principles/issues/new)
- **Want to contribute?** See [CONTRIBUTING.md](CONTRIBUTING.md)
- **Security issues?** See [SECURITY.md](SECURITY.md)
- **Email:** [rylan1012@gmail.com](mailto:rylan1012@gmail.com)

## Development

```bash
# Clone and setup
git clone https://github.com/rylanmalarchick/research-code-principles
cd research-code-principles
./bootstrap.sh

# Or manually
python -m venv .venv
source .venv/bin/activate
pip install -e ".[dev,hdf5]"

# Run tests
pytest tests/ -v

# Lint and type check
ruff check agentbible/
mypy agentbible/
```

## License

MIT - Use and adapt freely.

## Author

Rylan Malarchick - [rylan1012@gmail.com](mailto:rylan1012@gmail.com)

---

**v0.1.1** - Documentation site, Dependabot, C++ template (January 2026)
