clear ; close all; clc; %% 阵列信息 N = 16; d =1/2 ; % 均匀加权标准线列阵 %% 波束图绘制 % 均匀加权 Wt = [1;1;1;1;1;1;1;1;1;1;1;1;1;1;1;1]/16; theta_t = 90*pi/180; % 扫描方位角 theta_angle = 0:0.1:180; % 以0.1°为间隔从0°到180°对空间进行扫描 theta = theta_angle*pi/180; Vk = exp(-1i*2*pi*cos(theta_t)*d*(0:N-1)).'; % 阵列流型 B_0 = zeros(size(theta)); for i = 1:length(theta) p = exp(1i*2*pi*cos(theta(i))*d*(0:N-1)).'; % p列向量 p = Vk.*p; B_0(i) = Wt'*p; end B_0 = 20*log10(abs(B_0)/max(B_0)); % 归一化波束图(dB) % 绘图 figure(1) set(gcf,'color','white') plot(theta_angle, B_0, 'linewidth', 1.5,'Color','k'); grid on; xlim([0,180]); ylim([-50,0]); title('波束图 (N=16)'); 上述代码我想在绘制的图像中横坐标只显示0 90 180 这三个横坐标点 怎么更改
时间: 2024-01-17 17:03:09 浏览: 76
您可以在绘图之前将 `theta_angle` 变量的值更改为 `[0, 90, 180]`,然后在绘图的 `xlim` 函数中使用这些值。以下是更改后的代码:
```matlab
clear; close all; clc;
%% 阵列信息
N = 16;
d = 1/2; % 均匀加权标准线列阵
%% 波束图绘制
% 均匀加权
Wt = ones(N, 1) / N;
theta_t = 90 * pi / 180; % 扫描方位角
theta_angle = [0, 90, 180]; % 只显示这三个角度
theta = theta_angle * pi / 180;
Vk = exp(-1i * 2 * pi * cos(theta_t) * d * (0:N-1)).'; % 阵列流型
B_0 = zeros(size(theta));
for i = 1:length(theta)
p = exp(1i * 2 * pi * cos(theta(i)) * d * (0:N-1)).'; % p列向量
p = Vk .* p;
B_0(i) = 20 * log10(abs(Wt' * p) / max(abs(Wt' * p)));
end
B_0 = real(B_0); % 取实部,避免出现虚数部分的警告
% 绘图
figure(1)
set(gcf, 'color', 'white')
plot(theta_angle, B_0, 'linewidth', 1.5, 'Color', 'k');
grid on;
xlim([0, 180]); % 使用 [0, 180] 作为 x 轴范围
ylim([-50, 0]);
xticks(theta_angle) % 设置横坐标刻度
title('波束图 (N=16)');
```
运行后,您会得到一个只显示 0、90 和 180 度的波束图。
阅读全文