【雷达原理】雷达测角原理及实现方法

news2025/1/19 19:51:03

目录

  • 一、雷达测角原理
    • 1.1 测角研究历史和现状
    • 1.2 测角方法总结
    • 1.3 3DFFT测角
      • 1.3.1 基本原理
      • 1.2.2 测角性能
  • 二、MATLAB仿真案例
  • 参考文献

一、雷达测角原理

1.1 测角研究历史和现状

(1)早期采用窄波束对准目标,目标的角度对应于天线的角度读数,这种使得波束中目标回波的信号强度最大的方法并不能满足所需精度要求。
(2)1937 年一种称为波束切换的技术,首次在美军通信兵SCR-268雷达的原型机上得到演示。这种雷达专门为引导防空火力而设计,并且成为首批成功采用波束切换技术将天线对准目标的成品雷达。
(3)搜索照射技术是利用反射体天线在观测空间的俯仰维上产生窄的笔形波束,以机械扫描的方式对准待观测目标方向或者接近观测目标方向,从而确定待观测目标的空间俯仰角。
(4)点头式雷达广泛应用于雷达系统中的俯仰角测量之中,它通过利用雷达天线摆动或“点头”的方法,在俯仰维上使用窄垂直波束宽度的扇状水平波束进行扫描。
(5)相控阵雷达是一种自适应能力很强的雷达探测系统, 其阵元天线利用阵元间信号的相位关系,根据设定的观测角度快速的形成波束指向,同时可以有效的设定波束形状,不需要使用机械扫描方法。
(6)阵列天线的优势在于可以通过调节行馈源输出端的移相器实现俯仰维扫描或控制笔形窄波束。这种方法在 3D 雷达测高技术中应用广泛,能充分利用频带,并使波形和波束位置相互完全独立。
(7)在精密跟踪测量领域中,单脉冲测角技术是一种工程中较为实用的测角技术,它具有方法简单、计算量小的特点, 在雷达角度测量领域得到广泛应用。
(8)堆积波束雷达将同时形成的接收波束在俯仰维上垂直堆积起来,并在方位维机械旋转,以实现目标的检测和三坐标测量。

1.2 测角方法总结

测角方法分为相位法测角和振幅法测角
相位法测角: 通过比较两天线接收信号的相位信息来确定目标角度的方法。
振幅法测角: 利用目标回波的幅度来定向并利用幅度鉴别器确定目标角度的方法。振幅法测角可以分为最大信号法和等信号法两种。
在这里插入图片描述
对于毫米波雷达,通常采用波达方向估计(Direction of Arrival,DOA)进行测角,这类方法利用多个阵列接收的回波信号之间存在的相位变化关系进行计算,包括 F F T FFT FFT D B F DBF DBF 以及超分辨测角方法。

1.3 3DFFT测角

以一维均匀线阵为例,X波段甚至频率更高的毫米波雷达,其接收阵元的间距为厘米级,对于几米外的目标可视为远场目标,该目标到达各个阵元的回波均相互平行。回波到达相邻两个阵元之间的相位差相同,如图1所示。
对于 LFMCW 雷达的多个接收阵元,做空间 F F T FFT FFT 运算可求得目标反射波在不同天线阵列的相位变化规律,因此可以计算出目标的角度信息。

1.3.1 基本原理

如图1所示,设该雷达系统的天线为1发8收的均匀线阵,接收阵元的间距为 d d d d = λ / 2 d=λ/2 d=λ/2 λ 为波长 λ为波长 λ为波长,目标相对于天线法线方向的夹角为 θ θ θ,则相邻阵元之间接收信号的波程差为 d s i n θ dsinθ dsinθ,由此得到对应的相位差为:
w = 2 π d s i n θ λ ( 1 − 1 ) w=\frac{2πdsinθ}{λ} (1-1) w=λ2πdsinθ11
式(1-1)描述了相邻接收阵元的相位差与目标角度的关系,即通过测量出相邻阵元之间的相位差来间接解算出目标相对雷达的角度。
在这里插入图片描述
图1 一维均匀线阵信号接收示意图
对所有接收阵元的回波信号进行 N f f t N_{fft} Nfft F F T FFT FFT 处理,设获取峰值对应的下标为 k k k k ∈ [ − N f f t / 2 , N f f t / 2 − 1 ] k∈[-N_{fft}/2,N_{fft}/2-1] k[Nfft/2,Nfft/21],则根据 F F T FFT FFT 频谱分析的原理可知 w = 2 π k N f f t w=\frac{2πk}{N_{fft}} w=Nfft2πk,得到 w w w 后,并根据式(1-1)可计算得到目标角度信息:
θ = a r c s i n ( w λ 2 π d ) = a r c s i n ( k λ N f f t d ) = a r c s i n ( 2 k N f f t ) ( 1 − 2 ) θ=arcsin(\frac{wλ}{2πd})=arcsin(\frac{kλ}{N_{fft}d})=arcsin(\frac{2k}{N_{fft}})(1-2) θ=arcsin(2πdwλ)=arcsin(Nfftd)=arcsin(Nfft2k)12
由式(1-2)知,使用 F F T FFT FFT 的方法来进行DOA估计时,采用更多的 F F T FFT FFT 点数有利于提高角度计算精度。

1.2.2 测角性能

(1)测量精度
根据式(1-1)可知,相位差 w w w 与目标角度 θ θ θ 是一种非线性的关系。如图2所示, s i n θ sinθ sinθ 随着 θ θ θ 的增大而逐渐缓慢变化,即该曲线的斜率减小。因此,当 θ θ θ 为0°时,相位差 w w w 对目标角度 θ θ θ 的变化最敏感,此时角度测量的精度最高, w w w 对目标角度 θ θ θ 的灵敏度会随着 θ θ θ 的增加而降低,直到 θ θ θ 为90°时,相位差 w = 0 w=0 w=0,测角精度大大降低。
在这里插入图片描述
图2 正弦曲线示意图

(2)最大不模糊角度
在这里插入图片描述
雷达的最大视场角由估计的最大到达角(Angle of Arrival,AOA)决定。当相位差 w > 0 w>0 w>0 时,目标在雷达的左侧;当相位差 w < 0 w<0 w<0 时,目标在雷达的由侧;但当相位差 w > π w>π w>π 时,就无法确定目标在雷达的哪一侧,这便产生了角度模糊。因此为了测角无模糊,需要满足以下条件:
w = 2 π d s i n θ λ < π ,即 θ = a r c s i n ( λ 2 d ) ( 1 − 3 ) w=\frac{2πdsinθ}{λ}<π,即θ=arcsin(\frac{λ}{2d})(1-3) w=λ2πdsinθ<π,即θ=arcsin(2dλ)13
因此,对于间距为 d d d 的两个阵元可提供的最大不模糊角度为 θ m a x = a r c s i n ( λ 2 d ) θ_{max}=arcsin(\frac{λ}{2d}) θmax=arcsin(2dλ) ,当阵元间距满足 d = λ / 2 d=λ/2 d=λ/2 时, θ m a x = ± 90 ° θ_{max}=±90° θmax=±90°

(3)角度分辨率
角度分辨率反映了雷达对角度相近目标的分辨能力,在3DFFT的计算中则表现为两个目标频谱的峰值相靠近直至成一个单峰。
如下图所示,随着到达角的增加,雷达对目标的角度分辨力下降。
在这里插入图片描述
对于两个目标,其分辨率的计算方法推导如下:
Δ ω = 2 π d λ ( s i n ( θ + Δ θ ) − s i n ( θ ) ) ⁡⁡⁡⁡⁡⁡⁡⁡⁡⁡ ≈ 2 π d λ c o s ( θ ) Δ θ ( 1 − 4 ) Δω =\frac {2πd}{λ}(sin(θ + Δθ) − sin (θ)) ⁡⁡⁡⁡⁡⁡⁡⁡⁡⁡≈ \frac{2πd}{λ}cos(θ) Δθ(1-4) Δω=λ2πd(sin(θ+Δθ)sin(θ))⁡⁡⁡⁡⁡⁡⁡⁡⁡⁡λ2πdcos(θ)Δθ14
式(4-1)利用了导数的概念: s i n ( θ + Δ θ ) − s i n ( θ ) Δ θ = c o s ( θ ) \frac{sin(θ + Δθ) − sin (θ)}{Δθ}=cos(θ) Δθsin(θ+Δθ)sin(θ)=cos(θ)
又因为, Δ ω > 2 π N ( 1 − 5 ) 又因为,Δω >\frac{2π}{N}(1-5) 又因为,Δω>N2π15
由式(1-4)和式(1-5),可以得到:
2 π d λ c o s ( θ ) Δ θ > 2 π N ⇒ Δ θ > λ N d c o s ( θ ) \frac{2πd}{λ}cos(θ) Δθ >\frac{2π}{N} ⇒ Δθ >\frac{λ}{Ndcos(θ)} λ2πdcos(θ)Δθ>N2πΔθ>Ndcos(θ)λ
因此,角度分辨率 θ r e s = λ N d c o s ( θ ) θ_{res}=\frac{λ}{Ndcos(θ)} θres=Ndcos(θ)λ
通常认为 d = λ / 2 , θ = 0 d=λ/2,θ=0 d=λ/2θ=0,所以最终的角度分辨率为:
θ r e s = 2 N θ_{res}=\frac{2}{N} θres=N2

二、MATLAB仿真案例

有关测角的代码(不完整)如下:
1)该程序首先建立1发8收的雷达系统模型,对目标回波进行处理,得到8个通道的距离-多普勒二维数据;
2)其次,对8个通道的距离-多普勒二维数据进行通道间的非相干积累,进而分别在多普勒维和距离维进行不同类型的CFAR检测,得到目标的距离维、速度维下标;
3)最后,提取目标在8个通道的距离维、速度维下标的对应数据,进行空间FFT,获取目标的角度维下标;
4)最终计算出目标的距离、速度和角度等信息,与仿真设置的目标参数保持一致。

clc;
clear;
close all;

%% 雷达系统仿真模型
setParameter();     %  设置雷达系统参数
cancel_On = 0;      %  对消开启或者关闭
chioce = 1;         %  选择均值类CFAR器的类型

global para;
% 设置目标参数
set_TarInfo.tarNum = 5;
set_TarInfo.tar_R0 = [500,1000,1500,2000,2500];                 % 目标距离
set_TarInfo.tar_V0 = [5,1,-8,-1,8];                             % 目标速度
set_TarInfo.tar_Ag = [-20,-10,0,10,20];                         % 目标角度
set_TarInfo.Rcs = [0.1,1,5,1,5];                                % 目标rcs
set_TarInfo.SNR = 10;                                           % 信噪比

% 雷达发射和接收信号模型
para.Tx_Num = 1;        % 发射阵元数目
para.Rx_Num = 8;        % 接收阵元数目
rawData = RadarSigModel_MultiCh(set_TarInfo);

figure(101);plot(abs(rawData(:,1,1)));
xlabel('采样点');ylabel('幅度/mV');title('ADC输入信号');

%% 雷达信号处理
global NumADC;
global NumChirp;

fs = para.fs;
u = para.u;
PRT = para.PRT;
c = para.c;
B = para.B;
Lambda = para.Lambda;
Rx_Num = para.Rx_Num;

Nfft1 = 2^ceil(log2(NumADC));                           % 距离维FFT点数
Nfft2 = 2^ceil(log2(NumChirp));                         % 速度维FFT点数
Nfft3 = 64;                                             % 通道间FFT点数

R_point = (fs/Nfft1)*c/(2*u);                           % 距离点精度
delta_R = c/(2*B);                                      % 距离分辨率
V_point = Lambda/(2*PRT*Nfft2);                         % 速度点精度
delta_V = Lambda/(2*PRT*NumChirp);                      % 速度分辨率
Ag_point = 2/Nfft3*180/pi;                              
delta_Ag = 2/Rx_Num*180/pi;                              % 角度分辨率为delta_Ag=Lambda/(N*d),单位rad。其中N为阵元数目,d为阵元间距,所以要转换为角度

win1 = hamming(NumADC);       % 加汉明窗
fft_Data = zeros(Nfft1,NumChirp);
fft2D_Data = zeros(Nfft1,Nfft2,Rx_Num);
cfarData_In = 0;
for Ch_Num = 1:Rx_Num
    % 距离维FFT
    for ii = 1:NumChirp
        fft_Data(:,ii) = fft(rawData(:,ii,Ch_Num).*win1,Nfft1);
    end
    
    if cancel_On == 1
        % 二次对消
        H_coef = [1,-1];            % 对消器系数
        Cancel_Data = Cancellation(fft_Data,H_coef);
    else
        Cancel_Data = fft_Data;
    end
    
    % 速度维FFT
    fft_tempData = MTD(Cancel_Data);
    fft2D_Data(:,:,Ch_Num) = fft_tempData;
    
    % 通道间的非相干积累
    cfarData_In = cfarData_In+abs(fft_tempData);
end

figure(201);
for Ch_Num = 1:Rx_Num
    subplot(2,4,Ch_Num);
    mesh(mag2db(abs(fft2D_Data(:,:,Ch_Num))));
    xlabel('速度维');ylabel('距离维');zlabel('信号功率(dB)');title(['通道',num2str(Ch_Num),'-MTD']);
    view([0 90]);
end

figure(301);
mesh(mag2db(cfarData_In));
xlabel('速度维');ylabel('距离维');zlabel('信号功率(dB)');title('各通道积累结果');
view([0 90]);

% 计算平均底噪
noiseData = calcu_Noise(cfarData_In);

% 目标CFAR检测
global sensitive;
global P_fa;
global referWin;
global guradWin;
global os_ReferWin;
global os_GuardWin;

sensitive = 1;   % 灵敏度
P_fa = 1e-6;    % 虚警概率
referWin = 8;   % 参考窗大小
guradWin = 5;   % 保护窗大小
os_ReferWin = 8;    % os-cfar参考窗
os_GuardWin = 3;    % os-cfar保护窗

global CA_MaxNum;
CA_MaxNum = 128;    % 速度维CFAR最大检测目标数

% 速度维CFAR
T_start = tic;
cfarData = ML_CFAR(cfarData_In,chioce);
count1_Time = toc(T_start);
disp(['速度维CFAR用时t1=',num2str(count1_Time),'s']);

figure(401);
mesh(cfarData);xlabel('速度维');ylabel('距离维');title('CA-CFAR');
view([0 90]);

% 距离维CFAR
T_start = tic;
Os_cfarOut = OS_CFAR(cfarData_In,cfarData);
count2_Time = toc(T_start);
disp(['速度维CFAR用时t2=',num2str(count2_Time),'s']);

figure(402);
mesh(Os_cfarOut);xlabel('速度维');ylabel('距离维');title('OS-CFAR');
view([0 90]);

% 获取目标位置等参数
global get_TarInfo;
[Rpos,Vpos] = find(Os_cfarOut==1);
[Rpos,I] = sort(Rpos);      % 按距离从近到远排序
Vpos = Vpos(I);
TarNum = length(Rpos);

TargetA = zeros(1,TarNum);
fft3D_Data = zeros(TarNum,Nfft3);      %  用于获取fft测角数据
win3 = hamming(Rx_Num);
for num = 1:TarNum
    Data_temp = zeros(1,Rx_Num);
    for Ch_Num = 1:Rx_Num
        Data_temp(Ch_Num) = fft2D_Data(Rpos(num),Vpos(num),Ch_Num);
    end
    
	deltaPha = mean(phase(Data_temp(2:end)./Data_temp(1:end-1)));     % 求相邻两通道见的相位差,再取平均
    TargetA(num) = -asind(deltaPha/pi);      % 公式法计算目标角度

    fft3D_Data(num,:) = abs(fft(Data_temp.*win3',Nfft3));    %  获取3DFFT后取模值
    
    % 计算目标角度所在下标
    [~,Ag_Pos] = max(fft3D_Data(num,:));
    
    % 获取目标测量结果
    get_TarInfo.Range(num) = (Rpos(num)-1)*R_point;
    
    if Vpos(num)<=(NumChirp/2)
        get_TarInfo.Velocity(num) = (Vpos(num)-1)*V_point;
    else
        get_TarInfo.Velocity(num) = -(NumChirp-Vpos(num))*V_point;
    end
    
    if Ag_Pos<=(Nfft3/2)
        get_TarInfo.Azimu(num) = -(Ag_Pos-1)*Ag_point;
    else
        get_TarInfo.Azimu(num) = (Nfft3-Ag_Pos)*Ag_point;
    end
    
    get_TarInfo.Energy(num) = db(cfarData_In(Rpos(num),Vpos(num))); % 获取目标峰值能量
    get_TarInfo.SNR(num) = get_TarInfo.Energy(num) - noiseData;
    disp(['目标',num2str(num),':距离R=',num2str(get_TarInfo.Range(num)),',速度V=',num2str(get_TarInfo.Velocity(num)),',角度A=',num2str(get_TarInfo.Azimu(num))]);
    disp(['能量:',num2str(get_TarInfo.Energy(num)),',信噪比:',num2str(get_TarInfo.SNR(num))]);
end
get_TarInfo.TarNum = TarNum;

计算结果如下:
目标1:距离R=500.63,速度V=4.977,角度A=-19.6954
能量:79.9525,信噪比:61.125
目标2:距离R=1001.26,速度V=1.0247,角度A=-10.743
能量:76.3724,信噪比:57.5449
目标3:距离R=1496.6202,速度V=-7.9047,角度A=0
能量:75.7472,信噪比:56.9197
目标4:距离R=1997.2501,速度V=-0.95149,角度A=8.9525
能量:51.3515,信噪比:32.524
目标5:距离R=2503.1499,速度V=7.9779,角度A=17.9049
能量:57.9947,信噪比:39.1672

参考文献

[1] Introduction to mmwave Sensing:FMCW Radars.
[2] 许成洋. 相控阵LFMCW雷达信号处理方法及实现[D].西安电子科技大学,2021.
[3] 王成海. 雷达测角方法研究[D].西安电子科技大学,2014.
[4] 雷达测角原理、测角精度、测角分辨率以及3DFFT角度估计算法汇总

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

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

相关文章

Unity3D 转换微信小游戏指引 01

Unity3D 转换微信小游戏指引系列&#xff08;第一期&#xff09; 搭建环境 安装 WebGL 模块 首先&#xff0c;Unity 要安装WebGL Build Support模块。 在 Hub 找到安装的引擎&#xff0c;点击设置按钮&#xff0c;点击Add modules添加模块。 勾选WebGL Build Support&#…

股指期权交割日期是什么时候?在每个月几号?

今天带你了解股指期权交割日期是什么时候&#xff1f;在每个月几号&#xff1f;期权交割日是指合约到期之日&#xff0c;即投资者需要履行买卖合约的义务。 股指期权的交割日期通常是期权合约到期日的第三个星期五。如果这一天是公共假日&#xff0c;则交割日可能会提前到前一…

检索增强生成RAG系列3--RAG优化之文档处理

在上一章中罗列了对RAG准确度的几个重要关键点&#xff0c;主要包括2方面&#xff0c;这一章就针对其中一方面&#xff0c;来做详细的讲解以及其解决方案。 目录 1 文档解析1.1 文档解析工具1.2 实战经验1.3 代码演示 2 文档分块2.1 分块算法2.2 实战经验2.3 代码演示 3 文档e…

Workerman在线客服系统源码,附搭建教程

源码介绍&#xff1a; Workerman在线客服系统源码。 workerman是一个高性能的PHP socket 服务器框架&#xff0c;workerman基于PHP多进程以及libevent事件轮询库&#xff0c;PHP开发者只要实现一两个接口&#xff0c;便可以开发出自己的网络应用&#xff0c;例如Rpc服务、聊天…

基于Java的会员制医疗预约服务管理信息系统

你好呀&#xff0c;我是计算机学姐码农小野&#xff01;如果有相关需求&#xff0c;可以私信联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;Java技术ssm框架&#xff0c;结合JSPM工作流引擎 工具&#xff1a;IDEA/Eclipse、Navicat、Maven …

每日一题——Python实现PAT乙级1090 危险品装箱(举一反三+思想解读+逐步优化)4千字好文

一个认为一切根源都是“自己不够强”的INTJ 个人主页&#xff1a;用哲学编程-CSDN博客专栏&#xff1a;每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 题目链接&#xff1a;https://pintia.cn/problem-sets/994805260223102976/exam/problems/typ…

2024 vue3入门教程:windows系统下部署node环境

一、打开下载的node官网 Node.js — 下载 Node.js 二、根据个人喜好的下载方法&#xff0c;下载到自己的电脑盘符下 三、我用的是方法3下载的压缩包&#xff0c;解压到E盘nodejs目录下&#xff08;看个人&#xff09; 四、配置电脑的环境变量&#xff0c;新建环境变量的时候…

树莓派4B学习笔记17:RBG_LED全色域灯的驱动模块编写

今日继续学习树莓派4B 4G&#xff1a;&#xff08;Raspberry Pi&#xff0c;简称RPi或RasPi&#xff09; 本人所用树莓派4B 装载的系统与版本如下: 版本可用命令 (lsb_release -a) 查询: ​ Python 版本3.7.3&#xff1a; ​ 今日学习&#xff1a;RBG_LED全色域灯的驱动模块编写…

初学者轻松搞定19个经典的Python程序以及代码演示

Python的经典程序展示了Python语言基本特性和功能的简单示例,这些程序在学习和理解Python编程语言的过程中起着至关重要的作用. 一些常见的经典Python程序及其在学习Python时的功能&#xff1a; 1.Hello, World! print("Hello, World!")解释:这是Python的基本输出…

(单机架设教程)凯旋|当年的QQ游戏

前言 今天给大家带来一款单机游戏的架设&#xff1a;凯旋 &#xff0c; 当年的QQ游戏 如今市面上的资源参差不齐&#xff0c;大部分的都不能运行&#xff0c;本人亲自测试&#xff0c;运行视频如下&#xff1a; 凯旋单机 搭建教程 此游戏架设需要安装虚拟机&#xff0c; 没有…

【面试系列】Python 高频面试题

欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;欢迎订阅相关专栏&#xff1a; ⭐️ 全网最全IT互联网公司面试宝典&#xff1a;收集整理全网各大IT互联网公司技术、项目、HR面试真题. ⭐️ AIGC时代的创新与未来&#xff1a;详细讲解AIGC的概念、核心技术、…

基于源码详解ThreadPoolExecutor实现原理

个人博客地址 基于源码详解ThreadPoolExecutor实现原理 | iwts’s blog 内容拆分 这里算是一个总集&#xff0c;内容太多&#xff0c;拆分成几个比较重要的小的模块&#xff1a; ThreadPoolExecutor基于ctl变量的声明周期管理 | iwts’s blog ThreadPoolExecutor 工作线程…

【PL理论深化】(13) 变量与环境:文法结构 | 真假表达式:isZero E | let 表达式叠放 | 定义的规则 | 条件语句的使用

&#x1f4ac; 写在前面&#xff1a;从现在开始&#xff0c;让我们正式设计和实现编程语言。首先&#xff0c;让我们扩展在之前定义的整数表达式语言&#xff0c;以便可以使用变量和条件表达式。 目录 0x00 文法结构 0x01 真假表达式&#xff1a;isZero E 0x02 let 表达式叠…

1-5题查询 - 高频 SQL 50 题基础版

目录 1. 相关知识点2. 例题2.1.可回收且低脂的产品2.2.寻找用户推荐人2.3.大的国家2.4. 文章浏览 I2.5. 无效的推文 1. 相关知识点 sql判断&#xff0c;不包含null&#xff0c;判断不出来distinct是通过查询的结果来去除重复记录ASC升序计算字符长度 CHAR_LENGTH() 或 LENGTH(…

LeetCode-Leetcode 1120:子树的最大平均值

LeetCode-Leetcode 1120&#xff1a;子树的最大平均值 题目描述&#xff1a;解题思路一&#xff1a;递归解题思路二&#xff1a;0解题思路三&#xff1a;0 题目描述&#xff1a; 给你一棵二叉树的根节点 root&#xff0c;找出这棵树的 每一棵 子树的 平均值 中的 最大 值。 子…

文章浮现之单细胞VDJ的柱状图

应各位老师的需求复现一篇文章的中的某个图 具体复现图5的整个思路图&#xff0c;这里没有原始数据&#xff0c;所以我使用虚拟生产的metadata进行画图 不废话直接上代码&#xff0c;先上python的代码的结果图 import matplotlib.pyplot as plt import numpy as np# 数据&#…

RocketMQ常用基本操作

文章中的rabbitmq使用的是rocketmq-all-5.1.3-bin-release版本&#xff0c;需要安装包的可自行下载 RockerMQ启动停止命令 启动命令 nohup sh bin/mqnamesrv & nohup sh bin/mqbroker -n localhost:9876 --enable-proxy & 查看日志 tail -f ~/logs/rocketmqlogs/…

sqlmap注入详解

免责声明:本文仅做分享... 目录 1.介绍 2.特点 3.下载 4.帮助文档 5.常见命令 指定目标 请求 HTTP cookie头 HTTP User-Agent头 HTTP协议的证书认证 HTTP(S)代理 HTTP请求延迟 设定超时时间 设定重试超时 设定随机改变的参数值 利用正则过滤目标网址 避免过多的…

江大白 | 何凯明入职 MIT,首次带队提出Diffusion Loss,扩散模型思想提升生成速度和效果 !

本文来源公众号“江大白”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;何凯明入职 MIT&#xff0c;首次带队提出Diffusion Loss&#xff0c;扩散模型思想提升生成速度和效果 &#xff01; 导读 在图像生成领域中&#xff0c;作…

在数字化转型中,中小企业如何打造数字化产品和服务?

引言&#xff1a;随着社会的发展和消费者行为的变化&#xff0c;市场对数字化产品和服务的需求日益增长。中小企业需要紧跟这一趋势&#xff0c;通过开发数字化产品和服务来满足消费者的新需求。云计算、大数据、人工智能等先进技术的出现&#xff0c;为中小企业提供了更多的机…