SPI指数计算(Standardized Precipitation Index,标准化降水指数) 附完整MATLAB代码

SPI指数(Standardized Precipitation Index,标准化降水指数)是反映干湿状况的一个指标,主要计算步骤如下:

收集研究区域过去30年或以上时间尺度(一般选取30年)的月降水量资料。

对月降水量资料进行统计分析,拟合出最适合的概率分布函数。常用的有Pearson III 分布、Gamma分布等。

根据所选取的概率分布函数,估计出各个时间尺度下的平均值和标准差。

对于任意一个时间尺度,用其降水量减去该时间尺度下的平均值,再除以标准差,即可计算出该时间的SPI值。

根据SPI的值确定干湿状况。一般来说,SPI>0表示湿润,SPI<0表示干旱。干旱和湿润的强度根据SPI绝对值的大小判断。

绘制不同时间尺度下的SPI变化曲线,分析各个时间尺度的干湿状况。

综上,SPI指数借助长期历史资料,能很好地反映不同时间尺度下的干湿状况,是评估干旱的重要指标之一。

MATLAB代码:

%% SPI指数计算

clc;close all;clear all;%清除空间

%% 载入数据

data=xlsread('降水.xls');

x=data(:,3);

y=data(:,1);

% x=data(:,2);

% y=data(:,1);

%% 计算伽马分布的参数

% %生成降雨数据

% N=1000;%天数

% x=randi([0,100],N,1);%降雨量

n=length(x);

H1= x==0;

m=sum(H1);%0的项数

% A=sum(log(x(x~=0)))/m-log(mean(x));

% A=log(mean(x))-sum(log(x(x~=0)))/m;

x2=x(x~=0);

% [alpha,beta] = gamma_fit(x2);

[p,ci] = gamfit(x2);

alpha=p(1)

beta=p(2)

% alpha=(1+sqrt(1+4*A/3))/(4*A);

% beta=mean(x)/alpha;

q=m/n;

%% 参数设定

c0=2.515517;

c1=0.802853;

c2=0.010328;

d1=1.432788;

d2=0.189269;

d3=0.001308;

% 计算SPI指数

SPI=SPIfun(q,alpha,beta,c0,c1,c2,d1,d2,d3,x);

figure;

plot(y,SPI,'b-');

hold on;

plot(y,zeros(length(y),1),'r-');

xlabel('时间');

ylabel('SPI');

title('降雨量SPI');

function [a,b] = gamma_fit(x,s)

% GAMMA_FIT Maximum-likelihood gamma distribution.

%

% GAMMA_FIT(x) returns the MLE (a,b) for the data in vector x.

%

% GAMMA_FIT(m,s) returns the MLE (a,b) for data with sufficient statistics

% given by

% m = mean(x)

% s = log(m) - mean(log(x))

%

% The gamma distribution is parameterized as

% p(x) = x^(a-1)/(Gamma(a) b^a) exp(-x/b)

% E[x] = ab

%

% The algorithm is a generalized Newton iteration, described in

% "Estimating a Gamma distribution" by T. Minka.

% Written by Tom Minka

if nargin == 1

m = mean(x);

s = log(m) - mean(log(x));

else

% suff stats given

m = x;

end

a = 0.5/s;

if 0

% lower bound

for iter = 1:1000

old_a = a;

a = inv_digamma(log(a) - s);

if(abs(a - old_a) < 1e-8)

break;

end

end

end

% gen Newton

for iter = 1:100

old_a = a;

g = log(a)-s-digamma(a);

h = 1/a - trigamma(a);

a = 1/(1/a + g/(a^2*h));

if(abs(a - old_a) < 1e-8)

break;

end

end

b = m/a;

function H=Hfun(q,alpha,beta,x)

%% 计算累积概率

% gamcdf(x,a,b)

G=gamcdf(x,alpha,beta);

H=q+(1-q)*G;

function SPI=SPIfun(q,alpha,beta,c0,c1,c2,d1,d2,d3,x)

%% 计算SPI

H=Hfun(q,alpha,beta,x);

SPI=zeros(1,length(H));

for i=1:length(H)

if H(i)<=0.5

k=sqrt(log(1/(H(i).^2)));

SPI(i)=-(k-(c0+c1*k+c2*k^2)/(1+d1*k+d2*k^2+d3*k^3));

else

k=sqrt(log(1/(1-H(i))^2));

SPI(i)=k-(c0+c1*k+c2*k^2)/(1+d1*k+d2*k^2+d3*k^3);

end

end

function k=kfun(q,alpha,beta,c0,c1,c2,d1,d2,d3,x)

%% 计算k

H=Hfun(q,alpha,beta,x);

for i=1:length(H)

if H(i)<=0.5

else

end

end

程序结果:

alpha =

0.6792

beta =

10.4584

>>

相关推荐
劲夫学编程42 分钟前
leetcode:杨辉三角
算法·leetcode·职场和发展
毕竟秋山澪44 分钟前
孤岛的总面积(Dfs C#
算法·深度优先
深度学习实战训练营1 小时前
基于CNN-RNN的影像报告生成
人工智能·深度学习
昨日之日20063 小时前
Moonshine - 新型开源ASR(语音识别)模型,体积小,速度快,比OpenAI Whisper快五倍 本地一键整合包下载
人工智能·whisper·语音识别
浮生如梦_3 小时前
Halcon基于laws纹理特征的SVM分类
图像处理·人工智能·算法·支持向量机·计算机视觉·分类·视觉检测
深度学习lover3 小时前
<项目代码>YOLOv8 苹果腐烂识别<目标检测>
人工智能·python·yolo·目标检测·计算机视觉·苹果腐烂识别
热爱跑步的恒川4 小时前
【论文复现】基于图卷积网络的轻量化推荐模型
网络·人工智能·开源·aigc·ai编程
励志成为嵌入式工程师5 小时前
c语言简单编程练习9
c语言·开发语言·算法·vim
捕鲸叉5 小时前
创建线程时传递参数给线程
开发语言·c++·算法
A charmer5 小时前
【C++】vector 类深度解析:探索动态数组的奥秘
开发语言·c++·算法