Text Generation
Transformers
Safetensors
English
qwen3
chess
reasoning
chess-puzzles
reinforcement-learning
dapo
conversational
text-generation-inference
Instructions to use UofTCSSLab/C1-4B with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use UofTCSSLab/C1-4B with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="UofTCSSLab/C1-4B") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("UofTCSSLab/C1-4B") model = AutoModelForCausalLM.from_pretrained("UofTCSSLab/C1-4B") messages = [ {"role": "user", "content": "Who are you?"}, ] inputs = tokenizer.apply_chat_template( messages, add_generation_prompt=True, tokenize=True, return_dict=True, return_tensors="pt", ).to(model.device) outputs = model.generate(**inputs, max_new_tokens=40) print(tokenizer.decode(outputs[0][inputs["input_ids"].shape[-1]:])) - Notebooks
- Google Colab
- Kaggle
- Local Apps Settings
- vLLM
How to use UofTCSSLab/C1-4B with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "UofTCSSLab/C1-4B" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "UofTCSSLab/C1-4B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/UofTCSSLab/C1-4B
- SGLang
How to use UofTCSSLab/C1-4B with SGLang:
Install from pip and serve model
# Install SGLang from pip: pip install sglang # Start the SGLang server: python3 -m sglang.launch_server \ --model-path "UofTCSSLab/C1-4B" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "UofTCSSLab/C1-4B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker images
docker run --gpus all \ --shm-size 32g \ -p 30000:30000 \ -v ~/.cache/huggingface:/root/.cache/huggingface \ --env "HF_TOKEN=<secret>" \ --ipc=host \ lmsysorg/sglang:latest \ python3 -m sglang.launch_server \ --model-path "UofTCSSLab/C1-4B" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "UofTCSSLab/C1-4B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Docker Model Runner
How to use UofTCSSLab/C1-4B with Docker Model Runner:
docker model run hf.co/UofTCSSLab/C1-4B
File size: 3,960 Bytes
eeefeef | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | ---
license: apache-2.0
base_model: Qwen/Qwen3-4B-Instruct-2507
library_name: transformers
pipeline_tag: text-generation
language:
- en
tags:
- chess
- reasoning
- chess-puzzles
- qwen3
- reinforcement-learning
- dapo
---
# C1: Grounded Chess Reasoning in Language Models via Master Distillation
[](https://github.com/CSSLab/C1) [](https://arxiv.org/abs/2603.20510) [](https://huggingface.co/datasets/UofTCSSLab/C1-data)
The **final (SFT + RL)** model of **C1**. Given a chess position,
the model reasons step by step in natural language and ends with a single best
move in UCI notation.
This is the **final (SFT + RL) model**. The SFT-stage checkpoint is
[`UofTCSSLab/C1-SFT-4B`](https://huggingface.co/UofTCSSLab/C1-SFT-4B).
## Results
900-puzzle test set, greedy pass@1, `FINAL_ANSWER` exact-match UCI:
| stage | accuracy |
|---|---|
| SFT (base for RL) | 42.3% |
| **RL (this model)** | **48.3%** |
Average response length ~169 tokens.
## Usage
The prompt gives the FEN, piece positions, and legal moves, then asks for a
step-by-step analysis ending in `FINAL_ANSWER: <uci_move>`. **Greedy decoding
(temperature 0) is recommended**.
```python
# pip install chess
import chess
def build_prompt(fen: str) -> str:
board = chess.Board(fen)
names = {1: "Pawn", 2: "Knight", 3: "Bishop", 4: "Rook", 5: "Queen", 6: "King"}
pieces = {}
for sq in chess.SQUARES:
p = board.piece_at(sq)
if p:
key = f"{'White' if p.color else 'Black'} {names[p.piece_type]}"
pieces.setdefault(key, []).append(chess.square_name(sq))
order = [f"{c} {t}" for c in ("White", "Black")
for t in ("King", "Queen", "Rook", "Bishop", "Knight", "Pawn")]
arrangement = ", ".join(f"{k}: {sorted(pieces[k])}" for k in order if k in pieces)
legal = ", ".join(m.uci() for m in board.legal_moves)
return (
f"You are given a chess position in FEN: {fen}.\n"
f"Piece positions: {arrangement}\n"
f"Legal moves: {legal}\n"
"Find the best move for the side to play.\n"
"Analyze step by step and explain your reasoning.\n"
"Finish with a single line formatted EXACTLY as:\n"
"FINAL_ANSWER: <answer>\n"
"Use UCI notation (e.g., e2e4, c2b1q) for the final answer."
)
MODEL_ID = "UofTCSSLab/C1-4B"
FEN = "2kr3r/ppp2Npp/2nbp3/6N1/2PP2n1/4B2q/PP2BP2/R2Q1RK1 b - - 2 15"
messages = [{"role": "user", "content": build_prompt(FEN)}]
```
### Transformers
```python
# pip install transformers torch
from transformers import AutoModelForCausalLM, AutoTokenizer
tok = AutoTokenizer.from_pretrained(MODEL_ID)
model = AutoModelForCausalLM.from_pretrained(MODEL_ID, torch_dtype="bfloat16", device_map="auto")
ids = tok.apply_chat_template(messages, add_generation_prompt=True, return_tensors="pt").to(model.device)
out = model.generate(ids, max_new_tokens=1024, do_sample=False) # greedy
print(tok.decode(out[0, ids.shape[-1]:], skip_special_tokens=True))
# ... step-by-step reasoning ...
# FINAL_ANSWER: h3h2
```
### vLLM
```python
# pip install vllm
from vllm import LLM, SamplingParams
llm = LLM(model=MODEL_ID, dtype="bfloat16")
sampling = SamplingParams(temperature=0.0, max_tokens=1024) # greedy
out = llm.chat(messages, sampling_params=sampling)
print(out[0].outputs[0].text)
# ... step-by-step reasoning ...
# FINAL_ANSWER: h3h2
```
## Citation
```bibtex
@article{tang2026grounded,
title={Grounded Chess Reasoning in Language Models via Master Distillation},
author={Tang, Zhenwei and Wen, Qianfeng and Grief-Albert, Seth and Elgabra, Yahya and Yang, Blair and Dong, Honghua and Anderson, Ashton},
journal={arXiv preprint arXiv:2603.20510},
year={2026}
}
```
|