使用 Scikit-LLM 进行零样本和少样本分类

使用 Scikit-LLM 进行零样本和少样本分类

使用 Scikit-LLM 进行零样本和少样本分类

在本文中,您将学习:

  • Scikit-LLM如何将OpenAI的GPT等大型语言模型与Scikit-learn框架集成以进行文本分析。
  • 零样本和少样本分类之间的区别以及如何使用Scikit-LLM实现它们。
  • 一个指南,介绍如何配置 Scikit-LLM 并使用 OpenAI API 密钥,以及如何将其应用于一个示例文本分类任务。

介绍

Scikit-LLM 是一个旨在将大型语言模型(LLMs)如 OpenAI 的 GPT-3.5 和 GPT-4 与 Scikit-learn 机器学习框架集成的 Python 库。它提供了一个简单的接口,可以使用自然语言提示将 LLM 作为零样本或少样本分类器使用,使其非常适合下游文本分析任务,如分类、情感分析和主题标记。

本文重点介绍 Scikit-LLM的零样本和少样本分类能力,并展示了如何将其与Scikit-learn工作流程结合以完成这些任务。

在我们开始操作之前,让我们先弄清楚零样本分类和少样本分类之间的区别。

  1. 零样本分类: LLM类在没有来自数据集的任何先验标记示例的情况下对文本进行分类;它仅根据可能的类别标签进行提示。
  2. 少样本分类: 在提示中提供了一小组带标签的示例------通常是每个可能类别几组示例------以引导LLM的推理符合所请求的分类。

逐步过程

是时候尝试这两个使用案例了,主角是我们的文章中介绍的库:Scikit-LLM。我们首先安装它:

复制代码
!pip install scikit-llm

我们现在需要导入以下两个类:

复制代码
from skllm.config import SKLLMConfig
from skllm import ZeroShotGPTClassifier

由于使用OpenAI的模型需要一个API密钥,我们将需要进行配置。如果需要,请访问并注册 OpenAI平台 以创建一个新的API密钥。请注意,如果您没有付费计划,您在下面示例中使用模型的选项可能会有限制。

复制代码
SKLLMConfig.set_openai_key("API_KEY_GOES_HERE")

让我们考虑这个小型示例数据集,包含一些用户评论及其相关的感情标签:

复制代码
X = [
    "I love this product! It works great and exceeded my expectations.",
    "This is the worst service I have ever received.",
    "The movie was okay, not bad but not great either.",
    "Excellent customer support and very quick response.",
    "I am disappointed with the quality of this item."
]

y = [
    "positive",
    "negative",
    "neutral",
    "positive",
    "negative"
]

我们创建一个零样本分类器的实例如下:

复制代码
clf = ZeroShotGPTClassifier()

正如其名字所示,Scikit-LLM 强烈依赖于 Scikit-learn。因此,如果您对 Scikit-learn 生态系统有经验,那么训练和评估模型的过程将非常熟悉:

复制代码
clf.fit(X, y)
labels = clf.predict(X)

print(labels)

但是这里正是零样本分类真正发挥作用的地方:不需要训练数据。分类器可以仅使用可能的标签进行"拟合"。换句话说,可以做到类似这样的事情:

复制代码
clf_empty = ZeroShotGPTClassifier()
clf_empty.fit(None, ["positive", "negative", "neutral"])
labels = clf_empty.predict(X)

这仍然有效!这是真正的零样本分类的本质。

关于少样本分类 ,这个过程非常类似于我们提供训练数据的第一个零样本分类示例。事实上,fit()该方法是将少量标记示例传递给模型的正确方法。

复制代码
from skllm import FewShotGPTClassifier

clf = FewShotGPTClassifier()

# Fit uses few-shot examples to build part of the prompt
clf.fit(X, y)

test_samples = [
    "The new update is fantastic and really smooth.",
    "I'm not happy with the experience at all.",
    "Meh, it was neither exciting nor terrible."
]

predictions = clf.predict(test_samples)
print(predictions)

这听起来可能有些奇怪,但在少样本分类的特定使用案例中,fit()predict() 方法都是推理过程的一部分。fit() 提供了 prompt 的标记示例,而 predict() 提供了要分类的新文本。它们一起构成了发送到 LLM 的完整 prompt。

总结

本文展示了使用新发布的Scikit-llm 库的两种文本分类用例:零样本和少样本分类。使用类似于Scikit-learn的方法,这两种技术在利用示例数据进行推理的提示策略上略有不同。

零样本 分类不需要带标签的示例,并且仅依赖于加载的模型的普遍理解来分配标签。同时,少样本 分类将一小组带标签的示例纳入提示中,以更准确地引导模型的推理。

相关推荐
colfree4 分钟前
Scanpy
人工智能·机器学习
Akamai中国34 分钟前
基准测试:Akamai云上的NVIDIA RTX Pro 6000 Blackwell
人工智能·云计算·云服务·云存储
雨大王51240 分钟前
汽车AI智能体矩阵:驱动行业智能化变革的新范式
人工智能·汽车
SmartRadio1 小时前
在CH585M代码中如何精细化配置PMU(电源管理单元)和RAM保留
linux·c语言·开发语言·人工智能·单片机·嵌入式硬件·lora
旦莫1 小时前
Pytest教程:Pytest与主流测试框架对比
人工智能·python·pytest
●VON1 小时前
从模型到价值:MLOps 工程体系全景解析
人工智能·学习·制造·von
智慧地球(AI·Earth)1 小时前
Codex配置问题解析:wire_api格式不匹配导致的“Reconnecting...”循环
开发语言·人工智能·vscode·codex·claude code
GISer_Jing1 小时前
AI:多智能体协作与记忆管理
人工智能·设计模式·aigc
qq_411262422 小时前
纯图像传感器(只出像素),还是 Himax WiseEye/WE1/WE-I Plus 这类带处理器、能在端侧跑模型并输出“metadata”的模块
人工智能·嵌入式硬件·esp32·四博智联