AISuite:简化跨多个 LLM 提供商的 GenAI 集成

wufei123 2025-01-05 阅读:5 评论:0
生成式人工智能 (gen ai) 正在凭借其创造力、解决问题和自动化的潜力重塑行业。然而,由于 api 和配置分散,开发人员在集成来自不同提供商的大型语言模型 (llm) 时经常面临重大挑战。互操作性的缺乏使工作流程变得复杂,延长了开发时间...

生成式人工智能 (gen ai) 正在凭借其创造力、解决问题和自动化的潜力重塑行业。然而,由于 api 和配置分散,开发人员在集成来自不同提供商的大型语言模型 (llm) 时经常面临重大挑战。互操作性的缺乏使工作流程变得复杂,延长了开发时间,并阻碍了有效的 gen ai 应用程序的创建。

为了解决这个问题,andrew ng 的团队推出了 aisuite,这是一个开源 python 库,可以简化 openai、anthropic 和 ollama 等提供商之间的法学硕士集成。 aisuite 使开发人员能够使用简单的“provider:model”字符串(例如 openai:gpt-4o 或 anthropic:claude-3-5)在模型之间切换,从而无需大量重写代码。通过提供统一的接口,aisuite 显着降低了复杂性,加速了开发,并为构建多功能 gen ai 应用程序开辟了新的可能性。

在本文中,我们将探讨 aisuite 的工作原理、实际应用以及它在解决与不同法学硕士合作的挑战方面的有效性。

入门 目录
  • 什么是aisuite
  • 为什么aisuite很重要
  • 使用 aisuite 进行实验
  • 创建聊天完成
  • 创建通用查询函数
什么是aisuite

aisuite 是由 andrew ng 团队开发的开源 python 库,用于简化来自多个提供商的大型语言模型 (llm) 的集成和管理。它抽象化了使用不同 api、配置和数据格式的复杂性,为开发人员提供了一个统一的框架来简化他们的工作流程。

aisuite的主要特点:
  • 简单的界面:aisuite 提供了一个简单且一致的界面来管理各种 llm。开发者只需几行代码即可将模型集成到他们的应用程序中,大大降低了 gen ai 项目的进入门槛。
  • 统一框架:通过抽象多个api之间的差异,aisuite无缝处理不同类型的请求和响应。这减少了开发开销并加速了原型设计和部署。
  • 轻松模型切换:使用aisuite,模型之间的切换就像更改代码中的单个字符串一样简单。例如,开发人员可以指定“provider:model”组合,如 openai:gpt-4o 或 anthropic:claude-3-5,而无需重写应用程序的重要部分。
  • 可扩展性:aisuite 旨在适应不断发展的 gen ai 环境。开发人员可以在新模型和提供程序可用时添加它们,确保应用程序保持最新的人工智能功能。
为什么aisuite很重要?

aisuite 解决了 gen ai 生态系统中的一个关键痛点:不同提供商的法学硕士之间缺乏互操作性。通过提供统一的接口,它简化了开发过程,节省了时间并降低了成本。这种灵活性允许团队通过为特定任务选择最佳模型来优化性能。

早期基准测试和社区反馈凸显了 aisuite 减少多模型应用程序集成时间、提高开发人员效率和生产力的能力。随着 gen ai 生态系统的发展,aisuite 降低了实验、构建和扩展人工智能驱动的解决方案的障碍。

尝试 aisuite

让我们通过安装必要的依赖项开始探索 aisuite。

安装依赖项
  • 通过执行以下命令创建并激活虚拟环境。
python -m venv venv
source venv/bin/activate #for ubuntu
venv/scripts/activate #for windows
  • 使用 pip 安装 aisuite、openai 和 python-dotenv 库。
pip install aisuite[all] openai python-dotenv

AISuite:简化跨多个 LLM 提供商的 GenAI 集成

设置环境和凭据

创建一个名为 .env 的文件。该文件将存储您的环境变量,包括 openai 密钥。

  • 打开 .env 文件并添加以下代码来指定您的 openai api 密钥:
openai_api_key=sk-proj-7xypjkdag_gdl0_...
groq_api_key=gsk_8nigj24k2p0j5rwrwoobw...
  • 将 api 密钥添加到环境变量中。
import os
from dotenv import load_dotenv
load_dotenv()
os.environ['openai_api_key'] = os.getenv('openai_api_key')
os.environ['anthropic_api_key'] = getpass('enter your anthropic api key: ')
初始化aisuite客户端

创建 aisuite 客户端实例,实现与多个 llm 的标准化交互。

client = ai.client()
defining the prompt
the prompt syntax closely resembles openai’s structure, incorporating roles and content.

messages = [
   {"role": "system", "content": "you are a helpful assistant."},
   {"role": "user", "content": "tell a joke in 1 line."}
]
查询型号

用户可以使用aisuite查询模型,如下。

# openai model
response = client.chat.completions.create(model="openai:gpt-4o", messages=messages, temperature=0.75)
# ollama model
response = client.chat.completions.create(model="ollama:llama3.1:8b", messages=messages, temperature=0.75)
# anthropic model
response = client.chat.completions.create(model="anthropic:claude-3-5-sonnet-20241022", messages=messages, temperature=0.75)
# groq model
response = client.chat.completions.create(model="groq:llama-3.2-3b-preview", messages=messages, temperature=0.75)
print(response.choices[0].message.content)
  • model="openai:gpt-4o":指定模型的类型和版本。
  • messages=messages:将之前定义的提示发送到模型。
  • 温度=0.75:调整响应的随机性。较高的值鼓励创造性输出,而较低的值会产生更具确定性的结果。
  • response.choices[0].message.content:从模型的响应中检索文本内容。
创建聊天完成

让我们使用 openai 模型创建聊天完成代码。

import os
from dotenv import load_dotenv
load_dotenv()
os.environ['openai_api_key'] = os.getenv('openai_api_key')

import aisuite as ai

client = ai.client()

provider = "openai"
model_id = "gpt-4o"

messages = [
    {"role": "system", "content": "you are a helpful assistant"},
    {"role": "user", "content": "provide an overview of the latest trends in ai"},
]

response = client.chat.completions.create(
    model = f"{provider}:{model_id}",
    messages = messages,
)

print(response.choices[0].message.content)
  • 使用以下命令运行应用程序。
python app.py

您将得到如下输出,

AISuite:简化跨多个 LLM 提供商的 GenAI 集成

创建用于查询的通用函数

与其编写单独的代码来调用不同的模型,不如创建一个通用函数来消除代码重复并提高效率。

def ask(message, sys_message="you are a helpful assistant", model="openai:gpt-4o"):
    client = ai.client()
    messages = [
        {"role": "system", "content": sys_message},
        {"role": "user", "content": message}
    ]
    response = client.chat.completions.create(model=model, messages=messages)
    return response.choices[0].message.content

print(ask("provide an overview of the latest trends in ai"))

ask 函数是一个可重用的实用程序,设计用于向 ai 模型发送查询。它接受以下参数:

  • 消息:用户的查询或提示。 sys_message(可选):指导模型行为的系统级指令。
  • model:指定要使用的ai模型。 该函数处理输入参数,将其发送到指定模型,并返回 ai 的响应,使其成为与各种模型交互的多功能工具。

下面是使用通用询问函数与 openai 模型交互的完整代码。

import os
from dotenv import load_dotenv
load_dotenv()
os.environ['openai_api_key'] = os.getenv('openai_api_key')

import aisuite as ai

def ask(message, sys_message="you are a helpful assistant", model="openai:gpt-4o"):
    client = ai.client()
    messages = [
        {"role": "system", "content": sys_message},
        {"role": "user", "content": message}
    ]
    response = client.chat.completions.create(model=model, messages=messages)
    return response.choices[0].message.content

print(ask("provide an overview of the latest trends in ai"))

运行代码将产生以下输出。

AISuite:简化跨多个 LLM 提供商的 GenAI 集成

与多个 api 交互

让我们通过以下代码探索使用 aisuite 与多个模型进行交互。

import os
from dotenv import load_dotenv
load_dotenv()
os.environ['OPENAI_API_KEY'] = os.getenv('OPENAI_API_KEY')
os.environ['GROQ_API_KEY'] = os.getenv('GROQ_API_KEY')

import aisuite as ai

def ask(message, sys_message="You are a helpful assistant", model="openai:gpt-4o"):
    client = ai.Client()
    messages = [
        {"role": "system", "content": sys_message},
        {"role": "user", "content": message}
    ]
    response = client.chat.completions.create(model=model, messages=messages)
    return response.choices[0].message.content

print(ask("Who is your creator?"))
print(ask('Who is your creator?', model='ollama:qwen2:1.5b'))
print(ask('Who is your creator?', model='groq:llama-3.1-8b-instant'))
print(ask('Who is your creator?', model='anthropic:claude-3-5-sonnet-20241022'))

与 anthropic 或 groq 等提供商交互时可能会遇到挑战。希望 aisuite 团队正在积极解决这些问题,以确保无缝集成和功能。

aisuite 是一款用于浏览大型语言模型的强大工具。它使用户能够利用多个人工智能提供商的优势,同时简化开发并鼓励创新。凭借其开源基础和直观的设计,aisuite 成为现代人工智能应用程序开发的基石。

感谢您阅读这篇文章!!

感谢 gowri m bhatt 审阅内容。

如果您喜欢这篇文章,请点击心形按钮♥并分享以帮助其他人找到它!

本教程的完整源代码可以在这里找到,

github - codemaker2015/aisuite-examples : github.com

资源

github - andrewyng/aisuite:与多个生成式 ai 提供商的简单、统一的接口:github.com

以上就是AISuite:简化跨多个 LLM 提供商的 GenAI 集成的详细内容,更多请关注知识资源分享宝库其它相关文章!

版权声明

本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com

分享:

扫一扫在手机阅读、分享本文

发表评论
热门文章
  • 华为 Mate 70 性能重回第一梯队 iPhone 16 最后一块遮羞布被掀

    华为 Mate 70 性能重回第一梯队 iPhone 16 最后一块遮羞布被掀
    华为 mate 70 或将首发麒麟新款处理器,并将此前有博主爆料其性能跑分将突破110万,这意味着 mate 70 性能将重新夺回第一梯队。也因此,苹果 iphone 16 唯一能有一战之力的性能,也要被 mate 70 拉近不少了。 据悉,华为 Mate 70 性能会大幅提升,并且销量相比 Mate 60 预计增长40% - 50%,且备货充足。如果 iPhone 16 发售日期与 Mate 70 重合,销量很可能被瞬间抢购。 不过,iPhone 16 还有一个阵地暂时难...
  • 惠普新款战 99 笔记本 5 月 20 日开售:酷睿 Ultra / 锐龙 8040,4999 元起

    惠普新款战 99 笔记本 5 月 20 日开售:酷睿 Ultra / 锐龙 8040,4999 元起
    本站 5 月 14 日消息,继上线官网后,新款惠普战 99 商用笔记本现已上架,搭载酷睿 ultra / 锐龙 8040处理器,最高可选英伟达rtx 3000 ada 独立显卡,售价 4999 元起。 战 99 锐龙版 R7-8845HS / 16GB / 1TB:4999 元 R7-8845HS / 32GB / 1TB:5299 元 R7-8845HS / RTX 4050 / 32GB / 1TB:7299 元 R7 Pro-8845HS / RTX 2000 Ada...
  • 酷凛 ID-COOLING 推出霜界 240/360 一体水冷散热器,239/279 元

    酷凛 ID-COOLING 推出霜界 240/360 一体水冷散热器,239/279 元
    本站 5 月 16 日消息,酷凛 id-cooling 近日推出霜界 240/360 一体式水冷散热器,采用黑色无光低调设计,分别定价 239/279 元。 本站整理霜界 240/360 散热器规格如下: 酷凛宣称这两款水冷散热器搭载“自研新 V7 水泵”,采用三相六极马达和改进的铜底方案,缩短了水流路径,相较上代水泵进一步提升解热能力。 霜界 240/360 散热器的水泵为定速 2800 RPM 设计,噪声 28db (A)。 两款一体式水冷散热器采用 27mm 厚冷排,...
  • Nginx服务器的HTTP/2协议支持和性能提升技巧介绍

    Nginx服务器的HTTP/2协议支持和性能提升技巧介绍
    Nginx服务器的HTTP/2协议支持和性能提升技巧介绍 引言:随着互联网的快速发展,人们对网站速度的要求越来越高。为了提供更快的网站响应速度和更好的用户体验,Nginx服务器的HTTP/2协议支持和性能提升技巧变得至关重要。本文将介绍如何配置Nginx服务器以支持HTTP/2协议,并提供一些性能提升的技巧。 一、HTTP/2协议简介:HTTP/2协议是HTTP协议的下一代标准,它在传输层使用二进制格式进行数据传输,相比之前的HTTP1.x协议,HTTP/2协议具有更低的延...
  • 两个表格切换的快捷键是什么

    两个表格切换的快捷键是什么
    两个表格切换的快捷键是“ctrl+pageup”和“ctrl+pagedown”,按键盘上的“ctrl+pageup”键是向右切换表格,按“ctrl+pagedown”键是向左切换表格。 本教程操作环境:windows7系统、Microsoft Office Excel2010版、Dell G3电脑。 两个工作表之间切换是Ctrl+Tab,两个工作簿之间切换是Ctrl+PageUP和Ctrl+PageDown。 打开Excel表格,打开几个工作簿。 按键盘上的Ctrl+P...