Oscaner / bce-qianfan-sdk

Provide best practices for LMOps, as well as elegant and convenient access to the features of the Qianfan MaaS Platform. (提供大模型工具链最佳实践,以及优雅且便捷地访问千帆大模型平台)

Home Page:https://cloud.baidu.com/doc/WENXINWORKSHOP/index.html

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

百度千帆大模型平台 SDK

LICENSE Release Notes PyPI version Documentation Status

针对百度智能云千帆大模型平台,我们推出了一套 Python SDK(下称千帆 SDK),方便用户通过代码接入并调用千帆大模型平台的能力。

如何安装

目前千帆 SDK 已发布到 PyPI ,用户可使用 pip 命令进行安装。安装千帆 SDK 需要 3.7.0 或更高的 Python 版本

pip install qianfan

在安装完成后,用户即可在代码内引入千帆 SDK 并使用

import qianfan

快速使用

在使用千帆 SDK 之前,用户需要 百度智能云控制台 - 安全认证 页面获取 Access Key 与 Secret Key,并在 千帆控制台 中创建应用,选择需要启用的服务,具体流程参见平台 说明文档。在获得了 Access Key 与 Secret Key 后,用户即可开始使用 SDK:

import os
import qianfan

os.environ["QIANFAN_ACCESS_KEY"]="..."
os.environ["QIANFAN_SECRET_KEY"]="..."
# 通过 App Id 选择使用的应用
# 该参数可选,若不提供 SDK 会自动选择最新创建的应用
os.environ["QIANFAN_APPID"]="..."

chat_comp = qianfan.ChatCompletion(model="ERNIE-Bot")
resp = chat_comp.do(messages=[{
    "role": "user",
    "content": "你好,千帆"
}], top_p=0.8, temperature=0.9, penalty_score=1.0)

print(resp["result"])

除了通过环境变量设置外,千帆 SDK 还提供了 通过DotEnv加载 .env 文件和通过代码配置的方式,详细参见 SDK 配置 部分。

其他认证方式

这里是一些其他认证方式,请仅在无法获取 Access Key 与 Secret Key 时使用。这些认证方式已经过时,将在未来从 SDK 中移除。

API Key (AK) 和 Secret Key (SK)是用户在调用千帆模型相关功能时所需要的凭证。具体获取流程参见平台的应用接入使用说明文档,但该认证方式无法使用训练、发布模型等功能,若需使用请使用 Access Key 和 Secret Key 的方式进行认证。在获得并配置了 AK 以及 SK 后,用户即可开始使用 SDK:

import os
import qianfan

os.environ["QIANFAN_AK"]="..."
os.environ["QIANFAN_SK"]="..."

chat_comp = qianfan.ChatCompletion(model="ERNIE-Bot")
resp = chat_comp.do(messages=[{
    "role": "user",
    "content": "你好,千帆"
}], top_p=0.8, temperature=0.9, penalty_score=1.0)

print(resp["result"])

适用范围:

功能 API Key Access Key
Chat 对话
Completion 续写
Embedding 向量化
Plugin 插件调用
文生图
大模型调优
大模型管理
大模型服务
数据集管理

功能导览

我们提供了数个 cookbook,可以快速了解如何使用 SDK 以及与第三方组件进行交互。

大模型能力

目前千帆 SDK 支持用户使用如下大模型预测能力,详见预测服务

  • Chat 对话
  • Completion 续写
  • Embedding 向量化
  • Plugin 插件调用
  • 文生图

大模型调优

目前千帆平台支持如下训练调优能力,详见训练调优

  • 创建训练任务
  • 创建任务运行
  • 获取任务运行详情
  • 停止任务运行

模型管理

目前千帆平台支持对训练完成后的模型进行管理,详见模型管理

  • 获取模型详情
  • 获取模型版本详情
  • 训练任务发布为模型
  • 发起模型评估任务
  • 查看模型评估详情
  • 查看模型评估报告
  • 停止模型评估任务

模型服务

千帆平台支持将模型发布成服务,详见服务管理

  • 创建服务
  • 查询服务详情

平台数据集管理

千帆平台提供 API 接口对数据集进行管理,详见数据管理

目前支持的数据集管理操作有:

  • 创建数据集
  • 发起数据集发布任务
  • 发起数据集导入任务
  • 获取数据集详情
  • 获取数据集状态详情
  • 发起数据集导出任务
  • 删除数据集
  • 获取数据集导出记录
  • 获取数据集导入错误详情
  • 创建数据清洗任务
  • 查看数据清洗任务详情
  • 查看清洗任务列表
  • 删除数据清洗任务
  • 创建数据增强任务
  • 查看增强任务列表
  • 查看数据增强详情
  • 删除数据增强任务
  • 实体标注
  • 删除实体
  • 获取实体列表

Trainer

千帆 Python SDK 以Pipeline串联整个模型训练的流程,同时帮助用户更好的把控训练流程状态 Trainer 框架

本地数据集处理

千帆 Python SDK 集成了一系列本地的数据处理功能,允许用户在本地对来自多个数据源的数据进行增删改查等操作,详见Dataset 框架

Prompt 管理

千帆平台支持对文生文、文生图任务的 Prompt 进行管理,详见Prompt 管理

目前支持的 Prompt 管理操作有:

  • 创建 Prompt
  • 更新 Prompt
  • 删除 Prompt
  • 获取 Prompt 详情
  • 获取 Prompt 列表
  • 获取 Prompt 标签列表

其他

Check API References for more details.

License

Apache-2.0

About

Provide best practices for LMOps, as well as elegant and convenient access to the features of the Qianfan MaaS Platform. (提供大模型工具链最佳实践,以及优雅且便捷地访问千帆大模型平台)

https://cloud.baidu.com/doc/WENXINWORKSHOP/index.html

License:Apache License 2.0


Languages

Language:Python 72.9%Language:Jupyter Notebook 26.9%Language:Shell 0.1%Language:Makefile 0.1%