226 lines
8.2 KiB
Markdown
226 lines
8.2 KiB
Markdown
---
|
||
language:
|
||
- ja
|
||
license: apache-2.0
|
||
tags:
|
||
- math
|
||
- japanese
|
||
- fine-tuning
|
||
- sft
|
||
- lora
|
||
- chain-of-thought
|
||
- self-consistency
|
||
- llm-jp
|
||
- ft-competition-2026
|
||
base_model:
|
||
- llm-jp/llm-jp-4-8b-base
|
||
datasets:
|
||
- azuki-digital/ft-llm-2026-synthetic-ja-math-qwen-235b-v1
|
||
- azuki-digital/ft-llm-2026-synthetic-ja-math-qwen-235b-v2
|
||
pipeline_tag: text-generation
|
||
model-index:
|
||
- name: llm-jp-4-math-lion
|
||
results:
|
||
- task:
|
||
type: math-reasoning
|
||
name: Japanese Math Benchmark (Dev)
|
||
metrics:
|
||
- type: accuracy
|
||
value: 95
|
||
name: Accuracy (Dev 100Q)
|
||
---
|
||
|
||
# llm-jp-4-math-lion
|
||
|
||
**ファインチューニングコンペ LLM 2026 — 数学タスク(オープン枠)提出モデル**
|
||
|
||
日本の中学・高校レベルの数学問題に対する推論精度を最大化するために、2段階のSFT(Supervised Fine-Tuning)と推論時のSelf-Consistencyを組み合わせたモデルです。
|
||
|
||
## モデル概要
|
||
|
||
| 項目 | 詳細 |
|
||
|------|------|
|
||
| ベースモデル | LLM-JP 4 継続事前学習済みモデル(`llm-jp/llm-jp-4-8b-base`)|
|
||
| 学習手法 | 2段階 SFT(Stage 1: Full Fine-Tuning → Stage 2: LoRA) |
|
||
| 学習データ | 合成データ 約160万件(自作 + LLM蒸留) |
|
||
| 推論手法 | vLLM + `\boxed{}` 形式出力(Self-Consistency対応) |
|
||
| 開発ベンチマーク精度 | 95%(運営配布100問) |
|
||
| コンペ | ファインチューニングコンペ LLM 2026 数学タスク・オープン枠 |
|
||
|
||
|
||
## ベースモデルの選定
|
||
|
||
運営から提供された3つのベースモデル候補を開発用ベンチマーク100問で評価し、以下の結果を得ました。
|
||
|
||
| モデル | 精度 |
|
||
|--------|------|
|
||
| 事前学習のみ | 7% |
|
||
| 継続事前学習済み | 48% |
|
||
| インストラクションチューニング済み | 44% |
|
||
|
||
継続事前学習とSFTを組み合わせる方針だったため、追加の継続事前学習が行いやすく精度も最も高かった「継続事前学習済みモデル」を選定しました。
|
||
|
||
## 学習データセット
|
||
|
||
2種類のデータセットを作成し、段階的にモデルへ学習させています。
|
||
|
||
### データセット1: ベンチマーク指向型データ(約60万件)
|
||
|
||
評価ベンチマークの出題形式・分野を意識して作成したデータセットです。
|
||
|
||
- **問題生成**: LLMは不使用。日本語の設問テンプレートを手動で作成し、ランダムに組み合わせるロジックで生成。計算部分はSymPyを使用して式と回答の整合性を保証。
|
||
- **カバー範囲**: 中学・高校数学の評価対象カテゴリを網羅。約3万件のユニークな問題・回答ペアを作成。
|
||
- **CoT付与**: 各問題に対して Qwen/Qwen3-235B-A22B-Instruct-2507 で20個のCoTを生成(Temperature / Top-p制御で多様性を確保)。生成されたCoTと正解を突き合わせ、正確なもののみを採用。
|
||
- **最終データ量**: 約60万件(3万問 × 正確なCoT)
|
||
|
||
### データセット2: LLM完全生成型データ(約100万件)
|
||
|
||
問題・CoTの両方をLLMで生成した蒸留データセットです。NVIDIAの数学タスク精度向上に関する研究を参考にしています。
|
||
|
||
- **問題生成**: Qwen/Qwen3-235B-A22B-Instruct-2507 を使用。日本の中学・高校の数学カリキュラムに準拠した問題を全カテゴリで約5万件生成。ベンチマークとは独立した出題で汎化性能を意識。
|
||
- **回答・CoT生成**: Qwen/Qwen3-235B-A22B-Instruct-2507 を使用。各問題に対して20回の試行を行い、マジョリティ・ボーティング(多数決)で80%以上の一致率が得られたもののみを採用。
|
||
- **最終データ量**: 約100万件(5万問 × 正確なCoT)
|
||
|
||
## 学習手法
|
||
|
||
### Stage 1: Full Fine-Tuning
|
||
|
||
汎用的な数学推論能力の獲得を目的とし、LLM完全生成型データセット(約100万件:azuki-digital/ft-llm-2026-synthetic-ja-math-qwen-235b-v2)でフルパラメータのファインチューニングを実施。
|
||
|
||
| パラメータ | 値 |
|
||
|-----------|-----|
|
||
| 手法 | Full Fine-Tuning |
|
||
| 学習率 | 2e-5 |
|
||
| データ | LLM完全生成型データ(~100万件) |
|
||
|
||
### Stage 2: LoRA Fine-Tuning
|
||
|
||
ベンチマークの出題形式への適応を目的とし、ベンチマーク指向型データセット(約60万件:azuki-digital/ft-llm-2026-synthetic-ja-math-qwen-235b-v1)でLoRAによる追加学習を実施。
|
||
|
||
| パラメータ | 値 |
|
||
|-----------|-----|
|
||
| 手法 | LoRA |
|
||
| ランク (r) | 64 |
|
||
| Alpha (α) | 128 |
|
||
| ドロップアウト | 0.03 |
|
||
| 学習率 | 1e-4 |
|
||
| データ | ベンチマーク指向型データ(~60万件) |
|
||
|
||
## 使い方
|
||
|
||
### プロンプトテンプレート
|
||
|
||
本モデルは以下のプロンプトテンプレートで学習・推論を行っています。出力は必ず `\boxed{}` で最終回答を囲む形式になります。
|
||
|
||
```
|
||
次の数学の問題を解いてください。
|
||
|
||
【厳守】
|
||
- 数式はLaTeXで書く。
|
||
- 最後の答えは必ず \boxed{} で1回だけ囲む。
|
||
|
||
問題:
|
||
{problem}
|
||
|
||
解答:
|
||
```
|
||
|
||
### 推論コード(vLLM)
|
||
|
||
```python
|
||
from vllm import LLM, SamplingParams
|
||
|
||
PROMPT_TEMPLATE = """\
|
||
次の数学の問題を解いてください。
|
||
|
||
【厳守】
|
||
- 数式はLaTeXで書く。
|
||
- 最後の答えは必ず \\boxed{{}} で1回だけ囲む。
|
||
|
||
問題:
|
||
{problem}
|
||
|
||
解答:
|
||
"""
|
||
|
||
model_path = "azuki-digital/llm-jp-4-math-lion"
|
||
llm = LLM(model=model_path, trust_remote_code=True)
|
||
|
||
sampling_params = SamplingParams(
|
||
temperature=0.0,
|
||
top_p=1.0,
|
||
max_tokens=4096,
|
||
)
|
||
|
||
problem = "2次方程式 x^2 - 5x + 6 = 0 を解きなさい。"
|
||
prompt = PROMPT_TEMPLATE.format(problem=problem)
|
||
|
||
outputs = llm.generate([prompt], sampling_params=sampling_params)
|
||
print(outputs[0].outputs[0].text)
|
||
```
|
||
|
||
### 回答の抽出
|
||
|
||
モデルの出力から最終回答を取得するには、`\boxed{}` の中身を抽出してください。
|
||
|
||
```python
|
||
import re
|
||
|
||
def extract_answer(text: str) -> str:
|
||
"""text から最後の \\boxed{...} の中身を抽出する"""
|
||
key = r"\boxed{"
|
||
start = text.rfind(key)
|
||
if start == -1:
|
||
return ""
|
||
i = start + len(key)
|
||
depth = 1
|
||
out_chars = []
|
||
while i < len(text):
|
||
ch = text[i]
|
||
if ch == "{":
|
||
depth += 1
|
||
out_chars.append(ch)
|
||
elif ch == "}":
|
||
depth -= 1
|
||
if depth == 0:
|
||
return "".join(out_chars).strip()
|
||
out_chars.append(ch)
|
||
else:
|
||
out_chars.append(ch)
|
||
i += 1
|
||
return ""
|
||
```
|
||
|
||
### 推論時のTips
|
||
|
||
- **Self-Consistency(オプション)**: 精度をさらに向上させたい場合、同一問題に対して複数回(例: 20回)推論を行い、[Math-Verify](https://github.com/huggingface/Math-Verify)で回答を比較した上でマジョリティ・ボーティングを行う手法が有効です。学習に使用しなかった外部ベンチマークでは、この手法により精度が顕著に向上する傾向が確認されました。
|
||
- **リトライ**: `\boxed{}` が出力に含まれない場合は、同じ問題で再度推論を行うことで回答を得られる場合があります。
|
||
|
||
## 評価結果
|
||
|
||
| ベンチマーク | 精度 | 備考 |
|
||
|-------------|------|------|
|
||
| 開発用ベンチマーク(100問) | **95%** | 運営配布の評価データ |
|
||
|
||
参考として、Qwen/Qwen3-30B-A3B-Instruct-2507 の同ベンチマークに対する精度は84%であり、本モデルはこれを上回る精度を達成しています。
|
||
|
||
## 制限事項
|
||
|
||
- 日本の中学・高校レベルの数学問題に特化して学習しているため、それ以外の領域での性能は保証されません。
|
||
- 合成データ(Qwen3による蒸留データ)を中心に学習しているため、学習データの分布から外れるパターンの問題では精度が低下する可能性があります。
|
||
- 継続事前学習は当初計画していたものの、リソース・スケジュールの制約により未実施です。
|
||
|
||
## ライセンス
|
||
|
||
Apache License 2.0
|
||
|
||
## 引用
|
||
|
||
```bibtex
|
||
@misc{llm-jp-4-math-lion,
|
||
title={llm-jp-4-math-lion: Two-Stage SFT with Self-Consistency for Japanese Math Reasoning},
|
||
author={azuki-digital},
|
||
year={2026},
|
||
url={https://huggingface.co/azuki-digital/llm-jp-4-math-lion}
|
||
}
|
||
``` |