一文了解开源大语言模型文件结构,以 Hugging Face DeepSeek-V3.1 模型仓库为例

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/


文章目录

  • 一、前言
  • [二、DeepSeek-V3.1 模型文件结构](#二、DeepSeek-V3.1 模型文件结构)

一、前言

在当前 AI 技术讨论中经常提及 "大语言模型(Large Language Model,LLM)开源",但它到底 "开" 出来什么?一个开源 LLM 究竟包含哪些核心组成部分?本文将介绍 DeepSeek-V3.1 模型文件由哪些部分组成,有助于理解大语言模型开源的具体内容和运行流程。

下图展示了知名大模型厂商 DeepSeek 公司在 Hugging Face 平台的主页,Hugging Face 实为当前全球最大的开源机器学习模型社区。Hugging Face 对于 AI 模型领域而言,可类比为面向人工智能领域的 GitHub。

我们以 DeepSeek-V3.1 的模型仓库作为观察示例,网址为:https://huggingface.co/deepseek-ai/DeepSeek-V3.1

Model Card 页面展示了模型的基本信息,具体内容如下:

注意,真正的核心内容在 Files and versions 选项卡里:https://huggingface.co/deepseek-ai/DeepSeek-V3.1/tree/main


二、DeepSeek-V3.1 模型文件结构

.safetensors 格式的模型权重文件数量最多且体积最大,因其包含模型中所有层的参数。为便于并行加载,模型权重通常被切分为许多 .safetensors 文件 。在实际部署过程中,model.safetensors.index.json 索引文件负责记录模型层与对应权重文件之间的映射关系,从而确定各权重在具体文件中的存储位置。

config.json 定义了模型的结构参数,相当于该大语言模型的 "身份证",其内容包括 model_type、architectures、hidden_size、num_hidden_layers、vocab_size 等参数,以及 DeepSeek-V3.1 中所使用的混合专家(Mixture-of-Experts,MoE)配置。

config.json 文件以 JSON 格式存储模型参数,而这些参数由 configuration_deepseek.py 代码负责解析并转化为模型配置对象。因此,这两个文件构成了配置文件解析与模型配置初始化的核心组件。

modeling_deepseek.py 则负责实现模型架构与具体计算逻辑。

此外,诸如 DeepSeek 这类大语言模型并不直接处理原始文本,而是依赖分词器 将输入文本转换为模型可处理的数字表示 ,其中 tokenizer.json 包含了分词规则映射与词汇表数据。例如,在词表中查询词汇 "good",可获取其对应的 Token ID 为 25109。

tokenizer_config.json 用于配置文本处理方式、特殊 token、model_max_length 和 chat_template 等参数。总体而言,分词器的主要功能是将输入文本转换为模型可处理的 Token ID 序列;在解码过程中,则将模型输出的 Token ID 序列重新转换为自然语言文本。

generation_config.json 用于配置使用 transformers 库加载并推理 DeepSeek-V3.1 模型时的生成策略相关参数,例如 do_sample、temperature 和 top_p 等。

其他:

  • assets/ - 辅助资源目录

  • .gitattributes - Git 属性配置

  • LICENSE - 特定开源许可证,DeepSeek-V3.1 实际用的 MIT License

  • README.md - 模型说明文档


📚️ 有关链接:

相关推荐
赋创小助手3 小时前
“短小精悍”的边缘AI算力利器:超微SYS-E403-14B-FRN2T服务器评测
服务器·人工智能·科技·ai·架构·边缘计算·1024程序员节
qq_ddddd3 小时前
对于随机变量x1, …, xn,其和的范数平方的期望不超过n倍各随机变量范数平方的期望之和
人工智能·神经网络·线性代数·机器学习·概率论·1024程序员节
三坛海会大神5553 小时前
CICD(一)CI/CD概述及GitLab部署和一些Git命令
git·ci/cd·1024程序员节
问道飞鱼3 小时前
【Linux知识】Linux文本操作相关命令行
linux·运维·服务器·文本处理·1024程序员节
暴躁哥3 小时前
Flink Watermark(水位线)机制详解
1024程序员节
徐同保3 小时前
tailwindcss使用@apply指令定义自己的样式
1024程序员节
让我们一起加油好吗3 小时前
【数论】欧拉定理 && 扩展欧拉定理
c++·算法·数论·1024程序员节·欧拉定理·欧拉降幂·扩展欧拉定理
SEO-狼术3 小时前
How Users Interact with PDFs
1024程序员节
Yupureki3 小时前
从零开始的C++学习生活 14:map/set的使用和封装
c语言·数据结构·c++·学习·visual studio·1024程序员节