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)
热门推荐
如何接好乒乓球发球(提升接发球技巧,提高比赛胜率)
马云与阿里巴巴如何影响了DeepSeek的崛起
辽宁男篮引进广厦旧将,内线再添实力,冲击四连冠仍有待补强
完全攻略!香港八大院校硕士申请指南! 只需一篇攻略
比起跳出舒适圈更重要的,是扩大舒适圈
丝路视觉:《共和国没有开闸》聚焦“98年抗洪”细节,传承伟大抗洪精神
上海地区适合种植的16种优质草种
日本签证的有效期与停留期限详解
孩子越说越故意!挑战大人底线是啥心理?
AI在员工培训与发展中的应用:个性化学习推荐与技能提升
“植”此新绿——多地植树节活动扫描
都是沙坦类降压药,厄贝沙坦和缬沙坦有何区别?早知早获益
芒果过敏:了解它,预防它,应对它
多模态和单模态对比学习的比较
民事责任与赔偿是什么?一文详解相关概念与处理方法
《布鲁克林有棵树》:困住人生的,从来不是贫穷
【节能与新能源汽车技术路线图2.0评估报告】-9大专题领域技术进展解析
非遗项目团队如何调研
美国陷鸡蛋大危机

空气加湿器有用吗?如何选购适合的空气加湿器?
福建·南安古村长桥老厝探访之旅
街霸33 人物进阶攻略 KEN
聘用人员劳动合同由他人代签需要什么手续
肝血是最好的滋润剂!这个千古名方补肝血一绝
连续跌停的股票怎样才能快速卖出,连续跌停一般几天会被救
安全用药 | 服药前,药品说明书上的这几项一定要看!
淘宝详情页制作流程,超详细版
马斯克76岁母亲:一己之力培养出三位亿万富豪的传奇人生
国家级风景名胜区 -文山普者黑名胜区
《人生由我》作者梅耶·马斯克——硬核人生中的3个松弛育儿观