# DAG Construction Module

This repository is supplementary material for the paper "Characterizing, Evaluating, and Optimizing Complex Reasoning". It includes a simple demo module for constructing reasoning DAGs from partitioned step texts.

This repository is fully anonymized and contains no personal information.

## Overview
`dag_builder.py` constructs a reasoning DAG from a prompt and a list of partitioned step texts. It calls an OpenAI-compatible API to classify each step as a continuation, backtrack, or merge, then builds both the raw and merged DAG views.

## Usage
Import and call the main function:

```python
from dag_builder import OpenAIConfig, DagParams, build_dag

openai_config = OpenAIConfig(
    api_key="YOUR_API_KEY",
    base_url="your_base_url",
    model="model_name (e.g., deepseek-v3.2)",
    temperature=0.3,
    top_p=0.9,
    max_tokens=100000,
    n=1,
    timeout=1000,
)

dag_params = DagParams(
    regen_limit=5,
    main_path_cap=8,
    other_leaf_cap=5,
    sleep_between_retries=0.5,
    strict_mode=False,
    random_seed=0,
)

result = build_dag(
    prompt="...",
    steps=["step 1", "step 2", "step 3"],
    openai_config=openai_config,
    dag_params=dag_params,
)
```

### Batch mode (multi-threaded)

```python
from dag_builder import OpenAIConfig, DagParams, build_dag_batch

items = [
    {"prompt": "...", "steps": ["...", "..."]},
    {"prompt": "...", "steps": ["...", "..."]},
]

results = build_dag_batch(items, openai_config, dag_params, num_threads=4)
```


To run a single end-to-end DAG construction pass, set the OpenAI-compatible parameters in `data.json`, then run:

```bash
python test.py
```

This will construct a DAG for the provided example and write the resulting DAG to a JSON output file.

## Upcoming Releases
Full 103k training data and 1.5k test data, plus TRM model checkpoints and a more complete pipeline (response generation, verification, DAG construction, evaluation, TRM training, and TRM-guided optimization) are currently being organized and finalized, and will be provided later.
