news 2026/6/15 17:14:59

探索强化学习:DQN算法与Q - learning算法的奇妙对决

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
探索强化学习:DQN算法与Q - learning算法的奇妙对决

DQN算法 Q-learning算法 让红色方格自己寻找最便捷的路径避开障碍物到达黄色圆圈,非常的智能 视频里是DQN的训练过程,全程只需要3分钟 Q-learning需要训练半小时

在强化学习的世界里,Q - learning和DQN算法就像两颗璀璨的明星,各自闪耀着独特的光芒。今天咱们就通过一个有趣的例子,看看它们如何各显神通。

想象有一个场景,红色方格要在布满障碍物的环境中,找到一条最便捷的路径,最终抵达黄色圆圈。这就像是一场充满挑战的冒险游戏。

Q - learning算法

Q - learning是强化学习中的经典算法。它的核心思想是通过不断试错,学习在不同状态下采取何种行动能够获得最大的累计奖励。在这个例子里,红色方格所处的每个位置就是一个状态,而它能采取的上、下、左、右移动就是行动。

下面简单用Python代码展示一下Q - learning的基础框架(这里只是简单示意,实际完整代码会更复杂):

import numpy as np # 初始化Q表,假设环境大小为10x10 Q = np.zeros((10, 10, 4)) # 定义学习率 alpha = 0.1 # 定义折扣因子 gamma = 0.9 # 假设这里有个函数能获取当前状态下所有可能行动的奖励 def get_rewards(state): # 简单返回全0奖励,实际需根据环境计算 return np.zeros(4) # Q - learning更新过程 current_state = (0, 0) for _ in range(1000): current_state_index = np.unravel_index(current_state, (10, 10)) action = np.argmax(Q[current_state_index]) rewards = get_rewards(current_state) new_state = # 根据行动更新状态,这里省略具体实现 new_state_index = np.unravel_index(new_state, (10, 10)) Q[current_state_index][action] = (1 - alpha) * Q[current_state_index][action] + \ alpha * (rewards[action] + gamma * np.max(Q[new_state_index])) current_state = new_state

在这个代码片段中,我们首先初始化了一个Q表,用来存储每个状态 - 行动对的价值。然后通过循环不断更新Q表,根据当前状态选择价值最大的行动,再根据获得的奖励和新状态更新Q表中的值。但这个过程需要相对较长的训练时间,在咱们这个例子里,需要训练半小时之久。这是因为Q - learning在处理复杂环境时,Q表的维度会随着状态和行动数量的增加而急剧膨胀,计算量变得非常大。

DQN算法

DQN(深度Q网络)则是Q - learning与深度学习的结合体,它使用神经网络来近似Q函数,从而解决了Q - learning在处理高维状态空间时的困境。

同样用简单代码展示一下DQN的基础构建(同样为示意,非完整代码):

import torch import torch.nn as nn import torch.optim as optim # 定义简单的神经网络模型 class QNetwork(nn.Module): def __init__(self, state_size, action_size): super(QNetwork, self).__init__() self.fc1 = nn.Linear(state_size, 128) self.fc2 = nn.Linear(128, action_size) def forward(self, x): x = torch.relu(self.fc1(x)) return self.fc2(x) # 初始化网络、优化器等 state_size = 2 # 假设状态空间维度为2 action_size = 4 # 假设行动数量为4 q_network = QNetwork(state_size, action_size) optimizer = optim.Adam(q_network.parameters(), lr=0.001) criterion = nn.MSELoss() # DQN训练过程 for _ in range(100): state = torch.FloatTensor([0, 0]) # 初始状态 action = torch.argmax(q_network(state)).item() # 假设这里获取奖励和新状态 reward = 0 new_state = torch.FloatTensor([0, 1]) q_value = q_network(state)[action] target = reward + gamma * torch.max(q_network(new_state)) loss = criterion(q_value, target) optimizer.zero_grad() loss.backward() optimizer.step()

在这里,我们定义了一个简单的神经网络QNetwork来近似Q函数。通过不断训练这个网络,让它学会在不同状态下选择最优行动。DQN的优势就在于,它利用神经网络强大的函数逼近能力,能够处理复杂的状态空间,而且训练速度相对更快。在视频里,用DQN完成红色方格找路径的训练过程,全程只需要3分钟。这得益于神经网络可以更高效地处理信息,通过梯度下降等优化算法快速更新网络参数。

通过这个红色方格找路径的例子,我们能清楚看到DQN算法在训练效率上相较于Q - learning算法的巨大优势。但每种算法都有其适用场景,Q - learning简单直观,在一些状态空间较小的场景中依然发挥着重要作用,而DQN则在面对复杂的高维状态空间时更胜一筹。这就像是不同的工具,在强化学习的大工具箱里,各自有着独特的用途。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:49:17

用foreach快速构建数据处理原型:3个实用案例

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个基于foreach的快速数据处理原型生成器。用户可以选择数据类型(CSV/JSON/数组)和处理需求(过滤/转换/聚合),系统自动生成使用foreach的实现代码。功能包括&#…

作者头像 李华
网站建设 2026/6/15 13:15:41

企业级Maven配置实战:从安装到多环境部署

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个企业级Maven配置演示项目,包含:1.本地仓库与Nexus私服配置 2.多环境profile配置(dev/test/prod) 3.父子模块依赖管理 4.Jenkins集成配置 5.代码质量…

作者头像 李华
网站建设 2026/6/14 3:22:47

WSL2 多 GPU CUDA 初始化问题排查与解决指南

适用对象: WSL2 NVIDIA 多 GPU(如 4RTX 4090) PyTorch / CUDA 深度学习用户 科研训练、图像去噪、模型开发等场景 一、问题背景与典型现象 在 WSL2 中使用 PyTorch 时,可能出现如下情况: UserWarning: CUDA init…

作者头像 李华
网站建设 2026/6/14 13:47:40

ONNX Runtime:AI模型部署的终极加速器

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个Python项目,展示如何使用ONNX Runtime加载和运行预训练的ONNX模型。项目应包括以下功能:1. 从本地或云端加载ONNX模型文件;2. 准备输入数…

作者头像 李华
网站建设 2026/6/15 15:59:09

Vulkan教程(十):交换链,Vulkan图像呈现的核心基础设施

目录 Vulkan 不存在 “默认帧缓冲” 的概念,因此要将渲染结果显示到屏幕上,必须先构建一套专属的基础设施 —— 用于管理待呈现图像缓冲区的交换链(Swap Chain)。交换链需显式创建,本质上是一个等待被显示到屏幕的图像队列:应用程序从队列中获取图像进行绘制,完成后将其…

作者头像 李华