0

0

如何使用一个 API 创建 AI 聊天机器人来访问多个 LLM

王林

王林

发布时间:2024-08-24 09:15:18

|

1031人浏览过

|

来源于dev.to

转载

最初由 liz acosta 发表在 streamlit 博客上

还记得第一次使用人工智能图像生成器有多酷吗?那两千万根手指和噩梦般的吃意大利面的画面不仅仅是有趣,它们在不经意间透露了哎呀!人工智能模型的智能程度与我们一样。和我们一样,他们也很难画手。

如何使用一个 API 创建 AI 聊天机器人来访问多个 LLM

人工智能模型很快变得更加复杂,但现在的模型数量太多了。而且,和我们一样,他们中的一些人比其他人更擅长某些任务。以文本生成为例。尽管 llama、gemma 和 mistral 都是法学硕士,但他们中的一些人更擅长生成代码,而另一些人则更擅长头脑风暴、编码或创意写作。根据提示,它们提供不同的优势,因此在您的 ai 应用程序中包含多个模型可能是有意义的。

但是如何将所有这些模型集成到你的应用程序中而不需要重复代码?如何使人工智能的使用更加模块化,从而更易于维护和扩展?这就是 api 可以提供用于跨不同技术进行通信的标准化指令集的地方。

在这篇博文中,我们将了解如何使用 replicate 和 streamlit 来创建一个应用程序,该应用程序允许您通过单个 api 调用来配置和提示不同的 llm。别担心——当我说“应用程序”时,我并不是说必须启动整个 flask 服务器或繁琐地配置你的路由或担心 css。 streamlit 已经为您解决了这个问题 ?

继续阅读以学习:

  • 什么是复制
  • streamlit 是什么
  • 如何构建演示复制聊天机器人 streamlit 应用程序
  • 以及使用 replicate 的最佳实践

不想读书?以下是探索此演示的一些其他方法:

  • 在此处的 streamlit cookbook 存储库中查找代码
  • 在此处尝试应用程序的部署版本
  • 在此处观看 replicate 创始设计师 zeke sikelianos 的视频演练

什么是复制?

replicate 是一个平台,使开发人员能够通过 cli、api 或 sdk 部署、微调和访问开源 ai 模型。该平台可以轻松地以编程方式将人工智能功能集成到软件应用程序中。

replicate 上的可用模型

  • 文本:像 llama 3 这样的模型可以根据输入提示生成连贯且上下文相关的文本。
  • 图像:像稳定扩散这样的模型可以根据文本提示生成高质量的图像。
  • 语音:像 whisper 这样的模型可以将语音转换为文本,而像 xtts-v2 这样的模型可以生成听起来自然的语音。
  • 视频:像 animate-diff 这样的模型或像 videocrafter 这样的稳定​​扩散的变体可以分别根据文本和图像提示生成和/或编辑视频。

当一起使用时,replicate 允许您开发多模式应用程序,这些应用程序可以接受输入并生成各种格式的输出,无论是文本、图像、语音还是视频。

什么是 streamlit?

streamlit 是一个开源 python 框架,只需几行代码即可构建高度交互的应用程序。 streamlit 与生成式 ai 中的所有最新工具集成,例如任何 llm、矢量数据库或各种 ai 框架(如 langchain、llamaindex 或 weights & biases)。 streamlit 的聊天元素使与 ai 交互变得特别容易,因此您可以构建“与您的数据对话”的聊天机器人。

与 replicate 这样的平台相结合,streamlit 允许您创建生成式 ai 应用程序,而无需任何应用程序设计开销。

? 要了解有关 streamlit 如何让您取得进步的更多信息,请查看这篇博文。

要了解有关 streamlit 的更多信息,请查看 101 指南。

尝试应用程序配方:复制 + streamlit

但不要相信我的话。亲自尝试该应用程序或观看视频演示,看看您的想法。

在此演示中,您将使用 replicate 启动 streamlit 聊天机器人应用程序。该应用程序使用单个 api 来访问三个不同的 llm 并调整温度和 top-p 等参数。这些参数影响人工智能生成文本的随机性和多样性,以及选择标记的方法。

? 什么是模型温度? 温度控制模型如何选择令牌。较低的温度使模型更加保守,有利于常见和“安全”的词语。相反,较高的温度会鼓励模型通过选择可能性较小的令牌来承担更多风险,从而产生更多创意输出。

? 什么是top-p? 也称为“核采样”——是另一种调整随机性的方法。随着 top-p 值的增加,它的工作原理是考虑更广泛的代币集。较高的 top-p 值会导致采样的代币范围更加多样化,从而产生更加多样化的输出。

先决条件

  • python 版本 >=3.8, !=3.9.7
  • 复制 api 密钥 (请注意,需要使用付款方式才能访问超出免费试用限制的功能。)

? 要了解有关 api 密钥的更多信息,请查看此处的博客文章。

环境设置

本地设置

  1. 克隆 cookbook 存储库:git clone https://github.com/streamlit/cookbook.git
  2. 从cookbook根目录,将目录更改为复制配方:cdrecipes/replicate
  3. 将您的复制 api 密钥添加到 .streamlit/secrets_template.toml 文件中
  4. 将文件名从secrets_template.toml更新为secrets.toml: mv .streamlit/secrets_template.toml .streamlit/secrets.toml (要了解有关 streamlit 中秘密处理的更多信息,请参阅此处的文档。)
  5. 创建虚拟环境:python -m venvreplicatevenv
  6. 激活虚拟环境:sourcereplicatevenv/bin/activate
  7. 安装依赖项:pip install -rrequirements.txt

github codespaces 设置

  1. 从 github 上的 cookbook 存储库,通过从“代码”按钮中选择“代码空间”选项来创建一个新的代码空间

    如何使用一个 API 创建 AI 聊天机器人来访问多个 LLM

  2. 生成代码空间后,将您的 replicate api 密钥添加到recipe/replicate/.streamlit/secrets_template.toml 文件中

    阿里妈妈·创意中心
    阿里妈妈·创意中心

    阿里妈妈营销创意中心

    下载
  3. 将文件名从secrets_template.toml更新为secrets.toml
    (要了解有关 streamlit 中秘密处理的更多信息,请参阅此处的文档。)

  4. 从cookbook根目录,将目录更改为复制食谱:cdrecipes/replicate

  5. 安装依赖项:pip install -rrequirements.txt

使用 replicate 运行文本生成模型

  1. 在recipes/replicate目录中创建一个名为replicate_hello_world.py的文件
  2. 将以下代码添加到文件中:

    import replicate   
    
    import toml
    
    import os
    
    # read the secrets from the secrets.toml file
    with open(".streamlit/secrets.toml", "r") as f:
        secrets = toml.load(f)
    
    # create an environment variable for the replicate api token 
    os.environ['replicate_api_token'] = secrets["replicate_api_token"]
    
    # run a model
    for event in replicate.stream("meta/meta-llama-3-8b",
                                 input={"prompt": "what is streamlit?"},):
        print(str(event), end="")
    
  3. 运行脚本:pythonreplicate_hello_world.py

您应该会看到模型生成的文本的打印结果。

要了解有关复制模型及其工作原理的更多信息,您可以在此处参考其文档。从本质上讲,复制“模型”是指经过训练、打包和发布的软件程序,它接受输入并返回输出。

在这种特殊情况下,模型是meta/meta-llama-3-8b,输入是“提示”:“什么是streamlit?”。当您运行脚本时,将调用 replicate 端点,打印的文本是模型通过 replicate 返回的输出。

运行演示 replicate streamlit 聊天机器人应用程序

要运行演示应用程序,请使用 streamlit cli:streamlit run streamlit_app.py。

运行此命令会将应用程序部署到本地主机上的端口。当您访问此位置时,您应该会看到 streamlit 应用程序正在运行。

如何使用一个 API 创建 AI 聊天机器人来访问多个 LLM

您可以使用此应用程序通过复制提示不同的llm,并根据您提供的配置生成生成文本。

适用于多个 llm 模型的通用 api

使用 replicate 意味着您可以使用一个 api 提示多个开源 llm,这有助于简化 ai 与现代软件流程的集成。

这是通过以下代码块完成的:

for event in replicate.stream(model, 
                             input={"prompt": prompt_str,
                             "prompt_template": r"{prompt}", 
                             "temperature": temperature,
                             "top_p": top_p,}):
    yield str(event)

模型、温度和 top p 配置由用户通过 streamlit 的输入小部件提供。 streamlit 的聊天元素可以轻松地将聊天机器人功能集成到您的应用程序中。最好的部分是您不需要了解 javascript 或 css 来实现和设计这些组件 - streamlit 提供了所有开箱即用的功能。

复制最佳实践

使用提示的最佳模型

replicate 提供了一个 api 端点来搜索公共模型。您还可以在他们的网站上探索特色模型和用例。这可以让您轻松找到适合您特定需求的型号。

不同的型号有不同的性能特点。根据您对准确性和速度的需求使用适当的模型。

使用 webhooks、流媒体和图像 url 提高性能

replicate 的输出数据仅可用一个小时。使用 webhook 将数据保存到您自己的存储中。您还可以设置 webhooks 来处理来自模型的异步响应。这对于构建可扩展的应用程序至关重要。

尽可能利用流媒体。某些模型支持流式传输,允许您在生成部分结果时获得它们。这非常适合实时应用程序。

与使用 base 64 编码的上传图像相比,使用图像 url 可以提高性能。

使用 streamlit 释放 ai 的潜力

借助 streamlit,数月的应用程序设计工作简化为 只需几行 python 代码。它是展示最新人工智能发明的完美框架。

使用 streamlit cookbook 中的其他 ai 食谱快速启动并运行 快速。 (别忘了在论坛中向我们展示您正在构建的内容!)

祝 streamlit 快乐! ?

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

106

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

81

2025.12.15

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

437

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

803

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

371

2025.07.23

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

4371

2026.01.21

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

999

2023.07.05

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号