# RamanujanAgent

An AI research assistant for the [Ramanujan Machine](https://www.ramanujanmachine.com/) project — configured as a fully-equipped team member capable of mathematical research, algorithmic discovery, code development, and scientific writing.

## What Is This?

This repository contains all the **skills, instructions, policies, and templates** that define an AI agent ("the Ramanujan Agent") designed to work alongside human researchers in the Ramanujan Machine group. The agent operates at the intersection of:

- **Pure mathematics** — continued fractions, hypergeometric functions, Conservative Matrix Fields (CMFs), holonomic sequences, irrationality proofs.
- **Algorithmic discovery** — brute-force search, meet-in-the-middle, reinforcement learning, formula harvesting from literature.
- **High-performance computing** — arbitrary-precision arithmetic, C extensions, binary splitting, multi-processing.
- **Scientific communication** — LaTeX papers, convergence analysis, reproducible results.

## Repository Structure

```
RamanujanAgent/
├── .github/
│   └── copilot-instructions.md    # Root agent instructions (loaded by GitHub Copilot)
├── .instructions.md               # VS Code workspace-level instructions
├── DEFINITION_OF_DONE.md          # Completion criteria for every task type
├── COVERAGE_POLICY.md             # Testing and coverage requirements
├── README.md                      # This file
├── requirements.txt               # Python dependencies
├── skills/
│   ├── mathematician/SKILL.md     # Rigorous math: CMFs, convergence, proofs
│   ├── ai_scientist/SKILL.md      # Search algorithms, ML, acceleration
│   ├── ramanujan_machine_team_member/SKILL.md  # Unified agent persona
│   └── git_ramanujan_tools/SKILL.md            # ramanujantools library guide
├── templates/
│   ├── scientific_report.tex      # LaTeX template for scientific deliverables
│   └── code_review_checklist.md   # Checklist for code development tasks
└── tests/
    ├── conftest.py                # Shared pytest fixtures
    └── test_sanity.py             # Example test demonstrating coverage patterns
```

## How to Use

### As a GitHub Copilot Agent (VS Code)
1. Clone this repo as a submodule or copy the `skills/` directory and `.instructions.md` into your workspace.
2. The agent instructions in `.github/copilot-instructions.md` and `.instructions.md` are automatically loaded by GitHub Copilot Chat.
3. Skills are activated contextually — ask about CMFs and the mathematician skill activates; ask about performance and the AI scientist skill activates.

### As a Reference
- **Starting a new subproject?** Copy the relevant skills and `DEFINITION_OF_DONE.md` into your repo.
- **Onboarding a new team member (human or AI)?** Point them to this repo to understand the group's standards.
- **Writing a paper?** Use `templates/scientific_report.tex` as a starting point.

## Definition of Done

Every task has explicit completion criteria defined in [DEFINITION_OF_DONE.md](DEFINITION_OF_DONE.md). Summary:

| Task Type | Key Deliverables |
|-----------|-----------------|
| **Scientific request** | LaTeX summary with bottom line, examples, numerical verification, reproducible code |
| **Code development** | Working code + guardrails + sanity checks + tests + documentation |
| **Formula discovery** | Numerical verification to 100+ digits, convergence rate, CMF classification |
| **Paper writing** | Compiled LaTeX, consistent notation, all claims verified, proper citations |

## Coverage Policy

See [COVERAGE_POLICY.md](COVERAGE_POLICY.md). The key rule: **every new function must be tested** — either by an existing test or by a new one you provide alongside the code.

## Key Dependencies

- [`ramanujantools`](https://github.com/RamanujanMachine/ramanujantools) — The group's primary library for CMFs, PCFs, recurrences.
- [`mpmath`](https://mpmath.org/) — Arbitrary-precision arithmetic. Non-negotiable for verification.
- [`sympy`](https://www.sympy.org/) — Symbolic computation.
- [`gmpy2`](https://gmpy2.readthedocs.io/) — Fast big-integer arithmetic via GMP.

## Contributing

When you discover new optimizations, mathematical principles, or useful patterns:
1. Add them to the relevant skill file.
2. Update `DEFINITION_OF_DONE.md` if you find new failure modes worth guarding against.
3. Add test patterns to `tests/` to codify the insight.

## License

MIT
