当前位置: 首页 > news >正文

【大模型实践】基于文心一言的对话模型设计

文心一言(英文名:ERNIE Bot)是百度全新一代知识增强大语言模型,文心大模型家族的新成员,能够与人对话互动、回答问题、协助创作,高效便捷地帮助人们获取信息、知识和灵感。文心一言从数万亿数据和数千亿知识中融合学习,得到预训练大模型,在此基础上采用有监督精调、人类反馈强化学习、提示等技术,具备知识增强、检索增强和对话增强的技术优势。

本文使用gradio开发一个简单的对话页面,使用的大模型是文心一言。

一、获取token

百度的aistudio平台提供免费的文心一言调用token,每个用户100W个,点击token:

在我的令牌可以看到token:

后续会用到该token,请将代码中的token更换成自己的token。

二、编写代码

创建文件erniebot_test.py,代码如下,请将erniebot.access_token替换为自己的token:

import gradio as gr
import random
import time
import osimport erniebot 
import gradio as grdef predict(content, his):if len(his)>0 and isinstance(his[0], list):his = his[0]erniebot.api_type = "aistudio"erniebot.access_token ="xxx"     # 替换为自己的tokenmessage = []for idx, msg in enumerate(his):if idx % 2 == 0:message.append({'role': 'user','content': msg,})else:message.append({'role': 'assistant','content': msg,})message.append({'role': 'user','content': content,})response = erniebot.ChatCompletion.create(model="ernie-bot", messages=message)return response.resultwith gr.Blocks() as demo:chatbot = gr.Chatbot()msg = gr.Textbox()clear = gr.ClearButton([msg, chatbot])def respond(message, chat_history):bot_message = predict(message, chat_history)chat_history.append((message, bot_message))return "", chat_historymsg.submit(respond, [msg, chatbot], [msg, chatbot])if __name__ == "__main__":demo.launch(inbrowser=True, server_port=80, share=True, server_name="0.0.0.0")

三、创建环境

您可以参考【深度学习实践】换脸应用dofaker本地部署中的anaconda安装教程完成anaconda的安装。

创建虚拟环境erniebot_test :

conda create -n erniebot_test python=3.10

如下图,提示输入Y/N时输入y:

进入该虚拟环境:

conda activate erniebot_test

如下图:

安装依赖:

pip install -U erniebot -i https://mirrors.aliyun.com/pypi/simple/
pip install -U gradio -i https://mirrors.aliyun.com/pypi/simple/

运行代码:

python erniebot_test.py

如下图:

浏览器打开127.0.0.1即可:

在下方的文本框输入,按回车开启对话:

http://www.lryc.cn/news/269149.html

相关文章:

  • 聊聊PowerJob的StoreStrategy
  • HTML+CSS+JS网页设计期末课程大作业 web课程设计 web前端开发 网页规划与设计
  • vscode | python | remote-SSH | Debug 配置 + CLIP4Clip实验记录
  • 【Linux】实现windows主机与ubuntu虚拟机系统之间文件/字符复制粘贴
  • Ubuntu22.04-安装后Terminal无法调出
  • ffmpeg两种windows版本区别说明
  • 最新国内AI绘画Midjourney绘画提示词Prompt分享
  • ChatGPT4.0(中文版)国内无限制免费版(附网址)
  • 模拟电路基础知识笔记,你想知道的都有,建议收藏!
  • 【强化学习】基于蒙特卡洛MC与时序差分TD的简易21点游戏应用
  • Pandas 高级教程——高级时间序列分析
  • 解决Pycharm pip安装模块太慢问题,pycharm2022没有manage repositories配置镜像源
  • 十二:爬虫-Scrapy框架(上)
  • BUUCTF Reverse/[2019红帽杯]Snake
  • 概率论相关题型
  • C#中的Attribute详解(上)
  • 天津医科大学临床医学院专升本药学专业有机化学考试大纲
  • 电脑开机自动断电,简单4招,快速解决!
  • 线程基础知识(三)
  • elasticsearch系列七:聚合查询
  • SQL面试题挑战11:访问会话切割
  • 2023“楚怡杯”湖南省赛“信息安全管理与评估“--应急响应(高职组)
  • 【Python百宝箱】Python引领制造变革:CAM技术全景解析与实战指南
  • 【新版Hi3559AV100 旗舰8K30 AI摄像机芯片】
  • 小样本学习idea(不断更新)
  • 表情包搜索网站
  • Linux账号和权限管理
  • Qt/QML编程学习之心得:QML和C++的相互调用(十五)
  • 月入10.5K,专科小伙转行网优:据说每个领域都有一个“显眼包”
  • Python自动化测试:选择最佳的自动化测试框架