<div align="center">

# Fractured Chain-of-Thought Reasoning

</div>

## Table of Contents
- [Introduction](#introduction)
- [Environment Setup](#environment-setup)
- [Evaluation](#evaluation)

## Introduction
In this work, we first show that truncated CoT, which stops reasoning before completion and directly generates the final answer, often matches full CoT sampling while using dramatically fewer tokens. Building on this insight, we introduce **Fractured Sampling**, a unified inference-time strategy that interpolates between full CoT and solution-only sampling along three orthogonal axes: (1) the number of reasoning trajectories, (2) the number of final solutions per trajectory, and (3) the depth at which reasoning traces are truncated.
<p align="center">
  <img src="figs/frac_cot.gif" width="90%" />
</p>
<!-- <p align="center">
  <img src="figs/framework.png" width="80%" />
</p> -->

**Main Takeaways**
1. 🌟 The H dimension (truncated CoT) shows the steepest log-linear scaling gains in Pass@k.
2. 🚀 Fractured sampling over all 3 dimensions offers the highest Pass@k.

<p align="center">
  <img src="figs/passk_single_dim.png" width="90%" />
</p>
<p align="center">
  <img src="figs/passk_multi_dim.png" width="90%" />
</p>



## Environment Setup
```bash
conda create -n frac_cot python=3.10
conda activate frac_cot
pip install -r requirements.txt
```

## Evaluation
```bash
# Generation
bash ./scripts/gen.sh
# Evaluate
bash ./scriots/passk.sh
```