4.6 4bit量化与QLoRA模型训练
创作时间:
作者:
@小白创作中心
4.6 4bit量化与QLoRA模型训练
引用
CSDN
1.
https://blog.csdn.net/a131529/article/details/143060583
本文将介绍4bit量化与QLoRA模型训练的相关内容。从量化的本质出发,详细讲解4bit量化、线性量化以及QLoRA的核心思想,并通过代码实战演练展示具体实现过程。
1 量化的本质
4bit表示的范围是[-128,127]
2 4bit量化
4bit表示的范围是[-8,7]
3 线性量化
量化效果和数据的分布方式息息相关
4 QLoRA
QLoRA 的核心思想是在大型语言模型的微调过程中,采用4-bit 量化来压缩模型的权重,从而减少显存的占用,并使用LoRA技术来对模型进行微调。
具体来讲,QLoRA实现了3件事儿,分别是:
- NF4量化
- 双重量化
- 分页优化器
4.1 NF4量化
4.1.1 分位数量化
4.1.2 完整实例
看了上面那么多,可能有点懵,其实看下面这个例子即可:
- 先对原始数据进行归一化;
- 接着将其与NF4进行匹配得到临近表示;
- 再将其按表中顺序映射为[0,15]即可。
4.2 双重量化
4.3 分页优化器
5 代码实战演练
5.1 导包
from datasets import Dataset
from transformers import AutoTokenizer, AutoModelForCausalLM, DataCollatorForSeq2Seq, TrainingArguments, Trainer
5.2 加载数据集
ds = Dataset.load_from_disk("../data/alpaca_data_zh/")
ds
5.3 数据集处理
tokenizer = AutoTokenizer.from_pretrained("D:/Pretrained_models/modelscope/Llama-2-7b-ms")
tokenizer
tokenizer.padding_side = "right" # 一定要设置padding_side为right,否则batch大于1时可能不收敛
tokenizer.pad_token_id = 2 # 半精度训练时,正确加入eos_token后,要将pad_token_id也设置为eos_token_id,否则会因为溢出问题导致模型无法正常收敛
def process_func(example):
MAX_LENGTH = 384 # Llama分词器会将一个中文字切分为多个token,因此需要放开一些最大长度,保证数据的完整性
input_ids, attention_mask, labels = [], [], []
instruction = tokenizer("\n".join(["Human: " + example["instruction"], example["input"]]).strip() + "\n\nAssistant: ", add_special_tokens=False)
response = tokenizer(example["output"], add_special_tokens=False)
input_ids = instruction["input_ids"] + response["input_ids"] + [tokenizer.eos_token_id]
attention_mask = instruction["attention_mask"] + response["attention_mask"] + [1]
labels = [-100] * len(instruction["input_ids"]) + response["input_ids"] + [tokenizer.eos_token_id]
if len(input_ids) > MAX_LENGTH:
input_ids = input_ids[:MAX_LENGTH]
attention_mask = attention_mask[:MAX_LENGTH]
labels = labels[:MAX_LENGTH]
return {
"input_ids": input_ids,
"attention_mask": attention_mask,
"labels": labels
}
tokenized_ds = ds.map(process_func, remove_columns=ds.column_names)
tokenized_ds
5.4 创建模型
import torch
# 多卡情况,可以去掉device_map="auto",否则会将模型拆开
model = AutoModelForCausalLM.from_pretrained("D:/Pretrained_models/modelscope/Llama-2-13b-ms", low_cpu_mem_usage=True,
torch_dtype=torch.bfloat16, device_map="auto", load_in_4bit=True, bnb_4bit_compute_dtype=torch.bfloat16,
bnb_4bit_quant_type="nf4", bnb_4bit_use_double_quant=True)
bnb_4bit_quant_type="nf4":指定了使用NF4量化类型
bnb_4bit_use_double_quant=True:这个参数启用了双重量化
bnb_4bit_compute_dtype=torch.bfloat16:电脑的卡较好情况下可以使用bfloat16,不太好就可以使用FP16,FP16有时候会出现一些溢出的问题
两者的区别:
for name, parameter in model.named_parameters():
print(name)

model.config
5.4.1 配置文件
from peft import LoraConfig, TaskType, get_peft_model
config = LoraConfig(task_type=TaskType.CAUSAL_LM)
config
5.4.2 构建模型
model = get_peft_model(model, config)
model.enable_input_require_grads() # 开启梯度检查点时,要执行该方法
model.print_trainable_parameters()
5.5 配置训练参数
args = TrainingArguments(
output_dir="./chatbot",
per_device_train_batch_size=1,
gradient_accumulation_steps=32,
logging_steps=10,
num_train_epochs=1,
gradient_checkpointing=True,
optim="paged_adamw_32bit"
)
optim="paged_adamw_32bit":使用32位分页优化器
5.6 创建训练器
trainer = Trainer(
model=model,
args=args,
train_dataset=tokenized_ds.select(range(6000)),
data_collator=DataCollatorForSeq2Seq(tokenizer=tokenizer, padding=True),
)
数据集较大,这里只选前6000条做训练
5.7 模型训练
trainer.train()
5.8 模型推理
model.eval()
ipt = tokenizer("Human: {}\n{}".format("你好", "").strip() + "\n\nAssistant: ", return_tensors="pt").to(model.device)
tokenizer.decode(model.generate(**ipt, max_length=512, do_sample=True, eos_token_id=tokenizer.eos_token_id)[0], skip_special_tokens=True)
热门推荐
肌酐高的人可以吃南瓜吗?需要注意什么?
巴拿山旅游攻略:从岘港出发轻松玩转
从岘港出发,探索巴拿山的网红打卡地
水命家居风水大揭秘:如何通过装修提升运势?
2024年最受百度用户关注的九大明星:作品才是王道
水命人的职场避坑指南:避开这些行业!
益生菌粉真的能拯救你的肠道吗?
益生菌粉:抗疫新宠?最新研究揭示肠道微生物与新冠防治新思路
膳食纤维益生菌选购指南:4个关键点帮你避坑
青霉素与抗生素:二战时期的“救命药”
九龙坡法院首例!心理咨询解抚养权心结
灵芝新研究揭示神奇功效!
灵芝:养生界的网红药材,科学使用更健康
武夷山灵芝:仙草的秘密基地
上海五条特色路线,带你玩转春节年味
昆明滇池:从“臭水湖”到网红打卡地的生态蝶变
春节打卡昆明滇池绿道:超全游玩攻略!
郑和故里:滇池畔的历史文化明珠
秋冬养生必备?补中益气颗粒的正确使用指南
北京地铁2号线:打卡天安门与故宫!
不同情况的肾病患者如何选择水果,黄色水果到底能不能吃,一文说清!
不同情况的肾病患者如何选择水果,黄色水果到底能不能吃,一文说清!
东风风神AX7车主必看:1.6T发动机保养秘籍!
网络传销有哪些特征
大年初五“破五节”:破除禁忌迎财神,传统美食话团圆
苍耳子的功效与作用及禁忌是什么
维生素C美白针:效果与风险全解析
十二生肖职业大揭秘:你选对了吗?
属牛的白羊座女生如何在金融行业大展拳脚?
十二生肖职场大揭秘:你的命运由五行决定?