# UCPO: Uncertainty-Aware Policy Optimization

## 📖Overview

The key to building trustworthy Large Language Models (LLMs) lies in endowing them with inherent uncertainty expression capabilities to mitigate the hallucinations that restrict their high-stakes applications. However, existing RL paradigms such as GRPO often suffer from Advantage Bias due to binary decision spaces and static uncertainty rewards, inducing either excessive conservatism or overconfidence.
To tackle this challenge, this paper unveils the root causes of reward hacking and overconfidence in current RL paradigms incorporating uncertainty-based rewards, based on which we propose the **Uncertainty-Aware Policy Optimization (UCPO)** framework. UCPO employs **Ternary Advantage Decoupling** to separate and independently normalize deterministic and uncertain rollouts, thereby eliminating advantage bias. Furthermore, a **Dynamic Uncertainty Reward Adjustment** mechanism is introduced to calibrate uncertainty weights in real-time according to model evolution and instance difficulty. Experimental results in mathematical reasoning and general tasks demonstrate that UCPO effectively resolves reward imbalance, significantly enhancing model reliability and calibration beyond their knowledge boundaries.

![Architecture of the UCPO Framework.](assets/ucpo_framework.jpg)
---

## 📊 Data Preparation

We utilize a combination of reasoning and general-purpose datasets to evaluate model performance and uncertainty calibration.

### 1. Math & Text Reasoning Tasks

Used to evaluate the model's ability to handle complex logic within its knowledge boundaries.

* **Training**: [DAPO-Math-17k](https://huggingface.co/datasets/BytedTsinghua-SIA/DAPO-Math-17k)
* **Evaluation**: AIME24, AMC 2024, MATH500, Minerva, Olympiad Bench.

> **Note:** Evaluation scripts and datasets for this section are sourced from the processed versions provided by [understand-r1-zero](https://github.com/sail-sg/understand-r1-zero).

### 2. General Tasks

Used to examine overconfidence and forced-choice behavior in constrained scenarios.

* **MMLU-Redux2**: [Link](https://huggingface.co/datasets/edinburgh-dawg/mmlu-redux-2.0) (1,000 instances for testing; remainder used for training).
* **GPQA-Diamond**: [Link](https://huggingface.co/datasets/Idavidrein/gpqa).

---

## ⚙️ Installation

UCPO is built upon the **verl** framework. Follow these steps to set up your environment:

```bash
# Clone the repository
git clone <repository-url>
cd <repository-name>

# Install dependencies
pip install -r requirements.txt

```

---

## 🚀 Usage

### Training

To execute the UCPO training pipeline, ensure your data is in the `.parquet` format (e.g., `math_dapo_17k_processed_uc.parquet`).

```bash
# Start training with UCPO
bash run_train.sh

```

### Evaluation

Run the evaluation suite to test performance across math and general reasoning benchmarks:

```bash
# Run comprehensive evaluation
bash run_eval.sh

```

---

## 🧩Uncertainty Class Settings in the Reward Function

To implement **Ternary Advantage Decoupling**, UCPO utilizes a specialized reward structure that distinguishes between deterministic and uncertain outcomes:

```python
{
  "acc": True | False | None,
  "score": float,
  "isuc": bool
}

```

* **`acc` (Ternary Logic):** The core signal for outcome evaluation. Set to `True` for correct answers, `False` for incorrect ones, and `None` (None) for **uncertain/abstention** responses.
* **`score` (Deterministic Reward):** This scalar value is only active when `acc` is `True` or `False`. For uncertain rollouts (`acc: None`), the reward is not fixed; instead, its advantage is **dynamically computed** within `compute_ucpo_outcome_advantage` (`train/verl/trainer/ppo/core_algos.py`) to prevent advantage bias.
* **`isuc` (Tracking Flag):** A Boolean indicator used exclusively for monitoring the frequency of uncertain rollouts during training. It does not influence the backpropagation or advantage calculation.

> **Implementation Ref:** See `./train/recipe/ucpo/reward_fn/uc_reward.py` for reward formatting.
---

## ✨Acknowledgments

* **Base RL Framework**: [verl](https://github.com/volcengine/verl)
* **Math Evaluation Logic**: [understand-r1-zero](https://github.com/sail-sg/understand-r1-zero)

---

## 📝 Citation

If you find UCPO helpful in your research, please cite our work:

```bibtex

```
