Location: “~/R/COVID-19-master/vignettes/covid_lgm”

Introduction

The following document shows an analysis of the data associated with the coronavirus pandemic (Covid19).

The analysis is divided into two parts, the first comprises general graphs of the data and then a numerical simulation is performed using the logistic growth model (LGM) in order to forecast the possible total number of cases by country.

The data used for this analysis are updated daily and are stored in Data Repository by Johns Hopkins CSSE

Terms used

Recovery ratio (RR)

The proportion of people recovered from a specified disease among all individuals diagnosed with the disease over a certain period of time.

\[RecoveryRatio (RR) = \frac{Recovered}{Confirmed}\]

Case Fatality ratio (CFR)

Case fatality rate, also called case fatality ratio, in epidemiology, the proportion of people who die from a specified disease among all individuals diagnosed with the disease over a certain period of time.

https://www.britannica.com/science/case-fatality-rate

\[Case Fatality Ratio (CFR) = \frac{Deaths}{Confirmed}\]

Logistic Growth Model (LGM)

Clark (2011) propose a new empirical model based on logistic growth models.

A nonlinear model formula including variables and parameters.

\[ProjectedCases = \frac{(K * t ^ n)}{(a + t ^ n)}\]

Where:

Cases = Projected Case
K = Carrying capacity
n = Hyperbolic exponent
a = Constant
t = Time

The best-fit nonlineal model is obtained by an iterative least-squared method.

The logistic growth model was used to project the progression of the disease in certain countries.

The most relevant result of the model corresponds to the projected cases, this term is associated with the maximum number of cases estimated by the model for each country, where the model is executed.

Projected - Confirmed Cases Ratio

Assuming that the total number of projected cases corresponds to the maximum number of cases that would occur in a given country, the projected - confirmed cases ratio is calculated using the following expression.

\[ProjectedConfirmedCases Ratio = 100 - (100 * \frac{(max(Projected Case) - max(Confirmed))}{ max(Projected Case)}\]

Global Case

Average Cases (Last Three Days)

Global Case Summary

Country Cases

China

Korea, South

The Americas

Confirmed Case

Confirmed Case - Average Last Three Days

Confirmed Case - Cases Last Days

Mexico

Mexico & Other Countries

Dominican Republic

United State (US)

Argentina

Brazil

Canada

Colombia

Ecuador

Chile

Panama

Peru

Venezuela

Europe

Confirmed Case

Confirmed Case - Average Last Three Days

Belgium

Czechia

Greece

Italy

Spain

United Kingdom

France

Germany

Netherlands

Switzerland

Norway

Portugal

Other Countries

Taiwan*

Japan

Iran

Russia

Singapore

Israel

References

Source data: https://github.com/CSSEGISandData/COVID-19.git

Clark, A.J. (2011). “Decline Curve Analysis in Unconventional Resource Plays Using Logistic Growth Models.” M.S. Thesis, The University of Texas at Austin, August 2011.

---
title: "Covid19 Projected Cases by Countries"
author: "Andres PENA andrespena@gmail.com"
date: "May/07/2020"
output:
  html_notebook:
    toc: yes
    toc_float: yes
  html_document:
    df_print: paged
    toc: yes
    toc_float: yes    
---

Location: "~/R/COVID-19-master/vignettes/covid_lgm"

```{r setup, include=FALSE}
knitr::opts_chunk$set(
	echo = TRUE,
	message = FALSE,
	warning = FALSE
)
```

<style type="text/css">

body{ /* Normal  */
      font-size: 16px;
  }
td {  /* Table  */
  font-size: 14px;
}
h1.title {
  font-size: 38px;
  color: DarkRed;
}
h1 { /* Header 1 */
  font-size: 28px;
  color: Blue;
}
h2 { /* Header 2 */
    font-size: 24px;
  color: DarkBlue;
}
h3 { /* Header 3 */
  font-size: 20px;
  font-family: "Times New Roman", Times, serif;
  color: DarkBlue;
}
code.r{ /* Code block */
    font-size: 12px;
}
pre { /* Code block - determines code spacing between lines */
    font-size: 14px;
}
</style>

```{r echo=FALSE, message=FALSE, warning=FALSE}
rm(list = ls())
# Load libraries
library("tidyverse", warn.conflicts = F)
library("cowplot")
library("minpack.lm")
library("broom")
library("siop")
library("kableExtra")
library("plotly")
# Load functions
source("~/R/COVID-19-master/R/functions.R")
```


```{r echo=FALSE, message=FALSE, warning=FALSE}
# update data with some charged column names

covid19 <- read_csv("~/R/COVID-19-master/data/COVID-19-master 2020-05-07/csse_covid_19_data/csse_covid_19_daily_reports/05-07-2020.csv")

setwd("~/R/COVID-19-master/data/COVID-19-master 2020-05-07/csse_covid_19_data/csse_covid_19_time_series")

tsr <- read_csv("time_series_covid19_recovered_global.csv")

tsc <- read_csv("time_series_covid19_confirmed_global.csv")

tsd <- read_csv("time_series_covid19_deaths_global.csv")
```

```{r message=FALSE, warning=FALSE, include=FALSE}
# Run tidy_join_fun function
covid19 <- wrangl_covid19(covid19)
tsc <- wrangl_tsc(tsc)
tsd <- wrangl_tsc(tsd)
tsr <- wrangl_tsc(tsr)
tidy_join <- tidy_join_fun()
```

# Introduction  

The following document shows an analysis of the data associated with the coronavirus pandemic (Covid19).

The analysis is divided into two parts, the first comprises general graphs of the data and then a numerical simulation is performed using the logistic growth model (LGM) in order to forecast the possible total number of cases by country.  

The data used for this analysis are updated daily and are stored in **Data Repository by Johns Hopkins CSSE**

# Terms used    

### Recovery ratio (RR)     

The proportion of people recovered from a specified disease among all individuals diagnosed with the disease over a certain period of time.    

$$RecoveryRatio (RR) = \frac{Recovered}{Confirmed}$$  

### Case Fatality ratio (CFR)    

Case fatality rate, also called case fatality ratio, in epidemiology, the proportion of people who die from a specified disease among all individuals diagnosed with the disease over a certain period of time.  

https://www.britannica.com/science/case-fatality-rate

$$Case Fatality Ratio (CFR) = \frac{Deaths}{Confirmed}$$  

### Logistic Growth Model (LGM)      

Clark (2011) propose a new empirical model based on logistic growth models.  

A nonlinear model formula including variables and parameters.  

$$ProjectedCases = \frac{(K * t ^ n)}{(a + t ^ n)}$$    

Where:  

Cases = Projected Case   
K = Carrying capacity  
n = Hyperbolic exponent  
a = Constant  
t  = Time  

The best-fit nonlineal model is obtained by an iterative least-squared method.

The logistic growth model was used to project the progression of the disease in certain countries.

The most relevant result of the model corresponds to the **projected cases**, this term is associated with the maximum number of cases estimated by the model for each country, where the model is executed.  

### Projected - Confirmed Cases Ratio  

Assuming that the total number of **projected cases** corresponds to the maximum number of cases that would occur in a given country, the projected - confirmed cases ratio is calculated using the following expression.

$$ProjectedConfirmedCases Ratio = 100 - (100 * \frac{(max(Projected Case) - max(Confirmed))}{ 
                  max(Projected Case)}$$
                  
# Global Case  

## Average Cases (Last Three Days)

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
# Bar graph Average Confirmed Cases (Last three days)
bar_graph(tidy_join, c3d, 
                  "Global Cases - Confirmed Case", 
                  "Average Last Three Days")
```

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
bar_graph(tidy_join, d3d, 
                  "Global Cases - Deaths", 
                  "Average Last Three Days")
```

## Global Case Summary  

```{r echo=FALSE, message=FALSE, warning=FALSE}
covid19
```

```{r echo=FALSE, fig.width=10, message=FALSE, warning=FALSE}
plot_grid_global(tidy_join)
```

## Country Cases

```{r echo=FALSE, message=FALSE, warning=FALSE}
tidy_join_fun_max(tidy_join)
```

## China  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "China"
china <- country_resume("China", cutoff = 548, trace = F, tmax = 95)
```

## Korea, South    

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Korea, South"
sk <- country_resume("Korea, South", cutoff = 15, trace = F, tmax = 100)
countries_resume <- full_join(china, sk)
```

# The Americas  

## Confirmed Case

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Ecuador|Chile|Peru|Panama|Argentina|Colombia|Brazil|Mexico|Venezuela")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls")
bar_graph(foo, confirmed,  
                  "The Americas - Confirmed Cases", 
                  paste("Number of Cases", Sys.Date()))
```

## Confirmed Case - Average Last Three Days

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Ecuador|Chile|Peru|Panama|Argentina|Colombia|Brazil|Mexico|Venezuela")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls")
bar_graph(foo, c3d,  
                  "The Americas - Confirmed Case", 
                  paste("Average Last Three Days", Sys.Date()))
```

## Confirmed Case - Cases Last Days

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Ecuador|Chile|Peru|Panama|Argentina|Colombia|Brazil|Mexico|Venezuela")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  arrange(desc(date))
bar_graph(foo, head(cases_by_day, 1),  
                  "The Americas - Confirmed Case", 
                  paste("Cases Last Days", Sys.Date()))
```

## Mexico  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Mexico"
mexico <- country_resume("Mexico", cutoff = 251, trace = F, tmax = 180)
countries_resume <- full_join(countries_resume, mexico)
```

## Mexico & Other Countries

```{r echo=FALSE, fig.height=5, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Brazil|Mexico|Korea, South|Peru|Argentina|Chile|Colombia|Ecuador")
title <- "Mexico and Other Countries"
subtitle <- "Cumulative Confirmed Cases"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot
ggplot(df, aes(x = day, y = value)) + 
  geom_point(aes(color = country)) + 
  geom_line(aes(color = country)) +   
  facet_grid(.~country, scales = "free") +    
  theme_minimal_grid(13) +  
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "Number of Cases")
```


```{r echo=FALSE, fig.height=5, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Brazil|Mexico|Peru|Argentina|Chile|Korea, South|Ecuador|US")
title <- "Mexico and Other Countries"
subtitle <- "Cumulative Confirmed Cases - Log scale"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot

ggplot(df, aes(x = day, y = log(value))) + 
  geom_point(aes(color = country)) + 
  geom_smooth(aes(col = country), method = "loess", se = F) +
  facet_grid(.~country, scales = "free") +
  theme_minimal_grid(12) +
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "log(Number of Cases)")
```

```{r echo=FALSE, fig.height=5, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Brazil|Mexico|Peru|Argentina|Chile|Korea, South|Ecuador")
title <- "Mexico and Other Countries"
subtitle <- "Confirmed Cases by Days"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, cases_by_day) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot
ggplot(df, aes(x = day, y = value)) + 
  geom_point(aes(color = country, alpha = 0.15)) + 
  geom_smooth(aes(col = country), method = "auto", se = F) +
  facet_grid(.~country, scales = "free") +  
  theme_minimal_grid(13) +  
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "Number of Cases")
```

```{r echo=FALSE, fig.height=5, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Brazil|Mexico|Peru|Argentina|Chile|Korea, South|Ecuador|US")
title <- "Mexico and Other Countries"
subtitle <- "Confirmed Cases by Days - Log scale"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, cases_by_day) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot
ggplot(df, aes(x = day, y = log(value))) + 
  geom_point(aes(color = country)) + 
  geom_smooth(aes(col = country), method = "auto", se = F) +
  facet_grid(.~country, scales = "free") +  
  theme_minimal_grid(13) +  
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "log(Number of Cases)")
```

## Dominican Republic

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Dominican Republic"
dr <- country_resume("Dominican Republic", cutoff = 5, 
                     trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, dr)
```

## United State (US)

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
# https://covid19.healthdata.org

# http://www.healthdata.org/sites/default/files/files/research_articles/2020/covid_paper_MEDRXIV-2020-043752v1-Murray.pdf

Country <- "US"
us <- country_resume("US", cutoff = 1663, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, us)
```

## Argentina  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Argentina"
arg <- country_resume("Argentina", cutoff = 19, trace = F, tmax = 120)
countries_resume <- full_join(countries_resume, arg)
```

## Brazil  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Brazil"
bra <- country_resume("Brazil", cutoff = 200, trace = F, tmax = 150)
countries_resume <- full_join(countries_resume, bra)
```

## Canada 

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Canada"
can <- country_resume("Canada", cutoff = 80, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, can)
```

## Colombia 

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Colombia"
col <- country_resume("Colombia", cutoff = 1, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, col)
```

## Ecuador  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Ecuador"
ecu <- country_resume("Ecuador", cutoff = 1, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, ecu)
```

## Chile

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Chile"
chi <- country_resume("Chile", cutoff = 1, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, chi)
```

## Panama

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Panama"
pan <- country_resume("Panama", cutoff = 10, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, pan)
```

## Peru  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Peru"
per <- country_resume("Peru", cutoff = 318, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, per)
```

## Venezuela  

```{r eval=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE, include=FALSE}
Country <- "Venezuela"
ven <- country_resume("Venezuela", cutoff = 2, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, ven)
```

# Europe  

## Confirmed Case  

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Italy|Spain|France|Germany|Norway|United Kingdom|Netherlands|Switzerland|Portugal")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls")
bar_graph(foo, confirmed, 
                  "Europe - Confirmed Case", 
                  paste("Number of Cases", Sys.Date()))
```

## Confirmed Case - Average Last Three Days

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Italy|Spain|France|Germany|Norway|United Kingdom|Netherlands|Switzerland|Portugal")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls")
bar_graph(foo, c3d,  
                  "Europe - Confirmed Case", 
                  paste("Average Last Three Days", Sys.Date()))
```

```{r echo=FALSE, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Italy|Spain|Korea, South|Germany|United Kingdom|France")
title <- "Europa"
subtitle <- "Cumulative Confirmed Cases"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot
ggplot(df, aes(x = day, y = value)) + 
  geom_point(aes(color = country)) + 
  geom_line(aes(color = country)) +   
  geom_smooth(aes(col = country), method = "auto", se = T) +  
  facet_grid(.~country, scales = "free") +    
  theme_minimal_grid(13) +  
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "Number of Cases")
```

```{r echo=FALSE, fig.height=5, fig.width=9, message=FALSE, warning=FALSE}
countries <- ("Italy|Spain|Korea, South|Germany|United Kingdom|France|Switzerland|Czechia")
title <- "Europe"
subtitle <- "Cumulative Confirmed Cases - Log scale"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot

ggplot(df, aes(x = day, y = log(value))) + 
  geom_point(aes(color = country)) + 
  geom_smooth(aes(col = country), method = "loess", se = F) +
  facet_grid(.~country, scales = "free") +
  theme_minimal_grid(12) +
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "log(Number of Cases)")
```

## Belgium 

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Belgium"
cze <- country_resume("Belgium", cutoff = 50, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, cze)
```

## Czechia  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Czechia"
cze <- country_resume("Czechia", cutoff = 10, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, cze)
```

## Greece  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Greece"
cze <- country_resume("Greece", cutoff = 30, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, cze)
```

## Italy  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Italy"
ita <- country_resume("Italy", cutoff = 100, trace = F, tmax = 80)
countries_resume <- full_join(countries_resume, ita)
```

## Spain  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Spain"
spa <- country_resume("Spain", cutoff = 100, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, spa)
```

## United Kingdom  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "United Kingdom"
uk <- country_resume("United Kingdom", cutoff = 300, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, uk)
```

## France  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "France"
fra <- country_resume("France", cutoff = 100, trace = F, tmax = 120)
countries_resume <- full_join(countries_resume, fra)
```

## Germany  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Germany"
ger <- country_resume("Germany", cutoff = 100, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, ger)
```

## Netherlands

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Netherlands"
net <- country_resume("Netherlands", cutoff = 20, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, net)
```

## Switzerland  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Switzerland"
swi <- country_resume("Switzerland", cutoff = 50, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, swi)
```

## Norway  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Norway"
nor <- country_resume("Norway", cutoff = 15, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, nor)
```

## Portugal  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Portugal"
por <- country_resume("Portugal", cutoff = 35, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, por)
```

# Other Countries

```{r echo=FALSE, message=FALSE, warning=FALSE}
countries <- ("Japan|Korea, South|Iran|Russia|Israel|India|Turkey|Saudi Arabia|Pakistan")
foo <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls")
bar_graph(foo, confirmed, 
                  "Other Countries - Confirmed Case", 
                  paste("Number of Cases", Sys.Date()))
```

```{r echo=FALSE, fig.width=10, message=FALSE, warning=FALSE}
countries <- ("Iran|Turkey|Korea, South|Israel|Japan|Russia|Saudi Arabia")
title <- "Other Countries"
subtitle <- "Cumulative Confirmed Cases"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot
ggplot(df, aes(x = day, y = value)) + 
  geom_point(aes(color = country)) + 
  geom_line(aes(color = country)) +   
  geom_smooth(aes(col = country), method = "auto", se = T) +  
  facet_grid(.~country, scales = "free") +    
  theme_minimal_grid(13) +  
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "Number of Cases")
```

```{r echo=FALSE, fig.height=5, fig.width=8, message=FALSE, warning=FALSE}
countries <- ("Iran|Turkey|Korea, South|Israel|Japan|Russia|Saudi Arabia")
title <- "Other Countries"
subtitle <- "Cumulative Confirmed Cases - Log scale"
# Select data
df <- tidy_join %>%
  filter(stringr::str_detect(country, countries) & state == "alls") %>%
  filter(cases_by_day >= 1) %>%
  select(country, date, confirmed) %>%
  gather(key = "variable", value = "value", -date, -country) %>%
  group_by(country) %>%
  mutate(day = 1:n())

# Plot

ggplot(df, aes(x = day, y = log(value))) + 
  geom_point(aes(color = country)) + 
  geom_smooth(aes(col = country), method = "loess", se = F) +
  facet_grid(.~country, scales = "free") +
  theme_minimal_grid(12) +
  theme(legend.position = "none") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", y = "log(Number of Cases)")
```

Taiwan*

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Taiwan*"
jap <- country_resume("Taiwan*", cutoff = 30, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, jap)
```

## Japan    

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Japan"
jap <- country_resume("Japan", cutoff = 420, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, jap)
```

## Iran  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Iran"
ira <- country_resume("Iran", cutoff = 0, trace = F, tmax = 80)
countries_resume <- full_join(countries_resume, ira)
```

## Russia  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Russia"
rus <- country_resume("Russia", cutoff = 199, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, rus)
```

## Singapore

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Singapore"
isr <- country_resume("Singapore", cutoff = 385, trace = F, tmax = 80)
countries_resume <- full_join(countries_resume, isr)
```

## Israel  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Israel"
isr <- country_resume("Israel", cutoff = 126, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, isr)
```


```{r echo=FALSE, message=FALSE, warning=FALSE}
countries_resume[sapply(countries_resume, is.infinite)] <- NA
# Countries Analysis
countries_resume %>% arrange(country)
```

```{r fig.height=8, fig.width=5, message=FALSE, warning=FALSE, include=FALSE}
# Countries Analysis
countries_resume %>% 
summarise_if(is.numeric, mean, na.rm = TRUE)

ggplot(countries_resume) +
  geom_point(aes(case, CFR, col = isConv)) +
  geom_smooth(aes(case, CFR), method = "auto", se = T) +
  theme_bw()

countries_resume %>% filter(K < 200000) %>% 
  ggplot() +
  geom_point(aes(case, K, col = isConv)) +
  geom_smooth(aes(case, K), method = "lm", se = F) +  
  theme_bw()

countries_resume %>% filter(K < 200000) %>% 
  ggplot() +
  geom_point(aes(a, K, col = isConv)) +
  geom_smooth(aes(a, K), method = "lm", se = F) +  
  theme_bw()

countries_resume %>% filter(K < 200000) %>% 
  ggplot() +
  geom_point(aes(AIC, BIC, col = isConv)) +
  theme_bw()

countries_resume %>% 
  filter(K < 200000 & sigma < 500) %>% 
  select(country, prog, sigma) %>%
  plot_ly(x = ~prog, y = ~sigma, color = ~country)

countries_resume %>% 
  select(country, days, case) %>%
  plot_ly(x = ~days, y = ~case, color = ~country)

countries_resume %>% 
  select(country, death, case) %>%
  plot_ly(x = ~case, y = ~death, color = ~country)

# Bar graph Average Confirmed Cases (Last three days)
foo <- tidy_join_fun_max(tidy_join) %>%
  filter(confirmed > 2000) %>%
  arrange(desc(CFR)) %>%  
  ggplot(aes(x = as_factor(country), y = CFR)) +
  geom_bar(stat = "identity", 
           fill = "lightblue", 
           alpha = 0.6) + 
  geom_text(aes(label = round(CFR, 1)), 
            hjust = "rigth",
            size = 4.5,
            fontface = "bold") +
  labs(title = "Case Fatality Ratio",
       subtitle = "Countries with more than 2000 confirmed cases",
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "", y = "") +
  coord_flip() + theme_minimal_grid(12) 
foo
```

# References  

Source data: https://github.com/CSSEGISandData/COVID-19.git  

Clark, A.J. (2011). "Decline Curve Analysis in Unconventional Resource Plays
    Using Logistic Growth Models." M.S. 
    Thesis, The University of Texas at Austin, August 2011. 

