
ModelFusion是一个强大的TypeScript库,旨在简化AI应用程序的开发过程。作为一个抽象层,它为开发者提供了一套统一的API,用于集成各种AI模型到JavaScript和TypeScript应用中。ModelFusion支持多种常见操作,如文本生成、对象生成和工具使用等,同时还提供了诸如可观察性、日志记录和自动重试等生产级功能。
ModelFusion具有以下几个突出特点:
供应商中立: ModelFusion是一个非商业的开源项目,由社区驱动。开发者可以使用任何受支持的提供商。
多模态支持: 该库支持广泛的模型类型,包括文本生成、图像生成、视觉、文本到语音、语音到文本以及嵌入模型等。
类型推断和验证: ModelFusion在可能的情况下推断TypeScript类型,并验证模型响应。
可观察性和日志记录: 提供了观察者框架和日志支持,方便开发者监控和调试。
弹性和稳健性: 通过自动重试、限流和错误处理机制确保操作的无缝进行。
为生产而生: ModelFusion完全可树摇,可用于无服务器环境,并且只使用最小的依赖集。
要开始使用ModelFusion,您可以通过npm安装:
npm install modelfusion
或者使用以下入门模板之一:
ModelFusion提供了多种功能,以下是一些常用功能的示例:
使用语言模型和提示生成文本。如果模型支持,您可以流式传输文本。对于支持多模态提示的模型(如llama.cpp),您还可以使用图像作为提示的一部分。
import { generateText, openai } from "modelfusion"; const text = await generateText({ model: openai.CompletionTextGenerator({ model: "gpt-3.5-turbo-instruct" }), prompt: "Write a short story about a robot learning to love:\n\n", });
使用语言模型和模式生成类型化对象。
import { ollama, zodSchema, generateObject, jsonObjectPrompt, } from "modelfusion"; const sentiment = await generateObject({ model: ollama .ChatTextGenerator({ model: "openhermes2.5-mistral", maxGenerationTokens: 1024, temperature: 0, }) .asObjectGenerationModel(jsonObjectPrompt.instruction()), schema: zodSchema( z.object({ sentiment: z .enum(["positive", "neutral", "negative"]) .describe("Sentiment."), }) ), prompt: { system: "You are a sentiment evaluator. " + "Analyze the sentiment of the following product review:", instruction: "After I opened the package, I was met by a very unpleasant smell " + "that did not disappear even after washing. Never again!", }, });
从提示生成图像。
import { generateImage, openai } from "modelfusion"; const image = await generateImage({ model: openai.ImageGenerator({ model: "dall-e-3", size: "1024x1024" }), prompt: "the wicked witch of the west in the style of early 19th century painting", });

从文本合成语音(音频)。也称为TTS(文本到语音)。
import { generateSpeech, lmnt } from "modelfusion"; // `speech` is a Uint8Array with MP3 audio data const speech = await generateSpeech({ model: lmnt.SpeechGenerator({ voice: "034b632b-df71-46c8-b440-86a42ffc3cf3", // Henry }), text: "Good evening, ladies and gentlemen! Exciting news on the airwaves tonight " + "as The Rolling Stones unveil 'Hackney Diamonds,' their first collection of " + "fresh tunes in nearly twenty years, featuring the illustrious Lady Gaga, the " + "magical Stevie Wonder, and the final beats from the late Charlie Watts.", });
ModelFusion还提供了工具和向量索引 功能,这些功能对于构建聊天机器人和智能代理特别有用。
工具是可以由AI模型执行的函数(及相关元数据)。ModelFusion提供了几个开箱即用的工具,如Math.js、MediaWiki搜索、SerpAPI和Google自定义搜索。您还可以创建自定义工具。
向量索引允许您存储和检索嵌入向量,这对于实现高效的相似性搜索和信息检索非常有用。
const texts = [ "A rainbow is an optical phenomenon that can occur under certain meteorological conditions.", "It is caused by refraction, internal reflection and dispersion of light in water droplets resulting in a continuous spectrum of light appearing in the sky.", // ... ]; const vectorIndex = new MemoryVectorIndex<string>(); const embeddingModel = openai.TextEmbedder({ model: "text-embedding-ada-002", }); // update an index - usually done as part of an ingestion process: await upsertIntoVectorIndex({ vectorIndex, embeddingModel, objects: texts, getValueToEmbed: (text) => text, }); // retrieve text chunks from the vector index - usually done at query time: const retrievedTexts = await retrieve( new VectorIndexRetriever({ vectorIndex, embeddingModel, maxResults: 3, similarityThreshold: 0.8, }), "rainbow and water droplets" );
ModelFusion支持不同的提示样式(如文本、指令或聊天提示)。这些提示样式可以通过.withTextPrompt()、.withChatPrompt()和.withInstructionPrompt()方法访问:
const text = await generateText({ model: openai .ChatTextGenerator({ // ... }) .withTextPrompt(), prompt: "Write a short story about a robot learning to love", });
ModelFusion提供了观察者框架和日志支持。您可以轻松跟踪运行和调用层次结构,并添加自己的观察者。
import { generateText, openai } from "modelfusion"; const text = await generateText({ model: openai.CompletionTextGenerator({ model: "gpt-3.5-turbo-instruct" }), prompt: "Write a short story about a robot learning to love:\n\n", logging: "detailed-object", });
ModelFusion为开发者提供了一个强大而灵活的工具集,用于构建各种AI应用。无论您是想创建一个简单的聊天机器人,还是构建一个复杂的多模态AI系统,ModelFusion都能为您提供所需的抽象和功能。通过其统一的API、多模态支持和生产级功能,ModelFusion大大简化了AI应用的开发过程,使开发者能够专注于创造独特的用户体验,而不是处理底层的模型集成细节。
随着AI技术的不断发展,ModelFusion也在持续更新和改进。开发者社区的贡献使得这个库能够跟上最新的AI趋势和最佳实践。无论您是AI开发新手还是经验丰富的专家,ModelFusion都为您提供了一个理想的起点,让您能够快速、高效地将AI功能集成到您的应用中。

通过使用ModelFusion,您不仅可以加速开发过程,还可以确保您的AI应用具有良好的可扩展性和可维护性。随着项目的成长,ModelFusion的模块化设计和丰富的功能集将继续支持您的需求,使您的应用能够轻松适应新的挑战和机遇。
开始使用ModelFusion,探索AI应用开发的无限可能性吧!


免费创建高清无水印Sora视频
Vora是一个免费创建高清无水印Sora视频的AI工具


最适合小白的AI自动化工作流平台
无需编码,轻松生成可复用、可变现的AI自动化工作流

大模型驱动的Excel数据处理工具
基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自 动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。


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


AI论文写作指导平台
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。


AI一键生成PPT,就用博思AIPPT!
博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。


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


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


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


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号