Project Icon

ChatGLM-LoRA-RLHF-PyTorch

使用LoRA和RLHF在消费者硬件上微调ChatGLM的详细指南

该项目详细介绍了如何在消费者硬件上使用LoRA和RLHF微调ChatGLM LLM,包括环境配置、数据处理、监督微调及奖励模型的训练等步骤,帮助开发者轻松实现模型优化。

项目介绍:ChatGLM-LoRA-RLHF-PyTorch

ChatGLM-LoRA-RLHF-PyTorch 是一个旨在利用商业硬件设备来微调 ChatGLM 大型语言模型的完整流程。该项目结合了 LoRA (Low-Rank Adaptation of Large Language Models) 和 RLHF (Reinforcement Learning from Human Feedback) 技术,以提升语言模型的性能。

环境配置

为了运行本项目,您需要以下环境配置:

  • 显卡:2080Ti 12G
  • 安装 torch==2.0.0
  • 安装 cuda==11.8

计划列表

当前项目的发展计划如下:

  • 完成监督微调 (Supervised Finetune, SFT)
  • 将适配器合并到模型中
  • 暂未完成的任务包括:
    • 使用强化学习进行调优

运行流程

项目的运行流程可以分为以下几个步骤:

数据处理

  1. 数据集转化:将 alpaca 数据集转换为 JSONL 格式

    python cover_alpaca2jsonl.py --data_path data/alpaca_data.json --save_path data/alpaca_data.jsonl
    
  2. 数据标记化:对数据集进行分词处理

    python tokenize_dataset_rows.py --jsonl_path data/alpaca_data.jsonl --save_path data/alpaca --max_seq_length 200 --skip_overlength True
    

监督微调

进行监督微调需要使用最新版本的 PEFT:

  1. 安装最新 PEFT 版本(>=0.3.0.dev0)

    pip uninstall peft -y
    pip install git+https://github.com/huggingface/peft.git
    
  2. 开始微调

    python supervised_finetune.py --dataset_path data/alpaca --lora_rank 8 --per_device_train_batch_size 1 --gradient_accumulation_steps 32 --save_steps 200 --save_total_limit 3  --learning_rate 1e-4 --fp16 --remove_unused_columns false --logging_steps 10 --output_dir output
    

将 PEFT 适配器合并到模型中

由于 PEFT 的不同版本可能导致问题,因此建议使用 0.2.0 版本来合并适配器。

pip uninstall peft -y
pip install peft==0.2.0
python merge_peft_adapter.py --model_name ./output

奖励模型

训练奖励模型,之后可以合并到总模型中:

python train_reward_model.py --model_name 'THUDM/chatglm-6b' --gradient_accumulation_steps 32 --per_device_train_batch_size 1 --train_subset 100 --eval_subset 10 --local_rank 0 --bf16 False

并将其合并:

python merge_peft_adapter.py --model_name ./reward_model_chatglm-6b

注意事项

  1. PEFT 的最新版本在合并时可能会遇到问题,应使用版本 0.2.0。
  2. Huggingface 的 Transformer 暂不支持 ChatGLM 的接口,需要从 ChatGLM 的代码库中手动获取代码。
  3. Reward Model 的训练需要使用 SeqCLS 任务,推荐自定义实现。

参考资料

该项目在数据处理和环境配置上借鉴了下列项目的代码和结构:

  • alpaca-lora
  • ChatGLM-Tuning
  • trl
  • llama-trl

Star-History

项目的 Star 历史图:

star-history

捐赠

如果该项目对您的开发有所帮助,可以通过以下方式请我喝杯咖啡 :)

  • 支付宝和微信的二维码位于项目的相关文件夹中。

许可证

本项目采用 MIT 许可证进行授权。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号