微调后的模型保存与加载

在Hugging Face Transformers库中,微调后的模型保存与加载方式因微调方法(如常规微调或参数高效微调)而异。

一、常规微调模型的保存与加载

1、 保存完整模型
  • 使用 save_pretrained() 方法可将整个模型(包含权重、配置、分词器)保存到指定目录:
    保存模型、分词器、配置
python 复制代码
model.save_pretrained("./my_finetuned_model")
tokenizer.save_pretrained("./my_finetuned_model")
  • 生成以下文件:

    pytorch_model.bin(或 tf_model.h5):模型权重

    config.json:模型结构配置

    tokenizer_config.json:分词器配置

2、加载模型
  • 通过 from_pretrained() 加载已保存的完整模型:
python 复制代码
from transformers import AutoModelForSequenceClassification, AutoTokenizer

model = AutoModelForSequenceClassification.from_pretrained("./my_finetuned_model")
tokenizer = AutoTokenizer.from_pretrained("./my_finetuned_model")
3、将模型转换为 .safetensors 格式保存
python 复制代码
# 指定保存目录并启用安全序列化
save_path = "./saved_model"
model.save_pretrained(save_path, safe_serialization=True)  
  • 执行后会在 saved_model 目录生成以下文件:

    model.safetensors(权重文件)

    config.json(模型配置)

    tokenizer.json(分词器配置,如有)

4、分片保存大模型‌

针对体积较大的模型,可分割为多个 .safetensors 文件:

python 复制代码
# 设置分片尺寸(单位:MB)
model.save_pretrained(save_path, safe_serialization=True, max_shard_size="2GB")  
  • 生成文件名格式为 model-00001-of-00005.safetensors,并附带索引文件 model.safetensors.index.json。

二、参数高效微调(如LoRA)的保存与加载

1、仅保存适配器权重

使用LoRA等参数高效方法时,只需保存增量权重(通常几十MB):

  • 保存LoRA适配器
python 复制代码
model.save_pretrained("./lora_adapter")
  • 生成文件:
    adapter_model.bin(或 .safetensors):适配器权重
    adapter_config.json:适配器配置(含基础模型路径)
2、加载适配器

加载适配器,与原模型合并:

python 复制代码
from transformers import AutoModelForCausalLM
from peft import PeftModel, PeftConfig

# 加载基础模型
base_model = AutoModelForCausalLM.from_pretrained("./base_model")  

# 加载PEFT适配器
peft_config = PeftConfig.from_pretrained("./peft_adapter")
# 将adapter_model.safetensors中的低秩矩阵(如LoRA的A/B矩阵)加载到基础模型的指定位置(如q_proj、v_proj)
'''
PEFT的核心思想是通过冻结基础模型(如Llama-2、Mistral等)的原始参数,仅训练适配器层(如LoRA的低秩矩阵)。保存模型时:

​基础模型权重:保持原始精度(如FP32)或量化状态(如4-bit NF4)
​适配器参数:以独立文件存储(adapter_model.safetensors)
​配置元数据:记录适配器类型、注入位置等(adapter_config.json)
'''
peft_model = PeftModel.from_pretrained(base_model, "./peft_adapter")
3、合并权重
  • 若需独立部署,可将LoRA权重合并到原模型中:
python 复制代码
merged_model = model.merge_and_unload()
merged_model.save_pretrained("./merged_model")  # 保存完整模型(数GB)
  • 加载完整模型
python 复制代码
# 直接加载完整模型
full_model = AutoModelForCausalLM.from_pretrained("./full_model") 

三、使用Trainer API的自动保存

通过 TrainingArguments 设置自动保存策略:

python 复制代码
from transformers import TrainingArguments

args = TrainingArguments(
    output_dir="./results",
    save_strategy="epoch",  # 按epoch保存
    load_best_model_at_end=True  # 训练结束后加载最佳模型
)

训练完成后,最佳模型会保存在 output_dir 中

python 复制代码
trainer = Trainer(model, args, ...)
trainer.train()

四、unsloth 微调后的模型 保存

基于 Unsloth 的微调模型保存具有高度灵活性

1、LoRA 适配器轻量级保存
python 复制代码
model.save_pretrained("./lora_model")  # 仅保存适配器(约100MB)
tokenizer.save_pretrained("./lora_model")

特点:

  • 仅存储微调增量参数,适合迭代开发阶段

  • 需配合原始基础模型加载使用

  • 文件结构:adapter_model.bin + adapter_config.json

2、全量模型合并保存
  • 合并为FP16精度(生产环境推荐)
python 复制代码
model.save_pretrained_merged(
    output_dir="merged_16bit",
    tokenizer=tokenizer,
    save_method="merged_16bit"
)
  • 4位量化版(显存敏感场景)
python 复制代码
model.save_pretrained_merged(
    output_dir="merged_4bit",
    tokenizer=tokenizer,
    save_method="merged_4bit"
)
3、GGUF 高效推理格式导出
  • 标准Q8_0量化(平衡型)
python 复制代码
model.save_pretrained_gguf("gguf_model", tokenizer)
  • 极致压缩Q4_K_M(移动端适用)
python 复制代码
model.save_pretrained_gguf(
    "gguf_model",
    tokenizer,
    quantization_method="q4_k_m"
)
4、多格式混合保存
  • 适配器 + 合并模型 + GGUF
python 复制代码
model.save_pretrained("lora_model")  # 适配器
model.save_pretrained_merged(...)     # 16bit合并
model.save_pretrained_gguf(...)      # GGUF格式
相关推荐
AI绘画哇哒哒9 小时前
实战:SQL统一访问200+数据源,构建企业级智能检索与RAG系统(下)
人工智能·sql·深度学习·学习·ai·程序员·大模型
spader-ai16 小时前
RAG is really dead? 大模型和知识之间的桥梁没了?
人工智能·大模型·rag·上下文工程
烟锁池塘柳017 小时前
【大模型】深入理解大模型输出的Temperature、Top-k与Top-p采样
大模型·大模型应用
qq7422349841 天前
免费版Markdown 编辑器:Typora
大模型·编辑器·markdown
nju_spy1 天前
南京大学 LLM开发基础(二)大语言模型解析 -- 基于HF LlaMA实现的讲解
人工智能·pytorch·深度学习·大模型·多头注意力·rmsnorm·位置掩码
胡耀超1 天前
开源生态与技术民主化 - 从LLaMA到DeepSeek的开源革命(LLaMA、DeepSeek-V3、Mistral 7B)
人工智能·python·神经网络·开源·大模型·llama·deepseek
love530love2 天前
Windows 系统部署 阿里团队开源的先进大规模视频生成模型 Wan2.2 教程——基于 EPGF 架构
运维·人工智能·windows·python·架构·开源·大模型
大模型铲屎官2 天前
【LangChain 核心组件指南 | Agent篇】从零到精通:深度解析 create_agent 与 ReAct 智能体构建
人工智能·python·深度学习·langchain·大模型·agent·react智能体
数据堂官方账号2 天前
版权数据集上新 | 覆盖大模型、多模态大模型、语音识别、语音合成及计算机视觉等多领域
人工智能·计算机视觉·大模型·数据集·语音识别·语音合成·多模态大模型
人工智能培训3 天前
Transformer-位置编码(Position Embedding)
人工智能·深度学习·大模型·transformer·embedding·vision