Matlab 使用subplot绘制多个子图,一元拟合

实现效果:

Matlab 复制代码
clc; clear;

filename = 'sri.xlsx'; % 确认文件路径

data = readtable(filename);
datavalue = data{:,2:end};
datavalue = datavalue';

fig = figure('Position', [0, 0, 1500, 900]);
indexString = ["(a)","(b)","(c)","(d)","(e)","(f)","(g)",];
subplotName = ["h1","h2","h3","h4","h5","h6","h7"];
for i = 1:7
    subplot(4,2,i);
    years = datavalue(:,1); 
    values = datavalue(:,i+1);
    
    coefficients = polyfit(years, values, 1);
    k = coefficients(1);
    b = coefficients(2);
    
    % 计算Y轴上下限值,将其设置为最大值和最小值的 1.1 倍
    y_max = max(values) * 1.3;
    y_min = min(values) * 1.3;

    plot(years, values, 'o-', 'MarkerSize', 4, 'MarkerFaceColor', '#58CCFA', 'Color', '#58CCFA', 'LineWidth', 1.5);
    hold on;
    plot(years, k*years + b, 'r--',  'LineWidth', 1);%拟合线
    xlim([1960 2018]);
    xtick_values = 1960:10:2010;  
    if ~ismember(2018, xtick_values)
        xtick_values = [xtick_values, 2018];  
    end
    xticks(xtick_values);
    ylabel('SRI', 'FontSize', 12);
    ylim([y_min y_max]); % 设置Y轴上下限值
    grid on;
    yrange = ylim; % 获取当前子图的y轴值域范围
    text(1961, 0.9 * yrange(2),indexString(i), 'FontSize', 14, 'HorizontalAlignment', 'left', 'VerticalAlignment', 'top'); % 调整文本位置坐标

    ax = gca; 
    ax.FontSize = 12; 
    annotation('textbox', [ax.Position(1), ax.Position(2), ax.Position(3), ax.Position(4)], 'String', sprintf('k = %.4f, b = %.2f', k, b), 'FontSize', 14, 'EdgeColor', 'none', 'Color', 'black', 'HorizontalAlignment', 'center'); % 调整注释框位置

    hold off;
end

% 在第 8 个子图位置添加文本
subplot(4,2,8);
str = ["(a):华北湿润半湿润暖     (b):西北荒漠地区";...
       "(c):华中华南湿润亚热     (d):东北湿润半湿润温";...
       "(e):内蒙草原地区            (f):青藏高原";...
       "(g):华南湿润热带地区"];

text(0.15, 0.4, sprintf('%s\n', str{:}), 'FontSize', 14, 'HorizontalAlignment', 'left', 'VerticalAlignment', 'middle');
axis off; % 关闭坐标系显示


print(fig, 'data.tif', '-dtiff', '-r2000'); % 保存为 TIFF 文件,300 DPI 分辨率
相关推荐
一点七加一1 小时前
Harmony鸿蒙开发0基础入门到精通Day07--JavaScript篇
开发语言·javascript·ecmascript
qq_574656252 小时前
java后端初始化模版
java·开发语言
毕设源码-朱学姐3 小时前
【开题答辩全过程】以 基于JAVA的市级非物质文化遗产交流平台为例,包含答辩的问题和答案
java·开发语言
pedestrian_h4 小时前
操作系统-线程
android·java·开发语言
A-code4 小时前
C/C++ 中 void* 深度解析:从概念到实战
c语言·开发语言·c++·经验分享·嵌入式
国服第二切图仔6 小时前
Rust中泛型函数实现不同类型数据的比较
开发语言·后端·rust
技术砖家--Felix7 小时前
Spring Boot入门篇:快速搭建你的第一个Spring Boot应用
java·开发语言·音视频
国服第二切图仔7 小时前
Rust开发之使用Trait对象实现多态
开发语言·算法·rust
Yolo566Q7 小时前
Python驱动的无人机生态三维建模与碳储/生物量/LULC估算全流程实战技术
开发语言·python·无人机
我不是程序猿儿7 小时前
【C#】XtraMessageBox(DevExpress)与MessageBox(WinForms 标准库)的区别
开发语言·c#