`transformers`库是Hugging Face提供的一个开源库,它包含了大量的预训练模型和方便的API,用于自然语言处理(NLP)任务。在文本生成任务中,`transformers`库提供了许多预训练的生成模型,如GPT系列、T5、BART等。这些模型可以通过`pipeline()`函数方便地加载和使用,而`generate()`函数则是用于生成文本的核心函数。

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
性能测试 PTS,5000VUM额度
函数计算FC,每月15万CU 3个月
简介: `transformers`库是Hugging Face提供的一个开源库,它包含了大量的预训练模型和方便的API,用于自然语言处理(NLP)任务。在文本生成任务中,`transformers`库提供了许多预训练的生成模型,如GPT系列、T5、BART等。这些模型可以通过`pipeline()`函数方便地加载和使用,而`generate()`函数则是用于生成文本的核心函数。

一、引言

transformers库是Hugging Face提供的一个开源库,它包含了大量的预训练模型和方便的API,用于自然语言处理(NLP)任务。在文本生成任务中,transformers库提供了许多预训练的生成模型,如GPT系列、T5、BART等。这些模型可以通过pipeline()函数方便地加载和使用,而generate()函数则是用于生成文本的核心函数。

二、pipeline()函数的使用

pipeline()函数是transformers库中一个非常重要的函数,它允许用户通过简单的API调用加载和使用预训练的模型。对于文本生成任务,我们可以使用text-generation类型的pipeline。

示例代码

from transformers import pipeline

# 加载预训练的文本生成模型
generator = pipeline("text-generation", model="gpt2-medium")

# 使用模型生成文本
prompt = "In a world where machines can think, "
output = generator(prompt, max_length=50, num_return_sequences=1)

print(output[0]['generated_text'])

代码解释

  1. 导入必要的库:首先,我们导入了transformers库中的pipeline函数。
  2. 加载预训练的文本生成模型:通过调用pipeline()函数并传入"text-generation"作为参数,我们告诉库我们想要加载一个文本生成模型。然后,我们指定了模型的名称"gpt2-medium",这是Hugging Face Model Hub上的一个预训练模型。库会自动下载并加载这个模型。
  3. 使用模型生成文本:加载完模型后,我们可以使用它来生成文本。我们传入一个提示(prompt)作为输入,然后指定一些参数来控制生成的文本。在这个例子中,我们指定了max_length=50来限制生成的文本长度,以及num_return_sequences=1来指定只返回一条生成的文本。最后,我们打印出生成的文本。

三、generate()函数的使用

虽然pipeline()函数提供了方便的API来加载和使用模型,但在某些情况下,我们可能想要更直接地控制模型的生成过程。这时,我们可以使用模型的generate()函数。

示例代码

from transformers import GPT2LMHeadModel, GPT2Tokenizer
import torch

# 加载预训练的模型和分词器
model = GPT2LMHeadModel.from_pretrained("gpt2-medium")
tokenizer = GPT2Tokenizer.from_pretrained("gpt2-medium")

# 准备输入
prompt = "In a world where machines can think, "
input_ids = tokenizer.encode(prompt, return_tensors="pt")

# 使用模型生成文本
output = model.generate(input_ids, max_length=50, num_beams=1, no_repeat_ngram_size=2, early_stopping=True)

# 将生成的ID转换为文本
generated_text = tokenizer.decode(output[0], skip_special_tokens=True)

print(generated_text)

代码解释

  1. 导入必要的库和模型:首先,我们导入了GPT2LMHeadModelGPT2Tokenizer类,以及PyTorch库。这些类分别用于加载GPT-2模型和对应的分词器。
  2. 加载预训练的模型和分词器:我们使用from_pretrained()函数加载了预训练的GPT-2模型和分词器。这些资源会自动从Hugging Face Model Hub下载。
  3. 准备输入:我们将提示(prompt)文本编码为模型可以理解的输入ID。这是通过调用分词器的encode()函数完成的。我们还指定了return_tensors="pt"来返回PyTorch张量。
  4. 使用模型生成文本:然后,我们调用模型的generate()函数来生成文本。这个函数接受输入ID作为输入,并返回生成的文本ID。我们指定了一些参数来控制生成的文本,如max_lengthnum_beams(用于beam search的beam数量)、no_repeat_ngram_size(用于避免重复n-gram的n值)和early_stopping(是否提前停止生成)。
  5. 将生成的ID转换为文本:最后,我们将生成的ID解码为文本。这是通过调用分词器的decode()函数完成的。我们还指定了skip_special_tokens=True来跳过特殊标记(如[PAD]、[UNK]
    处理结果:

    一、引言

    transformers库是Hugging Face提供的一个开源库,它包含了大量的预训练模型和方便的API,用于自然语言处理(NLP)任务。在文本生成任务中,transformers库提供了许多预训练的生成模型,如GPT系列、T5、BART等。这些模型可以通过pipeline()函数方便地加载和使用,而generate()函数则是用于生成文本的核心函数。

    二、pipeline()函数的使用

    pipeline()函数是transformers库中一个非常重要的函数,它允许用户通过简单的API调用加载和使用预训练的模型。对于文本生成任务,我们可以使用text-generation类型的pipeline。

    示例代码

    ```python

    加载预训练的文本生成模型

    使用模型生成文本

    print(output[0]['generated_text'])
  6. 导入必要的库:首先,我们导入了transformers库中的pipeline函数。
    加载预训练的文本生成模型:通过调用pipeline()函数并传入"text-generation"作为参数,我们告诉库我们想要加载一个文本生成模型。然后,我们指定了模型的名称"gpt2-medium",这是Hugging Face Model Hub上的一个预训练模型。库会自动下载并加载这个模型。
    使用模型生成文本:加载完模型后,我们可以使用它来生成文本。我们传入一个提示(prompt)作为输入,然后指定一些参数来控制生成的文本。在这个例子中,我们指定了max_length=50来限制生成的文本长度,以及num_return_sequences=1来指定只返回一条生成的文本。最后,我们打印出生成的文本。

    三、generate()函数的使用

    虽然pipeline()函数提供了方便的API来加载和使用模型,但在某些情况下,我们可能想要更直接地控制模型的生成过程。这时,我们可以使用模型的generate()函数。

    示例代码

    ```python

    加载预训练的模型和分词器

    准备输入

    使用模型生成文本

    将生成的ID转换为文本

    print(generated_text)
  7. 导入必要的库和模型:首先,我们导入了GPT2LMHeadModelGPT2Tokenizer类,以及PyTorch库。这些类分别用于加载GPT-2模型和对应的分词器。
    加载预训练的模型和分词器:我们使用from_pretrained()函数加载了预训练的GPT-2模型和分词器。这些资源会自动从Hugging Face Model Hub下载。
    准备输入:我们将提示(prompt)文本编码为模型可以理解的输入ID。这是通过调用分词器的encode()函数完成的。我们还指定了return_tensors="pt"来返回PyTorch张量。
    使用模型生成文本:然后,我们调用模型的generate()函数来生成文本。这个函数接受输入ID作为输入,并返回生成的文本ID。我们指定了一些参数来控制生成的文本,如max_lengthnum_beams(用于beam search的beam数量)、no_repeat_ngram_size(用于避免重复n-gram的n值)和early_stopping(是否提前停止生成)。
    将生成的ID转换为文本:最后,我们将生成的ID解码为文本。这是通过调用分词器的decode()函数完成的。我们还指定了skip_special_tokens=True来跳过特殊标记(如[PAD]、[UNK]
相关文章
|
2天前
|
机器学习/深度学习 人工智能 自然语言处理
通古大模型:古籍研究者狂喜!华南理工开源文言文GPT:AI自动断句+写诗翻译,24亿语料喂出来的学术神器
通古大模型由华南理工大学开发,专注于古籍文言文处理,具备强大的古文句读、文白翻译和诗词创作功能。
48 11
通古大模型:古籍研究者狂喜!华南理工开源文言文GPT:AI自动断句+写诗翻译,24亿语料喂出来的学术神器
|
1月前
|
人工智能 前端开发 API
Gemini Coder:基于 Google Gemini API 的开源 Web 应用生成工具,支持实时编辑和预览
Gemini Coder 是一款基于 Google Gemini API 的 AI 应用生成工具,支持通过文本描述快速生成代码,并提供实时代码编辑和预览功能,简化开发流程。
143 38
Gemini Coder:基于 Google Gemini API 的开源 Web 应用生成工具,支持实时编辑和预览
|
4月前
|
数据采集 API 决策智能
华为诺亚联合中科大发布工具调用模型ToolACE,效果持平GPT-4获开源第一
 【10月更文挑战第10天】华为诺亚方舟实验室与中国科学技术大学合作推出ToolACE,一种自进化合成过程的工具调用模型。ToolACE通过多智能体交互和双重验证系统生成准确、复杂、多样化的工具学习数据,显著提升大型语言模型(LLM)的功能调用能力。实验结果显示,使用ToolACE数据训练的80亿参数模型性能媲美GPT-4,在伯克利功能调用排行榜上获得开源第一。
132 4
|
1月前
|
人工智能 Python
JoyCaption:开源的图像转提示词生成工具,支持多种风格和场景,性能与 GPT4o 相当
JoyCaption 是一款开源的图像提示词生成工具,支持多种生成模式和灵活的提示选项,适用于社交媒体、图像标注、内容创作等场景,帮助用户快速生成高质量图像描述。
183 21
JoyCaption:开源的图像转提示词生成工具,支持多种风格和场景,性能与 GPT4o 相当
|
1月前
|
人工智能 语音技术 iOS开发
MiniCPM-o 2.6:面壁智能开源多模态大模型,仅8B参数量就能媲美GPT-4o,支持实时交互,在ipad等终端设备上运行
MiniCPM-o 2.6 是面壁智能开源的多模态大模型,支持视觉、语音和多模态直播,性能媲美GPT-4o,能够在端侧设备上高效运行。
331 10
MiniCPM-o 2.6:面壁智能开源多模态大模型,仅8B参数量就能媲美GPT-4o,支持实时交互,在ipad等终端设备上运行
|
28天前
|
人工智能 自然语言处理 API
百聆:集成Deepseek API及语音技术的开源AI语音对话助手,实时交互延迟低至800ms
百聆是一款开源的AI语音对话助手,结合ASR、VAD、LLM和TTS技术,提供低延迟、高质量的语音对话体验,适用于边缘设备和低资源环境。
679 4
百聆:集成Deepseek API及语音技术的开源AI语音对话助手,实时交互延迟低至800ms
|
1月前
|
人工智能 JSON 安全
DeepSeek Engineer:集成 DeepSeek API 的开源 AI 编程助手,支持文件读取、编辑并生成结构化响应
DeepSeek Engineer 是一款开源AI编程助手,通过命令行界面处理用户对话并生成结构化JSON,支持文件操作和代码生成。
768 6
DeepSeek Engineer:集成 DeepSeek API 的开源 AI 编程助手,支持文件读取、编辑并生成结构化响应
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
MetaGPT开源自动生成智能体工作流,4.55%成本超GPT-4o
AFlow是由Jiayi Zhang等学者提出的一项新研究,发表于arXiv。它通过将工作流优化问题转化为代码表示空间中的搜索,并引入蒙特卡洛树搜索(MCTS)算法,实现了高效的工作流自动化生成与优化。在六个基准数据集上,AFlow性能比现有基线平均提高5.7%,并使小模型以较低成本超越GPT-4。尽管存在一些局限性,如通用性和计算复杂度,AFlow为降低大型语言模型应用成本提供了新思路,推动了人工智能技术的进步。论文地址:https://arxiv.org/abs/2410.10762。
84 27
|
2月前
|
存储 人工智能 API
AgentScope:阿里开源多智能体低代码开发平台,支持一键导出源码、多种模型API和本地模型部署
AgentScope是阿里巴巴集团开源的多智能体开发平台,旨在帮助开发者轻松构建和部署多智能体应用。该平台提供分布式支持,内置多种模型API和本地模型部署选项,支持多模态数据处理。
400 4
AgentScope:阿里开源多智能体低代码开发平台,支持一键导出源码、多种模型API和本地模型部署
|
2月前
|
数据采集 人工智能 数据可视化
InternVL 2.5,首个MMMU超过70%的开源模型,性能媲美GPT-4o
近期Internvl2.5发布,性能与GPT-4o和Claude-3.5-sonnet等领先的商业模型相媲美,成为首个在MMMU上超过70%的开源模型,通过链式思考(CoT)推理实现了3.7个百分点的提升,展示了强大的测试时间可扩展性潜力。