-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathcheckRates.m
71 lines (61 loc) · 1.87 KB
/
checkRates.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
function checkRates(time,Q,R,D,kappaFun,lambdaFun,kappa,lambda)
% function checkRates(time,Q,D,R,kappaFun,lambdaFun) compares the fitted
% and calcualted death and recovered ratios. The idea is to check whether
% the approximation of these ratios is appropriate
%
% Inputs
% time: datetime: [1xN]: time array
% Q: double [1xN]: Time histories of the quarantined/active cases :
% D: double [1xN]: Time histories of the deceased cases :
% R: double [1xN]: Time histories of the recovered cases :
% kappaFun: anonymous function approximating the death rate
% lambdaFun: anonymous function approximating the recovery rate
%
% Outputs:
% None
%
% Author: E. Cheynet - UiB - last modified 07-05-2020
%
% see also SEIQRDP.m fit_SEIQRDP.m
%% Compute the rate of deceased and recovered cases
Q = Q(:);
R = R(:);
D = D(:);
time = time(:);
rateD = (diff(D)./diff(datenum(time-time(1))))./Q(2:end);
rateD(abs(rateD)>3) = nan; % remove obvious outliers
rateD(abs(rateD)<0) = nan; % This is not a zombie simulation
if ~isempty(R)
rateR = (diff(R)./diff(datenum(time-time(1))))./Q(2:end);
rateR(abs(rateR)>3) = nan;
end
%% Define the time
x = datenum(time(2:end)-time(1));
x1 = x(1):1/24:x(end);
%% Compare the fitted and effective rates
if ~isempty(R)
figure;
subplot(121)
title('Death rate')
plot(x,rateD,'k*',x1,kappaFun(kappa,x1),'r')
xlabel('Time (days)')
ylabel('Death rate (day^{-1})')
axis tight
legend('Measured','Fitted')
subplot(122)
title('Recovery rate')
plot(x,rateR,'b*',x1,lambdaFun(lambda,x1),'r')
axis tight
set(gcf,'color','w')
xlabel('Time (days)')
ylabel('Recovery rate (day^{-1})')
legend('Measured','Fitted')
else
figure;
plot(x,rateD,'k*',x1,kappaFun(kappa,x1),'r')
xlabel('Time (days)')
ylabel('Pseudo-death rate (day^{-1})')
axis tight
legend('Measured','Fitted')
end
end