【亲测免费】 Tianshou 强化学习平台教程
2026-01-19 10:51:09作者:冯爽妲Honey
项目介绍
Tianshou(天授)是一个基于纯 PyTorch 的强化学习平台。与现有的主要基于 TensorFlow 的强化学习库不同,Tianshou 提供了快速的框架和友好的 Python API,用于构建深度强化学习代理。Tianshou 支持多种强化学习算法,并且具有多 GPU 训练的能力。
项目快速启动
安装
你可以通过以下命令从 PyPI 安装 Tianshou:
pip install tianshou
如果你使用 Anaconda 或 Miniconda,可以通过以下命令从 conda-forge 安装 Tianshou:
conda install tianshou -c conda-forge
快速启动示例
以下是一个简单的 DQN 示例代码:
import gym
import tianshou as ts
from tianshou.policy import DQNPolicy
from tianshou.trainer import offpolicy_trainer
from tianshou.data import Collector, ReplayBuffer
# 创建环境
env = gym.make('CartPole-v0')
train_envs = ts.env.DummyVectorEnv([lambda: gym.make('CartPole-v0') for _ in range(8)])
test_envs = ts.env.DummyVectorEnv([lambda: gym.make('CartPole-v0') for _ in range(100)])
# 定义策略
net = ts.net.DQN((env.observation_space.shape[0],), env.action_space.n)
optim = ts.optim.Adam(net.parameters(), lr=1e-3)
policy = DQNPolicy(net, optim, discount_factor=0.99)
# 数据收集器和回放缓冲区
buffer = ReplayBuffer(20000)
train_collector = Collector(policy, train_envs, buffer)
test_collector = Collector(policy, test_envs)
# 训练
result = offpolicy_trainer(
policy, train_collector, test_collector,
max_epoch=10, step_per_epoch=10000, collect_per_step=10,
batch_size=64, test_in_train=False
)
print(result)
应用案例和最佳实践
案例一:多智能体强化学习
Tianshou 支持多智能体强化学习(MARL),可以用于解决多个智能体在同一环境中的协同或竞争问题。以下是一个简单的多智能体示例:
import tianshou as ts
from tianshou.policy import MultiAgentPolicyManager, DQNPolicy
from tianshou.data import Collector
# 创建环境
env = ts.env.MultiAgentEnv('simple_spread')
# 定义策略
policies = [DQNPolicy for _ in range(env.n_agents)]
manager = MultiAgentPolicyManager(policies, env)
# 数据收集器
collector = Collector(manager, env)
# 训练
result = ts.trainer.onpolicy_trainer(
manager, collector,
max_epoch=10, step_per_epoch=10000, collect_per_step=10,
batch_size=64, test_in_train=False
)
print(result)
案例二:自定义强化学习算法
Tianshou 允许用户自定义强化学习算法。以下是一个自定义算法的示例:
import tianshou as ts
from tianshou.policy import BasePolicy
class CustomPolicy(BasePolicy):
def __init__(self, net, optim):
super().__init__()
self.net = net
self.optim = optim
def forward(self, batch, state=None):
# 自定义前向传播逻辑
pass
def learn(self, batch):
# 自定义学习逻辑
pass
# 创建环境
env = gym.make('CartPole-v0')
# 定义网络和优化器
net = ts.net.MLP((env.observation_space.shape[0],), env.action_space.n)
optim = ts.optim.Adam(net.parameters(), lr=1e-3)
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
285
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108