译文《Learning to Drive in a Day》

news2025/1/18 6:46:19

摘要——我们展示了深度强化学习在自动驾驶中的首次应用。从随机初始化的参数中,我们的模型能够使用单个单眼图像作为输入,在少数训练集中学习车道跟随策略。我们提供一个通用且易于获得的奖励:车辆在没有安全驾驶员控制的情况下行驶的距离。我们使用一种连续的、无模型的深度强化学习算法,所有的探索和优化都在车辆上进行。这证明了自动驾驶的一个新框架,它摆脱了对定义的逻辑规则、映射和直接监督的依赖。我们讨论了将这种方法扩展到更广泛的自动驾驶任务的挑战和机遇。

一、简介

自动驾驶是一个吸引了研究界和公司大量关注的话题,因为它有可能从根本上改变移动性和交通。从广义上讲,迄今为止,大多数方法都侧重于在标注的3D几何地图中定义驾驶行为的形式逻辑。这可能很难扩展,因为它严重依赖外部映射基础设施,而不是主要使用对本地场景的理解。

为了使自动驾驶成为一种真正普遍的技术,我们提倡机器人系统,该系统能够解决在没有地图和明确规则的情况下驾驶和导航的能力,就像人类一样,依靠对直接环境的全面理解[1],同时遵循简单的更高级别的方向(例如,转弯路线命令)。该领域的最新工作表明,使用GPS进行粗略定位和LIDAR了解当地场景,这在农村乡村道路上是可行的[2]。

近年来,强化学习(RL)——一个专注于解决马尔可夫决策问题(MDP)[3]的机器学习子领域,其中智能体学习在环境中选择动作以试图最大化某些奖励函数——已经显示出在围棋[4]或国际象棋[5]等游戏中实现超人结果的能力,在计算机游戏[6]等模拟环境中具有巨大的潜力, 以及使用机器人操纵器的简单任务 [7]。我们认为,强化学习的普遍性使其成为应用于自动驾驶的有用框架。最重要的是,它提供了一种纠正机制来改善习得的自动驾驶行为。为此,在本文中,我们:

1)将自动驾驶作为MDP,解释如何设计这个问题的各种元素,使其更容易解决,同时保持其通用性和可扩展性,

2)表明规范RL算法(深度确定性策略梯度[8])可以在仿真环境中快速学习简单的自动驾驶任务,

3)讨论在真实车辆上学习高效和安全驾驶所需的系统设置,

4)在几集中学习驾驶现实世界的自动驾驶汽车,使用连续的深度强化学习算法,仅使用车载计算。

因此,我们首次展示了驱动真实汽车的深度强化学习代理。

二、相关工作

我们相信这是第一项证明深度强化学习是自动驾驶可行方法的工作。我们被它超越模仿学习的潜力所激励,并希望研究界从强化学习的角度更仔细地研究自动驾驶。当前文献中最接近的工作主要可以归类为模仿学习或依赖映射的经典方法。

a)映射方法:自早期示例[9]、[10]以来,自动驾驶汽车系统已被设计为使用先进的传感和控制算法[11]、[12]、[13]在复杂环境中安全导航。这些系统传统上由许多特定的独立工程组件组成,如感知、状态估计、映射、规划和控制[14]。然而,由于每个组件都需要单独指定和调整,因此由于复杂的相互依赖性,这很难扩展到更困难的驾驶场景。

为实现这一模块化方法,已将大量精力集中在计算机视觉组件上。诸如[15]的定位有助于在映射环境中控制车辆[16],而诸如语义分割[1]的感知方法使机器人能够解释场景。这些模块化任务得到了[17]和[18]等基准的支持。

这些模块化映射方法在很大程度上是开发自动驾驶系统的商业努力的重点;然而,它们提出了一个极其复杂的系统工程挑战,这一挑战尚未解决。

b)模仿学习:一些驾驶任务的最新方法是模仿学习[19],[20],其目的是通过观察专家演示来学习控制策略。这种方法的一个重要优点是,它可以使用端到端深度学习,针对最终目标联合优化模型的所有参数,从而减少每个组件的调整工作量。然而,模仿学习在规模上也具有挑战性。对于代理可能遇到的每个潜在场景,不可能获得专家示例来模拟,而且处理已演示策略的分布(例如,在每条车道上行驶)是一项挑战。

c)强化学习:强化学习是一类用于解决马尔可夫决策问题 (MDP) 的宽泛算法 [21]。MDP 包括:

• 一组状态 S,

• 一组 A 动作,

• 转移概率函数 p:S × A → P(S),它为每对 (s,a) ∈ S × A 分配一个概率分布 p(·|s,a)表示概率使用操作 A 从状态 S 进入状态,

• 奖励函数 R:S ×S ×A → R,它描述了与使用操作从状态 st 进入状态 st+1 相关的奖励 R(st+1,st,at),

• 未来折扣系数γ ∈ [0,1] 表示我们对未来奖励的关心程度。

MDP的解决方案是一个策列π: S→ A对每一个s0 ∈ S 最大化:

(1)

式中根据 p(st+1|st(st))对st+1采样计算期望值。

在我们的设置中,我们使用有限时间范围T代替上述公式中的无穷大。这相当于其中一个状态是终端,即它不能被转义,并且在该状态下的任何操作都不会给出任何奖励。

将上述方程重新排列为递归形式,我们得到两个Bellman方程之一:

(2)

这里期望根据 p(s1|s0(s0))对s1进行采样计算。作为参考,让我们给出另一个Bellman方程:

(3)

其中 Qπ(s0,a0)是从状态 s0 开始,遵循策略 π,执行操作 a0 开始收到的预期累积折扣奖励。再次根据 p(s1|s0,a0) 对s1 进行采样计算期望值。

换句话说,强化学习算法旨在学习获得高累积奖励的策略 π。它们通常分为两类:基于模型的强化学习和无模型的强化学习。在前一种方法中,学习转换和奖励函数的显式模型,然后用于查找在这些估计函数下最大化累积奖励的策略。在后者中,我们直接估计在状态 s 中执行操作 a 的值 Q(s,a),然后遵循选择每个状态中估计值最高的操作的策略。

无模型强化学习非常普遍。使用它,我们可以(理论上)学习我们可以想象的任何任务,而基于模型的算法只能像学习的模型一样好。另一方面,基于模型的方法往往比无模型的方法更有数据效率。有关进一步讨论,请参见[22]。

在自动驾驶中,深度学习已用于使用离线数据学习基于模型的强化学习的动力学模型[23]。强化学习也被用于学习视频游戏中的自动驾驶代理。然而,这可能只是一个问题,因为可以获得真实世界中无法获得的地面真实奖励信号,例如汽车与车道的角度[8]。

与本文最接近的工作来自Riedmiller等人[24],他们训练了一个强化学习代理,该代理在无障碍环境中驾驶车辆遵循GPS轨迹。他们演示了使用基于GPS阈值跟踪误差的密集奖励函数在车上学习。我们在这项工作的基础上采取了多种方式;我们通过基于图像的输入,使用稀疏奖励函数进行车道跟踪,演示了如何通过深度学习学习驾驶。

三、 系统体系结构

A.作为马尔可夫决策过程的驾驶

本文的一个重点是将驾驶作为MDP进行设置。我们的目标是自动驾驶,状态空间S、动作空间A和奖励函数R的精确定义由我们自由定义。一旦状态和动作表示被固定,过渡模型就被隐式固定,剩余的自由度——过渡本身——由所使用的模拟器/车辆的力学决定。

a) 状态空间:定义状态空间的关键是算法在每个时间步接收的观察值 Ot 的定义。为了为驾驶算法提供复杂的观察,已经开发了许多传感器,不仅限于激光雷达、IMU、GPS 单元和红外深度传感器;无穷无尽的预算可以花在先进的传感技术上。在本文中,我们表明,对于简单的驾驶任务,使用单眼摄像头图像以及观察到的车速和转向角就足够了。从理论上讲,状态st是所有先前观测值的马尔可夫表示。固定长度近似马尔可夫状态可以通过例如使用递归神经网络递归组合观测值来获得。但是,对于我们考虑的任务,观察本身可以作为状态的足够好的近似。

第二个考虑因素是如何对待图像本身:原始图像可以通过一系列卷积直接输入强化学习算法[25];或者,可以使用图像的小压缩表示,例如使用变分自动编码器(VAE)[26] [27]。我们在第四节中使用这两种方法比较了强化学习的性能。在我们的实验中,我们使用KL损失和L2重建损失从五个纯随机探索事件中在线训练VAE [27]。

b) 动作空间:驾驶本身有一组人们可能认为是自然的动作:油门、刹车、信号等。但是强化学习算法的输出应该是什么领域?节气门本身可以被描述为在与[0,1]等距的范围内的离散、开或关或连续。另一种方法是根据速度设定点重新调整节气门的参数,通过经典控制器的节气门输出来匹配设定点。总之,在一个简单的模拟器上进行的实验(第IV-a节)表明,连续的动作虽然有些难以学习,但提供了一个更平滑的控制器。我们使用二维动作空间;转向角在[-1,1]范围内,速度设定值以km/h为单位。

c) 奖励功能:奖励功能的设计可以接近监督学习–给定车道分类系统,可以根据最小化距车道中心的预测距离来设置学习车道跟随的奖励,即[8]中的方法。这种方法在规模上是有限的:系统只能像手工制作的奖励背后的人类直觉一样好。我们不采取这种做法。相反,我们将奖励定义为前进速度,并在违反交通规则时终止事件——因此,给定状态V(st)的值对应于违反交通规则前的平均行驶距离。可以识别的一个故障是,代理人可能选择避免更困难的操作,例如在英国右转(在美国左转)。在未来的工作中可以使用命令条件奖励来避免这种情况。

B. 强化学习算法——深度确定性策略梯度

我们选择了一个简单的连续动作域无模型强化学习算法:深度确定性策略梯度(DDPG)[8],以表明没有特定于任务的适应的现成强化学习算法能够解决III-A节中提出的MDP。

DDPG 由两个函数逼近器组成:一个评论家 Q:S × A → R,它估计在状态 s 中使用动作 a 时预期累积折扣奖励的值 Q(s,a),经过训练以满足贝尔曼方程

通过演员给出的策略π:S->A,该策略尝试预估一个Q优化的策略;这里(st,at,rt+1,dt+1,st+1)是一个经验元组,从过去经验中选择一个从使用动作at状态st到st+1并获得奖励rt+1和“done”标志dt+1的转移格式。评论家试图最小化的Belllman等式中的误差,被称为时差(TD)误差。存在许多演员-评论家方法的变体,参见[28],[29]。

DDPG训练在线完成。除了在真实车辆上设置这样的缓冲区的基础设施之外(这要求它能够容忍缺失/故障事件,并且可以随时停止),通过从回放缓冲区中选择最“信息丰富”的示例,可以加快强化学习。我们使用一种通常建立的称为优先体验回放的方法[30]来实现这一点:我们对经验元组进行采样,其概率与评论家的TD误差成比例。用于此采样的权重在每个优化步骤时以最小开销进行更新;新的样本被赋予无限的权重,以确保所有样本至少被看到一次。

DDPG 是一种非策略学习算法,这意味着在训练期间执行的操作来自与参与者的学习最优策略不同的策略。这样做是为了在最优策略看到的狭隘分布之外获得不同的状态操作数据,从而提高稳健性。我们在连续强化学习方法的背景下使用标准方法来实现这一目标:我们的勘探策略是通过将离散的Ornstein-Uhlenbeck过程噪声[31]添加到最佳策略中形成的。因此,在每一步中,我们都会添加最佳动作噪声xt,如下所示:

(4)

其中 θ,μ,σ 是超参数,是从正态分布 N(0,1) 采样的 i.i.d. 随机变量。这些参数需要仔细调整,因为在噪音效用和安全驾驶员的舒适性之间需要直接权衡。强烈均值还原噪声具有较低的方差更容易预测,而方差较高的噪声提供更好的状态-动作空间覆盖范围。

while True do
    Request task
    Waiting for environment reset
    if task is train then
        Run episode with noisy policy
        if exploration time is over then
            Optimize model
        end if
    else if task is test then
        Run episode with optimal policy
    else if task is undo then
        Revert previous train/test task
    else if task is done then
        Exit experiment
    end if
end while

(a) 基于任务的车载训练或测试工作流

C.基于任务的培训架构

在真实世界环境中运行的全尺寸机器人车辆上部署强化学习算法需要调整常见的训练程序,以考虑驾驶员干预和影响训练的外部变量。

我们将算法的架构构建为一个简单的状态机,如图 2a 所示,其中安全驾驶员控制不同的任务。我们定义了四个任务:训练、测试、撤消和完成。这些任务的定义允许系统既是交互式的,又是有状态的,有利于按需执行剧集,而不是先验的固定时间表。

训练和测试任务允许我们在自主模式下与车辆交互,执行当前策略。这两个任务之间的区别在于将噪声添加到模型输出中,并在训练任务中优化模型,而测试任务直接运行模型输出操作。在早期的剧集中,我们跳过了优化,转而探索状态空间。我们继续实验,直到测试奖励停止增加。

每一集都会被执行,直到系统检测到自动化丢失(即驾驶员进行了干预)。在真实环境中,系统无法在剧集之间自动重置,这与模拟或受限环境中的代理不同。我们需要人类驾驶员将车辆重置为有效的启动状态。剧集终止后,当安全驾驶员执行此重置时,模型正在优化,从而最大限度地减少剧集之间的时间。

撤消和已完成任务描述了体系结构中的主要差异。系统可能会因各种正当原因终止发作,而不是无法正确驾驶:这些发作不能用于培训目的。因此引入了撤消任务,因为它允许我们撤消剧集并将模型恢复到运行该剧集之前的状态。在我们的实验中,一个常见的例子是遇到其他司机试图将道路用作环境。完成任务允许我们在任何给定时刻优雅地退出实验,并且很有帮助,因为该过程是交互式的,并且不会运行固定数量的集数。

四、实验

我们用来展示车辆的主要任务是车道跟随;这与[8]中提到的任务相同,但是在真实车辆和仿真中完成,并且通过图像输入完成,而无需了解车道位置。它是驾驶的任务核心,也是开创性ALVINN的基石[19]。我们首先在IV-A节的仿真中完成这项任务,然后利用这些结果和适当超参数的知识在IV-B节中演示真实车辆的解决方案。

对于模拟和真实世界的实验,我们使用一个小的卷积神经网络。我们的模型有四个卷积层,有 3 × 3 个内核,跨度为 2 和 16 个特征维度,在演员和评论家模型之间共享。然后,我们将编码状态展平,并将向量与Actor的标量状态连接起来,另外连接批评者网络的动作。对于这两个网络,我们在回归到输出之前应用一个特征大小为 8 的全连接层。在VAE实验中,使用与编码器相同尺寸的解码器,用转置卷积代替跨步卷积,对特征进行上采样。图形描述如图 1 所示。

A. 模拟

为了在图像输入的车道跟随环境中测试强化学习算法,我们使用虚幻引擎4开发了一个3D驾驶模拟器。它包含乡村道路的生成模型,支持各种天气条件和道路纹理,并且将来将支持更复杂的环境(游戏屏幕截图见图 3)。

事实证明,模拟器对于调整强化学习参数至关重要,包括:学习率、每次训练后要采取的梯度步骤数以及正确的终止程序——保守终止会导致更好的策略。它确认了连续动作空间是可取的 - 离散导致生涩的策略 - 并且DDPG是一种合适的强化学习算法。如第 III-A 节中的环境设置中所述,模拟器中授予的奖励对应于离开车道前行驶的距离,新情节将汽车重置到车道中央。

我们发现,我们可以在 10 个训练集中可靠地学习从原始图像中学习模拟中的跟随。此外,我们发现使用压缩状态表示(由变分自动编码器提供)几乎没有优势。我们发现以下超参数是最有效的,我们将其用于现实世界的实验:未来折扣因子为0.9,噪声半衰期为250集,噪声参数θ为0.6,σ为0.4,批次大小为64的剧集之间的250个优化步骤和0.005的梯度裁剪。

B. 真实世界的驾驶

我们现实世界的驾驶实验在许多方面都模仿了模拟实验。然而,在现实世界中执行这个实验更具挑战性。许多环境因素无法控制,必须实施实时安全和控制系统。对于这些实验,我们使用250米的道路。汽车从道路的起点开始训练。当汽车偏离车道并进入不可恢复的位置时,安全驾驶员将控制车辆结束这一集。然后车辆返回车道中央开始下一集。我们使用在仿真中发现有效的相同超参数,调整噪声模型,使车辆行为类似于车辆本身动力学下的仿真。

我们使用改装的雷诺 Twizy 车辆进行实验,这是一款双座电动汽车,如图 1 所示。该车重500kg,最高时速80km/h,单次充电续航里程100km。我们使用安装在车辆前部车顶中央的单目前置摄像机。我们使用改装的电动机来驱动制动和转向,并以电子方式模拟节气门位置以调节车轮的扭矩。所有计算均使用一台 NVIDIA Drive PX2 计算机在板上完成。如果安全驾驶员通过使用车辆控制(制动、油门或转向)、切换自动化模式或按下紧急停止进行干预,车辆的线控驱动自动化会自动脱离。当速度超过 10 公里/小时或线控自动化脱离时,事件将终止,表明安全驾驶员已进行干预。然后,安全驾驶员会将汽车重置到道路中央,并继续下一集。

表I显示了这些实验的结果。在这里,主要发现是强化学习可以在少数试验中解决这个问题。使用 250 个优化步骤(批量大小为 64)大约需要 25 秒,这使得实验非常易于管理,考虑到将汽车操纵到车道中央开始下一集无论如何都需要大约 10 秒。我们还观察到,在现实世界中,视觉复杂性比模拟困难得多,由在线训练的变分自动编码器提供的压缩状态表示与策略一起大大提高了算法的可靠性。我们将我们的方法与零策略(以恒定速度直行)和随机探索噪声进行比较,以确认试验确实需要一个非平凡的策略。

五、讨论

这项工作首次将深度强化学习应用于全尺寸自动驾驶汽车。实验表明,我们能够在不到三十分钟的训练中学会跟随车道——所有这些都是在车载计算机上完成的。

为了调整超参数,我们构建了一个简单的模拟驾驶环境,在那里我们尝试了强化学习算法,使用 DDPG 作为规范算法在交通违规之前最大化距离。发现的参数友好地转移到现实世界中,在那里我们迅速训练了一个策略,在私人道路上驾驶真实车辆,奖励信号仅包括速度和控制驾驶员控制时的终止信号。值得注意的是,此奖励不需要进一步的环境信息或地图。有了更多的数据、车辆和更大的模型,这个框架足够通用,可以扩展到更复杂的驾驶任务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/378654.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

numpy常用操作

文章目录1 numpy库2 数组对象 ndarray2.1 数组对象的创建2.1.1 利用array函数创建ndarray对象2.1.2 np.ones()和np.zeros()函数2.1.3 np.random.rand()函数2.1.4 np.arange()函数2.1.5 np.linspace()函数2.1.6 np.empty()函数2.2 ndarray对象常用属性2.3 ndarray常用操作2.3.1 …

SkyWalking简介和安装

APM系统 早期的监控系统功能比较单一,主要以监控CPU、内存、网络、I/O等基础设置为主(cacti、nagios) 后来随着中间件技术的不断发展,监控系统也开始监控缓存、数据库、MQ等各种基础组件的性能(zabbix、prommethus&a…

马斯克被曝正在“招兵买马”,准备进军AI赛道

知情人士透露,马斯克最近几周接触了人工智能研究人员,打算成立一个新的研究实验室,开发聊天机器人ChatGPT的竞品。 为了开展这项工作,马斯克一直在向Igor Babuschkin抛橄榄枝,这位研究人员曾经在谷歌和OpenAI任职&…

MySQL数据同步至ElasticSearch的相关实现方法

Python: MySQL数据同步到ES集群(MySQL数据库与ElasticSearch全文检索的同步) 通过logstash将mysql数据同步至es中 SpringbootElasticSearch构建博客检索系统-学习笔记01SpringbootElasticSearch构建博客检索系统-学习笔记02P43 43.新闻案例-数据库数据导入到ES中 13…

面了一个测试工程师,明显感觉他背了很多面试题...

最近有朋友去字节面试,面试前后进行了20天左右,包含4轮电话面试、1轮笔试、1轮主管视频面试、1轮hr视频面试。 据他所说,80%的人都会栽在第一轮面试,要不是他面试前做足准备,估计都坚持不完后面几轮面试。 其实&…

医疗床头卡(WIFI方案)

一、产品特性 7.5寸墨水屏显示WIFI无线通信,极简部署,远程控制按键及高亮LED指示灯指示800*480点阵屏幕锂电池供电,支持USB充电DIY界面支持文本/条码/二维码/图片超低功耗/超长寿命,一次充电可用一年基于现有Wifi环境&#xff0c…

【数据结构(四)】树

文章目录树1 树的基本概念1.1 树的定义1.2 基本术语1.3 数的性质2 二叉树的概念2.1 二叉树的定义与特性2.1.1 定义2.1.2 二叉树的性质2.2 几种特殊的二叉树2.2.1 满二叉树2.2.2 完全二叉树2.3 二叉树的存储结构2.3.1 顺序存储2.3.2 链式存储3 二叉树的遍历和线索二叉树3.1 二叉…

云端IDE系列教程:云原生 Terminal 大比拼 (看 ChatGPT 如何选择)

原文作者:行云创新技术总监 邓冰寒 概述 上一期在使用 Ubuntu 20.04 作为基础镜像而定制的 WeTTY 成功的在 TitanIDE 运行起来了 ,非常适合程序员使用。能作为云原生 Terminal 的候选项目有 WeTTY、GoTTY、ttyd。接下来,我将在这三者中选择…

Java学习笔记 --- CSS

一、CSS技术介绍 CSS是「层样式表单」。是用于&#xff08;增强&#xff09;控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。 二、CSS语法规则 三、CSS和HTML结合方式 第一种 在标签的style属性上设置key:value value”&#xff0c;修改标签样式 <!DOCTYP…

Zynq UltraScale系列使用MIPI CSI-2 RX Subsystem 解码MIPI视频PD输出 提供2套工程源码和技术支持

目录1、前言2、设计思路和架构3、vivado工程详解4、上板调试验证5、福利&#xff1a;工程代码的获取1、前言 本设计采用OV5640摄像头MIPI模式作为输入&#xff0c;分辨率为1280x72060Hz&#xff0c;MIPI解码方案采用Xilinx官方提供的MIPI CSI-2 RX Subsystem IP解码MIPI视频&a…

开源商城系统怎么选择?

随着电子商务的发展&#xff0c;开源商城系统越来越受到市场的重视&#xff0c;无论是大型企业还是小型企业&#xff0c;都在使用开源商城系统来提高自身的竞争力。 开源商城系统的优势&#xff1f; 开源商城系统可以节省企业的开发成本&#xff0c;减少企业的研发时间&#x…

【2023unity游戏制作-mango的冒险】-5.攻击系统的简单实现

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 秩沅 原创 收录于专栏&#xff1a;unity游戏制作 ⭐攻击系统的简单实现⭐ 文章目录⭐攻击系统的简单实现⭐&#x1f468;‍&#x1…

Ip2Region的Java本地实现

最近有个需求是将ip地址转换为对应的行政区划&#xff0c;存入数据库&#xff0c;在网上查阅相关资料&#xff0c;有ip2Region实现方案&#xff0c;记录下来&#xff0c;方便备查。 一、知识介绍 ip2region.xdb 即离线 IP 数据管理框架和定位库&#xff0c;免费。 数据格式&a…

北极星指标体系

北极星指标体系 每个产品都有很多指标,每个指标都反映了对应业务的经营情况。但是在实际业务经营中,却要求我们在不同的产品阶段寻找到合适的指标,让这个指标可以代表当前产品阶段的方向和目标,让这个指标不仅对业务经营团队,而且对产品的用户、对产品的价值都能有很好的…

多智能体集群协同控制笔记(1):线性无领航多智能体系统的一致性

对于连续时间高阶线性多智能体系统的状态方程为&#xff1a; x˙i(t)Axi(t)Bui(t),i1,2..N\dot {\mathbf{x}}_i(t)A\mathbf{x}_i(t)B\mathbf{u}_i(t),i1,2..N x˙i​(t)Axi​(t)Bui​(t),i1,2..N 下标iii代表第iii个智能体&#xff0c;ui(t)∈Rq1\mathbf{u}_i(t)\in R^{q \time…

【vulhub漏洞复现】Thinkphp 2.x 任意代码执行

一、漏洞详情影响版本 thinkphp 2.x但是由于thinkphp 3.0版本在Lite模式下没有修复该漏洞&#xff0c;所以也存在该漏洞漏洞原因&#xff1a;e 和 /e模式匹配路由&#xff1a;e 配合函数preg_replace()使用, 可以把匹配来的字符串当作正则表达式执行; /e 可执行模式&#xff0c…

vue入门

一、准备 本文是基于HBuilderX工具来讲解的。 1、工具 HBuilderX 2、 二、介绍 Vue是一个做网页的框架。 一个网页都是由多个模块&#xff08;组件&#xff09;拼成的。而Vue的组件化技术正式应用了这个思想。 三、创建项目 使用HBuilderX 创建项目。 1、创建空白项目…

【联机对战】微信小程序联机游戏开发流程详解

现有一个微信小程序叫中国象棋项目&#xff0c;棋盘类的单机游戏看着有缺少了什么&#xff0c;现在给补上了&#xff0c;加个联机对战的功能&#xff0c;增加了可玩性&#xff0c;对新手来说&#xff0c;实现联机游戏还是有难度的&#xff0c;那要怎么实现的呢&#xff0c;接下…

MySQL表的增删查改(基础)

gitee:博客中的所有操作整合新增语法:insert [into] table_name values(value_list)[案例] 创建一个学生表进行数据插入1.1单行数据全列插入[提示]我们可以想在记事本上写下命令,让后复制到数据库客户端,这样可以在出错的时候进行快速修改.同时为了美观和明了,我们可以进行适当…

15个Spring扩展点,一般人知道的不超过5个!

Spring的核心思想就是容器&#xff0c;当容器refresh的时候&#xff0c;外部看上去风平浪静&#xff0c;其实内部则是一片惊涛骇浪&#xff0c;汪洋一片。Spring Boot更是封装了Spring&#xff0c;遵循约定大于配置&#xff0c;加上自动装配的机制。很多时候我们只要引用了一个…