Text Generation
Transformers
Safetensors
English
Chinese
qwen3
code-generation
npu
ascend
chain-of-thought
conversational
text-generation-inference
Instructions to use AscendKernelGen/KernelGen-LM-32B with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use AscendKernelGen/KernelGen-LM-32B with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="AscendKernelGen/KernelGen-LM-32B") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("AscendKernelGen/KernelGen-LM-32B") model = AutoModelForCausalLM.from_pretrained("AscendKernelGen/KernelGen-LM-32B") 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 AscendKernelGen/KernelGen-LM-32B with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "AscendKernelGen/KernelGen-LM-32B" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "AscendKernelGen/KernelGen-LM-32B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/AscendKernelGen/KernelGen-LM-32B
- SGLang
How to use AscendKernelGen/KernelGen-LM-32B 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 "AscendKernelGen/KernelGen-LM-32B" \ --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": "AscendKernelGen/KernelGen-LM-32B", "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 "AscendKernelGen/KernelGen-LM-32B" \ --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": "AscendKernelGen/KernelGen-LM-32B", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Docker Model Runner
How to use AscendKernelGen/KernelGen-LM-32B with Docker Model Runner:
docker model run hf.co/AscendKernelGen/KernelGen-LM-32B
Update README.md
Browse files
README.md
CHANGED
|
@@ -15,12 +15,12 @@ KernelGen-LM-32B is a state-of-the-art domain-adaptive large language model spec
|
|
| 15 |
The Ascend KernelGen Technical Report is published at https://arxiv.org/abs/2601.07160.
|
| 16 |
|
| 17 |
**Other artifacts:**
|
| 18 |
-
* The **
|
| 19 |
* The **NPUKernelBench** evaluation framework is published at https://git.openi.org.cn/PCL-Benchmark/NPUKernelBench.
|
| 20 |
|
| 21 |
## Introduction
|
| 22 |
|
| 23 |
-
Our framework, **
|
| 24 |
|
| 25 |
* **Ascend-CoT Dataset:** A high-quality, domain-specific dataset incorporating **Chain-of-Thought (CoT)** reasoning. It combines documentation-based reasoning, code-centric reasoning derived from real-world kernel implementations, and general reasoning chains to capture the structured logic required for low-level NPU programming.
|
| 26 |
* **Domain-Adaptive Post-Training:** A two-stage optimization process that yields **KernelGen-LM**. We first employ **Supervised Fine-Tuning (SFT)** with error-derived supervision (correcting API misuse and numerical errors). This is followed by **Reinforcement Learning (RL)** using Direct Preference Optimization (DPO), driven by execution-based correctness and performance signals.
|
|
@@ -29,7 +29,7 @@ Our framework, **Ascend KernelGen (AKGen)**, bridges the gap between general-pur
|
|
| 29 |
|
| 30 |
## Citation
|
| 31 |
@article{cao2026ascendkernelgen,
|
| 32 |
-
title={
|
| 33 |
author={Xinzi Cao and Jianyang Zhai and Pengfei Li and Zhiheng Hu and Cen Yan and Bingxu Mu and Guanghuan Fang and Bin She and Jiayu Li and Yihan Su and Dongyang Tao and Xiansong Huang and Fan Xu and Feidiao Yang and Yao Lu and Chang-Dong Wang and Yutong Lu and Weicheng Xue and Bin Zhou and Yonghong Tian},
|
| 34 |
journal={arXiv preprint arXiv:2601.07160},
|
| 35 |
year={2026},
|
|
|
|
| 15 |
The Ascend KernelGen Technical Report is published at https://arxiv.org/abs/2601.07160.
|
| 16 |
|
| 17 |
**Other artifacts:**
|
| 18 |
+
* The **AscendKernelGen Technical Report** is published at https://arxiv.org/abs/2601.07160.
|
| 19 |
* The **NPUKernelBench** evaluation framework is published at https://git.openi.org.cn/PCL-Benchmark/NPUKernelBench.
|
| 20 |
|
| 21 |
## Introduction
|
| 22 |
|
| 23 |
+
Our framework, **AscendKernelGen (AKGen)**, bridges the gap between general-purpose code generation and hardware-specific programming through a closed-loop system of data construction, training, and evaluation. Key innovations include:
|
| 24 |
|
| 25 |
* **Ascend-CoT Dataset:** A high-quality, domain-specific dataset incorporating **Chain-of-Thought (CoT)** reasoning. It combines documentation-based reasoning, code-centric reasoning derived from real-world kernel implementations, and general reasoning chains to capture the structured logic required for low-level NPU programming.
|
| 26 |
* **Domain-Adaptive Post-Training:** A two-stage optimization process that yields **KernelGen-LM**. We first employ **Supervised Fine-Tuning (SFT)** with error-derived supervision (correcting API misuse and numerical errors). This is followed by **Reinforcement Learning (RL)** using Direct Preference Optimization (DPO), driven by execution-based correctness and performance signals.
|
|
|
|
| 29 |
|
| 30 |
## Citation
|
| 31 |
@article{cao2026ascendkernelgen,
|
| 32 |
+
title={AscendKernelGen: A Systematic Study of LLM-Based Kernel Generation for Neural Processing Units},
|
| 33 |
author={Xinzi Cao and Jianyang Zhai and Pengfei Li and Zhiheng Hu and Cen Yan and Bingxu Mu and Guanghuan Fang and Bin She and Jiayu Li and Yihan Su and Dongyang Tao and Xiansong Huang and Fan Xu and Feidiao Yang and Yao Lu and Chang-Dong Wang and Yutong Lu and Weicheng Xue and Bin Zhou and Yonghong Tian},
|
| 34 |
journal={arXiv preprint arXiv:2601.07160},
|
| 35 |
year={2026},
|