当前位置: 首页 > news >正文

基于RRT的优化器:一种基于快速探索随机树算法的新型元启发式算法

受机器人路径规划中常用的快速探索随机树(RRT)算法的搜索机制的启发,我们提出了一种新颖的元启发式算法,称为基于RRT的优化器(RRTO)。这是首次将RRT算法的概念与元启发式算法相结合。RRTO的关键创新是其三种位置更新策略:自适应步长游走、基于绝对差异的自适应步长和基于边界的自适应步长。
这些策略使RRTO能够有效地探索搜索空间,同时引导人群走向高质量的解决方案,于2025年3月发表在SCI计算机类期刊 IEEE Access。
在这里插入图片描述

数学模型的RRTQ

RRTQ模型由四个主要阶段组成:RRTQ算法的初始化、自适应步长游走策略、绝对差值自适应步长策略和基于边界的自适应步长策略。

A. 初始化

为了满足元启发式算法的要求,RRTQ算法中的每个代理都被视为一个起始点和搜索实体。最初,整个种群Q被初始化,如公式(7)所示。RRTQ种群由n个RRTQ代理 q i j q_{ij} qij组成,每个代理包含d维搜索参数。因此,整个种群Q可以由公式(8)表示。

Q = [ W 1 W 2 ⋮ W n ] ; W i = [ q i 1 , q i 2 , ⋯ q i d ] Q = \begin{bmatrix} W_1 \\ W_2 \\ \vdots \\ W_n \end{bmatrix}; \quad W_i = [q_{i1}, q_{i2}, \cdots q_{id}] Q= W1W2Wn ;Wi=[qi1,qi2,qid]

Q = [ q 11 q 12 ⋯ q 1 d q 21 q 22 ⋯ q 2 d ⋮ ⋮ ⋱ ⋮ q n 1 q n 2 ⋯ q n d ] Q = \begin{bmatrix} q_{11} & q_{12} & \cdots & q_{1d} \\ q_{21} & q_{22} & \cdots & q_{2d} \\ \vdots & \vdots & \ddots & \vdots \\ q_{n1} & q_{n2} & \cdots & q_{nd} \end{bmatrix} Q= q11q21qn1q12q22qn2q1dq2dqnd

其中i表示RRTQ代理的索引,d表示RRTQ维度的索引。每个粒子的初始化由公式(9)定义。

q i j = L j + r 1 ⋅ ( U j − L j ) , i = 1 , 2 , ⋯ n ; j = 1 , 2 , ⋯ d q_{ij} = L_j + r_1 \cdot (U_j - L_j), \quad i = 1, 2, \cdots n; \quad j = 1, 2, \cdots d qij=Lj+r1(UjLj),i=1,2,n;j=1,2,d

这里, L j L_j Lj U j U_j Uj分别是粒子在维度j上的下界和上界。初始化过程涉及在这些边界内随机化每个粒子的参数,以有效分布粒子在整个搜索空间中,从而提高多样性并防止过早收敛到局部最优。初始化后,计算每个粒子的位置,初始适应度值作为目标函数F的输入参数,如公式(10)所示。

f i = F ( W i ) f_i = F(W_i) fi=F(Wi)

B. 自适应步长游走策略

RRT算法以其在广泛探索未知区域时使用固定步长向随机选择点迭代的能力而闻名。然而,在复杂条件下,固定步长可能导致效率低下的探索。为了解决这个问题,我们将RRTQ的随机采样机制建模为自适应步长游走策略,以增强RRTQ算法的搜索能力。

为了在探索和开发之间平衡优化过程,设计了两种类型的函数,其迭代次数不同。K和E的函数表达式分别在公式(11)和公式(12)中给出。为了直观反映这两种函数的特性,它们在1000次迭代后进行了可视化,如图4所示。K是区间[0, 1]上的单调递减函数,早期阶段逐渐减少,后期阶段迅速减少。E是区间[0, 1]上的单调递增函数,早期阶段快速增长,后期阶段逐渐增加。

K = ln ⁡ ( T − t ) ln ⁡ ( T ) K = \frac{\ln(T - t)}{\ln(T)} K=ln(T)ln(Tt)

E = T t E = \sqrt[t]{T} E=tT
在这里插入图片描述

图4展示了E和K的可视化(迭代次数取1000为例)。

自适应步长游走的数学建模公式如下所示:

q i , j new = q i , j + s 3 q_{i,j}^{\text{new}} = q_{i,j} + s_3 qi,jnew=qi,j+s3

s 3 = ( r 1 − K 2 ) ⋅ K ⋅ ( U b i j − L b i j ) C , r 1 < K s_3 = \left( r_1 - \frac{K}{2} \right) \cdot K \cdot \frac{(U_{b_{ij}} - L_{b_{ij}})}{C}, \quad r_1 < K s3=(r12K)KC(UbijLbij),r1<K

这里, q i , j new q_{i,j}^{\text{new}} qi,jnew表示粒子的更新位置。 q i , j q_{i,j} qi,j表示当前粒子位置。 s 3 s_3 s3是此策略中的自适应步长。 r 1 r_1 r1是范围[0, 1]内的随机数, K − K / 2 K - K/2 KK/2确保了激活此策略时 s 3 s_3 s3方向的随机性。步长 s 3 s_3 s3随着迭代次数的增加而逐渐减小。 L b i j L_{b_{ij}} Lbij U b i j U_{b_{ij}} Ubij分别是搜索空间的下界和上界。 C = 10 C = 10 C=10表示步长因子,确定此参数的方法将在第7节的敏感性分析中详细讨论。仅当 r 1 < K r_1 < K r1<K时执行步长更新,该条件在早期迭代中最小化随机游走,导致稀疏更新。相反,此条件允许在后期迭代中更频繁地进行探索,从而实现更密集的更新。这种方法增强了算法在后期迭代中逃离局部最优的能力。在RRTQ代理的迭代过程中,如果代理的位置超过边界,则碰撞检测机制将其调整回边界。

自适应步长游走策略不仅促进了RRTQ代理对当前位置的深入探索,还通过结合全局随机初始化方法,大大增强了全局搜索的有效性,有效防止算法陷入局部最优。这种方法提高了粒子探索搜索空间的能力,与RRT算法的随机探索特性紧密结合,从而实现对搜索空间的更有效覆盖。自适应步长游走策略的伪代码如算法1所示。

算法1 自适应步长游走策略

在这里插入图片描述

C. 绝对差值基础自适应步长策略

在RRT算法中,使用固定步长向随机选择点迭代在不同阶段的适应性是有限的。为了增强RRTQ算法的全局探索能力,引入了绝对差值基础自适应步长策略。该策略通过计算当前粒子位置和当前最优位置之间的绝对差值动态调整步长。

更新基于当前最优位置,如公式(15)所示。该过程使用公式(16)计算代理的更新步长 s 2 s_2 s2

q i , j new = q best , j + s 2 q_{i,j}^{\text{new}} = q_{\text{best},j} + s_2 qi,jnew=qbest,j+s2

s 2 = α 1 ⋅ ∣ q best , j − q i , j ∣ , r 2 < m 1 s_2 = \alpha_1 \cdot |q_{\text{best},j} - q_{i,j}|, r_2 < m_1 s2=α1qbest,jqi,j,r2<m1

这里, q i , j new q_{i,j}^{\text{new}} qi,jnew表示代理的更新位置。 q best q_{\text{best}} qbest表示当前最优代理的位置。参数 r 2 r_2 r2是范围[0, 1]内的随机数, m 1 m_1 m1是此策略中的关键角色,随着迭代次数的增加,激活此策略的可能性增加。严格激活标准 ∣ q best , j − q i , j ∣ |q_{\text{best},j} - q_{i,j}| qbest,jqi,j有效地平衡了探索和开发。 m 1 m_1 m1设置为公式(17)通过测试。绝对差值 ∣ q best , j − q i , j ∣ |q_{\text{best},j} - q_{i,j}| qbest,jqi,j反映了当前和最优粒子之间的距离,反映了当前和最优位置。 α 1 \alpha_1 α1是自适应步长调整因子,如公式(18)所示。 ( r 2 − m 1 ) / 2 (r_2 - m_1)/2 (r2m1)/2用于控制RRTQ代理的更新方向。 ( r 2 − r 2 ) ⋅ e b (r_2 - r_2) \cdot e^{b} (r2r2)eb用于生成随机扰动,b设置为公式(19)。

m 1 = E / ( 10 ) m_1 = E/(10) m1=E/(10)

α 1 = 5 ⋅ ( r 2 − m 1 / 2 ) ⋅ cos ⁡ ( 2 ⋅ π ⋅ r 2 ) ⋅ e b \alpha_1 = 5 \cdot (r_2 - m_1/2) \cdot \cos(2 \cdot \pi \cdot r_2) \cdot e^{b} α1=5(r2m1/2)cos(2πr2)eb

b = e c m ( e − π / 4 ) b = e^{cm(e^{-\pi/4})} b=ecm(eπ/4)

这种设计不仅增强了步长更新的方向性,引导粒子朝向全局最优位置,还通过引入随机和非线性调整确保了搜索过程中的多样性和全局探索能力。

绝对差值基础自适应步长策略通过调整步长在搜索空间的广泛探索和局部微调之间实现了有效的平衡。这种策略通过动态调整搜索路径中的自适应步长,提高了算法的全局优化性能和效率。该策略确保了在算法的后期阶段,代理可以更精细地调整其位置。边界自适应步长策略结合RRT算法的局部扩展机制,提高了RRTQ算法在接近目标区域时的搜索精度和效率。该策略的伪代码在算法2中给出。

算法2 绝对差值基础自适应步长策略

在这里插入图片描述

D. 基于边界的自适应步长策略

为了实现更精确的优化,引入了基于边界的自适应步长策略。该策略的核心是使用非常小的随机步长进行探索,帮助RRTQ代理仔细搜索周围区域。这不仅确保了对当前最优位置的局部搜索,还防止陷入局部最小值。

更新基于当前最优位置,如公式(21)所示。该过程使用公式(20)计算代理的更新步长 s 3 s_3 s3

q i , j new = q best + s 3 q_{i,j}^{\text{new}} = q_{\text{best}} + s_3 qi,jnew=qbest+s3

s 3 = ( U b i j − L b i j ) ⋅ cos ⁡ β ⋅ α 2 , r 3 < m 2 s_3 = (U_{b_{ij}} - L_{b_{ij}}) \cdot \cos \beta \cdot \alpha_2, r_3 < m_2 s3=(UbijLbij)cosβα2,r3<m2

这里, q i , j new q_{i,j}^{\text{new}} qi,jnew表示代理的更新位置。 q best q_{\text{best}} qbest是当前最优代理位置。参数 r 3 r_3 r3是范围[0, 1]内的随机数。 U b i j − L b i j U_{b_{ij}} - L_{b_{ij}} UbijLbij表示每个粒子维度的边界长度。 cos ⁡ β \cos \beta cosβ随着迭代次数的变化而变化,用于生成周期性扰动。 β \beta β的值在公式(22)中定义。激活函数 m 2 m_2 m2,如公式(23)所示,在迭代的后期阶段起着关键作用,减少了激活此策略的可能性。更严格的激活标准显著降低了算法的计算负担。 α 2 \alpha_2 α2是控制粒子更新方向的自适应调整因子,并确保步长自适应减少,如公式(24)所示。

β = 10 ⋅ π ⋅ t / T \beta = 10 \cdot \pi \cdot t/T β=10πt/T

m 2 = E / 50 m_2 = E/50 m2=E/50

α 2 = r 3 ⋅ ( r 3 − m 2 / 2 ) ⋅ K ⋅ ( 1 − t / T ) \alpha_2 = r_3 \cdot (r_3 - m_2/2) \cdot K \cdot (1 - t/T) α2=r3(r3m2/2)K(1t/T)

r 3 − m 2 / 2 r_3 - m_2/2 r3m2/2确保了激活此策略时方向的随机性,帮助避免局部最优。 K ⋅ ( 1 − t / T ) K \cdot (1 - t/T) K(1t/T)确保了随着迭代次数的增加,步长自适应减小。

通过这种微调机制,RRTQ算法可以更准确地调整其搜索路径,因为它接近搜索终点,最大化每次迭代的价值,从而提高算法的整体搜索效率和结果质量。该策略确保了在算法的后期阶段,代理可以更精细地调整其位置。边界自适应步长策略结合RRT算法的局部扩展机制,提高了RRTQ算法在接近目标区域时的搜索精度和效率。该策略的伪代码在算法3中给出。

算法3 基于边界的自适应步长策略

在这里插入图片描述

E. 提出的RRTQ算法

通过结合上述策略开发了提出的RRTQ算法。三种步长更新策略总结在表1中。其详细伪代码和机制图分别在算法4和图5中给出。RRTQ算法有效地整合了核心RRT搜索策略与自适应机制,使其能够有效地适应搜索过程的不同阶段。在早期迭代中,粒子具有更高的概率探索较大步长。在后期迭代中,它们自适应地采取较小步长,逐步细化最优粒子位置以实现更高精度的解决方案。值得注意的是,每种策略的贡献和有效性通过消融实验进行了评估,如第9节所讨论的。
在这里插入图片描述

G. -J. Lai, T. Li and B. -J. Shi, “RRT-Based Optimizer: A Novel Metaheuristic Algorithm Based on Rapidly-Exploring Random Trees Algorithm,” in IEEE Access, vol. 13, pp. 42744-42776, 2025, doi: 10.1109/ACCESS.2025.3547537.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% RRT-Based Optimizer source codes version 1.0
%
% Programmer: Guangjin Lai
% 
% Original paper: Guangjin Lai, Tao Li, Baojun Shi
%                 RRT-Based Optimizer: A novel metaheuristic algorithm based on rapidly-exploring random trees algorithm
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [Bestscore,Bestposition,Convergence_curve]=RRTO(N,Max_iter,lb,ub,dim,fobj)
disp('RRTO starts to work now! Plaease wait......   :)')
disp('-------------------------------------------   :)')
%% initialization
Lb=lb.*ones(1,dim);
Ub=ub.*ones(1,dim);
Bestposition=zeros(1,dim);
Bestscore=inf;
Convergence_curve=zeros(1,Max_iter);
newscore=zeros(1,N);
Pop=RRTO_initialization(N,dim,ub,lb);
Currentscore=zeros(1,N);
for i=1:NCurrentscore(1,i)=fobj(Pop(i,:));if Currentscore(1,i)<BestscoreBestscore=Currentscore(1,i);Bestposition=Pop(i,:);end
end
it=1;
C=10; % Penalty Factor
%% Main loop
while it <= Max_iterk = log(Max_iter - it)/log(Max_iter);E =(it/Max_iter)^(1/3);m1=E/10;m2=E/50;newpop = Pop;for i=1:Nfor j=1:dim% adaptive step size wandering strategyr1=rand();if r1 < kS1=(r1-(k/2))*k*(Ub(j)-Lb(j))/C;newpop(i,j) = Pop(i,j)+S1;end% absolute difference-based adaptive step size strategyr2=rand();if r2 < m1b = exp(cos(pi*(1-(1/it))));alpha1=5*(r2-m1/2)*cos(2*pi*r2)*exp(b);S2=alpha1*abs(Bestposition(1,j)-Pop(i,:));newpop(i,:)= Bestposition(1,j)+S2;end% boundary-based adaptive step size strategyr3=rand();if r3 < m2beta=10*pi*it/Max_iter;alpha2=r3*(r3-m2/2)*k*(1-it/Max_iter);S3=(Ub(j)-Lb(j))*cos(beta)*alpha2;newpop(i,j)=Bestposition(1,j)+S3;endendendfor i=1:N% Coliision detectionC_ub=newpop(i,:)>ub;C_lb=newpop(i,:)<lb;newpop(i,:)=ub.*C_ub+lb.*C_lb+(newpop(i,:).*(~(C_ub+C_lb)));newscore(1,i)=fobj(newpop(i,:));% Updataif newscore(1,i)<Currentscore(1,i)Currentscore(1,i) = newscore(1,i);Pop(i,:) = newpop(i,:);if newscore(1,i)< BestscoreBestscore=Currentscore(1,i);Bestposition=Pop(i,:);endendendConvergence_curve(it)=Bestscore;% Next generation untill termination criterionit=it+1;
end
disp('RRTO is finished now! You can check the results!       :)')
disp('----------------------------------------------------   :)')

相关文章:

基于RRT的优化器:一种基于快速探索随机树算法的新型元启发式算法

受机器人路径规划中常用的快速探索随机树&#xff08;RRT&#xff09;算法的搜索机制的启发&#xff0c;我们提出了一种新颖的元启发式算法&#xff0c;称为基于RRT的优化器&#xff08;RRTO&#xff09;。这是首次将RRT算法的概念与元启发式算法相结合。RRTO的关键创新是其三种…...

设计模式每日硬核训练 Day 13:桥接模式(Bridge Pattern)完整讲解与实战应用

&#x1f504; 回顾 Day 12&#xff1a;装饰器模式小结 在 Day 12 中&#xff0c;我们学习了装饰器模式&#xff08;Decorator Pattern&#xff09;&#xff1a; 强调在不改变原类结构的前提下&#xff0c;动态为对象增强功能。通过“包装对象”实现运行时组合&#xff0c;支…...

【开发语言】悬空指针问题

悬空指针&#xff08;Dangling Pointer&#xff09;是编程中常见的内存管理问题&#xff0c;尤其在C/C这类手动管理内存的语言中。以下是详细解释&#xff1a; 什么是悬空指针&#xff1f; 悬空指针是指向已经被释放&#xff08;或失效&#xff09;内存的指针。这段内存可能已…...

深入剖析 WiFi 定位解析功能:原理、技术优势与应用场景

WiFi 定位解析功能的原理​ 信号强度与距离的关系​ WiFi 定位的核心原理基于无线信号传播过程中的一个基本特性&#xff1a;信号强度与信号发射源&#xff08;即 WiFi 接入点&#xff0c;Access Point&#xff0c;简称 AP&#xff09;和接收设备之间距离的关联。一般来说&am…...

从标准九九表打印解读单行表达式的书写修炼(Python)

解读单行表达式书写&#xff0c;了解修习单行捷径。 笔记模板由python脚本于2025-04-16 23:24:17创建&#xff0c;本篇笔记适合喜欢单行喜好python的coder翻阅。 【学习的细节是欢悦的历程】 博客的核心价值&#xff1a;在于输出思考与经验&#xff0c;而不仅仅是知识的简单复述…...

HTML5好看的水果蔬菜在线商城网站源码系列模板4

文章目录 1.设计来源1.1 主界面1.2 关于我们1.3 商品信息1.4 新闻资讯1.5 联系我们1.5 登录注册 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/147264262 HTML5好看的水果…...

Arkts应用全局UI状态存储和持久化V2(AppStorageV2、PersistenceV2和@Type)

目录 应用全局UI状态存储和持久化V2版本 AppStorageV2 connect remove keys 示例 使用限制 PersistenceV2 connect remove keys save notifyOnError 示例 使用限制 Type 使用限制 应用全局UI状态存储和持久化V2版本 以下实例AppStorageV2、PersistenceV2和装饰…...

【QT】常用控件 【多元素类 | 容器类 | 布局类】

&#x1f308; 个人主页&#xff1a;Zfox_ &#x1f525; 系列专栏&#xff1a;Qt 目录 一&#xff1a;&#x1f525; QT 常用控件【多元素类】 &#x1f98b; List Widget -- 列表&#x1f98b; Table Widget -- 表格&#x1f98b; Tree Widget -- 树形 二&#xff1a;&#x…...

uniapp实现图文聊天功能

Uniapp 实现图文聊天功能 下面我将介绍如何在 Uniapp 中实现一个基本的图文聊天功能&#xff0c;包括消息发送、接收和展示。 一、准备工作 创建 Uniapp 项目准备后端接口&#xff08;可以使用云开发、自己的服务器或第三方服务&#xff09; 二、实现步骤 1. 页面结构 &l…...

【场景应用9】多语言预训练语音模型进行自动语音识别

一、理论介绍 “多语言预训练语音模型进行自动语音识别”这个模块是近年来语音识别(ASR, Automatic Speech Recognition)领域非常重要的发展方向。下面我来为你系统地讲解这个模块的基础理论与算法流程,尤其聚焦在如 wav2vec 2.0 multilingual、XLSR(cross-lingual speech…...

华为HCIE-openEuler认证:能否成为国产操作系统领域的技术稀缺人才?

HCIE-openEuler是华为面向开源操作系统领域的高级专家认证&#xff0c;聚焦openEuler系统的深度运维、性能调优与生态集成。作为华为鲲鹏计算生态的核心技术栈&#xff0c;该认证要求持证者具备从底层内核优化到上层云原生适配的全栈能力。以下从技术能力、实验设计、行业适配三…...

Uniapp:列表选择提示框

目录 一、出现场景二、效果展示三、具体使用 一、出现场景 在项目的开发过程中&#xff0c;有这样一种场景&#xff0c;就是点击按钮走后续的逻辑之前还需要选择前提条件&#xff0c;就一个条件的情况下如果使用弹出框就显示比较多余&#xff0c;列表选择提示框刚好能够满足我…...

uni-app 开发安卓 您的应用在运行时,向用户索取(定位、相机、存储)等权限,未同步告知权限申请的使用目的,不符合相关法律法规要求

您的应用在运行时,向用户索取(定位、相机、存储)等权限,未同步告知权限申请的使用目的,不符合相关法律法规要求。 测试步骤:1、 工作台 -打卡,申请定位权限;2、工作台-设置-编辑资料-更换头像,申请相机、存 储权限。 修改建议:APP在申请敏感权限时,应同步说明权限申…...

李宏毅NLP-4-语音识别part3-CTC

Connectionist Temporal Classification&#xff5c;CTC 基于连接主义时间分类&#xff08;CTC&#xff09;的语音识别架构&#xff0c;具体描述如下&#xff1a; 输入层&#xff1a;底部的 x 1 , x 2 , x 3 , x 4 x^1, x^2, x^3, x^4 x1,x2,x3,x4代表输入的语音信号分帧数据…...

基于.NET后端实现图片搜索图片库 核心是计算上传图片与库中图片的特征向量相似度并排序展示结果

基于.NET 后端实现图片搜索图片库的方案&#xff0c;核心是计算上传图片与库中图片的特征向量相似度并排序展示结果。 整体思路 图像特征提取&#xff1a;使用深度学习模型&#xff08;如 ResNet&#xff09;提取图片的特征向量。特征向量存储&#xff1a;将图片的特征向量存…...

数据中台(大数据平台)之数据仓库建设

数据中台作为企业数据管理的核心枢纽&#xff0c;应支持并促进企业级数据仓库的建设&#xff0c;确保数据的有效整合、治理和高效应用。在建设数据仓库的过程中&#xff0c;设计和规划显得尤为重要&#xff0c;需要深入理解业务需求&#xff0c;制定合理的技术架构&#xff0c;…...

设计模式之工厂模式(factory pattern):在商品对象创建系统中的应用

目录 一、设计思路 1. 简单工厂模式 2. 工厂方法模式 3. 抽象工厂模式 二、UML类图&#xff08;PlantUML格式&#xff09; 1.简单工厂模式 2.工厂方法模式 3.抽象工厂模式 三、实现过程与结果 1. 简单工厂模式 2. 工厂方法模式 3. 抽象工厂模式 四、总结 在面向对…...

在ubuntu20.04+系统部署VUE及Django项目的过程记录——以腾讯云为例

目录 1. 需求2. 项目准备3. VUE CLI项目部署3.1 部署前的准备3.1.1 后端通信路由修改3.1.2 导航修改 3.2 构建项目3.3 配置nginx代理 4. 后端配置4.1 其他依赖项4.2 单次执行测试4.3 创建Systemd 服务文件4.4 配置 Nginx 作为反向代理 5. 其他注意事项 1. 需求 近期做一些简单…...

解决前端vue项目在linux上,npm install,node-sass 安装失败的问题

Unable to save binary /var/lib/jenkins/workspace/xxx/node_modules/node-sass/vendor/linux-x64-72 : Error: EACCES: permission denied, mkdir ‘/var/lib/jenkins/workspace/x/node_modules/node-sass/vendor’ 这个是node-sass安装失败导致的。 #将npm的默认仓库更改为…...

FPGA_YOLO(四)用HLS实现循环展开以及存储模块

Vivado HLS&#xff08;High-Level Synthesis&#xff0c;高层次综合&#xff09;是赛灵思&#xff08;Xilinx&#xff09;在其 Vivado 设计套件 中提供的一款工具&#xff0c;用于将 高级编程语言&#xff08;如 C、C、SystemC&#xff09; 直接转换为 硬件描述语言&#xff0…...

用户组与用户

用户组管理&#xff1a; 创建用户组&#xff1a; groupadd 用户组名 删除用户组&#xff1a; groupdel 用户组名 用户管理&#xff1a; 创建用户 useradd [-g -d] 用户名 -g&#xff1a;指定用户的组 -d&#xff1a;指定用户的home路径&#xff0c;如果不加上&…...

npm install 报错常见的解决方法

npm install 报错的情况有很多种&#xff0c;每种错误的具体解决方案也有所不同。这里我将汇总一些常见的npm install报错及其解决办法&#xff1a; 1. 下载速度慢/网络问题 解决办法&#xff1a;更换npm包的镜像源至国内镜像&#xff0c;如淘宝npm镜像&#xff1a;npm confi…...

暂存一下等会写

#include<easyx.h> IMAGE SNOW 图形变量 struct MOVE生存结构体 {int x0;int y0; bool livefalse;}; initgraph(800, 800);初始化图形界面 MOVE snowflake[5000];目标数量 loadimage(&SNOW, "snow.png");加载图片 BeginBatchDraw(); 开始批量绘图。…...

C语言 —— 指尖跃迁 刻印永恒 - 文件操作

目录 1. 什么是文件 1.1 程序文件 1.2 数据文件 1.3 文件名 2. 二进制文件和文本文件 3. 文件的打开与关闭 3.1 流和标准流 3.2 文件指针 3.3 文件的打开与关闭 fopen fclose 4. 文件的顺序读写 4.1 fgetc和fputc fgetc fputc 4.2 fgets和fputs fgets fputs…...

第二章 DQL查询语句

第一章&#xff1a;基础查询 一、SELECT 语句 作用 SELECT 语句用于从数据库中选取数据。 结果被存储在一个结果表中&#xff0c;称为结果集。 语法 SELECT column1, column2, … FROM table_name; 与 SELECT * FROM table_name; 参数说明&#xff1a; column1, column2, …...

系统与网络安全------弹性交换网络(1)

资料整理于网络资料、书本资料、AI&#xff0c;仅供个人学习参考。 Trunk原理与配置 Trunk原理概述 Trunk&#xff08;虚拟局域网中继技术&#xff09;是指能让连接在不同交换机上的相同VLAN中的主机互通。 VLAN内通信 实现跨交换的同VLAN通信&#xff0c;通过Trunk链路&am…...

有哪些哲学流派适合创业二

好的&#xff0c;让我们更深入地探讨如何将‌哲学与数学‌深度融合&#xff0c;构建一套可落地的创业操作系统。以下从‌认知框架、决策引擎、执行算法‌三个维度展开&#xff0c;包含具体工具和黑箱拆解&#xff1a; ‌一、认知框架&#xff1a;用哲学重构商业本质‌ 1. ‌本体…...

Python(18)Python中JSON的妙用:详解序列化与反序列化原理及实战案例

目录 一、背景&#xff1a;为什么Python需要JSON&#xff1f;二、核心技术解析&#xff1a;序列化与反序列化2.1 核心概念2.2 类型映射对照表 三、Python操作JSON的四大核心方法3.1 基础方法库3.2 方法详解1. json.dumps()2. json.loads()3. json.dump()4. json.load() 四、实战…...

Nautilus 正式发布:为 Sui 带来可验证的链下隐私计算

作为 Sui 安全工具包中的强大新成员&#xff0c;Nautilus 现已上线 Sui 测试网。它专为 Web3 开发者打造&#xff0c;支持保密且可验证的链下计算。Nautilus 应用运行于开发者自主管理的可信执行环境&#xff08;Trusted Execution Environment&#xff0c;TEE&#xff09;中&a…...

投资理财_从0到1:如何用1000元开启你的二级市场投资之旅?

投资理财_从0到1&#xff1a;如何用1000元开启你的二级市场投资之旅&#xff1f; 一、前言&#xff1a;投资不是赌博&#xff0c;而是科学与艺术的结合1.1 为什么学习二级市场投资&#xff1f;1.2 本篇博客的目标 二、投资的基本概念&#xff1a;先搞清楚“玩的是什么”2.1 二级…...

有没有适合企业用的局域网即时通讯聊天工具?

随着信息安全问题的日益凸显&#xff0c;用户对于即时通讯工具的安全性与隐私保护提出了更高的要求。 强大的即时通讯能力 BeeWorks提供了专业的IM即时通讯能力&#xff0c;支持多种消息类型&#xff0c;包括文字、语音、图片和文件等&#xff0c;满足不同场景下的沟通需求。…...

Web3技术如何提升用户数据保护

在这个信息爆炸的时代&#xff0c;用户数据保护已成为全球关注的焦点。Web3 技术&#xff0c;作为下一代互联网的代表&#xff0c;以其去中心化、安全性和用户主权等特点&#xff0c;为用户数据保护提供了新的解决方案。本文将探讨 Web3 技术如何提升用户数据保护。 去中心化存…...

CANoe自动化测试用例log保存(专栏:车载网络诊断测试攻略从零开始搭建一个UDS诊断自动化测试CANoe工程)

文章目录 前言实现思路以及对应的CAPL代码1.获取cfg工程路径2.获取系统时间3.html报告路径4.log路径5.保存报告6.用例示例在汽车电子系统的开发与测试中,CANoe作为主流的仿真测试工具,其自动化测试用例生成的Log是问题追溯、合规审计和数据分析的核心依据。然而,许多团队因日…...

理解 results = model(source, stream=True) 的工作原理和优势

1. 核心概念解析 (1) streamTrue 的作用 生成器模式&#xff1a;当处理视频或图像序列时&#xff0c;streamTrue 会将结果包装成一个 生成器&#xff08;Generator&#xff09;&#xff0c;逐帧生成 Results 对象&#xff0c;而不是一次性返回所有结果。内存优化&#xff1a;…...

# 手写数字识别:使用PyTorch构建MNIST分类器

手写数字识别&#xff1a;使用PyTorch构建MNIST分类器 在这篇文章中&#xff0c;我将引导你通过使用PyTorch框架构建一个简单的神经网络模型&#xff0c;用于识别MNIST数据集中的手写数字。MNIST数据集是一个经典的机器学习数据集&#xff0c;包含了60,000张训练图像和10,000张…...

ios app的ipa文件提交最简单的方法

ipa文件是ios的app打包后生成的二级制文件&#xff0c;在上架app store connect或做testflight测试的时候&#xff0c;它提示我们需要使用xcode、transporter或xcode命令行等方式来上传。 而xcode、transporter或xcode命令行的安装都需要使用mac电脑&#xff0c;假如没有mac电…...

与/或形演绎推理——基于王永庆著《人工智能原理与方法》的深度解析

前文&#xff0c;我们已经写了两种演绎推理&#xff1a;自然演绎推理和归结演绎推理。 自然演绎推理&#xff1a;自然演绎推理——基于王永庆著《人工智能原理与方法》的深度解析-CSDN博客 归结演绎推理&#xff1a;归结演绎推理——基于王永庆著《人工智能原理与方法》的深度…...

【Qt】Qt 按钮控件详解,PushButton,RadioButton,CheckBox,ToolButton

&#x1f351;个人主页&#xff1a;Jupiter. &#x1f680; 所属专栏&#xff1a;QT 欢迎大家点赞收藏评论&#x1f60a; 目录 &#x1f4da;按钮类控件&#x1f351;Push Button &#x1f965;Radio Buttion&#x1f343;click, press, release, toggled 的区别&#x1f341;…...

跨平台开发选Java还是C?应用场景与性能深度对比

&#x1f381;个人主页&#xff1a;User_芊芊君子 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 &#x1f50d;系列专栏&#xff1a;AI 【前言】 在计算机技术快速发展的今天&#xff0c;跨平台开发已经成为众多开发者的核心需求。Java和C作为两种历史悠…...

Node.js 的定义、用途、安装方法

关于 Node.js 的定义、用途、安装方法&#xff0c;以及为什么不能使用 DOM、BOM 和与浏览器不同的顶级对象的简明总结&#xff1a; &#x1f4a1; 一、Node.js 的定义 Node.js 是一个基于 Chrome V8 引擎 的 JavaScript 运行时环境&#xff0c;它让 JavaScript 不再局限于浏览…...

5、Props:组件间的密语——React 19 数据传递全解

一、密语启封&#xff1a;咒语学徒的困惑 "教授&#xff0c;我的魔法傀儡为什么总是不听指令&#xff1f;"年轻的学徒举着发光的魔杖&#xff0c;组件树中的傀儡们却像打人柳一样混乱。"记住&#xff0c;艾薇&#xff0c;"赫敏的魔杖在空中划出金色数据流…...

LangGraph中预构件,creat_react_agent的实现流程

LangGraph Prebuilt Agent 流程图 本文档展示了LangGraph的prebuilt模块中Agent的实现流程&#xff0c;重点是create_react_agent函数构建的代理系统流程和结构。 ReAct Agent构建流程 #mermaid-svg-ubcEEuBeApApT624 {font-family:"trebuchet ms",verdana,arial,s…...

python-将文本生成音频

将文本生成音频通常需要结合 文本转语音&#xff08;TTS&#xff0c;Text-to-Speech&#xff09; 工具或库来实现&#xff0c;比如 Google TTS (gtts)、Amazon Polly、Microsoft Azure TTS 等。 一、使用 Google TTS (gtts) 将文本生成音频 gtts 是一个简单易用的 Python 库&a…...

【虚幻C++笔记】接口

目录 概述创建接口 概述 简单的说&#xff0c;接口提供一组公共的方法&#xff0c;不同的对象中继承这些方法后可以有不同的具体实现。任何使用接口的类都必须实现这些接口。实现解耦解决多继承的问题 创建接口 // Fill out your copyright notice in the Description page o…...

白酒制造主数据管理全链路解析:业务重塑与AI赋能

作为中国消费领域的支柱产业之一&#xff0c;白酒行业在消费升级、渠道多元化的浪潮下&#xff0c;企业正面临库存积压、串货乱价、质量追溯难等核心痛点。如何通过主数据管理实现业务全链路的标准化与智能化&#xff0c;已成为行业数字化转型的关键命题。 01政策背景与行业现…...

Java与C在典型场景下的性能对比深度剖析

&#x1f381;个人主页&#xff1a;User_芊芊君子 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 &#x1f50d;系列专栏&#xff1a;AI 【前言】 在计算机编程领域&#xff0c;Java和C语言都是举足轻重的编程语言。Java以其跨平台性、自动内存管理和丰富…...

基于springboot+vue的数码产品抢购系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;Maven3.3.9 系统展示 系统首页 商品信…...

芯片封装制造技术分析

封装技术正由单一防护功能向集成化系统发展&#xff0c;核心需统筹电气参数、热耗散能力与生产成本之间的关系。 一、技术定义与基础功能 芯片封装指通过特定制程将半导体晶片封装于保护结构内的技术&#xff0c;核心作用包括&#xff1a; 环境隔离&#xff1a;阻隔机械冲击、…...

Linux:Makefile

编译器gcc 使用方式&#xff1a;gcc [ 选项 ] 要编译的⽂件 [ 选项 ] [ ⽬标⽂件 ] 编译分为以下几个步骤&#xff1a; 1.预处理(进⾏宏替换) 预处理功能主要包括宏定义,⽂件包含,条件编译,去注释等。 预处理指令是以#号开头的代码⾏。 实例: gcc –E hello.c –o hello…...

下篇:《高阶排序算法:分治思想与性能突破》

个人主页&#xff1a;strive-debug 1. 堆排序&#xff08;Heap Sort&#xff09; - **核心思想**&#xff1a;利用 **大根堆&#xff08;升序&#xff09;** 或 **小根堆&#xff08;降序&#xff09;** 进行选择排序。 - **关键步骤**&#xff1a; 1. **建堆**&#xff08;…...