# Symbolic Regression Phys-Osc EMO-STA

This directory is the EMO-STA-specific version of a narrow symbolic-regression family built from the standalone [examples/symbolic_regression](../symbolic_regression) benchmark assets. It is intentionally separate from the standalone generated-per-problem example so the EMO-STA workflow can keep one shared program interface and one shared evaluator.

The family contains exactly four public tasks:

- `sr_po11`
- `sr_po17`
- `sr_po30`
- `sr_po37`

All four tasks share the same semantic interface:

- inputs are always `(x, t, v)`
- the target is always `dv_dt`
- the evolving code always exposes:

```python
def func(x, params):
    ...

def run_search():
    return func
```

The shared EMO-STA phase optimizes average score across those four oscillator tasks. Spawned task-specific phases then warmstart from the shared checkpoint population and adapt to one selected task at a time. Direct single-task baselines use the same generic prompt and evaluator path.

The loader supports three modes:

1. `SYMBOLIC_REGRESSION_PHYS_OSC_USE_SYNTHETIC_FIXTURE=1` for deterministic test and smoke-test data with no benchmark dependency.
2. Already-generated problem directories under `SYMBOLIC_REGRESSION_PROBLEMS_ROOT`, repo-root `problems/`, or `examples/symbolic_regression/problems/`.
3. Benchmark-generation fallback through the standalone LLM-SRBench datamodule if its optional dependencies are installed and the benchmark data is available.

The evaluator does not expose exact ground-truth equations to the candidate. It only exposes the generic `(x, t, v) -> dv_dt` interface and numerical datasets.
