Sotopia 开源项目使用教程
sotopia 项目地址: https://gitcode.com/gh_mirrors/so/sotopia
1. 项目介绍
Sotopia 是一个开放式的社交学习环境,旨在让代理(agents)能够相互交互并与环境互动。该环境设计用于评估和促进语言代理的社交智能。Sotopia 具有以下特点:
- 开放式:环境可以轻松扩展以包含新的环境和新的代理。
- 可扩展:环境可以轻松扩展以包含大量代理和环境。
Sotopia 在 ICLR 2024 上作为 spotlight 项目展示。
2. 项目快速启动
安装
我们推荐使用虚拟环境进行安装,例如使用 Anaconda:
conda create -n sotopia python=3.11
conda activate sotopia
curl -sSL https://install.python-poetry.org | python3
然后安装 Sotopia:
python -m pip install sotopia
设置 OpenAI API 密钥
运行代码需要 OpenAI API 密钥,请设置环境变量 OPENAI_API_KEY
:
conda env config vars set OPENAI_API_KEY=your_key
运行示例服务器
您可以使用以下代码运行一个带有默认参数的示例服务器:
import asyncio
from sotopia.samplers import UniformSampler
from sotopia.server import run_async_server
asyncio.run(
run_async_server(
model_dict={
"env": "gpt-4",
"agent1": "gpt-3.5-turbo",
"agent2": "gpt-3.5-turbo"
},
sampler=UniformSampler()
)
)
或者运行以下命令:
python examples/minimalist_demo.py
3. 应用案例和最佳实践
应用案例
Sotopia 可以用于以下应用场景:
- 社交智能评估:通过模拟社交环境,评估语言代理的社交智能。
- 多代理交互:在开放式环境中,多个代理可以进行复杂的交互和学习。
最佳实践
- 环境扩展:根据需求扩展环境,添加新的环境和代理。
- 性能优化:通过调整模型参数和环境设置,优化系统的性能。
4. 典型生态项目
Sotopia 作为一个开放式社交学习环境,可以与其他项目结合使用,例如:
- OpenAI GPT 系列:作为语言模型的基础,提供强大的语言生成能力。
- Redis:用于数据存储和缓存,提高系统的响应速度。
通过这些生态项目的结合,Sotopia 可以构建更加复杂和智能的社交学习系统。