clear all;
close all;
K = 2; %信源数
M = 8; %阵元数
L = 200; %信号长度
w = [pi/4, pi/6].'; %信号频率
lamda = ((2 * pi * 3e8) / w(1) + (2 * pi * 3e8) / w(2)) / 2; %信号波长
d_lamda = 0.5; %阵元间距
snr = 20; %信噪比
theta1 = [49, 60]; %信号入射角
for k = 1: K
A(:, k) = exp(-1j * [0: M-1]' * d_lamda * 2 * pi * sin(theta1(k) * pi / 180)); %阵列流型
end
for kk = 1: L
s(:, kk) = sqrt(10.^((snr / 2) / 10)) * exp(1j * w * (kk - 1)); %仿真信号
end
x = A * s + (1 / sqrt(2)) * (randn(M, L) + 1j * randn(M, L)); %加入高斯白噪声
R = (x * x') / L; %协方差矩阵
%%%%%%第一种方法%%%%%%%%%%
[V, D] = eig(R); %对协方差矩阵进行特征分解?好像没排序
Un = V(:, 1: M-K); %取噪声子空间
Gn = Un * Un';
a = zeros(2 * M - 1, 1)'; %找出多项式的系数,并按阶数从高至低排列
for i = -(M - 1): (M - 1)
a(i + M) = sum(diag(Gn, i));
end
a1 = roots(a); %使用ROOTS函数求出多项式的根
a2 = a1(abs(a1) < 1); %找出在单位圆里且最接近单位圆的N个根
[lamda, I] = sort(abs(abs(a2) -1 )); %挑选出最接近单位圆的N个根
f = a2(I(1: K)); %计算信号到达方向角
source_doa = [asin(angle(f(1)) / pi) * 180 / pi asin(angle(f(2)) / pi) * 180 / pi];
source_doa = sort(source_doa);
disp('source_doa');
disp(source_doa);
%%%%%%%第二种方法%%%%%%%%%
% [V, D] = eig(R);
% Un = V(:, 1: M - K); %(4.5.7)
% Un1 = Un(1: M, :);
% Un2 = Un(K + 1: M, :);
% T = [1 0 0 0 0 0]'; %(阵元数-信源数)*1
% c = Un1 * inv(Un2) * T; % (K*(M-K))*((M-K)*(M-K))*((M-K)*1)=K*1
% c = [1, c(2, 1), c(1, 1)]; %(4.5.8)
% f = roots(c);
% source_doa = [asin(angle(f(1)) / pi) * 180 / pi, asin(angle(f(2)) / pi) * 180 / pi];
% source_doa = sort(source_doa);
% disp('source_doa');
% disp(source_doa);
没有合适的资源?快使用搜索试试~ 我知道了~
仿真是一种通过建立模型来模拟现实世界或虚拟场景的技术,广泛应用于工程、科研和教育等领域。 仿真技术的核心是计算机模拟,它利用计算机程序和数据来表示现实世界的系统或过程,以便研究、分析或培训。以下是关于仿真技术的详细介绍: 仿真类型 按时间分类:仿真可以分为实时仿真(与现实时间同步)和非实时仿真(加速或减速)。 按形式分类:分为物理仿真(使用实物模型)和数字仿真(完全基于计算机模拟)。 仿真步骤 定义问题:明确仿真的目的和需求。 建立模型:根据实际系统抽象出可计算的模型。 编程实现:将模型用计算机语言实现,并验证其正确性。 运行实验:进行多次实验,收集数据。 结果分析:分析数据,得出结论,并对模型进行校核和验证。 应用领域 制造业:用于产品设计、生产线优化等。 医疗健康:用于手术模拟、疾病传播模拟等。 教育培训:提供虚拟实操环境,增强理解和操作能力。 交通系统:用于交通流量分析和事故模拟。 军事防务:用于战术模拟和训练。 仿真软件 MATLAB Simulink:广泛用于工程领域的仿真软件。 ANSYS:主要用于有限元分析的仿真软件。 LabVIEW:用于数据采集和仪器控制的图形编程环境。
资源推荐
资源详情
资源评论
收起资源包目录
Music算法仿真实验.zip (5个子文件)
simulation
Music_snr.m 2KB
Music_snapshot.m 2KB
Music.m 2KB
Music_source_number.m 2KB
Root_Music.m 3KB
共 5 条
- 1
资源评论
热爱嵌入式的小佳同学
- 粉丝: 1w+
- 资源: 2136
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- bdwptqmxgj11.zip
- onnxruntime-win-x86
- onnxruntime-win-x64-gpu-1.20.1.zip
- vs2019 c++20 语法规范 头文件 <ratio> 的源码阅读与注释,处理分数的存储,加减乘除,以及大小比较等运算
- 首次尝试使用 Win,DirectX C++ 中的形状渲染套件.zip
- 预乘混合模式是一种用途广泛的三合一混合模式 它已经存在很长时间了,但似乎每隔几年就会被重新发现 该项目包括使用预乘 alpha 的描述,示例和工具 .zip
- 项目描述 DirectX 引擎支持版本 9、10、11 库 Microsoft SDK 功能相机视图、照明、加载网格、动画、蒙皮、层次结构界面、动画控制器、网格容器、碰撞系统 .zip
- 项目 wiki 文档中使用的代码教程的源代码库.zip
- 面向对象的通用GUI框架.zip
- 基于Java语言的PlayerBase游戏角色设计源码
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功