使用LLM-API开发应用-DataWhale笔记

news2024/11/14 13:43:40

调用API

先使用一个例子

from openai import OpenAI
​
client = OpenAI(
    # This is the default and can be omitted
    api_key=os.environ.get("OPENAI_API_KEY"), //这个在环境env中
)
​
completion = client.chat.completions.create(
    # 调用模型:ChatGPT-3.5
    model="gpt-3.5-turbo",
    # messages 是对话列表
    messages=[
        {"role": "system", "content": "You are a helpful assistant."},
        {"role": "user", "content": "Hello!"}
    ]
)

申请API key可以从OpenAI、文心一言、讯飞星火等网站获取,得到之后调用各自api并进行自定义prompt来提升模型回答效果。这里我使用的是OpenAI的API key,调用API可能会用到一些参数

  • · model,即调用的模型,一般取值包括“gpt-3.5-turbo”(ChatGPT-3.5)、“gpt-3.5-turbo-16k-0613”(ChatGPT-3.5 16K 版本)、“gpt-4”(ChatGPT-4)。

  • · messages,即我们的 prompt。ChatCompletion 的 messages 需要传入一个列表,列表中包括多个不同角色的 prompt。我们可以选择的角色一般包括

    • system:系统角色,通常用来设置对话的初始条件;

    • user:用户输入的 prompt;

    • assistant:助手,一般是模型历史回复,作为提供给模型的参考内容。

  • · temperature,即 Temperature 系数。控制输出的随机程度,温度系数越低,生成更加一致可控性的答案,若越高,则会产生更多样化的答案,适合创造性的任务例如故事生成;而低温度系数更适合问题回答。

  • · max_tokens,最大 token 数,即模型输出的最大 token 数。OpenAI 计算 token 数是合并计算 Prompt 和 Completion 的总 token 数,要求总 token 数不能超过模型上限(如默认模型 token 上限为 4096)。因此,如果输入的 prompt 较长,需要设置较大的 max_token 值,否则会报错超出限制长度。

Prompt Engineering

prompt(提示)就是用户与大模型交互输入的代称。即我们给大模型的输入称为 Prompt,而大模型返回的输出一般称为 Completion。

Prompt设计的原则

编写清晰、具体的指令

  • 使用分隔符清晰表示输入的不同部分,一般使用“”“

  • 使用结构化的输出

让模型自己思考

  • 指导模型在下结论前找出一个自己的解法并加以判断

    例如:

不过文档中给出的答案是错误的,可能是调用的gpt-3.5能力没那么强,还要加以引导才能判断,我自己测试的时候使用的是gpt-4,这种程度的prompt就已经让模型能够发现错误了,如下:

大模型”幻觉“

开发与应用语言模型时,需要注意它们可能生成虚假信息的风险,尽管大模型经过了大量大规模的预训练,掌握了丰富知识,但是实际上并没有完全记住所见的信息,难以判断自己的知识边界,如果让其描述一个不存在的产品,它可能会自行构建似是而非的细节,这被称为”幻觉“。

例如给出以下代码

prompt = f"""
给我一些研究LLM长度外推的论文,包括论文标题、主要内容和链接
"""
​
response = get_completion(prompt)
print(response)

大模型输出结果很可能是它自己瞎编的,虽然看起来很正确

1. 论文标题: "Extrapolating LLM Lengths: A Study on the Impact of Training Data Size"
主要内容: 该论文研究了在训练数据规模不断增加的情况下,LLM长度的外推效果。通过实验和数据分析,论文探讨了训练数据规模对LLM长度外推性能的影响,并提出了一些改进方法。
链接:https://arxiv.org/abs/2106.12345
​
2. 论文标题: "Analyzing the Extrapolation of LLM Lengths in Natural Language Understanding Tasks"
主要内容: 该论文分析了LLM长度在自然语言理解任务中的外推情况。通过实验和对比分析,论文探讨了不同任务对LLM长度外推的需求,以及如何优化LLM模型在不同长度下的性能。
链接:https://arxiv.org/abs/2110.67890
​
3. 论文标题: "Improving LLM Length Extrapolation through Data Augmentation Techniques"
主要内容: 该论文提出了一种通过数据增强技术来改进LLM长度外推的方法。通过在训练数据中引入多样性和噪声,论文探讨了如何提高LLM模型在不同长度下的泛化能力。
链接:https://arxiv.org/abs/2201.23456
​
希望以上论文能够帮助到您的研究工作。

不过我改用gpt-4进行测试,发现这个答案就变成

截至我的最后更新(2023年4月),关于LLM(语言模型)长度外推的研究还在不断发展之中。长度外推通常指的是模型处理比其在训练期间见过的更长的文本的能力。这在大型语言模型(如GPT系列)中尤其受到关注,因为它们在多种任务上展现出了卓越的性能,包括但不限于文本生成、翻译、摘要等。
​
虽然我无法提供实时的论文数据库,但我可以指出一些研究方向和可能的关键词,帮助你在学术数据库和预印本服务器(如arXiv)中找到相关论文:
​
### 关键词
- Length Extrapolation in Language Models
- Long Context in Language Models
- Text Generation Beyond Training Length
- Scaling Laws for Language Models
​
### 研究方向
1. **大型语言模型的长度外推能力**:研究大型语言模型(如GPT-3)处理超出其训练长度限制的文本的能力。
2. **长度外推对模型性能的影响**:分析当输入长度超过模型在训练期间见过的最大长度时,模型性能(如准确性、连贯性)的变化。
3. **改进模型的长度外推能力**:探索技术和方法来增强模型处理长文本的能力,例如通过改进模型架构、训练策略等。
​
### 查找论文
为了找到具体的论文,你可以访问以下资源:
- **arXiv** (https://arxiv.org/): 一个包含物理学、数学、计算机科学等领域预印本论文的数据库。
- **Google Scholar** (https://scholar.google.com/): 一个广泛的学术搜索引擎,可以用来搜索各个领域的学术论文。
- **ACL Anthology** (https://aclanthology.org/): 专注于计算语言学和自然语言处理领域的论文集合。
​
### 示例论文
虽然我不能直接提供最新论文的链接,但以下是一些可能与你的兴趣相关的论文标题示例(请注意,这些标题是根据你的要求构造的,可能并不存在):
- "Exploring the Limits of Length Extrapolation in Transformer-Based Language Models"
- "Beyond the Horizon: Length Extrapolation in Large-Scale Language Models"
- "Scaling Laws for Length Extrapolation in Neural Language Models"
​
请使用上述关键词和资源进行搜索,以找到最新和最相关的研究成果。

明显严谨程度上升,看来模型更强也更不容易出现”幻觉“的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1617304.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

科研基础与工具(论文写作)

免责申明: 本文内容只是学习笔记,不代表个人观点,希望各位看官自行甄别 参考文献 科研基础与工具(YouTube) 学术写作句型 Academic Phrase bank 曼彻斯特大学维护的一个网站 写论文的时候,不不知道怎么…

vue快速入门(四十一)组件通信-依赖注入

注释很详细&#xff0c;直接上代码 上一篇 新增内容 祖先组件向下传值子代组件接受数据 源码 App.vue <template><div id"app"><sonComponent></sonComponent></div> </template> <script> import sonComponent from &qu…

广东海洋大学成功部署(泰迪智能科技)大数据人工智能实验室建设

广东海洋大学简称广东海大&#xff0c;坐落于广东省湛江市&#xff0c;是国家海洋局与广东省人民政府共建的省属重点建设大学、广东省高水平大学重点学科建设高校、粤港澳高校联盟成员 &#xff0c;入选卓越农林人才教育培养计划&#xff0c;是教育部本科教学水平评估优秀院校。…

隋总分享的Temu蓝海项目究竟能不能做?

在当前的互联网经济大潮中&#xff0c;跨境电商作为一个新兴的商业模式&#xff0c;吸引了众多创业者和投资者的目光。其中&#xff0c;Temu作为拼多多旗下的跨境电商平台&#xff0c;凭借其独特的模式和强大的背景&#xff0c;成为了不少人心中的蓝海项目。近日&#xff0c;网…

java中线程的生命周期和线程安全

目录 生命周期 线程安全 生命周期 在Java中&#xff0c;线程的生命周期可以分为以下几个状态&#xff1a; 新建状态&#xff08;New&#xff09;&#xff1a; 当线程对象被创建后&#xff0c;它就处于新建状态。此时线程对象已经在内存中了&#xff0c;但是还没有开始执行。…

提升效率与质量:钣金加工行业设备数据采集的重要性

钣金加工作为制造业的重要一环&#xff0c;在现代工业中扮演着举足轻重的角色。随着市场竞争的日益激烈&#xff0c;钣金加工企业必须不断提升生产效率和产品质量&#xff0c;以应对市场的挑战。在这一背景下&#xff0c;设备数据采集变得尤为重要&#xff0c;因为它可以帮助企…

Dapp智能合约开发搭建

随着区块链技术的飞速发展&#xff0c;去中心化应用&#xff08;Dapp&#xff09;逐渐崭露头角&#xff0c;成为金融科技领域的一股新势力。而在Dapp中&#xff0c;智能合约发挥着不可或缺的作用。本文将从专业角度深入探讨Dapp智能合约的概念、优势、挑战以及未来发展趋势&…

Service: Amazon S3; Status Code: 403; Error Code: AccessDenied

1、使用minio报错 Access Denied. (Service: Amazon S3; Status Code: 403; Error Code: AccessDenied; Request ID: 17C8C89ED481E74E; S3 Extended Request ID: dd9025bab4ad464b049177c95eb6ebf374d3b3fd1af9251148b658df7ac2e3e8; Proxy: null) 2、将Access Policy值改为…

Bentley二次开发教程17-文件及模型管理-模拟输入调用命令

对于目前使用C#在Addin框架编程来说&#xff0c;对于某些方法可能封装的并不是十分完全&#xff0c;或者说目前的MicroStation软件中的原生功能可以完美的实现业务需求&#xff0c;但是需要对其进行参数化&#xff0c;自动化并进行重复工作&#xff0c;那么模拟输入调用命令的方…

Redis入门到通关之Redis实现Session共享

文章目录 ☃️前期概要☃️基于Session实现登录方案☃️现有方案存在的问题☃️Redis代替Session的业务流程❄️❄️设计key的结构❄️❄️设计key的具体细节❄️❄️整体访问流程 欢迎来到 请回答1024 的博客 &#x1f353;&#x1f353;&#x1f353;欢迎来到 请回答1024的博…

CSS基础:width,height尺寸属性详解

你好&#xff0c;我是云桃桃。 一个希望帮助更多朋友快速入门 WEB 前端的程序媛。云桃桃&#xff0c;大专生&#xff0c;一枚程序媛&#xff0c;感谢关注。回复 “前端基础题”&#xff0c;可免费获得前端基础 100 题汇总&#xff0c;回复 “前端工具”&#xff0c;可获取 Web…

C++中的stack(容器适配器)

目录 一、成员函数 一、构造函数 二、入栈 三、出栈 四、判空 empty () 五、栈大小 size 六、取栈顶元素 top 七、入栈 emplace 八、交换函数 swap 二、非成员函数重载 一、关系运算符重载 二、交换函数 C中的stack不再是容器&#xff0c;而是容器适配器 注意&a…

详解汽车充电桩主板的硬件设计与软件系统

随着电动汽车时代的到来&#xff0c;充电桩逐渐成为城市新地标。而在每一个充电桩的核心&#xff0c;隐藏着一颗强大的“心脏”——充电桩主板。 充电桩主板是充电桩的核心部件&#xff0c;决定着充电桩的充电效率、安全和用户体验。今天&#xff0c;我们将深入探索汽车充电桩主…

ubuntu18.04安装F4PGA教程

环境搭建教程&#xff1a; f4pga-arch-defs/xilinx/xc7 at main f4pga/f4pga-arch-defs GitHub git clone https://github.com/SymbiFlow/f4pga-arch-defs.git cd f4pga-arch-defs make env cd build 主要是make env&#xff0c;会下载很多东西&#xff0c;然后生成很多描…

账号安全基本措施2

sudo命令 sudo(superuser do)&#xff0c;允许系统管理员让普通用户执行一些或者全部的root命令的一个工具。 其配置在/etc/sudoers权。它允许系统管理员集中的管理用户的使用权限和使用的主机。属性必须为0440。 语法检查&#xff1a; 检查语法&#xff1a; 修改文件时&…

Mysql学习一

目录 1.启动数据库&#xff1a; 2.命令行连接到MySQL&#xff08;winr输入cmd&#xff09; 3.MySQL的三重结构&#xff1a; 4.SQL语句分类&#xff1a; 1.启动数据库&#xff1a; winr——输入services.msc进入本地服务 2.命令行连接到MySQL&#xff08;winr输入cmd&#x…

【Linux】学习记录_14_线程

14 线程 14.1 线程和进程 进程是资源管理的最小单位&#xff0c;每个进程都有数据段、代码段和堆栈段&#xff0c;进程切换时都有复杂的上下文切换等动作。进程切换上下文时&#xff0c; 需要重新映射虚拟地址空间、进出OS内核、寄存器切换&#xff0c;还会干扰处理器的缓存机…

关于agi中的Function Calling深入解析

接口(Interface) 两种常见接口&#xff1a; 1、人机交互接口&#xff0c;User Interface,简称UI 2、应用程序编程接口&#xff0c;Application Programming Interface,简称API 接口能【通】的关键&#xff0c;是两边都要遵守约定。 人要按照UI的设计来操作。UI的设计要符合…

easyexcel升级3.3.4失败的经历

原本想通过easyexcel从2.2.6升级到3.3.3解决一部分问题&#xff0c;结果之前的可以用的代码&#xff0c;却无端的出现bug 1 Sheet index (1) is out of range (0…0) 什么都没有改&#xff0c;就出了问题&#xff0c;那么问题肯定出现在easyexcel版本自身.使用模板填充的方式进…

从构成看自来水厂自动化控制系统的创新与发展

自来水厂自动化控制系统涵盖了多个关键组成部分&#xff0c;包括水管理云平台、供水监控系统以及供水调度平台。 系统内嵌了一系列自主创新的核心算法&#xff0c;这些算法结合了数学建模、机器仿真和流体力学等多元数据模型&#xff0c;以优化设备间的关联和控制关系&#xf…