跳到主要内容

在 Hugging Face 使用 PEFT

🤗 参数高效微调 (PEFT) 是一个库,用于高效地将预训练语言模型适配到各种下游应用,而无需微调模型的所有参数。

在 Hub 上探索 PEFT

你可以通过在模型页面左侧筛选来找到 PEFT 模型。

安装

要开始使用,你可以查看 PEFT 文档中的快速入门。要安装,请遵循 PEFT 安装指南。 你也可以通过 pip 使用以下一行安装:

$ pip install peft

使用现有模型

所有 PEFT 模型都可以从 Hub 加载。要使用 PEFT 模型,你还需要加载被微调的基础模型,如下所示。每个微调模型在其模型卡片中都有基础模型。

from transformers import AutoModelForCausalLM, AutoTokenizer
from peft import PeftModel, PeftConfig

base_model = "mistralai/Mistral-7B-v0.1"
adapter_model = "dfurman/Mistral-7B-Instruct-v0.2"

model = AutoModelForCausalLM.from_pretrained(base_model)
model = PeftModel.from_pretrained(model, adapter_model)
tokenizer = AutoTokenizer.from_pretrained(base_model)

model = model.to("cuda")
model.eval()

加载后,你可以将输入传递给分词器进行准备,并以常规 transformers 方式调用 model.generate()

inputs = tokenizer("Tell me the recipe for chocolate chip cookie", return_tensors="pt")

with torch.no_grad():
outputs = model.generate(input_ids=inputs["input_ids"].to("cuda"), max_new_tokens=10)
print(tokenizer.batch_decode(outputs.detach().cpu().numpy(), skip_special_tokens=True)[0])

它输出以下内容:

Tell me the recipe for chocolate chip cookie dough.

1. Preheat oven to 375 degrees F (190 degrees C).
2. In a large bowl, cream together 1/2 cup (1 stick) of butter or margarine, 1/2 cup granulated sugar, and 1/2 cup packed brown sugar.
3. Beat in 1 egg and 1 teaspoon vanilla extract.
4. Mix in 1 1/4 cups all-purpose flour.
5. Stir in 1/2 teaspoon baking soda and 1/2 teaspoon salt.
6. Fold in 3/4 cup semisweet chocolate chips.
7. Drop by

如果你想加载特定的 PEFT 模型,可以在模型卡片中点击 Use in PEFT,你将获得一个可用的代码片段!

在 PEFT 中使用模型在 PEFT 中使用模型
在 PEFT 中使用模型在 PEFT 中使用模型

其他资源