高频地波雷达电离层回波方向估计附matlab代码

简介: 高频地波雷达电离层回波方向估计附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

高频地波雷达是一种利用高频波段垂直极化电磁波沿海面绕射的特性而设计出来的一种既可以进行海面目标检测又可以从事海态遥感的设备。目前电离层杂波干扰抑制是高频地波雷达应用的一个重要瓶颈,人们对于如何抑制电离层杂波已经做了相当多的研究。然而,电离层杂波也携带着电离层的某些信息。本文的目的便是要利用现有的高频地波雷达设备提取这些信息中最重要的一个参数——电离层虚高。这项研究将拓展高频地波雷达的应用领域。本文仿真各种回波估计算法,包括最佳权矢量波束形成算法、权值自适应调整算法、超分辨率DOA算法;。

⛄ 部分代码

function [rmse]=espirit(theta0,element_num)

   %*******************************************************

   % 共轭ESPRIT算法

   %

   % Inputs

   %    d_lamda       sensor separation in wavelength

   %    Rxx(K,K)      array output covariance matrix

   %    echos_num     estimated number of sources ==L=iwave

   %  

   % Output

   %    estimate  estimated angles in degrees

   %              estimated powers

   %*******************************************************

   source_number=length(theta0);%信元数

   sub_sensor_number=element_num-1;%子阵元数

   theta0_sort = sort(theta0);

   snapshot_number=1024;

   d_lamda = 0.5;

   A=exp(j*d_lamda*2*pi*(0:element_num-1).'*sin(theta0/180*pi));

   %估计信源个数

   snr=10;

   s=sqrt(10.^(snr/10))*randn(source_number,snapshot_number);%仿真信号

   x=A*s+(1/sqrt(2))*(randn(element_num,snapshot_number)+1j*randn(element_num,snapshot_number));

   Rxx = x*x'/snapshot_number;

   [~,value]=eig(Rxx);

   value = diag(value);

   [value_sort,~] = sort(value,'descend');

   for i = 1:(size(value)-2)

       gama(i) = value_sort(i)/value_sort(i+1);

   end

   [~,esti_source_num] = max(gama);

   disp(['信噪比为10dB下估计信源数目:' num2str(esti_source_num)]);


   snr0=-10:1:10;

   rmse = zeros(1,20);

   store_doa = zeros(20,source_number);

   for isnr=1:20

       s=sqrt(10.^(snr0(isnr)/10))*randn(source_number,snapshot_number);%仿真信号

       x=A*s+(1/sqrt(2))*(randn(element_num,snapshot_number)+1j*randn(element_num,snapshot_number));

       x1=x(1:sub_sensor_number,:);

       x2 = x(2:sub_sensor_number+1,:);


       %对两个子阵的模型进行合并

       X=[x1;x2];

       R=X*X'/snapshot_number;


       %对R进行奇异值分解

       [U,S,V]=svd(R);

       R=R-S(2*sub_sensor_number,2*sub_sensor_number)*eye(2*sub_sensor_number);

       [U,S,V]=svd(R);

       Us=U(:,1:source_number);

       Us1=Us(1:sub_sensor_number,:);

       Us2=Us((sub_sensor_number+1):2*sub_sensor_number,:);

       %形成矩阵Us12

       Us12=[Us1,Us2];

       %对“Us12'*Us12”进行特征分解,得到矩阵E

       [F,Sa,Va]=svd(Us12'*Us12);

       %将E分解为四个小矩阵

       %F11=F(1:source_number,1:source_number);

       F12=F(1:source_number,(1+source_number):(2*source_number));

       %F21=F((1+source_number):(2*source_number),1:source_number);

       F22=F((1+source_number):(2*source_number),(1+source_number):(2*source_number));

       %按照公式得到旋转不变矩阵M

       E=-(F12*(inv(F22)));

       %对得到的旋转不变矩阵进行特征分解

       [V,d_lamda]=eig(E);

       d_lamda=(diag(d_lamda)).';

       doa=asin(angle(d_lamda)/pi)*180/pi;

       doa=sort(doa);

       rmse(isnr) = sqrt( sum(((theta0_sort-doa).^2))/source_number );

       i = 1:source_number;

       store_doa(isnr,i) = doa(i);

   end

   figure('Color','white');

   plot(snr0(1:20),store_doa(1:20,1:source_number).','o-');

   grid on;

   xlabel('SNR/dB');

   ylabel('DOA 估计/度');

   title('ESPRIT 算法在不同信噪比下的DOA估计');

end

⛄ 运行结果

⛄ 参考文献

[1]杨旭光. 高频地波雷达电离层回波机理及应用研究[D]. 哈尔滨工业大学.

[2]刘强, 尚尚, 石依山,等. 高频地波雷达电离层杂波抑制方法综述[J]. 航天电子对抗, 2022, 38(6):6.

⛳️ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
2月前
|
算法 定位技术 计算机视觉
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
114 0
|
2月前
|
算法 机器人 计算机视觉
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
|
2月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
147 8
|
2月前
|
机器学习/深度学习 编解码 算法
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
144 8
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
213 0
|
2月前
|
新能源 Java Go
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
109 0
|
2月前
|
机器学习/深度学习 数据采集 测试技术
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
|
2月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
159 8
|
2月前
|
编解码 运维 算法
【分布式能源选址与定容】光伏、储能双层优化配置接入配电网研究(Matlab代码实现)
【分布式能源选址与定容】光伏、储能双层优化配置接入配电网研究(Matlab代码实现)
156 12
|
2月前
|
人工智能 数据可视化 网络性能优化
【顶级SCI复现】虚拟电厂的多时间尺度调度:在考虑储能系统容量衰减的同时,整合发电与多用户负荷的灵活性研究(Matlab代码实现)
【顶级SCI复现】虚拟电厂的多时间尺度调度:在考虑储能系统容量衰减的同时,整合发电与多用户负荷的灵活性研究(Matlab代码实现)
106 9

热门文章

最新文章