# AutoNumerics Release Code

This directory contains the curated code release for the precision-aware
automated numerical-kernel search system. It includes the agent controller,
DAG search runtime, constant fitting utilities, validation/code-generation
tools, and lightweight classical baseline helpers.

The release intentionally excludes generated experiment artifacts, local
logs, cached virtual environments, paper build products, and large result
archives. Running the code will create fresh runtime outputs under
`experiments/` and `op/`.

This release is intended for reviewer inspection and reproduction. The code
does not hard-code the paper's reported metrics; all candidate quality numbers
are produced by search, baseline, comparison, and verification tools at run
time.

## Contents

- `agent/`: LLM-guided experiment controller, partition management,
  supervision, resume, and final report aggregation.
- `server/`: local run manager and optional search server.
- `master/`, `worker/`: DAG search orchestration and worker execution.
- `python_src/`: DAG definitions, precision utilities, and spec IO.
- `schemas/`: typed approximation-spec and tool-contract schemas.
- `tools/`: math inspection, baseline generation, validation,
  verification entry points, and codegen tools.
- `traditional/`: Chebyshev, Taylor, and minimax helper baselines.
- `verify/`: numerical verification utilities.
- `c_code/`: C reference functions and native-library build script.
- `start_master.sh`, `start_worker.sh`: manual search launch helpers.

## Installation

Requires Python 3.10+ on Linux or macOS (the file-based coordination layer
uses `fcntl`; Windows is not supported).

```bash
python -m venv .venv
source .venv/bin/activate
python -m pip install -r requirements.txt
```

Build the local C reference libraries:

```bash
bash c_code/make.sh
```

The generated shared libraries are written under `lib/` and are not part of
the source release.

## Configuration

Copy `.env.example` to `.env.local` and fill in an OpenAI-compatible API
endpoint and key.

```bash
cp .env.example .env.local
```

Then load the environment before starting an agent run:

```bash
set -a
source .env.local
set +a
```

The main variables are:

- `ANUM_LLM_API_BASE`: OpenAI-compatible chat-completions endpoint.
- `ANUM_LLM_API_KEY`: API key for the selected provider.
- `ANUM_LLM_MODEL`: model name.
- `ANUM_DEFAULT_WORKER_NUM`: default worker count for agent-dispatched runs.
- `ANUM_OP_ROOT`: directory for search outputs.

## Quick Start

Start a small agent-controlled search:

```bash
python -m agent.cli start \
  --exp_id exp_demo \
  --request "Approximate sin(x) on [0,1] with fp32. Target abs error 1e-3. Use a small run budget."
```

Check progress:

```bash
python -m agent.cli status --exp_id exp_demo
```

Build the final report:

```bash
python -m agent.cli final --exp_id exp_demo --refresh
```

Stop a run if needed:

```bash
python -m agent.cli stop --exp_id exp_demo
```

## Manual Search Entry Points

The master/worker scripts can be used directly when a fixed spec is already
available:

```bash
./start_worker.sh --task_tag demo_piece --fun sin --eps 1e-3 --run_time 600
./start_master.sh --task_tag demo_piece --worker_num 4 --max_tasks 200
```

Agent-driven runs are the recommended path because they manage partitioning,
search dispatch, verification, and final aggregation.

## Agent and Tool Loop

The reviewer-facing agent path follows the paper's layered control design:

1. The LLM proposes an initial `ApproxSpec`; the runtime accepts it only after
   schema validation and spec-policy normalization.
2. `anum.math.inspect` records target properties such as symmetry,
   monotonicity, special points, and domain warnings.
3. The deterministic supervisor dispatches only search-mode pieces to the DAG
   engine and polls per-piece progress.
4. When a piece has enough completed search tasks but stagnates, the runtime
   calls `anum.strategy.suggest` before asking for any repartition. The
   strategy tool can apply symmetry-based mapped reuse directly, including odd
   mirrors (`sin`, `tanh`, `sinh`), even mirrors (`cos`, `cosh`), and sigmoid
   complement symmetry.
5. If no direct mapped reuse is available and the piece budget allows it, the
   LLM receives the math-inspector context plus the strategy recommendation and
   chooses whether to split the stagnating interval.
6. Final aggregation re-verifies each piece at verification level 2 and emits
   piecewise code only from verified candidates.

## Output Layout

New runs produce:

```text
experiments/<exp_id>/
  state.json
  config.json
  events.jsonl
  supervision.json
  final.json

op/<task_tag>/
  spec.json
  run.json
  status.json
  bestof/
  logs/
```

These generated directories are not included in the release package.

## Third-Party Notes

No third-party source code or native math library is vendored in this anonymous
review package.
