# String Seed of Thought
Leveraging random string for probabilistic reasoning in CoT.

## Installation
We recommend using uv:
```bash
uv sync
```

We use `rsm` as an alias to SSoT in this project.

## Running Tasks
### Probabilistic Instruction Following
```bash
uv run scripts/run_rsp_probability_experiments.py --multirun \
    model=deepseek_r1 \
    prompt.type=rsm \
    prompt=biased_10moves,biased_rsp
```

### Rock-Paper-Scissors
```bash
uv run src/pcot/tasks/rsp/run.py
```

### Novelty Bench (DAG)
We first generate LLM response by `inference.py`, and then use `run_eval_novelbench.sh` to get distinct and utility scores.
```bash
uv run src/pcot/tasks/novelty_bench/inference.py

./run_eval_novelbench.sh <GENRERATED_EVAL_DIR_PATH>
```

### PIF CoT Analysis
```bash
uv run scripts/classify_pif.py
```

### NoveltyBench CoT Analysis
```bash
uv run scripts/classify_novelty.py
```

### CoT Scaling Analysis
config file path is: `scripts/conf/random_generation/config.yamlscripts/conf/random_generation/config.yaml`

```bash
uv run scripts/run_random_generation_experiments.py
```
