TypeChat 入门指南

什么是 TypeChat

TypeChat 是一个革命性的库,它简化了使用 TypeScript 构建自然语言模型界面的过程。 传统模式下,创建自然语言模型界面是一项复杂的任务,通常依赖复杂的决策树来确定意图并收集行动所需的输入。 随着大型语言模型(LLM)的出现,这个过程变得更加容易,但它也带来了新的挑战,例如限制模型回复的安全性、构建响应以供进一步处理以及确保模型回复的有效性。

TypeChat 通过用 schema 工程取代 prompt 工程来应对这些挑战。它允许开发者定义代表其自然语言模型应用程序支持的意图的类型。这适用于从简单的情感分类到复杂的购物车或音乐应用场景。一旦定义了类型,TypeChat 就会处理剩下的事情,使用类型构建对 LLM 的 prompt,根据 schema 验证 LLM 响应,总结实例来确保与用户意图保持一致。

你可以在以下位置找到该项目的网站:microsoft.github.io/TypeChat/

该项目的源代码(包括示例)托管在 GitHub 上:github.com/microsoft/T...

TypeChat 的目的

TypeChat 的主要目的是抹平自然语言与应用程序可以使用的结构化数据之间的差距。 它的目的是让开发者更容易地将自然语言界面集成到他们的应用程序中。 通过提供具有 shema(某些类型)和请求的模型,开发者可以处理类型良好的结构化数据,从而使将自然语言集成到应用程序中的过程更加简化和高效。

构建 TypeChat 的分步指南

构建 TypeChat 的过程非常简单

  1. 安装 Node.js:确保计算机上安装了 Node.js(18.16.0 LTS 或更高版本)。 可以从 Node.js 官方网站下载

  2. 克隆 TypeChat 仓库

    bash 复制代码
    $ git clone <https://github.com/microsoft/TypeChat>
  3. 进入 TypeChat 目录

    bash 复制代码
    $ cd TypeChat
  4. 安装依赖

    bash 复制代码
    $ npm i
  5. 构建 TypeChat

    bash 复制代码
    $ npm run build-all
  6. 配置OpenAI环境变量:需要设置 OpenAI 环境变量。 可以通过在项目的根目录中创建 .env 文件并添加以下内容来完成此操作

    bash 复制代码
    OPENAI_MODEL=gpt-3.5-turbo
    OPENAI_API_KEY=openAI 帐号的key
  7. 运行示例,所有的示例代码都在 examples 目录中。要以互动的方式运行示例,请导航到 examples 下对应的目录并运行以下命令

    bash 复制代码
    $ node ./dist/main.js

    你可以在出现提示时输入请求,然后键入 quitexit 来结束会话

    比如在 examples/calendar 目录下

    也可以直接使用项目自带的 input 文件,来运行

    bash 复制代码
    $ node ./dist/main.js ./dist/input.txt

    你可以看到控制的输出是这样的

TypeChat 的入门示例

要检验 TypeChat 代码的实际效果,让我们思考一个示例。 假设我们有一个咖啡店应用程序,我们希望将用户意图转换为咖啡订单项目列表。 我们可以为咖啡订单项目定义一个类型,并使用 TypeChat 处理自然语言输入并将其映射到经过验证的 JSON 作为输出。 通过这种方式,我们可以轻松地将用户的自然语言请求转换为我们的应用程序可以理解和处理的结构化数据。

以下是咖啡订单的 TypeScript 类型定义:

typescript 复制代码
interface CoffeeOrder {
  type: string;
  size: string;
  extras: string[];
}

要使用 TypeChat,我们可以创建一个新实例并将 CoffeeOrder 类型传递给它:

typescript 复制代码
import { TypeChat } from 'typechat';
const typeChat = new TypeChat<CoffeeOrder>();

// 用户输入
const userInput = "I would like a large cappuccino with extra foam and a shot of vanilla.";

// 使用 TypeChat 获取一个结构化的数据
const order = typeChat.process(userInput);
console.log(order);

// 输出: { type: 'cappuccino', size: 'large', extras: ['extra foam', 'shot of vanilla'] }

在此示例中,TypeChat 获取用户的自然语言输入并将其转换为我们的应用程序可以轻松处理的结构化数据 CoffeeOrder

总结

总之,TypeChat 是一个强大的工具,它利用 TypeScript 的强大功能来简化构建自然语言界面的过程。 它抹平了自然语言和结构化数据之间的差距,使开发人员更容易将自然语言界面集成到他们的应用程序中。 凭借其易于设置和使用的特点,TypeChat 将彻底改变我们与软件交互的方式,使其更加直观和用户友好。 因此,如果你是一名希望通过自然语言界面增强应用程序的开发人员,那么 TypeChat 绝对值得探索

后续

后面我会采用 React ,Express, TypeChat 等技术栈做一个全栈的项目,帮助大家对 TypeChat 有一个更加深刻的理解。欢迎关注我或者给我留言🌹

相关推荐
MR·Feng7 分钟前
使用Electron将vue2项目打包为桌面exe安装包
前端·javascript·electron
萧大侠jdeps19 分钟前
图片生成视频-右进
前端·javascript·音视频
Domain-zhuo42 分钟前
JS对于数组去重都有哪些方法?
开发语言·前端·javascript
夏沫の梦1 小时前
常见LLM大模型概览与详解
人工智能·深度学习·chatgpt·llama
明月清风徐徐1 小时前
Vue实训---2-路由搭建
前端·javascript·vue.js
王解1 小时前
速度革命:esbuild如何改变前端构建游戏 (1)
前端·vite·esbuild
葡萄城技术团队1 小时前
使用 前端技术 创建 QR 码生成器 API1
前端
WangYan20221 小时前
泥石流灾害风险评估与模拟丨AI与R语言、ArcGIS、HECRAS融合,提升泥石流灾害风险预测的精度和准确性
arcgis·chatgpt·遥感技术·地质灾害·泥石流·hecras·风险评价
DN金猿1 小时前
Vue移动端网页(H5)预览pdf文件(pdfh5和vue-pdf)(很详细)
前端·vue.js·pdf
鸽鸽程序猿2 小时前
【前端】javaScript
开发语言·前端·javascript