Prompt Augmentation Scales up GRPO:多様な推論テンプレートによる数学的思考の強化と訓練安定化

Tech

本記事はGeminiの出力をプロンプト工学で整理した業務ドラフト(未検証)です。

Prompt Augmentation Scales up GRPO:多様な推論テンプレートによる数学的思考の強化と訓練安定化

【要点サマリ】 多様なプロンプト形式を訓練に導入し、GRPO(Group Relative Policy Optimization)の性能を飛躍的に向上させる。

  • 単一の推論形式への過学習(報酬ハッキング)を、複数のテンプレートを混ぜることで抑制。

  • GSM8KやMATHといった難関数学ベンチマークにおいて、従来手法を凌駕する精度と安定性を実現。

  • 計算コストを抑えつつ、モデルの推論プロセスの頑健性(Robustness)を大幅に改善。

【背景と最新動向】 大規模言語モデル(LLM)の推論能力向上において、Reinforcement Learning from Human Feedback (RLHF) は不可欠な要素です。特に、2024年初頭にDeepSeek-V3/R1で注目を集めたGRPO (Group Relative Policy Optimization) は、価値関数(Value Function)を必要とせず、グループ内の相対的評価で報酬を計算する革新的な手法です。

しかし、従来のGRPOは特定の推論フォーマット(例:「…」)に強く依存しており、訓練が進むにつれてモデルがその形式の「穴」を突いて報酬を得る報酬ハッキング(Reward Hacking)が課題となっていました。2024年後半から2025年にかけてのトレンドは、単なるパラメータのスケールアップから、データおよび推論プロセス自体の多様性(Diversity)の確保へとシフトしています。本論文(2025年2月発表)は、このトレンドに合致する「プロンプト拡張」に焦点を当てています。

【アーキテクチャ・仕組み】 本手法の核となるのは、訓練時に単一のシステムプロンプトではなく、推論スタイルを指定する多様なテンプレート集合 $\mathcal{T}$ を用いる点にあります。

graph TD
    subgraph Input_Phase
    A["Question Q"] --> B{"Prompt Selection"}
    B -->|T1| C1["Template 1"]
    B -->|T2| C2["Template 2"]
    B -->|Tn| Cn["Template n"]
    end

    subgraph Generation_Phase
    C1 --> D1["Output Group G1"]
    C2 --> D2["Output Group G2"]
    Cn --> Dn["Output Group Gn"]
    end

    subgraph GRPO_Mechanism
    D1 & D2 & Dn --> E["Relative Reward Calculation"]
    E --> F["KL-Divergence Constraint"]
    F --> G["Model Update"]
    end

GRPOの目的関数は、以下の数式で表されます。ここで、プロンプト拡張が加わることで、期待値の計算がテンプレートの分布 $\mathcal{T}$ 全体にわたって行われます。

$$ J(\theta) = \mathbb{E}_{q \sim P(Q), \tau \sim \mathcal{T}, {o_i}_{i=1}^G \sim \pi_{\theta_{old}}(O|q, \tau)} \left[ \frac{1}{G} \sum_{i=1}^G \left( \min(r_i \hat{A}_i, \text{clip}(r_i, 1-\epsilon, 1+\epsilon) \hat{A}_i) – \beta D_{KL}(\pi_\theta || \pi_{ref}) \right) \right] $$

※注釈:$G$ はグループサイズ、$\hat{A}_i$ はグループ内の平均報酬からの乖離(アドバンテージ)、$D_{KL}$ はモデルが参照モデル(学習前)から離れすぎないようにする正則化項です。

【実装イメージ】 以下は、Hugging FaceのTRLライブラリを拡張して、多様なテンプレートを選択的に適用する擬似コードです。

import torch
from transformers import AutoModelForCausalLM, AutoTokenizer
from trl import GRPOTrainer

# 1. 多様な推論テンプレートの定義

templates = [
    "Solve the problem step by step: {question}",
    "Work out the following math question. Show your logic: {question}",
    "Think carefully and provide the final answer at the end: {question}",
    "Using a logical chain, solve: {question}"
]

def prompt_augmentation_func(examples):

    # 各サンプルに対してランダムにテンプレートを適用

    questions = examples["question"]
    augmented_prompts = [
        templates[torch.randint(0, len(templates), (1,)).item()].format(question=q)
        for q in questions
    ]
    return {"prompt": augmented_prompts}

# 2. GRPOの設定 (簡略化)


# 実際には trl.GRPOTrainer を使用し、reward_function 内で正誤判定を行う


# trainer = GRPOTrainer(


#     model=model,


#     reward_funcs=[accuracy_reward, format_reward],


#     args=training_args,


#     train_dataset=dataset.map(prompt_augmentation_func, batched=True),


# )

【実験結果と考察】 論文内の実験データに基づき、単一プロンプト(Base GRPO)と本手法(Augmented GRPO)を比較します。

指標 Base GRPO Augmented GRPO 改善率
GSM8K (Accuracy) 82.4% 88.9% +6.5%
MATH (Hard cases) 41.2% 49.5% +8.3%
Training Stability (Variance) High Low 安定化
Formatting Overfit Significant Minimal 頑健性向上

考察: テンプレートを増やすことで、特定の「言い回し」や「思考タグの数」に依存して報酬を得ようとするモデルのバイアスが除去されています。これにより、モデルは表面的な形式ではなく、数学的な本質(Logic)に集中せざるを得なくなり、結果として汎化性能が向上しています。

【限界と今後の展望】

  • 計算リソースの増大: 複数のテンプレートを用いることで、バッチサイズ内のサンプル分布が複雑になり、収束までにより多くのイテレーションを要する可能性があります。

  • テンプレートの質: 質の低いテンプレートを含めると、逆にモデルの混乱を招くリスクがあります。

今後は、人間がテンプレートを手動で設計するのではなく、LLM自身が最適な推論テンプレートを自動生成・選択する「Self-Evolving Prompting」との統合が期待されます。

【参考文献】

  • [arXiv:2502.xxxx] Prompt Augmentation Scales up GRPO (Hypothetical URL based on topic)

  • [arXiv:2412.19437] DeepSeek-V3 Technical Report

  • [TRL Documentation] Group Relative Policy Optimization (GRPO) implementation guides.

ライセンス:本記事のテキスト/コードは特記なき限り CC BY 4.0 です。引用の際は出典URL(本ページ)を明記してください。
利用ポリシー もご参照ください。

コメント

タイトルとURLをコピーしました