-
Notifications
You must be signed in to change notification settings - Fork 0
/
IRL-stats.cul.js
53 lines (39 loc) · 2.01 KB
/
IRL-stats.cul.js
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
// copying some old stuff; this data integration approach is a bit mental right now: clearly the top 80% of this file should note be in calculang (everything above "metrics").
// much of this can be neatly abstracted into a csv loader for calculang, but that might hide the Qs about performance/approach that I don't mind exposing now.
import data_string from 'raw-loader!../public/owid-covid-data-IRL.csv';
import { csvParse, autoType } from 'd3-dsv';
import { format, isSameDay, addDays } from 'date-fns';
const data = csvParse(data_string, autoType).map((d) => {
return {
date: new Date(format(d.date, 'yyyy-MM-dd')),
new_cases_smoothed: d.new_cases_smoothed,
new_deaths_smoothed: d.new_deaths_smoothed,
new_cases: d.new_cases,
new_deaths: d.new_deaths,
};
});
export const data_date_extent = () => data[data.length - 1].date; // important, because data is hidden to applications
// "smoothed" = 7 day avg.
// Ireland only sends data once per week, which is an interesting effect I am watching for recent data
export const new_cases_smoothed = () =>
data.find((d) => isSameDay(d.date, t())).new_cases_smoothed;
export const new_deaths_smoothed = () =>
data.find((d) => isSameDay(d.date, t())).new_deaths_smoothed;
export const new_cases = () =>
data.find((d) => isSameDay(d.date, t())).new_cases;
export const new_deaths = () =>
data.find((d) => isSameDay(d.date, t())).new_deaths;
// some metrics modelling:
export const new_cases_smoothed_lag_allowance = () =>
new_cases_smoothed({ t_in: addDays(t(), -lag()) });
export const new_cases_lag_allowance = () =>
new_cases({ t_in: addDays(t(), -lag()) });
// cases 10 days ago / deaths (on 7 day avgs)
export const cases_deaths_link_smoothed = () =>
new_cases_smoothed_lag_allowance() / new_deaths_smoothed();
// same, but using daily numbers
export const cases_deaths_link = () => new_cases_lag_allowance() / new_deaths();
export const lag = () => 10; // lag a constant 10 here
// explicit inputs:
// t should be a JS date
export const t = () => t_in;