MATLAB绘制局部放大图

今天,我将分享一段 MATLAB 代码,该代码生成了一个主副图结合的可视化展示,用于比较不同控制系统性能表现。

Matlab 复制代码
clc; clear; close all;

% 生成时间向量
t = 0:0.1:12;

% 生成模拟数据
zero_feedback = 0.5 * ones(size(t));                 % 恒定的0.5
adrc = 0.5 + 0.3*sin(t/1.2) - 0.2*exp(-t/3);        % 带振荡的曲线
third_curve = -1.5*(t/max(t)) + 0.1*randn(size(t));  % 线性下降带噪声

% 主图绘制
figure('Color','white')
main_ax = subplot(1,1,1);
hold on
plot(t, zero_feedback, '--', 'LineWidth', 1.5)
plot(t, adrc, 'LineWidth', 2)
plot(t, third_curve, 'LineWidth', 1.5)
xlabel('time [s]')
ylabel('Amplitude')
legend('Zero feedback controller', 'ADRC proposed controller', 'Third curve',...
       'Location','southwest')
grid on
xlim([0 12])

% 创建放大区域
zoom_ax = axes('Position',[0.6 0.6 0.25 0.25]); % 调整放大图位置
box on
hold on
idx = t >= 9.5 & t <= 11.5; % 截取放大时间段

% 绘制放大区域数据(保持相同的颜色和样式)
plot(t(idx), zero_feedback(idx), '--', 'LineWidth', 1)
plot(t(idx), adrc(idx), 'LineWidth', 1.2)
plot(t(idx), third_curve(idx), 'LineWidth', 1)
xlim([9.5 11.5])
ylim([-1.6 0.6])
set(zoom_ax, 'XTick', 9.5:0.5:11.5)
grid on

% 添加连接线
annotation('line',[0.4 0.6],[0.4 0.6],'LineStyle','--','Color',[0.5 0.5 0.5])
annotation('line',[0.4 0.6],[0.35 0.55],'LineStyle','--','Color',[0.5 0.5 0.5])

% 统一图形样式
set(findall(gcf,'Type','axes'), 'FontSize', 9)

看下效果

这段代码展示了如何将技术性能比较以直观且专业的方式呈现,对于控制系统研究或数据可视化爱好者而言,具有很好的参考价值,同时也为MATLAB图表定制提供了实用范例。

Over!

相关推荐
构建的乐趣1 小时前
Givens rotation matlab实验
matlab·linear algebra
Deep-w7 小时前
【MATLAB】基于 MATLAB/Simulink 的无刷直流电机(BLDC)转速控制模糊 PID 算法
开发语言·算法·matlab
Evand J9 小时前
【MATLAB代码介绍】到达时间(TOA)定位,三维空间,带EKF的轨迹滤波与误差分析
开发语言·matlab
吃好睡好便好12 小时前
用if…elseif…end语句输出成绩等级
开发语言·前端·javascript·数据库·学习·matlab·信息可视化
Deep-w12 小时前
【MATLAB】基于遗传算法的直流电机 PI 控制器参数优化研究
开发语言·算法·matlab
吃好睡好便好1 天前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
Matlab程序猿小助手1 天前
【MATLAB源码-第319期】基于matlab的帝王蝶优化算法(MBO)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab
Evand J1 天前
【MATLAB控制例程】(9)多无人机编队协同控制与三维轨迹规划仿真,附下载链接
开发语言·分布式·matlab·无人机·控制
爱怪笑的小杰杰1 天前
Leaflet 高性能大数据量图圆:彻底解决缩放/拖拽偏移问题
大数据·前端·vue.js·贴图
吃好睡好便好1 天前
在Matlab中绘制质点三维运动轨迹图
开发语言·学习·matlab·信息可视化