Matlab中collectPlaneWave函数的应用

查看文档如下:
在这里插入图片描述
可以看出最多5个参数,分别是阵列对象,信号幅度,入射角度,信号频率,光速。
在下面的代码中,我们先创建一个3阵元的阵列,位置为:(-1,0,0),(0,0,0),(1,0,0)。然后创建入射信号,其方位角位180度,高度角为45度。

clear
close all
clc

% 定义信号参数
fc = 1e9; % 频率 1 GHz
c = physconst('LightSpeed'); % 光速
lam = c/fc;
incidentAngle = [180; 45]; % 入射角度(方位角 180 度,高度角 45 度)
kw = 2*pi*fc/c;

% 定义天线元素位置,分别位于 x 轴上的 -1, 0 和 1
ant = lam/2*[-1 0 1; 0 0 0; 0 0 0]; % 3 个天线元素的位置

% 创建符合阵列对象
array = phased.ConformalArray('ElementPosition', ant);

% 发射信号参数
signalAmplitude = 1; % 信号的幅度

% 收集入射信号
sig = collectPlaneWave(array, signalAmplitude, incidentAngle, fc, c);

% 显示结果
disp('收集到的信号:');
disp(sig);
sig2 = conj(sig);

kw = 2*pi*fc/c;
phy = kw*lam/2/sqrt(2);                         % 利用几何直接计算(1,0,0)处比(0,0,0)超前的相位
phy2 = atan2(imag(sig(1,1)), real(sig(1,1)));   % 根据收集到的信号计算(1,0,0)处比(0,0,0)超前的相位

运行之后结果为:

收集到的信号:
 -0.6057 + 0.7957i   1.0000 + 0.0000i  -0.6057 - 0.7957i

同时我们也可以在工作区看到,对于两种计算相位的方式,其结果是一样的。
在这里插入图片描述

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值