线性调频信号的解线调(dechirp,去斜)处理matlab仿真

线性调频信号的解线调

      • 线性调频信号的回波模型
      • 参考信号
      • 去斜处理
      • 去斜处理傅里叶变换得到脉压结果
      • 解线调仿真
      • 总结

线性调频信号的回波模型

对于线性调频脉冲压缩雷达,其发射信号为:
s ( t ) = r e c t ( t T ) e x p ( j π μ t 2 ) \begin{equation} s(t)=rect(\frac{t}{T})exp(j\pi \mu t^2) \end{equation} s(t)=rect(Tt)exp(μt2)
其中
r e c t ( t T ) = { 1 , 0 ≤ t ≤ T 0 , o t h e r w i s e . \begin{equation} rect(\frac{t}{T})= \left\{ \begin{array}{ll} 1, & 0\leq t \leq T\\ 0, & otherwise. \end{array} \right. \end{equation} rect(Tt)={1,0,0tTotherwise.
其中 t t t为快时间变量, T T T为脉冲宽度, μ \mu μ为调频斜率, B = T μ B=T\mu B=Tμ为雷达信号的带宽,搭载到载频上的发射信号为:
s ( t ) = r e c t ( t T ) e x p ( j π μ t 2 ) e x p ( j 2 π f c t ) \begin{equation} s(t)=rect(\frac{t}{T})exp(j\pi \mu t^2)exp(j2\pi f_c t) \end{equation} s(t)=rect(Tt)exp(μt2)exp(j2πfct)
假设单目标的情况,目标位于 R t a r R_{tar} Rtar处,接收到的回波信号表达式为
s r ( t ) = r e c t ( t − t 0 T ) e x p ( j π μ ( t − t 0 ) 2 ) e x p ( j 2 π f c ( t − t 0 ) ) \begin{equation} s_r(t)=rect(\frac{t-t_0}{T})exp(j\pi \mu (t-t_0)^2)exp(j2\pi f_c (t-t_0)) \end{equation} sr(t)=rect(Ttt0)exp(μ(tt0)2)exp(j2πfc(tt0))
其中 t 0 = 2 R t a r / c t_0=2R_{tar}/c t0=2Rtar/c

参考信号

参考信号同样是一个线性调频信号,调频斜率、载频与雷达发射的信号一样,但是脉宽大于雷达发射线性调频信号的 T T T,这个脉宽其实就是一个信号处理窗,我们接收到一个脉冲重复周期的雷达回波之后,对选定的一段信号进行处理,这一段信号的长度就是窗,因为我们不知道雷达回波中的脉冲位置,所以选取的窗应该至少等于脉冲宽度才能将其“覆盖”住。参考信号可以表示为:
s r e f ( t ) = r e c t ( t − t r e f T r e f ) e x p ( j π μ ( t − t r e f ) 2 ) e x p ( j 2 π f c ( t − t r e f ) ) \begin{equation} s_{ref}(t)=rect(\frac{t-t_{ref}}{T_{ref}})exp(j\pi \mu (t-t_{ref})^2)exp(j2\pi f_c (t-t_{ref})) \end{equation} sref(t)=rect(Trefttref)exp(μ(ttref)2)exp(j2πfc(ttref))
其中, t r e f = 2 R r e f / c t_{ref}=2R_{ref}/c tref=2Rref/c c c c为光速, R r e f R_{ref} Rref是参考距离, T r e f T_{ref} Tref是接收窗,一般而言 T r e f > T T_{ref}>T Tref>T
在这里插入图片描述

图1 雷达回波和参考信号示意图

去斜处理

解线调就是将雷达回波和参考信号的共轭进行混频
s d e ( t ) = s r ( t ) ⋅ s r e f ∗ ( t ) = r e c t ( t − t 0 T ) e x p ( j 2 π ( − μ ( t 0 − t r e f ) ) t ) e x p ( − f c ( t 0 − t r e f ) ) e x p ( 1 / 2 μ ( t 0 2 − t r e f 2 ) ) ) \begin{equation} s_{de}(t)=s_r(t)\cdot s_{ref}^{*}(t)=rect(\frac{t-t_0}{T})exp(j2\pi (-\mu (t_0-t_{ref}))t)exp(-f_c(t_0-t_{ref}))exp(1/2\mu(t_0^2-t_{ref}^2))) \end{equation} sde(t)=sr(t)sref(t)=rect(Ttt0)exp(j2π(μ(t0tref))t)exp(fc(t0tref))exp(1/2μ(t02tref2)))
上面式子中一共有3个指数项,且只有第一个指数项是时间 t t t的函数,后面两个记为 e x p ( j ϕ ) exp(j\phi) exp(jϕ),则可以化简为:
s d e ( t ) = s r ( t ) ⋅ s r e f ∗ ( t ) = r e c t ( t − t 0 T ) e x p ( j 2 π ( − μ ( t 0 − t r e f ) ) t ) e x p ( j ϕ ) \begin{equation} s_{de}(t)=s_r(t)\cdot s_{ref}^{*}(t)=rect(\frac{t-t_0}{T})exp(j2\pi (-\mu (t_0-t_{ref}))t)exp(j\phi) \end{equation} sde(t)=sr(t)sref(t)=rect(Ttt0)exp(j2π(μ(t0tref))t)exp(jϕ)
可以看到解线调后的信号是一个单频信号,其频率为 f = − μ ( t 0 − t r e f ) f=-\mu (t_0-t_{ref}) f=μ(t0tref),它是调频斜率 − μ -\mu μ和相对时间 ( t 0 − t r e f ) (t_0-t_{ref}) (t0tref)的函数, ( t 0 − t r e f ) (t_0-t_{ref}) (t0tref)也就是雷达回波的脉冲相对于参考信号时间窗的延时。 t r e f t_{ref} tref是已知的,那么由解线调信号的频率便可以得到目标的延时。

去斜处理傅里叶变换得到脉压结果

我么对解线调信号进行傅里叶变换
S d e ( f ) = F { s d e ( t ) } = ∫ s d e ( t ) e x p ( − j 2 π f t ) d t = T r e f e x p ( j φ ( f ) ) s i n c ( T r e f ( f − f t a r ) ) \begin{equation} S_{de}(f)=\mathcal{F}\{s_{de}(t) \}=\int s_{de}(t)exp(-j2\pi ft)dt=T_{ref}exp(j\varphi (f))sinc(T_{ref}(f-f_{tar})) \end{equation} Sde(f)=F{sde(t)}=sde(t)exp(j2πft)dt=Trefexp(jφ(f))sinc(Tref(fftar))
其中 f t a r f_{tar} ftar R t a r R_{tar} Rtar具有以下关系:
R t a r = R r e f + ( c ⋅ f t a r ) / ( 2 μ ) \begin{equation} R_{tar}=R_{ref}+(c\cdot f_{tar})/(2\mu) \end{equation} Rtar=Rref+(cftar)/(2μ)

整个流程如下图所示,解线调之后由频域图可以得到和匹配滤波相同的结果,它们都是sinc函数。
在这里插入图片描述

图2 解线调流程图及时频图

解线调仿真

下面仿真的例子:
线性调频信号的带宽为2MHz,采样频率为8MHz,雷达发射线性调频信号脉宽50us,解线调脉宽100us。

%%Dechirp仿真,解线性调频
% 雷达信号采用线性调频信号,
% 主要内容:线性调频信号的生成、雷达回波的模拟、解线调参考信号生成、解线调操作、结果绘制
% Author: baidan @beijing 2023.1.11
%=========================================================================%
%                        雷达参数设置                                     %
%=========================================================================%
clear all;close all;clc;
C = 3.0e8;              %光速(m/s)
BandWidth = 2.0e6;      %雷达发射信号带宽,带宽=B=1/tau,tau是脉冲宽度
TimeWidth = 50.0e-6;    %雷达发射信号的脉冲时宽
k = BandWidth/TimeWidth;%调频斜率
PRT = 100e-6;           %雷达发射脉冲重复周期(s),100us对应1/2*100*300=15000米最大无模糊距离
Fs = BandWidth*4;       %采样频率 采样点数为PRT*FS=480
NoisePower = 1;         %噪声功率
SNR = 0;                %信噪比,以dB为单位
SigPower = 10^(SNR/10); %目标功率,无量纲
TargetDistance = 2500;  %目标距离,单位:
TargetDelay = 2*TargetDistance/C;           %延时时间,由目标的距离换算成时间,即线性调频信号的时间
mDelayNumber = fix(Fs*2*TargetDistance/C);  %把目标距离换算成采样点(距离门)
plot_enable_H = 1;      %绘图控制符
plot_enable_L = 0;      %绘图控制符
%=========================================================================%
%                            调用函数产生线性调频信号                     %
%=========================================================================%
[LFMPulse,targetEchoPRT,matchedFilterCoeff,pulseNumber,PRTNumber] = GenerateLFMSignal(BandWidth,TimeWidth,PRT,Fs,SigPower,TargetDistance,plot_enable_L);%调用函数
fprintf('Target appear in the %.1f us, distence is %.1f m, at %dth sampling point\n',TargetDelay*1e6,TargetDistance,mDelayNumber);
%=========================================================================%
% %                        产生功率为1高斯白噪声并添加噪声                  %
% %=========================================================================%
noise = GaussianNoise(PRT,Fs);
%mixedSignal = targetEchoPRT + noise; %添加噪声
mixedSignal = targetEchoPRT; %不添加噪声
%=========================================================================%
%                                   产生参考信号                          %
%=========================================================================%
[referSig,sigSamNumber] = ReferenceSignal(k,PRT,Fs,plot_enable_H); %四个参数分别是调频斜率,脉宽,采样率,绘图控制符
sref = referSig; %进行共轭
sde = targetEchoPRT.*(sref); %雷达回波和参考信号相乘
Sde = fftshift(fft(sde))*2/1600; % 对dechirp之后的信号进行fft
f=Fs*(0:PRTNumber-1)/PRTNumber-Fs/2;% -fs/2到 fs/2
figure;
subplot(4,1,1);plot(real(targetEchoPRT),'linewidth',1);axis tight;title('Target echo '); %绘制雷达回波
subplot(4,1,2);plot(real(sref),'linewidth',1);axis tight;title('Reference signal'); %绘制参考信号
subplot(4,1,3);plot(real(sde),'linewidth',1);axis tight;title('Dechirp signal'); %绘制参考信号
subplot(4,1,4);plot(f,(abs(Sde)),'linewidth',1);axis tight;title('fft of Dechirp signal'); %绘制参考信号

其中的子函数,产生线性调频信号:

function [LFMPulse,targetEchoPRT,matchedFilterCoeff,pulseNumber,PRTNumber] = GenerateLFMSignal(bandWidth,pulseDuration,PRTDuration,samplingFrequency,signalPower,targetDistece,plotEnableHigh)
% 该函数用于产生线性调频信号,以及雷达的目标反射回波,仅产生单个回波
%  Author:壮神 2023.9.21 @Beijing
% Input : 
%   * bandWidth: 信号带宽 ,参考值:2.0e6 表示2MHz
%   * pulseDuration:脉冲持续时间,参考值:40.0e-6 表示40ms
%   * PRTDuration:脉冲重复周期,参考值:240ms
%   * samplingFrequency:采样频率,参考值:2倍的信号带宽
%   * signalPower:信号能量,参考值:1
%   * targetDistece:目标距离,最大无模糊距离由脉冲重复周期决定。计算公式:1/2*PRTDuration*光速
%   * plotEnableHigh: 绘图控制符,1:打开绘图,0:关闭绘图
% Output : 
%    * LFMPulse:线性调频信号
%    * targetEchoPRT: 目标反射回波
%    * matchedFilterCoeff: 匹配滤波器系数
%    * pulseNumber:当前采样率下线性调频信号的采样点数
%    * PRTNumber:1个PRT对应的采样点数
C = 3.0e8;      %光速(m/s)
BandWidth = bandWidth;  %雷达发射信号带宽,带宽=B=1/tau,tau是脉冲宽度
TimeWidth = pulseDuration; %雷达发射信号的脉冲时宽PRT = PRTDuration;       %雷达发射脉冲重复周期(s),240us对应1/2*240*300=360000米最大无模糊距离
Fs = samplingFrequency;         %采样频率
SampleNumber = fix(Fs*PRT);
%=========================================================================%
%                        目标参数设置                                     %
%=========================================================================%
SigPower = signalPower;           %目标功率,无量纲
TargetDistance = targetDistece; %目标距离,单位:m
DelayNumber = fix(Fs*2*TargetDistance/C); %把目标距离换算成采样点(距离门)
fprintf('目标出现在距离门%d\n',DelayNumber);
%=========================================================================%
%                        产生线性调频信号、匹配滤波器                     %
%=========================================================================%
number = fix(Fs*TimeWidth); %回波采样点数=脉压系数长度=暂态点数目+1
if rem(number,2)~=0nember = nember + 1;
end
Chirp = zeros(1,number);
for i = -fix(number/2):fix(number/2)-1Chirp(i+fix(number/2)+1)=exp(1j*(pi*(BandWidth/TimeWidth)*(i/Fs)^2));%产生复ChIrp信号
end
coeff = conj(fliplr(Chirp)); %把Chirp信号翻转并把复数共轭,产生脉压系数
%=========================================================================%
%                      绘制线性调频信号                                   %
%=========================================================================%
if plotEnableHigh == 1figure;plot(real(Chirp)); %绘制线性调频信号xlabel('Sampling points'); ylabel('Amplitude');title('线性调频信号实部');
end
SignalTemp = zeros(1,SampleNumber); %1个PRT
SignalTemp(DelayNumber+1:DelayNumber+number) = sqrt(SigPower)*Chirp;%将线性调频信号按照距离进行延时
if plotEnableHigh == 1figure;plot(real(SignalTemp)); %绘制1个完整的PRT的雷达回波信号xlabel('Range bin'); ylabel('Amplitude');title('雷达回波的实部');
end
%=========================================================================%
%                          进行脉冲压缩                                   %
%=========================================================================%
Echo = SignalTemp; % 目标回波
pc_time0 = conv(Echo,coeff); % 回波和滤波器卷积的结果
pc_time1 = pc_time0(number:number+SampleNumber-1); %去掉暂态点
realTargetRange = find(abs(pc_time1)==max(abs(pc_time1)))-1; %由脉压结果目标距离
fprintf('The target range bin is  %d',realTargetRange);
if plotEnableHigh == 1figure; %时域脉压结果subplot(2,1,1);plot(abs(pc_time0),'r-');xlabel('Range bin'); ylabel('Amplitude');title('时域脉压结果');subplot(2,1,2);plot(abs(pc_time1),'r-');xlabel('Range bin'); ylabel('Amplitude');title('去掉暂态点的时域脉压结果');
end
%=========================================================================%
%                              返回参数                                   %
%=========================================================================%
LFMPulse = Chirp; %线性调频信号
targetEchoPRT = SignalTemp; %目标反射回波
matchedFilterCoeff = coeff; %匹配滤波器系数
pulseNumber = number; %线性调频信号的采样点数
PRTNumber = SampleNumber; %目标反射回波的采样点数
end

其中的子函数,产生解线调参考信号:

function [referSig,sigSamNumber] = ReferenceSignal(chirpRate,windowDuration,samplingFrequency,plotEnableHigh)
% 该函数用于产生dechirp雷达的参考信号
%  Author:王壮壮 2024.1.14 @shenzhen
% Input : 
%   * chirpRate: 调频斜率
%   * windowDuration:接收信号的时间窗,一般要大于雷达的线性调频信号的脉宽
%   * samplingFrequency:采样频率,参考值:2倍的信号带宽
%   * plotEnableHigh: 绘图控制符,1:打开绘图,0:关闭绘图
% Output : 
%    * referSig:参考信号,也是一个线性调频信号,但是脉宽要大于雷达发射的LFM信号
%    * pulseNumber:当前采样率下线性调频信号的采样点数
C = 3.0e8;      %光速(m/s)
TimeWidth = windowDuration; %接收窗的时宽
Fs = samplingFrequency;         %采样频率
%=========================================================================%
%                              产生线性调频信号                           %
%=========================================================================%
number = fix(Fs*TimeWidth); %采样点数
if rem(number,2)~=0nember = nember + 1;
end
% Chirp = zeros(1,number);
for i = -fix(number/2):fix(number/2)-1Chirp(i+fix(number/2)+1)=exp(1j*(pi*chirpRate*(i/Fs)^2));%产生复ChIrp信号
end
%=========================================================================%
%                              返回参数                                   %
%=========================================================================%
referSig = conj(Chirp); %对复chirp信号进行共轭得到参考信号
sigSamNumber = number; %参考信号的采样点数
%=========================================================================%
%                        分析参考信号的频域                               %
%=========================================================================%
CHIRP = fftshift(fft(referSig))*2/sigSamNumber;  %对参考信号进行fft得到它的频域
frequency_index = Fs*(0:sigSamNumber-1)/sigSamNumber-Fs/2; %频率下标
%=========================================================================%
%                        绘制参考信号                                     %
%=========================================================================%
if plotEnableHigh == 1figure;subplot(2,1,1);plot((1:sigSamNumber),real(Chirp)); %绘制参考信号的时域波形xlabel('Sampling points'); ylabel('Amplitude');title('参考信号实部');subplot(2,1,2);plot(frequency_index,abs(CHIRP)); %绘制参考信号的频谱图xlabel('Frequency/Hz'); ylabel('Amplitude');title('参考信号的频谱');
end
end

绘制图形如下:
在这里插入图片描述

图3 参考信号时频图

在这里插入图片描述

图4 解线调信号时频图

总结

去斜处理的主要原理为用发射副本信号与回波混频得到基带信号,再用傅里叶变换提取基带信号频率,通过时域到频域的转换将时域脉冲信号压缩为频域上的一个峰。匹配滤波和解线调其实都是一个sinc函数乘以一个复指数项的形式,两者的sinc函数一个位于快时间域一个位于距离频率域。去斜处理在一些特殊场合,不仅运算简单,而且可以简化设备,已经广泛应用于SAR和ISAR中作脉冲压缩。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32——ADC知识总结及多通道采样实验

1.ADC概念 ADC,全称:Analog-to-Digital Converter,指模拟/数字转换器 2 STM32各系列ADC的主要特性 3.F4框图 4.转换序列与转换时间 A/D转换被组织为两组:规则组(常规转换组)和注入组(注入…

PCL ISS关键点提取(C++详细过程版)

边界提取 一、概述二、代码实现三、结果展示PCL ISS关键点提取(C++详细过程版)由CSDN点云侠原创,爬虫自重。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、概述 ISS关键点提取在PCL里有现成的调用函数,具体算法原理和实现代码见:PCL ISS关键点提…

【Spring 篇】深入探索:Spring集成Web环境的奇妙世界

嗨,亲爱的小白们!欢迎来到这篇有关Spring集成Web环境的博客。如果你曾对如何在Spring中构建强大的Web应用程序感到好奇,那么这里将为你揭示Web开发的神秘面纱。我们将用情感丰富、语句通顺的文字,以小白友好的方式,一探…

机器视觉系统选型-参数—景深

镜头在垂直方向上,能清晰成像的空间距离(清晰成像范围),称为景深

定期推荐:PMO前沿每周讲座中的博弈论普及讲座

【圆桌第107期】博弈论与我们的工作生活 李彤老师【圆桌第107期】博弈论与我们的工作生活 李彤老师_哔哩哔哩_bilibili 推荐PMO前沿这个公众号,2年多来每天都大量的优秀管理文章,每周还请各行业的老师腾讯会议开讲,有视频回放,今天…

中仕公考:2024年上半年中小学教师资格考试(笔试)报名已开始

2024年上半年中小学教师资格考试(笔试)报名工作于1月12日开始,此次笔试在31个省(自治区、直辖市)举办,各省(自治区、直辖市)的报名公告将陆续上网。 个别地区报名截止时间有所差异,上海1月13日报名截止,浙江、天津、河南1月14日截…

华西建筑智能化寻找志同道合的创业团队

我今天四十多了,之前也创过业,做软件开发系统集成的。 19年进入华西建筑装饰工程有限公司负责机电安装及弱电智能化版块。后公司成立建筑智能化事业部,我负责。现在想全身心打造施工企业项目管理平台,同时进军智慧康养领域。我想…

Makefile编译原理 make和makefile

一.什么是makefile 如图所示,一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中, Makefile 文件定义了一系列的规则来指定哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译&#xff…

GitHub项目推荐-incubator

项目地址 Github地址:GitHub - apache/incubator-anser 官网:Apache Answer | Free Open-source Q&A Platform 项目简述 这是Apache的一个开源在线论坛,也可以部署成为一个自有的QA知识库。项目主要使用了Go和Typescript来开发&#…

SpringBoot知识03

1、多模块项目无法启动,报错Failed to execute goal on project*: Could not resolve dependencies for project

Scanner接收用户键盘输入数据(Java)

1.导包:import java.util.Scanner; 一般情况不需要自己导包,idea工具会自动帮助我们导包 2.代码: 得到键盘扫描器对象: Scanner sc new Scanner(System.in); 接收用户输入数据: int sth sc.nextInt(); String…