【机器学习】深度强化学习–RL的基本概念、经典场景以及算法分类
引言
深度强化学习(Deep Reinforcement Learning, DRL)是机器学习的一个分支,它结合了深度学习(Deep Learning)和强化学习(Reinforcement Learning, RL)的技术
文章目录
- 引言
- 一、深度强化学习–RL的基本概念
- 1.1 强化学习基础
- 1.2 强化学习的核心概念
- 1.2.1 探索(Exploration)与利用(Exploitation)
- 1.2.2 价值函数(Value Function)
- 1.2.3 Q函数(Q-function)
- 1.3 深度强化学习
- 1.3.1 深度神经网络
- 1.3.2 经验回放(Experience Replay)
- 1.3.3 目标网络(Target Network)
- 1.4 流行算法
- 1.4.1 深度Q网络(DQN)
- 1.4.2 异步优势演员评论家(A3C)
- 1.4.3 信任区域策略优化(TRPO)
- 1.4.4 近端策略优化(PPO)
- 1.4.5 模型预测控制(MPC)
- 1.5 应用领域
- 1.6 挑战
- 1.7 总结
- 二、强化学习的典型场景
- 三、强化学习算法分类
- 3.1 根据学习策略分类
- 3.1.1 策略学习(Policy Learning)
- 3.1.2 模型学习(Model Learning)
- 3.2 根据策略类型分类
- 3.3 根据学习方法分类
- 3.3.1 基于模型的强化学习(Model-Based Reinforcement Learning)
- 3.3.2 无模型强化学习(Model-Free Reinforcement Learning)
- 3.4 根据应用领域分类
- 3.4.1 离线强化学习(Off-Policy Reinforcement Learning)
- 3.4.2 在线强化学习(On-Policy Reinforcement Learning)
- 3.4.3 离线到在线学习(Off-Policy to On-Policy Learning)
- 3.5 总结
一、深度强化学习–RL的基本概念
1.1 强化学习基础
- 代理(Agent):执行动作并学习策略的主体
- 环境(Environment):代理与之交互的整个外部世界
- 状态(State):代理在环境中的当前情况
- 动作(Action):代理可以执行的操作
- 奖励(Reward):代理执行某个动作后,环境给予的正面或负面反馈
- 策略(Policy):代理用于决策的函数或规则,即给定当前状态,选择下一步动作的方法
1.2 强化学习的核心概念
1.2.1 探索(Exploration)与利用(Exploitation)
探索是指尝试新的动作以获取更多信息,而利用是基于现有信息做出最佳决策
1.2.2 价值函数(Value Function)
预测从某个状态开始,遵循特定策略能够获得的期望回报
1.2.3 Q函数(Q-function)
对于给定状态和动作,预测采取该动作后能够获得的期望回报
1.3 深度强化学习
深度强化学习结合了深度学习的感知能力和强化学习的决策能力
1.3.1 深度神经网络
用于近似价值函数或策略函数,处理复杂的输入,如图像
1.3.2 经验回放(Experience Replay)
存储代理的经验,并在训练时随机抽取批次来打破数据间的相关性,稳定学习过程
1.3.3 目标网络(Target Network)
用于生成目标Q值,帮助稳定训练过程
1.4 流行算法
1.4.1 深度Q网络(DQN)
使用深度神经网络来近似Q函数,能够处理高维输入空间
1.4.2 异步优势演员评论家(A3C)
并行训练多个代理,每个代理都在不同的环境中执行,以学习一个共享的全球策略
1.4.3 信任区域策略优化(TRPO)
一种策略梯度方法,使用信任区域来优化策略,保证改进的稳定性
1.4.4 近端策略优化(PPO)
TRPO的改进版本,更加简单且稳定
1.4.5 模型预测控制(MPC)
使用模型来预测未来状态,并基于这些预测做出最优决策
1.5 应用领域
- 游戏:如DeepMind的AlphaGo在围棋上的胜利
- 机器人技术:如机械臂的操控、自动驾驶汽车
- 资源优化:如数据中心能源管理
- 金融:如算法交易策略
1.6 挑战
- 稳定性和收敛性:深度强化学习算法可能会遇到训练不稳定的问题
- 样本效率:强化学习通常需要大量的交互数据
- 安全性:在现实世界中部署的代理需要能够安全地与动态环境互动
1.7 总结
深度强化学习是一个快速发展的领域,随着算法和计算资源的进步,它有望在更多领域实现突破
二、强化学习的典型场景
在 Flappy bird 这个游戏中,我们需要简单的点击操作来控制小鸟,躲过各种水管,飞的越远越好,因为飞的越远就能获得更高的积分奖励
- 机器有一个明确的小鸟角色——代理
- 需要控制小鸟飞的更远——目标
- 整个游戏过程中需要躲避各种水管——环境
- 躲避水管的方法是让小鸟用力飞一下——行动
- 飞的越远,就会获得越多的积分——奖励
三、强化学习算法分类
了解强化学习中常用到的几种方法,以及他们的区别,对我们根据特定问题选择方法时很有帮助。强化学习是一个大家族,发展历史也不短,具有很多种不同方法。比如说比较知名的控制方法 Q learning,Policy Gradients,还有基于对环境的理解的 model-based RL 等等
3.1 根据学习策略分类
3.1.1 策略学习(Policy Learning)
- 策略迭代(Policy Iteration):一种确定性策略,通过策略评估和策略改进来寻找最优策略。
- 值迭代(Value Iteration):一种策略评估方法,通过迭代更新状态值函数来找到最优策略。
3.1.2 模型学习(Model Learning)
- 模型预测控制(Model Predictive Control, MPC):在每一步都通过预测模型来选择动作。
- 无模型强化学习(Model-Free Reinforcement Learning):不需要了解环境模型的强化学习,如Q-Learning
3.2 根据策略类型分类
- 确定性策略(Deterministic Policy):在给定状态下,总是选择同一个动作
- 随机策略(Stochastic Policy):在给定状态下,选择动作的概率分布
3.3 根据学习方法分类
3.3.1 基于模型的强化学习(Model-Based Reinforcement Learning)
- 模型预测控制(MPC):在每一步都使用预测模型来选择动作
3.3.2 无模型强化学习(Model-Free Reinforcement Learning)
- Q-Learning:基于状态-动作值函数的强化学习算法
- Sarsa:与Q-Learning类似,但在选择下一个动作时使用当前策略
- 深度Q网络(DQN):结合了深度学习和Q-Learning的强化学习算法
- 策略梯度(Policy Gradient):直接学习策略,通过策略梯度来优化策略
- 近端策略优化(PPO):一种改进的策略梯度方法,通过近端策略优化来稳定训练过程
3.4 根据应用领域分类
3.4.1 离线强化学习(Off-Policy Reinforcement Learning)
- Q-Learning:学习状态-动作值函数,可以与离线数据一起使用
3.4.2 在线强化学习(On-Policy Reinforcement Learning)
- Sarsa:在线学习状态-动作值函数,需要实时与环境交互
3.4.3 离线到在线学习(Off-Policy to On-Policy Learning)
- 信任区域策略优化(TRPO):一种从离线策略转移到在线策略的方法
3.5 总结
这些分类方式可以帮助我们更好地理解强化学习算法的不同特性和适用场景。随着研究的不断深入,新的算法和分类方式也在不断涌现
相关文章:
【机器学习】深度强化学习–RL的基本概念、经典场景以及算法分类
引言 深度强化学习(Deep Reinforcement Learning, DRL)是机器学习的一个分支,它结合了深度学习(Deep Learning)和强化学习(Reinforcement Learning, RL)的技术 文章目录 引言一、深度强化学习–…...
【git】将本地文件上传到github
安装git 选择一个文件夹作为git仓库,cd到文件夹输入 git init文件夹出现.git文件夹,该文件夹默认为隐藏文件夹,设置为不隐藏 在cmd中输入 ssh-keygen -t rsa -C "xxxxxx.com"该邮箱为github邮箱,然后一路enter出现以…...
安卓应用开发学习:手机摇一摇功能应用尝试--摇骰子和摇红包
一、引言 前几天,我发布的日志《安卓应用开发学习:查看手机传感器信息》记录了如何查看手机传感器的信息,通过上述的方法,可以看到我的OPPO手机支持19种传感器。本篇日志就记录一下常见的加速度传感器的典型应用——“摇一摇”功…...
HTML中的<fieldset>标签元素框的使用
HTML 提供的 <fieldset> 标签用于在表单中分组相关元素。 <fieldset> 标签会在相关元素周围绘制一个框。 <legend> 标签为 fieldset 元素定义标题。 语法如下: <fieldset><legend>标题</legend><!-- 元素内容... -->…...
Linux驱动入门实验班——SR501红外模块驱动(附百问网视频链接)
目录 一、工作方式 二、接口图 三、编写思路 1.构造file_operations结构体 2.实现read函数 3.编写入口函数 4.编写中断处理函数 5.编写出口函数 6.声明出入口函数以及协议 四、源码 五、课程链接 一、工作方式 SR501人体红外感应模块有两种工作模式: …...
windows C++- Com技术简介(上)
在介绍C和winrt与COM组件技术的关系之前,有必要介绍一下com组件技术,这项技术比较古老,但是它一直作为windows的基石存在。COM 是一类独立于平台且面向对象的分布式系统,用于创建可交互的二进制软件组件。 COM 技术是 Microsoft O…...
Jenkins持续集成工具学习
一、从装修厨房看项目开发效率优化 二、持续集成工具 三、JavaEE项目部署方式对比 四、JenkinsSVN持续集成环境搭建 五、JenkinsGitHub持续集成环境搭建...
Redis:查询是否包含某个字符/字符串之三
上一篇:Redis:查询是否包含某个字符/字符串之二-CSDN博客 摘要: 遍历key,在跟进value的类型遍历value是否包含指定字符串 search_strings ,这里使用redis-py库,默认只能处理utf-8编码,如果存在…...
【Redis】数据类型详解及其应用场景
目录 Redis 常⻅数据类型预备知识基本全局命令小结 数据结构和内部编码单线程架构引出单线程模型为什么单线程还能这么快 Redis 常⻅数据类型 Redis 提供了 5 种数据结构,理解每种数据结构的特点对于 Redis 开发运维⾮常重要,同时掌握每种数据结构的常⻅…...
PARA-Drive:设计并行模型实现端到端自动驾驶
论文链接 https://openaccess.thecvf.com/content/CVPR2024/papers/Weng_PARA-Drive_Parallelized_Architecture_for_Real-time_Autonomous_Driving_CVPR_2024_paper.pdfhttps://openaccess.thecvf.com/content/CVPR2024/papers/Weng_PARA-Drive_Parallelized_Architecture_fo…...
vs2022 x64 C/C++和汇编混编 遇到的坑
vs2022 x64 C/C和汇编混编 遇到的坑 遇到的问题二、问题复现1.出错代码2.问题分析2.1 堆栈对齐问题 3.解决方案 总结奇数和偶数个寄存器的影响为什么 sub rsp, 8 对奇数个寄存器有用?结论 遇到的问题 0x00007FFFFAE24A29 (msvcp140.dll)处(位于 TestCompileConsole…...
PHP概述、环境搭建与基本语法讲解
目录 【学习目标、重难点知识】 什么是网站? 1. PHP 介绍 1.1. PHP 概述 1.1.1. PHP 是什么? 1.1.2. PHP 都能做什么? 1.2. PHP 环境搭建 1.2.1. PhpStudy 2. PHP 基本语法 2.1. PHP 语法入门 2.1.1. 第一个 PHP 程序 2.1.2. PHP …...
实现信创Linux麦克风摄像头录制(源码,银河麒麟、统信UOS)
随着信创国产化浪潮的来临,在国产操作系统上的应用开发的需求越来越多,其中一个就是需要在银河麒麟或统信UOS上实现录制摄像头视频和麦克风声音,将它们录制成一个mp4文件。那么这个要如何实现了? 一. 技术方案 要完成这些功能&a…...
深度学习9--目标检测
1.概念介绍 目标检测不仅可以检测数字,而且可以检测动物的种类、汽车的种类等。例如,自动驾驶车辆需要自动识别前方物体是车辆还是行人,需要自动识别道路两 旁的指示牌和前方的红绿灯颜色。对于自动检测的算法,有两个要求…...
第131天:内网安全-横向移动Kerberos 攻击SPN扫描WinRMWinRSRDP
案例一:域横向移动-RDP-明文&NTLM RDP利用的三种方式 1.直接在当前被控主机上进行远程连接 2.建立节点进行连接 3.端口转发,(访问当前主机的2222端口等于访问目标的3389) 第一种方式(动静太大) 直接利用被控主机进行远程连接…...
微信小程序的四种弹窗使用
在做小程序的过程中,弹窗也算是非常实用的功能了,这几天写的几个功能就用到了弹窗,也可能是初学者的问题,比较菜,想找一个可以带图片的自定义的弹窗,,这里简单介绍一下官方封装好的四个弹窗…...
我的第一个CUDA程序
MatAdd算法 实现两个矩阵对应元素相加 #include <stdio.h> #include <stdlib.h>// 矩阵加法函数 void MatAdd(int height, int width) {// 在主机内存中为 A、B 和 C 分配内存float* A (float*)malloc(height * width * sizeof(float));float* B (float*)malloc…...
workerman下的webman路由浏览器跨域的一种问题
软件版本 "php": ">7.2", "workerman/webman-framework": "^1.5.0",问题情景 使用“分组路由”做API接口前后端分离跨域,在接口测试工具调试是能正常获取数据的;但在网页浏览器上调试就遇到了CORS、404的错…...
Windows11 -MASKRCNN-部署测试
文章目录 Detectron2环境配置搭建python 环境安装Cuda \CUDNN 、PyTorch、 torchvision、cudatoolkit1、Cuda \CUDNN2、 PyTorch、 torchvision、cudatoolkit进入python测试:错误信息 3、detectron2环境在安装detecteron中,遇到报错:编译的时…...
函数(子程序)的常见、易混淆概念详解【对初学者有帮助】
C语⾔中的函数也被称做子程序,意思就是⼀个完成某项特定的任务的⼀小段代码。 C语⾔标准中提供了许多库函数,点击下面的链接可以查看c语言的库函数和头文件。 C/C官⽅的链接:https://zh.cppreference.com/w/c/header 目录 一、函数头与函…...
TiDB-从0到1-DM工具
TiDB从0到1系列 TiDB-从0到1-体系结构TiDB-从0到1-分布式存储TiDB-从0到1-分布式事务TiDB-从0到1-MVCCTiDB-从0到1-部署篇TiDB-从0到1-配置篇TiDB-从0到1-集群扩缩容TiDB-从0到1-数据导出导入TiDB-从0到1-BR工具 一、DM原理 支持全量抽取数据\检测新的数据变化同步到下游实例…...
AppScan——Web 应用安全扫描的得力工具
一、引言 在当今数字化时代,Web 应用成为企业业务的重要支撑,但同时也面临着各种安全威胁。AppScan 作为一款专业的 Web 应用安全扫描工具,为保障 Web 应用的安全性提供了有力的支持。本文将对 AppScan 进行详细介绍,包括其功能、…...
虚幻5|AI行为树,进阶篇
一,打开敌人的角色蓝图,编写以下蓝图,该蓝图只是创建一个敌人并非ai行为树 1.编写蓝图 2.打开主界面,创建一个导航网格体积,上一章都有讲,在添加体积这里面,找到导航网格体积,点击创…...
在 Spring Boot 中配置 Tomcat 监听多个端口
在现代微服务架构中,应用程序可能需要监听多个端口,以支持不同的服务或协议。Spring Boot 提供了灵活的配置选项,使得这一需求变得简单而高效。本文将介绍如何在 Spring Boot 中配置 Tomcat 以监听多个端口,并简要说明其中一些关键…...
stm32f407新建项目工程及烧录
1、新建一个文件夹,打开keil5将项目工程放入文件夹中 2、弹出选择对应型号设备 3、弹出选择对应库 可以看见出现下图:感叹号表示有错 最后如图所示:点击ok就行了 4、创建对应的文件夹存放文件 4、建立main.c 5、添加对应的设置 最后写一个空白…...
c++中加不加const的值传递和引用传递的区别
文章目录 可以修改参数值的比较值传递(int x)和引用传递(int &x)使用const不修改参数值的比较值传递(const int x)和引用传递(const int &x)1. const int x 示例2. const int &x 示例 可以修改参数值的比较值传递(int x)和引用传递(int &x) #include <iost…...
Qt的窗口设置
本文介绍Qt的窗口设置。 采用Qt开发界面程序,会涉及到窗口的设置,如窗口标题栏是否显示,是否有最小,最大化按钮等,窗口当前显示最小化,最大化等。本文简要介绍常用的窗口设置方法。 1.窗口属性 窗口属性…...
51单片机-LCD1602显示屏
简介 是一个液晶显示屏,通过电压对显示区域进行控制,有电就显示。 能够同时显示32个字符,分为两行,一行显示16个字符。可以显示的内容只能是字母、数字或者一些特殊符号。 使用ASCII码来让LCD1602来显示对应的字符。 电路图 …...
多模态分析代理 MAIA:多智能体解决 视觉模型 黑盒问题
多模态分析代理 MAIA:多智能体解决 视觉模型 黑盒问题 论文:https://arxiv.org/pdf/2404.14394 代码:https://github.com/multimodal-interpretability/maia 提出背景 神经网络方法提取的特征,没有可解释性。 数据在通过多个层…...
AT360-6T杭州中科微单频高精度授时模块场景应用
AT360-6T是一款高性能多系统卫星定位授时模块,基于自主研发的北斗多系统SOC芯片,可以同时接收中国的BDS(北斗二号和北斗三号)、美国的GPS、俄罗斯的GLONASS、欧盟的 GALILEO 和日本的QZSS等多个卫星导航系统的GNSS信号来实现多系统联合定位授时ÿ…...
苏州建网站哪个好/网络营销推广方案有哪些
万科官方公众号发声:王石“认输”?假的! 2015-12-23 20:34:10 来源: 网易财经分享到: 2740(原标题:万科官方公众号发声:王石“认输”?假的!)(来源…...
杭州网站建站/行业关键词词库
首先去特硬去下载vscode的安装包 mkdir /tmp/vscode cd /tmp/vscode/ wget https://az764295.vo.msecnd.net/public/0.3.0/VSCode-linux-x64.zip 解压安装包 unzip /tmp/vscode/VSCode-linux-x64.zip -d /opt/ 此时就可以正常运行VSCode了 sudo chmod x /opt/VSCode-linux-x64/…...
网站制作收费明细表/百度推广代理商有哪些
前言现在越来越多项目都采用前后端分离模式开发,这样前后端就可以同时开发,而且互不影响。但是目前项目跟进的很紧,没什么时间写后台,但是前端没接口测试可能会隐藏很多bug,到后面再来排查就麻烦了。所以在后端接口没有…...
美图在线图片编辑器/广州seo公司官网
计算机基础-SQL详细教学-SQL教学SQL 基础SQL 语法数据库表一个数据库通常包含一个或多个表。每个表由一个名字标识(例如“客户”或者“订单”)。表包含带有数据的记录(行)。下面的例子是一个名为 "Persons" 的表:IdLastNameFirstNameAddressCity1AdamsJoh…...
参考消息官方网站/软文广告营销
一、A a(1) 栈中分配,隐式调用,栈中内存的分配和释放是由系统管理 二、A b A(1) 栈中分配,显式调用 三、A* c new A(1) 堆中分配,堆中内存的分配和释放必须由程序员手动释放。采用第三种方式时,必须注意一下几点问…...
微信开发功能/合肥seo
/** 250.Count Univalue Subtrees* 2016-7-21 by Mingyang* 先列出我的解法:自底向上,而且使用了二维数组来进行传递,第一个数有0,1两种可能性* 0就表示root节点的sub不是uni的,1就表示是uni的,第二个就表示…...