PyTorch教程:强化学习实战指南(基于niconielsen32/pytorch-tutorials项目)
2025-06-19 09:01:01作者:姚月梅Lane
强化学习基础概念
强化学习(Reinforcement Learning)是机器学习的一个重要分支,它通过智能体(Agent)与环境(Environment)的交互来学习最优策略。与监督学习不同,强化学习不需要预先标记的数据,而是通过试错和奖励信号来指导学习过程。
强化学习的核心要素包括:
- 状态(State):描述环境的当前情况
- 动作(Action):智能体可以采取的行为
- 奖励(Reward):环境对智能体动作的反馈
- 策略(Policy):从状态到动作的映射规则
- 价值函数(Value Function):评估状态或状态-动作对的长期价值
环境构建:网格世界
在本教程中,我们首先构建了一个简单的网格世界环境(GridWorld),这是理解强化学习基础概念的理想起点。
class GridWorld:
"""5x5网格世界环境"""
def __init__(self, size=5):
self.size = size
self.reset()
def reset(self):
"""重置环境到初始状态"""
self.agent_pos = [0, 0] # 智能体起始位置
self.goal_pos = [self.size-1, self.size-1] # 目标位置
self.done = False
return self._get_state()
def _get_state(self):
"""获取当前状态表示"""
state = np.zeros((self.size, self.size))
state[self.agent_pos[0], self.agent_pos[1]] = 1 # 标记智能体位置
state[self.goal_pos[0], self.goal_pos[1]] = 2 # 标记目标位置
return state.flatten()
这个环境具有以下特点:
- 5x5的网格空间
- 智能体从左上角(0,0)出发
- 目标是到达右下角(4,4)
- 每步动作会获得-0.1的惩罚(鼓励尽快到达目标)
- 到达目标获得+10的奖励
深度Q网络(DQN)实现
DQN是深度强化学习的里程碑算法,它结合了Q学习和深度神经网络,能够处理高维状态空间。
网络结构设计
class DQN(nn.Module):
"""DQN网络结构"""
def __init__(self, state_size, action_size, hidden_size=128):
super().__init__()
self.fc1 = nn.Linear(state_size, hidden_size)
self.fc2 = nn.Linear(hidden_size, hidden_size)
self.fc3 = nn.Linear(hidden_size, action_size)
def forward(self, x):
x = F.relu(self.fc1(x))
x = F.relu(self.fc2(x))
x = self.fc3(x)
return x
这个网络包含三个全连接层,使用ReLU激活函数,输出层直接输出每个动作的Q值估计。
经验回放机制
经验回放(Experience Replay)是DQN的关键技术,它通过存储和随机采样过去的经验来打破数据间的相关性。
Transition = namedtuple('Transition', ('state', 'action', 'next_state', 'reward', 'done'))
class ReplayBuffer:
"""经验回放缓冲区"""
def __init__(self, capacity=10000):
self.buffer = deque(maxlen=capacity)
def push(self, *args):
"""保存一个转移"""
self.buffer.append(Transition(*args))
DQN智能体实现
class DQNAgent:
"""DQN智能体实现"""
def __init__(self, state_size, action_size, lr=1e-3, gamma=0.99,
epsilon=1.0, epsilon_decay=0.995, epsilon_min=0.01):
# 初始化参数
self.q_network = DQN(state_size, action_size).to(device)
self.target_network = DQN(state_size, action_size).to(device)
self.optimizer = optim.Adam(self.q_network.parameters(), lr=lr)
self.memory = ReplayBuffer()
def act(self, state, training=True):
"""ε-贪婪策略选择动作"""
if training and random.random() < self.epsilon:
return random.randint(0, self.action_size - 1)
state_tensor = torch.FloatTensor(state).unsqueeze(0).to(device)
with torch.no_grad():
q_values = self.q_network(state_tensor)
return q_values.argmax().item()
训练过程分析
DQN的训练过程包含几个关键步骤:
- 初始化环境和智能体
- 智能体与环境交互,收集经验
- 从经验回放中采样小批量数据
- 计算当前Q值和目标Q值
- 通过最小化均方误差更新网络参数
- 定期更新目标网络
策略梯度方法:REINFORCE
REINFORCE是一种基于蒙特卡洛的策略梯度方法,它直接优化策略参数以最大化期望回报。
策略网络设计
class PolicyNetwork(nn.Module):
"""策略网络"""
def __init__(self, state_size, action_size, hidden_size=128):
super().__init__()
self.fc1 = nn.Linear(state_size, hidden_size)
self.fc2 = nn.Linear(hidden_size, hidden_size)
self.fc3 = nn.Linear(hidden_size, action_size)
def forward(self, x):
x = F.relu(self.fc1(x))
x = F.relu(self.fc2(x))
return F.softmax(x, dim=-1) # 输出动作概率分布
REINFORCE算法实现
class REINFORCEAgent:
"""REINFORCE智能体"""
def train(self):
"""使用收集的奖励更新策略"""
R = 0
policy_loss = []
returns = []
# 计算折扣回报
for r in self.rewards[::-1]:
R = r + self.gamma * R
returns.insert(0, R)
# 标准化回报
returns = torch.tensor(returns)
returns = (returns - returns.mean()) / (returns.std() + 1e-9)
# 计算策略梯度损失
for log_prob, R in zip(self.saved_log_probs, returns):
policy_loss.append(-log_prob * R)
# 参数更新
self.optimizer.zero_grad()
policy_loss = torch.cat(policy_loss).sum()
policy_loss.backward()
self.optimizer.step()
实验结果与可视化
通过训练过程的可视化,我们可以直观地理解算法的学习过程:
- 训练得分曲线:展示智能体在训练过程中获得的累计奖励变化
- 损失函数曲线:反映Q网络或策略网络的优化过程
- ε衰减曲线:显示探索率随训练的变化
- 学习路径可视化:展示训练后智能体在环境中的移动路径
强化学习实践建议
- 超参数调优:学习率、折扣因子γ、探索率ε等参数对性能影响很大
- 奖励设计:合理的奖励函数对算法收敛至关重要
- 网络结构:根据任务复杂度调整网络深度和宽度
- 训练技巧:适当使用目标网络、双网络等技术提高稳定性
- 评估方法:定期测试智能体性能,避免过拟合训练环境
通过本教程,读者可以掌握使用PyTorch实现强化学习算法的核心方法,为进一步研究更复杂的强化学习问题打下坚实基础。
登录后查看全文
热门项目推荐
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00
最新内容推荐
STM32到GD32项目移植完全指南:从兼容性到实战技巧 JDK 8u381 Windows x64 安装包:企业级Java开发环境的完美选择 开源电子设计自动化利器:KiCad EDA全方位使用指南 网页设计期末大作业资源包 - 一站式解决方案助力高效完成项目 STDF-View解析查看软件:半导体测试数据分析的终极工具指南 Adobe Acrobat XI Pro PDF拼版插件:提升排版效率的专业利器 MQTT 3.1.1协议中文版文档:物联网开发者的必备技术指南 Jetson TX2开发板官方资源完全指南:从入门到精通 昆仑通态MCGS与台达VFD-M变频器通讯程序详解:工业自动化控制完美解决方案 ONVIF设备模拟器:开发测试必备的智能安防仿真工具
项目优选
收起
deepin linux kernel
C
24
9
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
64
19
暂无简介
Dart
670
155
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
660
308
Ascend Extension for PyTorch
Python
219
236
仓颉编译器源码及 cjdb 调试工具。
C++
134
867
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
392
3.82 K
React Native鸿蒙化仓库
JavaScript
259
322