码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 大模型应用--prompt工程实践


    在使用大模型进行prompt 训练时,自己做的相关笔记。

    本文以openai<1.0版为例。

    1.调用大模型

    定义调用openai大模型的函数 get_completion()

    1. def get_completion(prompt, model="gpt-3.5-turbo"):
    2. messages = [{"role": "user", "content": prompt}]
    3. response = openai.ChatCompletion.create(
    4. model=model,
    5. messages=messages,
    6. temperature=0, # 模型输出的随机性,0 表示随机性最小
    7. )
    8. print(response)
    9. return response.choices[0].message["content"]

    在openai.ChatCompletion.create函数中,还有以下这些参数:

    1. response = openai.ChatCompletion.create(
    2. model=model,
    3. messages=_session,
    4. # 以下默认值都是官方默认值
    5. temperature=1, # 生成结果的多样性 0~2之间,越大越随机,越小越固定
    6. stream=False, # 数据流模式,一个个字接收
    7. top_p=1, # 随机采样时,只考虑概率前百分之多少的 token。不建议和 temperature 一起使用
    8. n=1, # 一次生成 n 条结果
    9. max_tokens=100, # 每条结果最多多少个 token(超过截断)
    10. presence_penalty=0, # 对出现过的 token 的概率进行降权
    11. frequency_penalty=0, # 对出现过的 token 根据其出现过的频次,对其的概率进行降权
    12. logit_bias={}, # 对指定 token 的采样概率手工加/降权,不常用
    13. )

    2.定义prompt

    下面就开始写prompt中的内容,prompt中的内容通常包含:

    1. • 角色: 定义一个最匹配任务的角色。
    2. • 指示{instruction}:对任务进行描述
    3. • 上下文{context}: 给出与任务相关的其它背景信息 (尤其在多轮交互中)
    4. • 例子{example}: 必要时给出举例
    5. • 输入{input_text}:任务的输入信息;在提示词中明确的标识出输入
    6. • 输出{output_format}: 输出的格式描述,比如 (JSON、XML)

    对于以上的内容都可以在propmt中定义。

    然后,把各个部分都写到propmt中即可,

    1. prompt = f"""
    2. {instruction}
    3. {output_format}
    4. {context}
    5. {example}
    6. # 用户输入
    7. {input_text}
    8. """

    有很多的方法可以调优

    在实际应用的过程中,对于prompt的训练还有很多的方法,需要一点一点实践。

    下面的链接是官方给的prompt教程,一起学起来吧!!!🥝🥝🥝

    Prompt Engineering Guide | Learn Prompting: Your Guide to Communicating with AI

    我是大模型的初学者,慢慢完善,欢迎大佬指点一二,欢迎同学一起学习。🍭🍭🍭

  • 相关阅读:
    Shiro权限控制
    【疑难】使用ARM development studio仿真 error:Failed to create Jython interpreter
    别再用 System.currentTimeMillis 统计耗时了,太 Low,试试 Spring Boot 源码在用的 StopWatch吧,够优雅!
    一个奇葩的线上问题,导致我排查了一天!
    Java实现发送Get、Post请求仅需两步
    【LeetCode】242. 有效的字母异位词 - hashmap
    皮质-皮质网络的多尺度交流
    SpringBoot+Vue+Element-UI实现家具商城系统
    python functools.wraps保留被装饰函数属性
    (附源码)Springboot美食教程小程序的设计与实现 毕业设计190900
  • 原文地址:https://blog.csdn.net/weixin_44323744/article/details/134363742
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号