爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 216|回复: 2

[讨论] 最大连续干旱日数CDD绘图出错

[复制链接]

新浪微博达人勋

发表于 2024-3-23 22:48:42 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
各位大佬们晚上好,我是一个学习matlab的新手小白。在画CDD时出的图是这样的,我找不到问题,有人能帮我看看吗?感恩♥附上我的代码:
clc;
clear;
datadir = '\\wsl.localhost\Ubuntu-22.04\home\afei\1_in\pre\';
filelist = dir([datadir,'*.nc']);
k=length(filelist);

for a = 1:1  %依次读取并处理   
    %% 批量读取NC文件
    ncFilePath = ['\\wsl.localhost\Ubuntu-22.04\home\afei\1_in\pre\',filelist(a).name]; %设定NC路径
    num = filelist(a).name(1:20); %读取数据编号,以便于保存时以此编号储存tif
   
    %% 读取变量值
    Lon=ncread(ncFilePath,'lon');          %读取经度信息(范围、精度)
    Lat=ncread(ncFilePath,'lat');          %读取纬度信息
    time=ncread(ncFilePath,'time');        %读取时间序列
    pr=ncread(ncFilePath,'pr');            %获取降雨变量数据
    pre = pr*3600*24;
   
    %1986-1987年干季
    days = zeros(1440,600,365);
    for i = 1:1440
       for j = 1:600
           X = squeeze(pre(i,j,:));%X为一维
           days(i,j)=find_max_dryday(X);  
       end
    end
    days(days==0) = nan;
    CDD1986_1987dry=days;
    %1986年
    ydays=zeros(1440,600);
    for i = 1:1440
        disp(i)
        for j = 1:600
            ydays(i,j)=max(CDD1986_1987dry(i,j,:));
        end
    end
    max86CDD=ydays;
end

[x,y]=meshgrid(-179.875:0.25:179.875,89.875:-0.25:-59.875);
sz=[600 1440];
max86CDD = reshape(max86CDD,sz);

scrsz = get(0,'ScreenSize')
figure('Position',[1 1 scrsz(3) scrsz(4)]);
contourf(x,y,max86CDD,100);
shading flat
load coast
hold on
plot(long,lat,'-k','Linewidth',1);
hold off
colorbar('SouthOutside','Position',[0.2,0.1,0.6,0.04])  %左端位置 下端位置 右端位置 宽度
set(gca,'LineWidth',2,'FontSize',12,'Ylim',[-60 90],'Xlim',[-180 180],'clim',[0 150],'Position',[0.2 0.2 0.6 0.7]...
    ,'Xtick',[-180:60:180],'Xticklabel',{'-180W','-120W','-60W','0','60E','120E','180E'}...   
    ,'Ytick',[-60:30:90],'Yticklabel',{'-90S','-60S','-30S','0','30N','60N','90N'});
屏幕截图 2024-03-23 224319.png

密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2024-3-24 10:26:09 | 显示全部楼层
contourf(x,y,max86CDD,100);  
盲猜100太大了 可以把100删了 让matlab自动来画 然后再微调参数
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2024-3-25 11:03:55 | 显示全部楼层
wjy_ecnu 发表于 2024-3-24 10:26
contourf(x,y,max86CDD,100);  
盲猜100太大了 可以把100删了 让matlab自动来画 然后再微调参数

谢谢你,但是还是错的,我用matlab看数据的表格形式也是隔一段经度有数据,一段经度没有数据,可能是算错了
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表