Project Icon

starcoder2

先进的多语言代码生成模型家族

StarCoder2是一系列代码生成模型,包括3B、7B和15B参数规模。模型在600多种编程语言和自然语言文本上训练,使用分组查询注意力机制,具有16,384个token的上下文窗口。支持代码补全、多GPU部署和量化推理,提供使用说明和微调指南。StarCoder2在代码生成任务中表现优异,是开发者的有力工具。

StarCoder 2

[🤗 模型与数据集] | [论文]

StarCoder2是一系列代码生成模型(3B、7B和15B),在来自The Stack v2的600多种编程语言以及一些自然语言文本(如维基百科、Arxiv和GitHub问题)上进行训练。这些模型使用分组查询注意力机制,上下文窗口为16,384个标记,滑动窗口注意力为4,096个标记。3B和7B模型在3万亿以上的标记上训练,而15B模型在4万亿以上的标记上训练。更多详情请查看论文

目录

  1. 快速开始
  2. 微调
  3. 评估

快速开始

StarCoder2模型主要用于代码补全,它们不是指令模型,像"编写一个计算平方根的函数"这样的命令效果不佳。

安装

首先,我们需要安装requirements.txt中列出的所有库

pip install -r requirements.txt
# 导出你的HF令牌,可以在这里找到:https://huggingface.co/settings/account
export HF_TOKEN=xxx

模型使用和内存占用

以下是一些加载模型和生成代码的示例,以及最大模型StarCoder2-15B的内存占用情况。确保你已从源代码安装了transformers(如果你使用了requirements.txt,应该已经安装了)

pip install git+https://github.com/huggingface/transformers.git

在CPU/GPU/多GPU上运行模型

  • 使用全精度
# pip install git+https://github.com/huggingface/transformers.git # TODO: 合并PR到主分支
from transformers import AutoModelForCausalLM, AutoTokenizer

checkpoint = "bigcode/starcoder2-15b"
device = "cuda" # 使用GPU,或使用"cpu"进行CPU运算

tokenizer = AutoTokenizer.from_pretrained(checkpoint)
# 使用多个GPU,可以这样做:`model = AutoModelForCausalLM.from_pretrained(checkpoint, device_map="auto")`
model = AutoModelForCausalLM.from_pretrained(checkpoint).to(device)

inputs = tokenizer.encode("def print_hello_world():", return_tensors="pt").to(device)
outputs = model.generate(inputs)
print(tokenizer.decode(outputs[0]))
  • 使用torch.bfloat16
# pip install accelerate
import torch
from transformers import AutoTokenizer, AutoModelForCausalLM

checkpoint = "bigcode/starcoder2-15b"
tokenizer = AutoTokenizer.from_pretrained(checkpoint)

# 对于fp16,使用`torch_dtype=torch.float16`
model = AutoModelForCausalLM.from_pretrained(checkpoint, device_map="auto", torch_dtype=torch.bfloat16)

inputs = tokenizer.encode("def print_hello_world():", return_tensors="pt").to("cuda")
outputs = model.generate(inputs)
print(tokenizer.decode(outputs[0]))
>>> print(f"内存占用:{model.get_memory_footprint() / 1e6:.2f} MB")
内存占用:32251.33 MB

通过bitsandbytes进行量化

  • 使用8位精度(int8)
# pip install bitsandbytes accelerate
from transformers import AutoTokenizer, AutoModelForCausalLM, BitsAndBytesConfig

# 使用4位,改用`load_in_4bit=True`
quantization_config = BitsAndBytesConfig(load_in_8bit=True)

checkpoint = "bigcode/starcoder2-15b_16k"
tokenizer = AutoTokenizer.from_pretrained(checkpoint)
model = AutoModelForCausalLM.from_pretrained("bigcode/starcoder2-15b_16k", quantization_config=quantization_config)

inputs = tokenizer.encode("def print_hello_world():", return_tensors="pt").to("cuda")
outputs = model.generate(inputs)
print(tokenizer.decode(outputs[0]))
>>> print(f"内存占用:{model.get_memory_footprint() / 1e6:.2f} MB")
# load_in_8bit
内存占用:16900.18 MB
# load_in_4bit
>>> print(f"内存占用:{model.get_memory_footprint() / 1e6:.2f} MB")
内存占用:9224.60 MB

你也可以使用pipeline进行生成:

from transformers import AutoModelForCausalLM, AutoTokenizer, pipeline
checkpoint = "bigcode/starcoder2-15b"

model = AutoModelForCausalLM.from_pretrained(checkpoint)
tokenizer = AutoTokenizer.from_pretrained(checkpoint)

pipe = pipeline("text-generation", model=model, tokenizer=tokenizer, device=0)
print( pipe("def hello():") )

文本生成推理:

docker run -p 8080:80 -v $PWD/data:/data -e HUGGING_FACE_HUB_TOKEN=<YOUR BIGCODE ENABLED TOKEN> -d  ghcr.io/huggingface/text-generation-inference:latest --model-id bigcode/starcoder2-15b --max-total-tokens 8192

更多详情,请参见此处

微调

这里我们展示如何微调StarCoder2模型。更多微调资源,你可以查看StarCoder的GitHub仓库SantaCoder-Finetuning

设置

安装pytorch参见文档,例如以下命令适用于cuda 12.1:

conda install pytorch torchvision torchaudio pytorch-cuda=12.1 -c pytorch -c nvidia

安装要求(这将从源代码安装transformers以支持StarCoder2架构):

pip install -r requirements.txt

在运行任何脚本之前,确保你已登录wandb和HuggingFace Hub以推送检查点:

wandb login
huggingface-cli login

现在一切就绪,你可以克隆仓库并进入相应目录。

训练

为了高效且低成本地微调,我们使用PEFT库进行低秩适应(LoRA)训练,并使用bitsandbytes进行4位量化。我们还使用了来自TRLSFTTrainer

在这个例子中,我们将在the-stack-smolRust子集上微调StarCoder2-3b。这只是为了说明目的;对于更大更干净的Rust代码数据集,你可以使用The Stack dedup

启动训练:

accelerate launch finetune.py \
        --model_id "bigcode/starcoder2-3b" \
        --dataset_name "bigcode/the-stack-smol" \
        --subset "data/rust" \
        --dataset_text_field "content" \
        --split "train" \
        --max_seq_length 1024 \
        --max_steps 10000 \
        --micro_batch_size 1 \
        --gradient_accumulation_steps 8 \
        --learning_rate 2e-5 \
        --warmup_steps 20 \
        --num_proc "$(nproc)"

如果你想在其他文本数据集上进行微调,需要将dataset_text_field参数更改为包含你想训练的代码/文本的列名。

评估

要评估StarCoder2及其衍生模型,你可以使用BigCode-Evaluation-Harness来评估代码LLM。你还可以查看BigCode排行榜

项目侧边栏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号