-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.Rmd
191 lines (126 loc) · 15.6 KB
/
README.Rmd
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
message = FALSE,
warning = FALSE,
error = FALSE,
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# oxcgrt: An Interface to the Oxford COVID-19 Government Response Tracker API <img src="man/figures/logo.png" width="200" align="right" />
<!-- badges: start -->
[data:image/s3,"s3://crabby-images/50e01/50e01ab16b24ac988524a7b9a87465ea9a5415fc" alt="Project Status: Active – The project has reached a stable, usable state and is being actively developed."](https://www.repostatus.org/#active)
[data:image/s3,"s3://crabby-images/b1188/b118805435842f11524232186ba827bd737e812b" alt="Lifecycle: experimental"](https://www.tidyverse.org/lifecycle/#experimental)
[data:image/s3,"s3://crabby-images/3369d/3369d19b88fedf7e993a54556a538744ee0bf0d1" alt="CRAN status"](https://CRAN.R-project.org/package=oxcgrt)
[data:image/s3,"s3://crabby-images/5cdd0/5cdd06f66d692e8c855e927777db0e2b685d2b9b" alt="cran checks"](https://cran.r-project.org/web/checks/check_results_oxcgrt.html)
[data:image/s3,"s3://crabby-images/7a967/7a967d6dddd23dd89c9d01a46d6cb534dcb316b2" alt="CRAN"](https://CRAN.R-project.org/package=oxcgrt)
[data:image/s3,"s3://crabby-images/46928/46928a4ea02558f0d5a06bd026e1c9a8b9c00e90" alt="CRAN"](https://CRAN.R-project.org/package=oxcgrt)
[data:image/s3,"s3://crabby-images/4b043/4b043a7367384b48ea9d271eba5f356eeccbca50" alt="CRAN"](https://CRAN.R-project.org/package=oxcgrt)
[data:image/s3,"s3://crabby-images/93234/9323419a6ccd557f4277842e001208d7a04d8316" alt="R-CMD-check"](https://github.com/como-ph/oxcgrt/actions)
data:image/s3,"s3://crabby-images/b2781/b27812fe95a9b723877a4f4916ebe0b42e466fc7" alt="test-coverage"
[data:image/s3,"s3://crabby-images/34057/34057dabf373beb6bbce6647617690919d9cbbc9" alt="Codecov test coverage"](https://codecov.io/gh/como-ph/oxcgrt?branch=master)
[data:image/s3,"s3://crabby-images/e524b/e524b023481704dbba3e5a64aec50769e955a13c" alt="CodeFactor"](https://www.codefactor.io/repository/github/como-ph/oxcgrt)
[data:image/s3,"s3://crabby-images/6a7a0/6a7a06822b955d721ad038f470101d12f603bdbc" alt="DOI"](https://zenodo.org/badge/latestdoi/276819663)
<!-- badges: end -->
The [Oxford COVID-19 Government Response Tracker (OxCGRT)](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) tracks and compares worldwide government responses to the COVID-19 pandemic rigorously and consistently. [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) makes available systematic information in a consistent way, aiding those who require information have access to it efficiently. This package facilitates access to the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data for [R](https://cran.r-project.org) users via version 2 of its API. This package also includes functions to calculate the various [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) indices in [R](https://cran.r-project.org). This package is aimed at [R](https://cran.r-project.org) users who use or plan to use the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data for their research or for other academic purposes or who develop or want to develop other metrics or indices that build on the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) approach.
## What does `oxcgrt` do?
The `oxcgrt` package has two main sets of functions that:
1. Retrieve [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data (`get_*` functions) via version 2 of its API; and,
2. Calculate various [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) [indicators, sub-indices and indices](https://github.com/OxCGRT/covid-policy-tracker/blob/master/documentation/index_methodology.md) (`calculate_*` functions).
There are other [R](https://cran.r-project.org) packages that provide access to data from the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker). The [`COVID19` package](https://cran.r-project.org/package=COVID19) and the [`oxcovid19` package](https://como-ph.github.io/oxcovid19/) are just two examples of these. However, all these packages provide access to the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data as *data dumps* and only for the time-series of the stringency index per country. To our knowledge, the `oxcgrt` package is the only [R](https://cran.r-project.org) package currently that provides an interface to the available API for querying and retrieving data. Also, the `oxcgrt` package provides functions to calculate the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) sub-indices and indices based on their methodology. None of the other [R](https://cran.r-project.org) packages that we have seen and reviewed have this functionality.
## Installation
You can install the released version of oxcgrt from [CRAN](https://CRAN.R-project.org) with:
```{r, echo = TRUE, eval = FALSE}
install.packages("oxcgrt")
```
And the development version from [GitHub](https://github.com/) with:
```{r, echo = TRUE, eval = FALSE}
if(!require(remotes)) install.packages("remotes")
remotes::install_github("como-ph/oxcgrt")
```
## Usage
### The `oxcgrt` data retrieval workflow via API
The *retrieve data* functions are based on the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker)'s JSON API described [here](https://covidtrackerapi.bsg.ox.ac.uk). Two API endpoints are provided: 1) endpoint for JSON providing data for stringency index by country over time; and, 2) endpoint for JSON providing data on policy actions and stringency index for a specific country on a specific day.
For each of these endpoints, the data retrieval workflow is composed of two steps: first is the creation of the appropriate API URL query; and, second is the retrieval of the appropriate data as per query into a data.frame structure usable in [R](https://cran.r-project.org). This workflow is show in code below:
```{r usage1, echo = TRUE, eval = FALSE}
## Load oxcgrt package
library(oxcgrt)
## Step 1: Create the appropriate API URL query for time series data from
## 1 June 2020 up to current day
query <- get_json_time(from = "2020-06-01")
## Step 2: Retrieve the data
get_data_time(query)
```
This results in the following:
```{r usage1a, echo = FALSE, eval = TRUE}
## Load oxcgrt package
library(oxcgrt)
## Step 1: Create the appropriate API URL query for time series data from
## 1 June 2020 up to current day
query <- get_json_time(from = "2020-06-01")
## Step 2: Retrieve the data
get_data_time(query)
```
The `oxcgrt` functions are designed to work with pipe operators via the `magrittr` package. The steps shown above can be replicated using pipe operators as follows:
```{r usage2, echo = TRUE, eval = FALSE}
## Load magrittr package
library(magrittr)
get_json_time(from = "2020-06-01") %>% ## Step 1: Creat API URL query
get_data_time() ## Step 2: Retrieve data
```
This results in the same output as the earlier workflow albeit sorted alphabetically by country code:
```{r usage2a, echo = FALSE, eval = TRUE}
## Load magrittr package
library(magrittr)
get_json_time(from = "2020-06-01") %>% ## Step 1: Creat API URL query
get_data_time() ## Step 2: Retrieve data
```
For more detailed examples of how to retrieve data via the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) API version 2, read [Retrieve data via OxCGRT API](https://como-ph.github.io/oxcgrt/articles/retrieve.html).
### The `oxcgrt` calculate workflow
The `calculate_*` functions are based on the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker)'s methodology described [here](https://github.com/OxCGRT/covid-policy-tracker/blob/master/documentation/index_methodology.md). There are two sets of calculate functions included in `oxcgrt`. The first calculates the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) **sub-indices** and the second calculates the four [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) **indices** which are composed of various combinations of the indicators used by [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) sub-indices and indices.
For more detailed examples of how to calculate the various [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) sub-indices and indices, read [Calculate OxCGRT sub-indices and indices](https://como-ph.github.io/oxcgrt/articles/calculate.html).
### Datasets
The `oxcgrt` package comes with helpful datasets which serve as guides to facilitate in usage and interpretation of the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data.
#### Codebook
The [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) provides an authoritative codebook found [here](https://github.com/OxCGRT/covid-policy-tracker/blob/master/documentation/codebook.md). The `oxcgrt` package has extracted the tables from this documentation into a single codebook that can serve as a handy and convenient reference for an [R](https://cran.r-project.org) user when working with [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data in [R](https://cran.r-project.org). The [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) codebook can be accessed as follows:
```{r usage13, echo = TRUE, eval = FALSE}
codebook
```
which outputs the codebook as a singular table in `tbl` format as shown below:
```{r usage13a, echo = FALSE, eval = TRUE}
codebook
```
The current `oxcgrt` package version includes the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) **codebook version 2.5** released on 4 November 2020.
#### Example OxCGRT indicators dataset
In the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) methodology [document](https://github.com/OxCGRT/covid-policy-tracker/blob/master/documentation/index_methodology.md), an example indicator dataset is used to demonstrate the calculation of per indicator sub-indices and the four main indices that [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) provides. This example dataset has been made available in table format in the `oxcgrt` package and can be accessed as follows:
```{r usage14, echo = TRUE, eval = FALSE}
indicatorData
```
which outputs the example data as a singular table in `tbl` format as shown below:
```{r usage14a, echo = FALSE, eval = TRUE}
indicatorData
```
This dataset is used by the `oxcgrt` package to test the `calculate_*` functions and for demonstrating how these functions work. This dataset can be useful for those trying to learn the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker)'s calculation methods and [R](https://cran.r-project.org) users who are learning how to use the `oxcgrt` package `calculate_*` functions.
## Limitations
The current version of `oxcgrt` package is *experimental* in that its stability and future development would depend on the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker)'s current and future development. The [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) is in continuous evolution given that the COVID-19 pandemic is still on-going and various governments' responses to it are continuously changed and/or updated. The [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) has also been developing other indices that capture other aspects of governments' responses not yet covered by current indices.
The `oxcgrt` package author and maintainer commit to ensuring that current functions are maintained and/or updated in a manner that ensures backwards compatibility should changes to the data structure and/or to the indices calculation are implemented by the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) team. This would include maintaining the arguments used by the current functions, maintaining the functionality of the current functions, and maintaining the type of outputs of the current functions. Should changes implemented by the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) team to the data structure and/or to the indices calculation require the breaking of the syntax, functionality and/or outputs of the current functions, a formal and proper deprecation process will be implemented that include proper and detailed documentation of the changes and the potential impact on current users.
## Disclaimer
The `oxcgrt` package is an independent development and is separate from and not recognised and approved by the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) team. The author and maintainer of the package is not affiliated with [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) but is committed to ensure fidelity to the methods and usage specified by [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) and accuracy of outputs described and required by [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker).
Any mistakes, problems and issues with the functionality and outputs of the `oxcgrt` including mistakes in interpretation of the calculation of the sub-indices and indices noted (if any) are that of the author and maintainer and not of the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker). Hence any problems and issues to the usage, functionality and outputs of the `oxcgrt` package should be addressed directly to the author and maintainer [here](https://github.com/como-ph/oxcgrt/issues).
## Citation
When using the `oxcgrt` package, please cite both the source of the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data and `oxcgrt` package itself.
For the source of the [OxCGRT](https://www.bsg.ox.ac.uk/research/research-projects/coronavirus-government-response-tracker) data, the following citation is recommended:
*Hale, Thomas, Noam Angrist, Emily Cameron-Blake, Laura Hallas, Beatriz Kira, Saptarshi Majumdar, Anna Petherick, Toby Phillips, Helen Tatlow, Samuel Webster (2020). Oxford COVID-19 Government Response Tracker, Blavatnik School of Government.*
For the `oxcgrt` package, the suggested citation can be obtained using a call to the `citation` function as follows:
```{r cite, echo = TRUE, eval = TRUE}
citation("oxcgrt")
```
## Community guidelines
Feedback, bug reports and feature requests are welcome; file issues or seek support [here](https://github.com/como-ph/oxcgrt/issues). If you would like to contribute to the package, please see our [contributing guidelines](https://como-ph.github.io/oxcgrt/CONTRIBUTING.html).
This project is released with a [Contributor Code of Conduct](https://como-ph.github.io/oxcgrt/CODE_OF_CONDUCT.html). By participating in this project you agree to abide by its terms.