基于matlab的长时间栅格序列的残差分析
2019-04-04 本文已影响0人
画长空_yin
在量化人类活动对生态参量的影响时,常常引入残差分析法来进行量化,本文在matlab平台下对NDVI进行残差分析,选取的自变量是降水和温度。代码如下所示,通过下面代码,能够获取残差的空间分布及残差趋势以及统计得到的研究区每年的残差值。
%author yinlichang3064@163.com
[aa,R]=geotiffread('D:\年NDVI\2000anveage_ndvi.tif');%先投影信息
info=geotiffinfo('D:\年NDVI\2000anveage_ndvi.tif');
[m,n]=size(aa);
begin_year=2000;%用户修改
end_year=2017;%用户修改
long=end_year-begin_year+1;
temsum=zeros(m*n,long);
presum=zeros(m*n,long);
ndvisum=zeros(m*n,long);
k=1;
for year=begin_year:end_year
temp=importdata(['D:\年NDVI\',int2str(year),'TEMP.tif']) ; %根据自己名称修改,本数据名称为2000TEMP.tif
pre=importdata(['D:\年NDVI\',int2str(year),'PRE.tif']) ; %根据自己名称修改,本数据名称为2000PRE.tif
ndvi=importdata(['D:\年NDVI\',int2str(year),'anveage_ndvi.tif']) ; %根据自己名称修改,本数据名称为'anveage_ndvi.tif'
%注意数据的有效范围
temp(temp<-1000)=NaN;%温度有效范围
pre(pre<0)=NaN;%有效范围大于0
ndvi(ndvi<-1)=NaN; %有效范围是-1到1
temsum(:,k)=reshape(temp,m*n,1);
presum(:,k)=reshape(pre,m*n,1);
ndvisum(:,k)=reshape(ndvi,m*n,1);
k=k+1;
end
%多元回归,ndvi=a*pre+b*tem
cc=zeros(m,n)+NaN;
ccsum=zeros(m*n,long)+NaN;
for i=1:m*n
pre=presum(i,:)';
if min(pre)>=0 %进行筛选有效范围
ndvi=ndvisum(i,:)';
tem=temsum(i,:)';
X=[ones(size(ndvi)),tem,pre];
[b,bint,r,rint,stats] = regress(ndvi,X);
cc1=ndvi-b(1)-b(2).*tem-b(3).*pre;
cc1=cc1';
ccsum(i,:)=cc1;
cc1=cc1';
X=[ones(size(ndvi)),[1:long]'];
[b,bint,r,rint,stats] = regress(cc1,X);
cc(i)=b(2);
end
end
filename=['D:\年NDVI\2000-2017年残差的趋势.tif'];
geotiffwrite(filename,cc,R,'GeoKeyDirectoryTag',info.GeoTIFFTags.GeoKeyDirectoryTag)
data2sum=[];
for i=1:long
data1=ccsum(:,i);
data2=mean(~isnan(data1));
data2sum=[data2sum;data2];
data1=reshape(data1,m,n);
filename=['D:\年NDVI\残差',int2str(i-1+begin_year),'.tif'];
geotiffwrite(filename,data1,R,'GeoKeyDirectoryTag',info.GeoTIFFTags.GeoKeyDirectoryTag)
end
data2sum=[[begin_year:end_year]',data2sum];
xlswrite('D:\年NDVI\每年的残差均值.xlsx',data2sum)
更多需求,请查看个人介绍