-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathtsEvaComputeReturnLevelsGEVFromAnalysisObj.m
41 lines (38 loc) · 2.22 KB
/
tsEvaComputeReturnLevelsGEVFromAnalysisObj.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
function [returnLevels, returnLevelsErr, returnLevelsErrFit, returnLevelsErrTransf] = tsEvaComputeReturnLevelsGEVFromAnalysisObj(nonStationaryEvaParams, returnPeriodsInYears, varargin)
args.timeIndex = -1;
args = tsEasyParseNamedArgs(varargin, args);
timeIndex = args.timeIndex;
epsilon = nonStationaryEvaParams(1).parameters.epsilon;
epsilonStdErr = nonStationaryEvaParams(1).paramErr.epsilonErr;
epsilonStdErrFit = epsilonStdErr;
epsilonStdErrTransf = 0;
nonStationary = isfield(nonStationaryEvaParams(1).paramErr, 'sigmaErrTransf');
if timeIndex > 0
sigma = nonStationaryEvaParams(1).parameters.sigma(timeIndex);
mu = nonStationaryEvaParams(1).parameters.mu(timeIndex);
sigmaStdErr = nonStationaryEvaParams(1).paramErr.sigmaErr(timeIndex);
sigmaStdErrFit = nonStationaryEvaParams(1).paramErr.sigmaErrFit(timeIndex);
sigmaStdErrTransf = nonStationaryEvaParams(1).paramErr.sigmaErrTransf(timeIndex);
muStdErr = nonStationaryEvaParams(1).paramErr.muErr(timeIndex);
muStdErrFit = nonStationaryEvaParams(1).paramErr.muErrFit(timeIndex);
muStdErrTransf = nonStationaryEvaParams(1).paramErr.muErrTransf(timeIndex);
else
sigma = nonStationaryEvaParams(1).parameters.sigma;
mu = nonStationaryEvaParams(1).parameters.mu;
sigmaStdErr = nonStationaryEvaParams(1).paramErr.sigmaErr;
muStdErr = nonStationaryEvaParams(1).paramErr.muErr;
if nonStationary
sigmaStdErrFit = nonStationaryEvaParams(1).paramErr.sigmaErrFit;
sigmaStdErrTransf = nonStationaryEvaParams(1).paramErr.sigmaErrTransf;
muStdErrFit = nonStationaryEvaParams(1).paramErr.muErrFit;
muStdErrTransf = nonStationaryEvaParams(1).paramErr.muErrTransf;
end
end
[returnLevels, returnLevelsErr] = tsEvaComputeReturnLevelsGEV( epsilon, sigma, mu, epsilonStdErr, sigmaStdErr, muStdErr, returnPeriodsInYears, varargin{:} );
if nonStationary
[~, returnLevelsErrFit] = tsEvaComputeReturnLevelsGEV( epsilon, sigma, mu, epsilonStdErrFit, sigmaStdErrFit, muStdErrFit, returnPeriodsInYears, varargin{:} );
[~, returnLevelsErrTransf] = tsEvaComputeReturnLevelsGEV( epsilon, sigma, mu, epsilonStdErrTransf, sigmaStdErrTransf, muStdErrTransf, returnPeriodsInYears, varargin{:} );
else
returnLevelsErrFit = returnLevelsErr;
returnLevelsErrTransf = zeros(size(returnLevelsErr));
end