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

>>

相关推荐
方大刚23316 分钟前
【Tools】计算机视觉(CV)技术的优势和挑战。
人工智能·计算机视觉
代码定制、代码分享、合作交流21 分钟前
opencv车道偏离系统-代码+原理-人工智能-自动驾驶
人工智能·python·opencv·yolo·机器学习·计算机视觉·自动驾驶
想七想八不如1140837 分钟前
【PyTorch】基础环境如何打开
人工智能·pytorch·python
数模加油站1 小时前
【2024数模国赛赛题思路公开】国赛C题第三套思路丨无偿自提
算法·数学建模·数学建模国赛·高教社杯·2024国赛
28BoundlessHope1 小时前
论文速读|通过人类远程操作的深度模仿学习框架:人型机器人的行走操纵技能
人工智能·深度学习·机器人
一水鉴天1 小时前
AI模型:追求全能还是专精?-- 之5 “机器人”最终会成为“人类”的主导者吗?--答案是:不会!
人工智能·机器人
COOL_DREAM_1 小时前
具身智能猜想 ——机器人进化
人工智能·机器人·具身智能·未来
晓shuo1 小时前
FLTRNN:基于大型语言模型的机器人复杂长时任务规划
人工智能·语言模型·机器人
晓shuo1 小时前
基于视觉-语言模型的机器人任务规划:ViLaIn框架解析
人工智能·语言模型·机器人
不脱发的程序猿1 小时前
MATLAB实现PID参数自动整定
matlab·pid