English | 中文
- 11/12/2024: OmAgent v0.2.0 正式发布!我们完全重构了OmAgent的底层框架,使其更加灵活和易于扩展。新版本加入了设备的概念,使你可以更简单的面向智能硬件进行快速开发~
- 10/20/2024: 我们正在积极开发版本0.2.0 🚧 激动人心的新功能正在路上!欢迎在X和Discord上加入我们~
- 09/20/2024: 我们的论文已经被 EMNLP 2024 收录。 迈阿密见!🏝
- 07/04/2024: OmAgent开源项目发布 🎉
- 06/24/2024: OmAgent论文发布
OmAgent 是一个开源的代理框架,旨在简化设备上多模态代理的开发。我们的目标是使代理能够增强各种硬件设备的功能,从智能手机、智能可穿戴设备(如眼镜)、IP 摄像头到未来的机器人。因此,OmAgent 对各种类型的设备进行抽象,并简化了将这些设备连接到最先进的多模态基础模型和代理算法的过程,以便每个人都能构建最有趣的设备上代理。此外,OmAgent 专注于优化端到端计算管道,以提供开箱即用的实时用户交互体验。
总之,OmAgent 的关键特性包括:
-
轻松连接多样化设备:我们使连接物理设备变得非常简单,例如手机、眼镜等,以便代理/模型开发者可以构建不仅在网页上运行而是在设备上运行的应用程序。我们欢迎对更多设备的支持贡献!
-
速度优化的最先进多模态模型:OmAgent 集成了最先进的商业和开源基础模型,为应用开发者提供最强大的智能。此外,OmAgent 简化了音频/视频处理和计算过程,轻松实现设备与用户之间自然流畅的交互。
-
最先进的多模态代理算法:OmAgent 为研究人员和开发者提供了一个简单的工作流编排接口,以实现最新的代理算法,例如 ReAct、DnC 等。我们欢迎任何新代理算法的贡献,以实现更复杂的问题解决能力。
-
可扩展性和灵活性:OmAgent 提供了一个直观的界面,用于构建可扩展的代理,使开发者能够构建适合特定角色并高度适应各种应用的代理。
OmAgent 使用 Conductor 作为工作流编排引擎。Conductor 是一个开源的、分布式的、可扩展的工作流引擎,支持多种编程语言和框架。它默认使用 Redis 进行持久化,Elasticsearch(7.x) 作为索引后端。
推荐使用docker部署Conductor:
docker compose -f docker/conductor/docker-compose.yml up -d
- 部署完成后可以通过访问
http://localhost:5001
访问Conductor UI。(注:Mac系统默认会占用5000端口,因此我们使用5001端口,你可以在部署Conductor的时候指定其它端口。) - 通过
http://localhost:8080
调用Conductor API。
-
Python 版本: 确保已安装 Python 3.10 或更高版本。
-
安装
omagent_core
:pip install -e omagent-core
-
安装示例项目所需的依赖:
pip install -r requirements.txt
-
安装可选组件:
- 安装 Milvus VectorDB 以更好支持长期记忆 OmAgent默认使用Milvus Lite作为智能体长期记忆的向量数据库存储向量数据。如果你希望使用完整的Milvus服务,可以使用docker部署milvus向量数据库。
如果你希望使用智能设备来访问你的智能体,我们提供了智能手机APP以及对应的后端程序,这样你可以专注于实现智能体功能,而无需担心复杂的设备连接问题。
- APP后端部署
TODO - 手机APP下载安装以及调试
TODO
container.yaml
文件是一个管理系统中不同组件的依赖和设置的配置文件。按以下步骤设置您的配置:
-
生成
container.yaml
文件:cd examples/step2_outfit_with_switch python compile_container.py
这将在
examples/step2_outfit_with_switch
下创建一个具有默认设置的container.yaml
文件。 -
在
configs/llms/gpt.yml
和configs/llms/text_res.yml
中配置您的 LLM 设置:- 通过环境变量或直接修改 yml 文件来设置您的 OpenAI API 密钥或兼容的 endpoint
export custom_openai_key="your_openai_api_key" export custom_openai_endpoint="your_openai_endpoint"
-
更新生成的
container.yaml
中的设置:- 配置 Redis 连接设置,主要是主机地址、端口、密码凭证,包括
redis_stream_client
和redis_stm_client
部分都要进行设置。 - 在
conductor_config
下更新 Conductor 服务器的 URL - 根据需要调整其他组件设置
- 配置 Redis 连接设置,主要是主机地址、端口、密码凭证,包括
有关 container.yaml
配置的更多信息,请参阅 container 模块
-
运行 outfit with switch 示例:
对于终端/CLI 使用:输入和输出在终端窗口中
cd examples/step2_outfit_with_switch python run_cli.py
对于app/GUI 使用:输入和输出在应用程序中
cd examples/step2_outfit_with_switch python run_app.py
OmAgent的设计架构遵循三项基本原则:
- 基于图的工作流编排;
- 本地多模态;
- 设备中心化。
通过OmAgent,您有机会打造一个定制的智能代理程序。
为了更深入地理解OmAgent,让我们阐明一些关键术语:
Devices:OmAgent愿景的核心是通过人工智能代理赋予智能硬件设备力量,使设备成为OmAgent本质的关键组成部分。通过我们慷慨提供的可下载移动应用程序,您的移动设备可以成为连接到OmAgent的首个基础节点。设备用于接收环境刺激,如图像和声音,可能提供响应性反馈。我们已经发展了一个简化的后端流程来管理应用中心的业务逻辑,从而使开发人员能够集中精力构建智能代理的逻辑框架。
Workflow:在OmAgent框架中,智能代理的架构结构通过图形进行表达。开发人员可以自由创新、配置和序列化节点功能。目前,我们选择了Conductor作为工作流编排引擎,支持诸如switch-case、fork-join和do-while等复杂操作。
Task and Worker:在整个OmAgent工作流开发过程中,Task 和 Worker 是至关重要的概念。Worker 体现了工作流节点的实际操作逻辑,而 Task 负责编排工作流的逻辑。Task分为Operator,用于管理工作流逻辑(例如循环、分支)和 SimpleTask,代表由开发人员定制的节点。每个SimpleTask与一个Worker相关联;当工作流进展到特定的SimpleTask时,任务将被分派给相应的Worker进行执行。
-
模块化:将代理程序的功能拆分为独立的工作者,每个工作者负责一个特定的任务。
-
可重用性:设计工作者以便在不同的工作流程和代理程序中可重用。
-
可扩展性:通过添加更多工作者或调整工作流程顺序,利用工作流程来扩展代理程序的功能。
-
互操作性:工作者可以与各种后端进行交互,如LLMs、数据库或API,从而使代理程序能够执行复杂操作。
-
异步执行:工作流引擎和任务处理程序异步管理执行,实现资源的高效利用。
我们提供了一些示例项目来展示如何使用OmAgent构建智能代理程序。您可以在 examples 目录中找到完整的示例列表。以下是参考顺序:
- step1_simpleVQA 展示了如何使用OmAgent构建一个简单的多模态VQA智能体。文档
- step2_outfit_with_switch 展示了如何使用OmAgent构建一个带有switch-case分支的智能体。文档
- step3_outfit_with_loop 展示了如何使用OmAgent构建一个带有循环的智能体。文档
- step4_outfit_with_ltm 展示了如何使用OmAgent构建一个带有长期记忆的智能体。文档
- dnc_loop 展示了如何使用OmAgent构建一个使用DnC算法的智能体,用于解决通用性的复杂问题。文档
- video_understanding 展示了如何使用OmAgent构建一个视频理解智能体,用于理解视频内容。文档
完整的API文档请访问 这里.
如果您对多模态算法,大语言模型以及智能体技术感兴趣,欢迎进一步了解我们的研究工作:
🔆 How to Evaluate the Generalization of Detection? A Benchmark for Comprehensive Open-Vocabulary Detection(AAAI24)
🏠 Github Repository
🔆 OmDet: Large-scale vision-language multi-dataset pre-training with multimodal detection network(IET Computer Vision)
🏠 Github Repository
如果您发现我们的仓库对您有帮助,请引用我们的论文:
@article{zhang2024omagent,
title={OmAgent: A Multi-modal Agent Framework for Complex Video Understanding with Task Divide-and-Conquer},
author={Zhang, Lu and Zhao, Tiancheng and Ying, Heting and Ma, Yibo and Lee, Kyusong},
journal={arXiv preprint arXiv:2406.16620},
year={2024}
}