kani

kani

轻量且高度可定制的聊天语言模型框架

kani是一个轻量且高度可定制的聊天语言模型框架,适用于自然语言处理研究人员、爱好者和开发人员。kani支持OpenAI和Anthropic等多种托管模型,以及通过Hugging Face和llama.cpp支持的开源模型。kani提供无缝的聊天记忆管理、函数调用、提示控制和异步设计功能。此外,开发者可以快速迭代并方便地学习使用kani框架。

kani框架轻量级语言模型自定义Github开源项目

项目介绍:kani

项目概述

kani 是一个轻量级且高度可定制的框架,专为基于对话的语言模型而设计,还支持工具使用和功能调用。与其他框架不同,kani 提供了更精细的定制选项,适合自然语言处理(NLP)研究人员、业余爱好者和开发人员使用。

支持的模型

kani 具有丰富的模型支持能力,包括:

  • 托管模型:OpenAI 的 GPT-3.5 和 GPT-4 等模型,以及 Anthropic 的 Claude 模型。

  • 开源模型:通过 Hugging Face 和 llama.cpp 平台上的许多开源聊天模型:

    • LLaMA 3、Mistral 和 Vicuna 等多种变体。
    • 这些模型的参考实现和调优版本。

用户可以在项目的模型库中查看如何在不同应用中使用这些模型。

项目特点

  • 轻量与高级别:kani 提供与语言模型接口的基本功能,而不过多干预开发者的提示形式。
  • 模型无关性:kani 提供了简单的接口,可以轻松切换底层运行的语言模型,而无需大幅重构代码。
  • 自动对话记忆管理:无需手动管理对话历史中的 token 数量,kani 会自动处理。
  • 支持模型反馈和重试的函数调用:通过简单的代码行即可让模型访问函数,kani 会优雅地处理参数偏差和错误,并支持重试。
  • 完全控制提示:kani 不会擅自决定数据的格式,开发者拥有完全的提示控制权。
  • 快速迭代和直观学习:在 kani 中仅需编写 Python 代码,其余部分由框架处理。
  • 异步设计:可轻松并行运行多个对话会话,无需管理多个进程或程序。

安装指南

安装要求 Python 3.10 或以上版本。可以通过 pip 安装特定模型的依赖项:

# 对于 OpenAI 模型 $ pip install "kani[openai]" # 对于 Hugging Face 模型 $ pip install "kani[huggingface]" torch # 或者安装所有内容: $ pip install "kani[all]"

如需最新的更改和新模型,用户还可以从 Git 的 main 分支安装开发版本。

快速入门

kani 的快速开始指南展示了如何通过 OpenAI 的 ChatGPT 创建一个简单的对话机器人:

第一步是安装库,然后使用以下代码来运行:

import asyncio from kani import Kani, chat_in_terminal from kani.engines.openai import OpenAIEngine api_key = "sk-..." # 替换为您的 OpenAI API 密钥 engine = OpenAIEngine(api_key, model="gpt-4o-mini") ai = Kani(engine) chat_in_terminal(ai) # 或通过异步函数调用 async def main(): resp = await ai.chat_round("What is the airspeed velocity of an unladen swallow?") print(resp.text) asyncio.run(main())

功能调用

kani 通过简单的 @ai_function 装饰器,将 Python 函数暴露给语言模型。例如:

import asyncio from typing import Annotated from kani import AIParam, Kani, ai_function, chat_in_terminal from kani.engines.openai import OpenAIEngine api_key = "sk-..." engine = OpenAIEngine(api_key, model="gpt-4o-mini") class MyKani(Kani): @ai_function() def get_weather(self, location: Annotated[str, AIParam(desc="The city and state, e.g. San Francisco, CA")]): return f"Weather in {location}: Sunny, 72 degrees fahrenheit." ai = MyKani(engine) chat_in_terminal(ai)

kani 确保函数调用的有效性,让开发人员可以将精力集中在实现功能上。

流式处理

kani 支持从底层语言模型逐个 token 地流式输出响应,即使处于函数调用过程中,也能够无缝处理。

开发背景

kani 由宾夕法尼亚大学的三位计算机与信息科学博士生 Andrew Zhu、Liam Dugan 和 Alyssa Hwang 开发,他们参与并使用 kani 进行 NLP 研究,确保其符合现代 NLP 实践。

通过其轻量级、灵活且强大的设计,kani 成为开发和研究语言模型应用的有力工具。

编辑推荐精选

潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

下拉加载更多