# ChronosCore Reproduction Skeleton

This repository contains a runnable skeleton to reproduce ChronosCore-style experiments:  
a Transformer-based scheduler agent compared to classical schedulers (RM, EDF) with  
support for multicore mapping and migration penalty analysis.

---

## 🚀 Quickstart

1. **Create environment and install dependencies:**
   ```bash
   python -m venv venv
   source venv/bin/activate
   pip install -r requirements.txt
   ```
Run unit tests:
pytest -q


Run a small training experiment (debug preset):
python scripts/run_experiment.py --preset debug --out ./outputs_debug


Run benchmarks comparing classical schedulers and the transformer agent:
python experiments/benchmarks.py

Generate deterministic tasksets for ablations:
python experiments/generate_targets.py

File Layout (important files)

chronoscore/ — environment, schedulers, encoder and model glue.

models/ — TransformerAgent, value mapping and helpers.

multicore/ — multi-core masked-greedy mapper and migration penalty code.

train/ — training loop and loss utilities.

data/ — dataset generator (UUniFast-like).

eval/ — evaluation helpers for hit-rate and schedule comparison.

tests/ — pytest unit tests.

viz/ — plotting and diagnostics.

Repro Tips

Fix random seeds via utils.io_utils.set_seed(...).

Save and reuse generated tasksets under experiments/targets for 1-to-1 reproducibility.

Tune hyperparameters in configs.py to align with the paper’s appendix.

For multi-core experiments:

Implement masked-greedy mapping usage in train/train_agent.py.

Integrate multicore/migration_penalty.py when computing rewards.


Expected Runtime

Small debug runs (few episodes / small tasksets) complete within seconds on CPU.

Larger reproductions (thousands of tasksets / transformer layers) require minutes to hours
depending on CPU/GPU and dataset size.