LFM雷达实现及USRP验证【章节3:连续雷达测距测速】

第一章介绍了在相对速度为0时候的雷达测距原理

目录

1. LFM测速

1.1 雷达测速原理

1.2 Chrip信号测速

2. LFM测速代码实现

参数设置

仿真图像

matlab源码

代码分析


第一章介绍了在相对速度为0时候的雷达测距原理,第二章介绍了基于LFM的雷达测距原理及其实现,但是存在相对运动时,无法得到目标物体的多普勒信息,进而无法计算目标物体的速度。本章将在第二章的基础上,实现连续LFM波形的雷达测距测速。

该笔记参考资料:Radar测距及测速原理(2)——快速Chirp序列方法推导及实际应用 - 知乎 (zhihu.com)https://zhuanlan.zhihu.com/p/77500626

(114条消息) 线性调频(LFM信号)脉冲压缩雷达matlab仿真- 脉冲压缩 测距 测速 距离速度三维像(附matlab代码)_格桑蓝莲的博客-CSDN博客https://blog.csdn.net/weixin_44566643/article/details/107508520

1. LFM测速

1.1 雷达测速原理

通常来说,我们可以通过确定电磁波传播的时间来估算距离,通过多普勒效应产生的频率偏移来估算相对速度。但实际使用中我们会发现,对于没有经过调制的连续波谱(Continuous Wave),我们只发出相同的正弦或余弦信号,接收到的波也是呈周期性变化的,所以我们无从知道从发出到接受到底经过了多少个波长,从而无法确定信号从发出到接受所经历的时间(time of flight),也就无法测算距离。

于是,我们引入了线性调频LFM,使发出信号的频率随时间处于不断的变化中。LFM雷达在扫频周期内发射频率变化的连续波,被物体反射后的回波与发射信号有一定的频率差,通过测量频率差可以获得目标与雷达之间的距离信息。

第一章讨论了相对速度为0的情况,现考虑存在相对运动速度v_{r},当存在相对速度(正值表示远离,负值表示靠近),距离R会随着时间进行变化,当相对速度 v_{r}>0,R不断增大,故f_{b}也不断变大;当相对速度 v_{r}<0,R不断减小,故f_{b}也不断减小。因此当目标物同观测点有相对运动时,多普勒频偏也要放在考虑之中,发出及接受的信号频率变化变成如下图所示:

为了简化模型,且考虑到信号从发出到接收所经历的时间极短,加速度不变,目标物体相对速度几乎不变,信号频率变化如下所示:

蓝色表示原始发射波形,虚线的红黄两线表示接收到的不同回波信号,因为目标物体存在相对速度,接收到的回波信号在原始信号的基础上不但右移(时延)如黄虚线所示,同时存在上下移动(频移f_{D})如红虚线所示,具体解释如下: 

1.2 Chrip信号测速

结合第一章节以及本章前面内容,雷达测距测速的基本原理相信各位已经明白,现在将基本原理与LFM相结合,通过缩短每一个Chrip信号的频扫时间,使得在每一个Chrip时间内,相对速度基本保持不变(降低相对速度带来的影响)。此时,可以将每一个Chrip信号看成一个准静态情况(一个Chirp中相对速度为0,相对距离R不变,从而不考虑多普勒效应),从而比较容易的确定一个Chirp中的相对距离R。但是因为视为准静态过程,我们无从得知相对速度的值,因此,我们需要发出很多个连续相同的Chirp(Chirp序列)来确定相对速度,如下图:

如图所示,很多个Chirp组成了一个”Sequence“,总时间用t_{seq} 表示。在每个Chirp中,相对距离R被视为定值,因此,在一个Chirp序列中,R是以离散值表示出来的,每一个Chirp给出一个R,这里将离散的相对距离序列称为Range Cells。我们假设总共发出N个相同Chirp,那么从第0到第N-1个Chirp的扫频周期及扫频带宽相等均为t_{c}f_{c}

为了得到每个Chirp的相对距离R,我们首先要得到每个Chirp中的差频(beat frequency),因此,我们将每一个Chirp进行采样,共得到k个采样值。利用快速傅里叶变换(FFT)得出每个Chirp中的f_{b}值,从而得到相对距离R。因为这里的FFT之后得到的是距离,所以在这里称为“Range-FFT"。经过FFT后,对于每个Chirp我们得都到了k个频点(frequency bins),其也对应着测量相对距离R的分辨率。

 由于在一个测量序列t_{seq}中,经历的时间较短,我们假设其相对速度是不变的,不存在加速度。并且,相对速度可由R的变化求出,而R又可以由差频得到,因此,我们就可以利用上一步Range-FFT得出的一个序列中各个Chirp的f_{b}的变化来求相对速度。

在上一步中,由FFT得到的f_{b}是一个复数,由于t_{seq}极短,所以f_{b}的变化也很小,从而不足以使得不同Chirp得到的相对距离R跳跃到不同的Range cells中(FFT后,幅值最大的序号不变),但其变化还是存在的。其结果可以在复频域中表示出来:在一个测量序列中,f_{b}在复频域中旋转,其旋转的频率即为相对速度v_{r}的标尺!f_{b}再进行FFT,可以得到其变化的频率,从而得到相对速度。因为这里的FFT之后得到的是相对速度,所以我们这里称为“Speed-FFT”

由于每个Chirp可以得到一个相对距离R,所以相对距离的分辨率为:

\Delta R=\frac{c_{0}}{2f_{c}}

而在一个序列中我们假设相对速度不变,因此相对速度的分辨率为: 

\Delta v_{r}=\frac{c_{0}}{2f_{s}t_{seq}}

注意:公式中各个物理量的表示可能与我们仿真所使用到的表示不同,如f_{c}在仿真中用带宽表示。

2. LFM测速代码实现

  • 参数设置

参数设置参数含义
fc载波频率4GHz
Fs采样率为200MHz(USRP最大采样率受限)
Ts采样周期Ts=1/FS=5ns
BB=0.4Fs=80MHz(满足奈奎斯特带宽)
Tp一个Chrip信号的时宽10us,Tp=10e-6
c光速,设置为3e8
PRF每秒脉冲重复频率为200
Tr脉冲重复周期等于1/PRF=5ms
lamda波长等于光速/载波频率=75cm(厘米波波段)
Rmax受到采样时间的限制Rmax = c/2*16*t,t为采样时间
R_resolution距离分辨率=光速/两倍波长=c/(2B)=1.875m
N_pulse发射脉冲个数num_pulse=50
t采样时间t = 0:1/Fs:Tp,采样时间,会决定最大检测距离
N_samples采样点数N_samples=N_time/Fs
  • 仿真图像

第一个回波信号的距离幅度谱

测距(Range FFT)

测距测速三维图像
  • matlab源码

%==========================================================================
%%   连续脉冲LFM雷达测距测速
%%   完美实现,没有bug
% matlab2021b
%==========================================================================
clear;clc;close all;
%% LFM参数设置
fc = 4e9;               %载波频率
PRF = 2000;               %脉冲重复频率
Tr = 1/PRF;             %脉冲重复周期
B = 80e6;               %带宽
Fs = 2.5*B;             %采样频率
Ts = 1/Fs;              %采样时间
Tp = 10e-6;             %脉宽
c = 3e8;                
lamda = c/fc;           %载波波长
Kr = B/Tp;               %调频斜率
N_pulse = 50;           %脉冲个数(个数不能太少)
t = 0:1/Fs:Tp;        %采样时间
N_samples = length(t);   %采样点个数
N_targets= 5;           %目标物体个数
Rmax = c/2*1*Tp;       %最大检测距离(受到采样时间的限制,采样时间为16Tp)
Vmax = lamda*PRF/2;     %目标最大速度,最大测速范围满足在第一盲速之内
R_targets = [1000,230,680,860,145];%物体的距离随机生成
RCS = 10*(exp(1i*2*pi*rand(1,N_targets)));%目标物体RCS,幅度为10,相位在(0,2pi)之间随机分布
V_targets = Vmax*((rand(1,N_targets))/2);%目标物体速度

%% 接收矩阵sr计算
sr = zeros(N_pulse,N_samples);%sr的每一行表示一个回波信号所含的采样点,一共有50行不同回波信号构成
for i = 1:N_pulse
    delay = (i-1)*Tr;   %发送第i个Chrip信号时相对初始时间的时延
    sr_row = 0;
    % 内层for循环,一个目标一个目标来研究,对应每一个回波脉冲是由每一个目标回波之和组成
    for k=1:N_targets
        tao=2*(R_targets(k)-V_targets(k).*(delay+t))/c;   %在当前时刻,雷达信号往返的时间(目标物体在运动,距离在变化)
        sr_temp=RCS(k).*rectpuls(t-tao-Tp/2,Tp).*exp(-1j*2*pi*fc*tao+1j*pi*Kr.*(t-tao-Tp/2).^2);
        sr_row=sr_row+sr_temp;
    end
    % 外层for循环,不同的脉冲,对应的delay是不同值,再代入来计算回波
    sr(i,:)=sr_row;
end
R_range = c*t/2;    %在采样时间内,距离的范围
%% 脉冲压缩
% 参考信号st
st=rectpuls(t-Tp/2,Tp).*exp(1i*pi*Kr*(t-Tp/2).^2);%时域参考信号(将原始信号右移Tp/2)
stf=conj(fft(st));%匹配滤波器的频域特性
for i=1:N_pulse
    sr_mf(i,:)=ifft(fft(sr(i,:)).*stf);  %分别对每一行脉冲压缩 频域脉冲压缩(匹配滤波mf)          
end

%% 图像输出
%----------------------------测距(Range FFT)------------------------------
% 第一个回波信号的距离幅度谱
figure(2);
plot(t*c/2,abs(sr_mf(1,:)))                       
title('第一个回波信号的距离幅度谱');
%----------------------------测速(Speed FFT)------------------------------
sr_speed=fft(sr_mf,[],1);
V=linspace(0,PRF,50)*lamda/2;

% 尝试着画一下三维图
figure(4)
mesh(R_range,V,abs(sr_speed)/max(max(abs(sr_speed))));
xlabel('距离/m'); 
ylabel('速度/(m/s)');
zlabel('幅度/db');
title('目标距离速度信息一览');



  • 代码分析

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构第十一期——线段树的原理和应用

目录 一、前言 二、线段树的概念 1、区间最值问题RMQ (Range Minimum/Maximum Query) &#xff08;1&#xff09;暴力法 &#xff08;2&#xff09;高效的办法&#xff1a;线段树 &#xff08;3&#xff09;把数列放在二叉树上 &#xff08;4&#xff09;查询最小值的复…

43-二叉树练习-LeetCode236二叉树的最近公共祖先

题目 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&#xff08;一个节点也可以是它…

一款全新的基于GPT4的Python神器,关键还免费

chartgpt大火之后&#xff0c;随之而来的就是一大类衍生物了。 然后&#xff0c;今天要给大家介绍的是一款基于GPT4的新一代辅助编程神器——Cursor。 它最值得介绍的地方在于它免费&#xff0c;我们可以直接利用它来辅助我们编程&#xff0c;真正做到事半功倍。 注意&#…

k8s实践 | configmapsecretpvpvc

文章目录configmap&secret&pv&pvc一、configMap1、应用场景2、创建configMap2.1、help文档2.2、使用目录创建2.3、根据文件创建2.4、文字创建2.5、直接方法2.6、pod中应用2.7、热更新二、secret1、Service Account2、opaque Secret2.1、创建示例2.2、使用方式三、k…

eNSP 本地AAA配置实验

关于本实验本实验要求将路由器AR1配置为AAA服务器&#xff0c;以本地认证方式对尝试登录AR1的用户进行身份认证和授权。路由器AR2作为登录用户&#xff08;AAA客户端&#xff09;&#xff0c;以Telnet的方式登录AR1.读者需要在AR1中创建一个名为datacom的管理员域&#xff0c;并…

【Unity游戏开发教程】零基础带你从小白到超神22——旧动画和新动画组件的使用

制作一个动画 创建动画 添加变化属性 实现方块向右移动10 添加关键帧 实现先慢后快的效果 录制动画 旧动画组件(Animation组件) 如果想让一个游

PMP项管2023年5月的备考准备攻略!

2023年共有4次PMP考试&#xff0c;分别是3月、5月、8月、11月&#xff0c;由于3月份考试不开放新报名&#xff0c;所以第一次备考PMP的同学可以选择参加5月份考试。那么&#xff0c;现在备考5月份PMP考试还来得及吗&#xff1f; 现在开始备考5月PMP考试&#xff0c;时间是非常…

GEE:克里金 Kriging 插值(以陕西省2013年生物量为例)

本文记录了在Google Earth Engine(GEE)平台上进行 Kriging 插值的介绍和代码案例。本文通过选取的2013年陕西省生物量样本点数据为例,利用 Kriging 插值对未知区域做了插值计算。 Google Earth Engine(GEE)是一个用于分析地理空间数据的云平台,其中包含了许多地理空间分…

Office E5 OneDrive API使用指南:注册+密钥获取+获取临时上传链接+分片

异想之旅&#xff1a;本人原创博客完全手敲&#xff0c;绝对非搬运&#xff0c;全网不可能有重复&#xff1b;本人无团队&#xff0c;仅为技术爱好者进行分享&#xff0c;所有内容不牵扯广告。本人所有文章仅在CSDN、掘金和个人博客&#xff08;一定是异想之旅域名&#xff09;…

Java 各种锁的理解与实现

1. volatile 是轻量级锁&#xff1a; 只能修饰在变量上&#xff0c;使得 cpu 每次对于该变量的修改和读取都从内存中操作&#xff0c;而不是从CPU cache 中操作&#xff0c;保证共享变量对所有线程的可见性&#xff0c;但是并不能保证原子性 2. synchronized 悲观锁&#xff…

Mybatis的CRUD使用详解

文章目录一.Mybatis的CRUD使用详解1.1 select1.2 insert1.3 update1.3 delete二.常见错误一.Mybatis的CRUD使用详解 注意&#xff1a;增删改需要提交事务。 namespace&#xff08;UserMapper.xml&#xff09; namespace中的包名需要和Dao/mapper接口的包名一致。 <!--na…

论文阅读 10 | Instance Credibility Inference for Few-Shot Learning

小样本学习的实例可信度推理作者摘要1. Introduction2. Related Work作者 摘要 小样本学习&#xff08;FSL&#xff09;旨在识别每个类别极其有限的训练数据的新对象。以前的努力是通过利用元学习范式或数据增强中的新原理来缓解这个极其缺乏数据的问题。相比之下&#xff0c;本…

taro--之使用nutui组件库

安装 Taro 脚手架# 使用 npm 安装 CLI npm install -g tarojs/cli# 使用 yarn 安装 CLI yarn global add tarojs/cli# 使用 cnpm 安装 CLI cnpm install -g tarojs/cli使用 NutUI 模板创建项目1、使用命令创建 Taro 项目&#xff1a;taro init myApp2、按照下方图片依次选择&am…

ChatGPT如何批量撰写最新的热点自媒体文章

如何用ChatGPT创作高质量的自媒体文章 自媒体已成为互联网上的一个重要组成部分&#xff0c;无论您是想在社交媒体、博客中发布内容&#xff0c;高质量的文章都是自媒体成功的重要组成部分。ChatGPT是一个智能文章生成器&#xff0c;能够帮助创作者快速、高效地生成高质量的自…

数据结构——二叉搜索树

一、二叉搜索树概念 二叉搜索树又叫二叉排序树&#xff0c;它或是空树&#xff0c;或是具有以下性质的二叉树&#xff1a; &#xff08;1&#xff09;若它的左子树不为空&#xff0c;则左子树上的所有节点的值都小于根节点的值&#xff1b; &#xff08;2&#xff09;若它的…

LeetCode-718. 最长重复子数组

目录题目思路动态规划遇到的坑动态规划(优化)题目来源 718. 最长重复子数组 题目思路 用二维数组可以记录两个字符串的所有比较情况&#xff0c;这样就比较好推递推公式了。 动态规划 1.确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i][j]的定义也就决定…

【云原生】我将ChatGPT变成Kubernetes 和Helm 终端

{kubectl get po&#xff0c;deploy&#xff0c;svc}{kubectl run --imagenginx nginx-app --port80 --env“DOMAINcluster”}{kubectl expose deployment nginx-app --port80 --namenginx-http}{kubectl get po&#xff0c;svc&#xff0c;deploy}{curl 10.100.67.94:80}{helm…

Spring事务

目录 手动操作 声明式提交 注解的属性 事务隔离级别 事务传播机制 事务可以将一组操作封装成为一个单元&#xff0c;一组操作要么全部成功&#xff0c;要么全部失败 Mysql中操作事务&#xff0c;有三个步骤&#xff1b; 1、start transaction &#xff1b;开启事务 2、com…

springboot 整合Mybatis-Plus分页、自动填充功能

springboot 整合Mybatis-Plus分页、自动填充功能功能 此次分页、自动填充功能的实现是在Spring Boot整合 druid、Mybatis-plus实现的基础上完成的&#xff0c;包括数据源配置、各种依赖添加、mapper和service的实现。不在重复记录。 Java开发手册要求数据表必须要有三个字段&am…

【lwIP(第九章)】ICMP协议

目录一、ICMP协议简介1. ICMP协议类型与结构2. ICMP 差错报文3. ICMP 查询报文二、ICMP协议原理1. ICMP报文数据结构2. ICMP的差错报文3. 差错报文的原理4. ICMP的查询报文一、ICMP协议简介 ICMP协议是一个网络层协议。 一个新搭建好的网络&#xff0c;往往需要先进行一个简单的…