HuggingFace镜像/nanowhale-100m
模型介绍文件和版本分析

nanowhale-100m 🐳

一个小型的约1.1亿参数语言模型,采用DeepSeek-V4架构,针对对话/指令遵循任务进行了微调。该模型从零开始训练——未使用DeepSeek-V4的任何权重。

  • 预训练基础模型:HuggingFaceTB/nanowhale-100m-base
  • 本模型:在HuggingFaceTB/smol-smoltalk数据集上进行监督微调(SFT)
  • 训练代码:github.com/huggingface/nanowhale

架构

本模型以微型规模实现了DeepSeek-V4的关键创新:

组件详情
参数规模总计约1.1亿(4100万嵌入参数,6900万非嵌入参数)
隐藏层维度320
网络层数8
注意力头数8(1个键值头——MQA架构)
MLA多头潜在注意力,q_lora_rank=160
MoE4个路由专家 + 1个共享专家,top-2路由
超连接(Hyper-Connections)hc_mult=4,Sinkhorn路由(替代残差连接)
MTP1个下一个token预测层
词汇表129,280(DeepSeek-V4分词器)
上下文长度2,048 tokens

训练

阶段1:预训练

  • 数据集:HuggingFaceFW/fineweb-edu
  • 步数:5,000 | ** tokens量 :约26亿 - 批次大小 :32(有效,8 × 4 GA)| 序列长度 :2,048 - 学习率 :6e-4,余弦衰减,3%预热 - 精度 **:bf16混合精度

阶段2:监督微调(本模型)

-** 数据集 :HuggingFaceTB/smol-smoltalk(46万对话) - 步数 :3,000 | tokens量 :约7270万 - 批次大小 :32(有效,8 × 4 GA)| 序列长度 :2,048 - 学习率 :2e-5,余弦衰减,5%预热 - 精度 **:fp32

指标

指标预训练模型监督微调模型
** 评估损失 **—2.607
** 困惑度 **(留出集)13.6212.90
** Token准确率 **33.8%48.5%

使用方法

import torch
from safetensors.torch import load_file
from transformers import AutoConfig, AutoModelForCausalLM, AutoTokenizer
from huggingface_hub import hf_hub_download

# Load model (recommended: manual load for reliability)
config = AutoConfig.from_pretrained("HuggingFaceTB/nanowhale-100m", trust_remote_code=True)
model = AutoModelForCausalLM.from_config(config, trust_remote_code=True).float()

# Download and load weights
weights_path = hf_hub_download("HuggingFaceTB/nanowhale-100m", "model.safetensors")
state_dict = load_file(weights_path)
model.load_state_dict(state_dict, strict=True)
model = model.cuda().eval()

tokenizer = AutoTokenizer.from_pretrained("HuggingFaceTB/nanowhale-100m")

# Chat
messages = [{"role": "user", "content": "What are 3 benefits of exercise?"}]
prompt = tokenizer.apply_chat_template(messages, tokenize=False, add_generation_prompt=True)
input_ids = tokenizer.encode(prompt, return_tensors="pt").cuda()
output = model.generate(input_ids, max_new_tokens=200, temperature=0.7, top_p=0.9,
                        pad_token_id=tokenizer.eos_token_id)
print(tokenizer.decode(output[0][input_ids.shape[1]:], skip_special_tokens=True))

局限性

  • 模型规模极小:仅包含110M参数和129K词汇量——大部分容量用于嵌入层。生成内容往往不连贯或与事实不符。
  • 训练不充分:仅进行了5K预训练步数和3K SFT(监督微调)步数。生产级模型通常会在数万亿tokens上训练10万步以上。
  • 仅用于教育目的:本模型旨在小尺度下演示DeepSeek-V4架构。不适合任何生产环境使用。
  • bf16精度下的NaN问题:请使用fp32精度——在此规模下,Hyper-Connections架构会产生超出bf16范围的值,导致溢出。
  • 自定义代码:需要设置trust_remote_code=True。

硬件

在1× NVIDIA H100 80GB上完成训练。

许可证

Apache-2.0

下载使用量0