Instructions to use openbmb/BitCPM-CANN-3B with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use openbmb/BitCPM-CANN-3B with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="openbmb/BitCPM-CANN-3B") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("openbmb/BitCPM-CANN-3B") model = AutoModelForCausalLM.from_pretrained("openbmb/BitCPM-CANN-3B") 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
- vLLM
How to use openbmb/BitCPM-CANN-3B with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "openbmb/BitCPM-CANN-3B" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "openbmb/BitCPM-CANN-3B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/openbmb/BitCPM-CANN-3B
- SGLang
How to use openbmb/BitCPM-CANN-3B 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 "openbmb/BitCPM-CANN-3B" \ --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": "openbmb/BitCPM-CANN-3B", "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 "openbmb/BitCPM-CANN-3B" \ --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": "openbmb/BitCPM-CANN-3B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Docker Model Runner
How to use openbmb/BitCPM-CANN-3B with Docker Model Runner:
docker model run hf.co/openbmb/BitCPM-CANN-3B
Create README.md
Browse files
README.md
ADDED
|
@@ -0,0 +1,161 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
---
|
| 2 |
+
license: apache-2.0
|
| 3 |
+
language:
|
| 4 |
+
- zh
|
| 5 |
+
- en
|
| 6 |
+
pipeline_tag: text-generation
|
| 7 |
+
library_name: transformers
|
| 8 |
+
---
|
| 9 |
+
<div align="center">
|
| 10 |
+
<img src="https://github.com/OpenBMB/MiniCPM/blob/main/assets/minicpm_logo.png?raw=true" width="500em" ></img>
|
| 11 |
+
</div>
|
| 12 |
+
|
| 13 |
+
<p align="center">
|
| 14 |
+
<a href="https://github.com/OpenBMB/MiniCPM/" target="_blank">GitHub Repo</a> |
|
| 15 |
+
<a href="TODO_TECHNICAL_REPORT_LINK" target="_blank">Technical Report</a>
|
| 16 |
+
</p>
|
| 17 |
+
<p align="center">
|
| 18 |
+
👋 Join us on <a href="https://discord.gg/3cGQn9b3YM" target="_blank">Discord</a> and <a href="https://github.com/OpenBMB/MiniCPM/blob/main/assets/wechat.jpg" target="_blank">WeChat</a>
|
| 19 |
+
</p>
|
| 20 |
+
|
| 21 |
+
## Introduction
|
| 22 |
+
|
| 23 |
+
BitCPM4-CANN is the first end-to-end 1.58-bit (ternary) large language model training system natively built on Huawei Ascend NPU. The system integrates quantization-aware training (QAT) into the Megatron-LM framework with MindSpeed acceleration, covering the full training stack from custom ternary operators to distributed parallel training on Ascend 910B.
|
| 24 |
+
|
| 25 |
+
We train a family of four models—BitCPM4-CANN-0.5B/1B/3B/8B—and evaluate them against their full-precision MiniCPM4 counterparts across 11 benchmarks. The 1B/3B/8B models retain **95.7%–97.2%** of full-precision performance, while enabling approximately **6× memory reduction** at inference time. QAT introduces only **5% training throughput overhead** (148 vs. 155 TFLOP/s per NPU).
|
| 26 |
+
|
| 27 |
+
### Key Features
|
| 28 |
+
|
| 29 |
+
- 🔬 **1.58-Bit Ternary Quantization**: Compresses model weights to ternary values {-1, 0, 1}, achieving ~90% bit-width reduction compared to BF16.
|
| 30 |
+
- 🖥️ **Native Ascend NPU Training**: First publicly reported 1.58-bit training effort on domestic NPU platform at 8B scale, establishing reusable low-bit training infrastructure for the Ascend ecosystem.
|
| 31 |
+
- ⚡ **Minimal Training Overhead**: Only 5% throughput degradation compared to full-precision training on Ascend 910B.
|
| 32 |
+
- 📦 **~6× Inference Memory Reduction**: Enables longer contexts, more serving replicas, and edge deployment on consumer devices.
|
| 33 |
+
|
| 34 |
+
### Important Note
|
| 35 |
+
|
| 36 |
+
> The models in this repository are in **pseudo-quantized (fake quantization) format**. This means the weights are stored in standard floating-point format with ternary values already applied during training. You can load and run inference with these models **exactly the same way as full-precision models**—no special quantization libraries or custom kernels are required.
|
| 37 |
+
|
| 38 |
+
## BitCPM4-CANN Model Family
|
| 39 |
+
|
| 40 |
+
| Model | HuggingFace | GGUF |
|
| 41 |
+
|-------|-------------|------|
|
| 42 |
+
| BitCPM4-CANN-0.5B | [openbmb/BitCPM4-CANN-0.5B](https://huggingface.co/openbmb/BitCPM4-CANN-0.5B) | [openbmb/BitCPM4-CANN-0.5B-gguf](https://huggingface.co/openbmb/BitCPM4-CANN-0.5B-gguf) |
|
| 43 |
+
| BitCPM4-CANN-1B | [openbmb/BitCPM4-CANN-1B](https://huggingface.co/openbmb/BitCPM4-CANN-1B) | [openbmb/BitCPM4-CANN-1B-gguf](https://huggingface.co/openbmb/BitCPM4-CANN-1B-gguf) |
|
| 44 |
+
| BitCPM4-CANN-3B | [openbmb/BitCPM4-CANN-3B](https://huggingface.co/openbmb/BitCPM4-CANN-3B) | [openbmb/BitCPM4-CANN-3B-gguf](https://huggingface.co/openbmb/BitCPM4-CANN-3B-gguf) |
|
| 45 |
+
| BitCPM4-CANN-8B | [openbmb/BitCPM4-CANN-8B](https://huggingface.co/openbmb/BitCPM4-CANN-8B) | [openbmb/BitCPM4-CANN-8B-gguf](https://huggingface.co/openbmb/BitCPM4-CANN-8B-gguf) |
|
| 46 |
+
|
| 47 |
+
## Usage
|
| 48 |
+
|
| 49 |
+
### Inference with Transformers
|
| 50 |
+
|
| 51 |
+
Since BitCPM4-CANN models are in pseudo-quantized format, you can use them exactly like standard full-precision models:
|
| 52 |
+
|
| 53 |
+
```python
|
| 54 |
+
from transformers import AutoModelForCausalLM, AutoTokenizer
|
| 55 |
+
import torch
|
| 56 |
+
torch.manual_seed(0)
|
| 57 |
+
|
| 58 |
+
path = 'openbmb/BitCPM4-CANN-3B'
|
| 59 |
+
device = "cuda"
|
| 60 |
+
tokenizer = AutoTokenizer.from_pretrained(path)
|
| 61 |
+
model = AutoModelForCausalLM.from_pretrained(path, torch_dtype=torch.bfloat16, device_map=device, trust_remote_code=True)
|
| 62 |
+
|
| 63 |
+
# User can directly use the chat interface
|
| 64 |
+
responds, history = model.chat(tokenizer, "Write an article about Artificial Intelligence.", temperature=0.7, top_p=0.7)
|
| 65 |
+
print(responds)
|
| 66 |
+
|
| 67 |
+
# User can also use the generate interface
|
| 68 |
+
# messages = [
|
| 69 |
+
# {"role": "user", "content": "Write an article about Artificial Intelligence."},
|
| 70 |
+
# ]
|
| 71 |
+
# prompt_text = tokenizer.apply_chat_template(
|
| 72 |
+
# messages,
|
| 73 |
+
# tokenize=False,
|
| 74 |
+
# add_generation_prompt=True,
|
| 75 |
+
# )
|
| 76 |
+
# model_inputs = tokenizer([prompt_text], return_tensors="pt").to(device)
|
| 77 |
+
|
| 78 |
+
# model_outputs = model.generate(
|
| 79 |
+
# **model_inputs,
|
| 80 |
+
# max_new_tokens=1024,
|
| 81 |
+
# top_p=0.7,
|
| 82 |
+
# temperature=0.7
|
| 83 |
+
# )
|
| 84 |
+
# output_token_ids = [
|
| 85 |
+
# model_outputs[i][len(model_inputs[i]):] for i in range(len(model_inputs['input_ids']))
|
| 86 |
+
# ]
|
| 87 |
+
|
| 88 |
+
# responses = tokenizer.batch_decode(output_token_ids, skip_special_tokens=True)[0]
|
| 89 |
+
# print(responses)
|
| 90 |
+
```
|
| 91 |
+
|
| 92 |
+
## Evaluation Results
|
| 93 |
+
|
| 94 |
+
### Main Results
|
| 95 |
+
|
| 96 |
+
BitCPM4-CANN models are evaluated against their full-precision MiniCPM4 counterparts across 11 benchmarks spanning commonsense reasoning, domain knowledge, and mathematics & reasoning.
|
| 97 |
+
|
| 98 |
+
| Category | Task | 8B FP | 8B Ternary | 3B FP | 3B Ternary | 1B FP | 1B Ternary | 0.5B FP | 0.5B Ternary |
|
| 99 |
+
|----------|------|-------|------------|-------|------------|-------|------------|---------|--------------|
|
| 100 |
+
| Commonsense | ARC-c | 87.46 | 86.10 | 80.34 | 78.98 | 64.41 | 67.12 | 51.86 | 50.51 |
|
| 101 |
+
| Commonsense | ARC-e | 95.06 | 93.47 | 92.77 | 88.36 | 79.89 | 79.01 | 71.78 | 65.08 |
|
| 102 |
+
| Commonsense | BoolQ | 84.89 | 83.39 | 79.85 | 77.89 | 68.38 | 65.50 | 62.29 | 43.55 |
|
| 103 |
+
| Commonsense | PIQA | 80.52 | 78.78 | 70.57 | 72.69 | 66.16 | 65.45 | 60.99 | 58.49 |
|
| 104 |
+
| Commonsense | WinoGrande | 63.30 | 61.17 | 58.41 | 52.96 | 51.62 | 53.28 | 51.07 | 51.54 |
|
| 105 |
+
| Domain Knowledge | CMMLU | 80.62 | 78.92 | 78.11 | 76.53 | 74.57 | 67.42 | 65.22 | 60.49 |
|
| 106 |
+
| Domain Knowledge | C-Eval | 81.36 | 77.50 | 75.85 | 75.89 | 73.25 | 65.96 | 66.11 | 60.74 |
|
| 107 |
+
| Domain Knowledge | MMLU | 75.83 | 70.65 | 66.95 | 64.41 | 57.71 | 57.71 | 55.55 | 50.73 |
|
| 108 |
+
| Domain Knowledge | MMLU-Redux | 77.14 | 69.85 | 65.82 | 60.07 | 54.80 | 54.16 | 48.00 | 43.79 |
|
| 109 |
+
| Math & Reasoning | BBH | 76.72 | 70.70 | 68.29 | 68.30 | 64.40 | 60.40 | 49.87 | 47.44 |
|
| 110 |
+
| Math & Reasoning | GSM8K | 91.51 | 85.75 | 81.64 | 79.45 | 63.15 | 61.56 | 52.08 | 39.42 |
|
| 111 |
+
| **Average** | **(11 tasks)** | **81.31** | **77.84** | **74.42** | **72.32** | **65.30** | **63.42** | **57.71** | **51.98** |
|
| 112 |
+
| **Retention** | | | **95.7%** | | **97.2%** | | **97.1%** | | **90.1%** |
|
| 113 |
+
|
| 114 |
+
### Key Observations
|
| 115 |
+
|
| 116 |
+
- **1B and above achieve ≥95.7% retention**: The 3B model achieves the highest retention at 97.2%, demonstrating that ternary QAT at this scale introduces minimal capability loss.
|
| 117 |
+
- **0.5B reveals scale-dependent sensitivity**: The smallest model retains 90.1%, indicating that quantization perturbation is more damaging when model capacity is limited.
|
| 118 |
+
- **1:1 alignment with MiniCPM4**: The matched evaluation enables direct substitution decisions—deployments can replace specific full-precision models with their ternary counterparts with clearly quantified trade-offs.
|
| 119 |
+
|
| 120 |
+
### Training Efficiency
|
| 121 |
+
|
| 122 |
+
| Configuration | TFLOP/s per NPU | Overhead |
|
| 123 |
+
|---------------|-----------------|----------|
|
| 124 |
+
| Full-precision | 155 | — |
|
| 125 |
+
| Ternary QAT | 148 | 4.5% |
|
| 126 |
+
|
| 127 |
+
System-level throughput on 2-node 16-card Ascend 910B:
|
| 128 |
+
- 3B model: ~2700 tokens/s per card
|
| 129 |
+
- 8B model: ~1340 tokens/s per card
|
| 130 |
+
|
| 131 |
+
## Technical Approach
|
| 132 |
+
|
| 133 |
+
BitCPM-CANN uses a ternary quantizer that maps each weight group to {-1, 0, 1} scaled by a group-wise factor, trained with Straight-Through Estimator (STE) for gradient flow. The training follows a two-stage strategy: **complete QAT followed by post-training distillation**, which avoids amplifying training instability during early training.
|
| 134 |
+
|
| 135 |
+
The system is built as a four-layer vertical stack on Ascend NPU:
|
| 136 |
+
1. **QAT Training Logic**: Ternary quantizer with STE, pluggable quantization layers in Megatron-LM.
|
| 137 |
+
2. **Megatron-LM Quantized Model Layer**: Tensor-parallel linear layers with integrated weight/activation quantizers.
|
| 138 |
+
3. **Framework Entry Layer**: `torch_npu` and `mindspeed.megatron_adaptor` injection for NPU execution.
|
| 139 |
+
4. **Ascend Software-Hardware Stack**: MindSpeed, CANN, HCCL communication, Ascend 910B NPU hardware.
|
| 140 |
+
|
| 141 |
+
For full technical details, please refer to our [Technical Report](TODO_TECHNICAL_REPORT_LINK).
|
| 142 |
+
|
| 143 |
+
## Statement
|
| 144 |
+
- As a language model, BitCPM4-CANN generates content by learning from a vast amount of text.
|
| 145 |
+
- However, it does not possess the ability to comprehend or express personal opinions or value judgments.
|
| 146 |
+
- Any content generated by BitCPM4-CANN does not represent the viewpoints or positions of the model developers.
|
| 147 |
+
- Therefore, when using content generated by BitCPM4-CANN, users should take full responsibility for evaluating and verifying it on their own.
|
| 148 |
+
|
| 149 |
+
## LICENSE
|
| 150 |
+
- This repository and BitCPM4-CANN models are released under the [Apache-2.0](https://github.com/OpenBMB/MiniCPM/blob/main/LICENSE) License.
|
| 151 |
+
|
| 152 |
+
## Citation
|
| 153 |
+
- Please cite our technical report if you find our work valuable.
|
| 154 |
+
|
| 155 |
+
```bibtex
|
| 156 |
+
@article{bitcpm4cann,
|
| 157 |
+
title={{BitCPM-CANN}: Native 1.58-Bit Large Language Model Training on Ascend NPU},
|
| 158 |
+
author={BitCPM Team},
|
| 159 |
+
year={2026}
|
| 160 |
+
}
|
| 161 |
+
```
|