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

China


Korea, South


The Americas
Confirmed Case

Confirmed Case - Average Last Three Days

Confirmed Case - Cases Last Days

Mexico


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: "April/13/2020"
output:
  html_notebook:
    toc: yes
    toc_float: yes
  html_document:
    df_print: paged
    toc: yes
    toc_float: yes    
---

```{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())
library("tidyverse", warn.conflicts = F)
library("cowplot")
library("minpack.lm")
library("broom")
library("siop")
library("kableExtra")
library("plotly")
```


```{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-04-13/csse_covid_19_data/csse_covid_19_daily_reports/04-12-2020.csv")

setwd("~/R/COVID-19-master/data/COVID-19-master 2020-04-13/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 echo=FALSE, message=FALSE, warning=FALSE}
#' @title A wrangl_covid19 function
#' @param covid19 -  input data frame
#' @return wrangl_covid19
#' @export wrangl_covid19
#' @keywords wrangl_covid19
#'
wrangl_covid19 <- function(covid19) {
covid19 %>% 
  rename(state = "Province_State", 
         country = "Country_Region",
         last_upd = "Last_Update") %>%
  summarise(confirmed = sum(Confirmed, na.rm = T),
            recovered = sum(Recovered, na.rm = T),                
            deaths = sum(Deaths, na.rm = T),
            RR = round(100 * recovered/confirmed, 0),
            CFR = round(100 * deaths/confirmed, 0))    
}

#' @title A wrangl_tsc function
#' @param tsc -  input data frame
#' @return wrangl_tsc
#' @export wrangl_tsc
#' @keywords wrangl_tsc
#'
wrangl_tsc <- function(tsc) {
tsc %>% rename(state = "Province/State", 
                      country = "Country/Region",
                      lat = Lat, long = Long)  
}

#' @title A wrangl_tsc function
#' @param tsd -  input data frame
#' @return wrangl_tsd
#' @export wrangl_tsd
#' @keywords wrangl_tsd
#'
wrangl_tsd <- function(tsd) {
tsd %>% rename(state = "Province/State", 
                      country = "Country/Region",
                      lat = Lat, long = Long)
}

#' @title A wrangl_tsr function
#' @param tsr -  input data frame
#' @return wrangl_tsr
#' @export wrangl_tsr
#' @keywords wrangl_tsr
#'
wrangl_tsr <- function(tsr) {
tsr %>% rename(state = "Province/State", 
                      country = "Country/Region",
                      lat = Lat, long = Long)
}

#' @title A tidy_join_fun_max by country function
#' @param tidy_join -  input data frame
#' @return tidy_join_fun_max
#' @export tidy_join_fun_max
#' @keywords tidy_join_fun_max
#'
tidy_join_fun_max <- function(tidy_join) {
tidy_join %>% group_by(country) %>%
  summarise(confirmed = max(confirmed, na.rm = T),
            recovered = max(recovered, na.rm = T),                
            deaths = max(death, na.rm = T),
            RR = round(100 * recovered/confirmed, 1),
            CFR = round(100 * deaths/confirmed, 1)) %>%
  arrange(-confirmed)  
}

#' @title A gather function
#' @param data -  input data frame
#' @param var -  x input data
#' @return gather_fun
#' @export gather_fun
#' @keywords gather_fun
#' 
gather_fun <- function(data, var) {
  var <- enquo(var)
  data %>% gather(date, !!var, -lat, -long, -state, -country) %>%  
  mutate(date = as.Date(date, "%m/%d/%y"))
}

#' @title tidy_join_fun
#' @return tidy_join
#' @export tidy_join
#' @keywords tidy_join_fun
#' 
tidy_join_fun <- function() {
  
# Run gather function
tsc_tidy <- gather_fun(tsc, confirmed)
tsd_tidy <- gather_fun(tsd, death)
tsr_tidy <- gather_fun(tsr, recovered)

# Join data frames
tidy_join <- full_join(tsc_tidy, tsd_tidy, 
                       by = c("state", "country", "lat", "long", "date")) 
tidy_join <- full_join(tidy_join, tsr_tidy, 
                       by = c("state", "country", "lat", "long", "date")) 

# Convert to numeric
tidy_join$confirmed <- as.numeric(tidy_join$confirmed)
tidy_join$death <- as.numeric(tidy_join$death)
tidy_join$recovered <- as.numeric(tidy_join$recovered)

# Calculate additional variables
tidy_join <- tidy_join %>% 
# Recovery Ratio (%) & Case Fatality Ratio (%)         
  mutate(RR = round(100 * recovered/confirmed, 0),
       CFR = round(100 * death/confirmed, 1)) %>%
  group_by(country) %>% 
# mean confirmed case last 3 days        
  mutate(c3d = mean(tail(confirmed, 3L)),
         d3d = mean(tail(death, 3L)),
         r3d  = mean(tail(recovered, 3L)),
         state = ifelse(is.na(state), "alls", state),
         cases_by_day = (confirmed - lag(confirmed, 1L))) %>%
  ungroup()
}

#' @title plot_enquo function
#' @param data -  input data frame
#' @param x -  x input data
#' @param y -  y input data
#' @param Title -  title
#' @return plot
#' @export plot plot graph
#' @keywords plot
#' 
plot_enquo <- function(.data, x, y, Title)
{
  x <- enquo(x)
  y <- enquo(y)
  ggplot(.data, aes(!!x, !!y)) +
    geom_point(aes(alpha = 0.6, color = !!y)) + 
    geom_line(aes(alpha = 0.6, color = !!y)) +
    labs(title = Title, x = "", y = "")  +
    theme_minimal_grid(12) +
    theme(legend.position = "none")
}

#' @title global_case function
#' @param data -  input data frame
#' @param confirmed -  confirmed input data
#' @param recovered -  recovered input data
#' @param death -  deaths input data
#' @return global_case
#' @export global_case plot graph
#' @keywords global_case
#' 
global_case <- function(data, confirmed, recovered, death) {
  confirmed <- enquo(confirmed)
  recovered <- enquo(recovered)
  death <- enquo(death)    
  
data %>% 
  group_by(date) %>%
  summarise(confirmed = sum(!!confirmed, na.rm = T),
            recovered = sum(!!recovered, na.rm = T),
            death = sum(!!death, na.rm = T), 
            RR = round(100 * recovered / confirmed, 1),
            CFR = round(100 * death / confirmed, 1)) 
}

#' @title plot_grid_global
#' @param tidy_join -  input data frame
#' @return plot_grid_global
#' @export plot_grid_global
#' @keywords plot_grid_global
#' 
plot_grid_global <- function(tidy_join){
  data <- global_case(tidy_join, confirmed, recovered, death) 
  p1 <- plot_enquo(data, date, confirmed, "Confirmed")
  p2 <- plot_enquo(data, date, recovered, "Recovered")
  p3 <- plot_enquo(data, date, death, "Deaths")
  p4 <- plot_enquo(data, date, RR, "Recovery Ratio (%)")
  p5 <- plot_enquo(data, date, CFR, "Case Fatality Ratio (%)")
  
title_gg <- ggplot() + 
  labs(title = "Global Cases", 
       subtitle = paste("Report date:", Sys.Date(),
                        min(data$date[data$confirmed >= 1], na.rm = T))) +
  theme_minimal_grid() +
  theme(legend.position = "none") 

  plot_grid(title_gg, p1, p2, p3, p4, p5, ncol = 3)   
}

#' @title plot_grid_country
#' @param country -  input data frame
#' @param tidy_join -  input data frame
#' @return plot_grid_country
#' @export plot_grid_country
#' @keywords plot_grid_country
#'   
plot_grid_country <- function(country, tidy_join){
  country <- enquo(country)  
  data <- country_calc(!!country, tidy_join, confirmed, recovered, death) 
  p1 <- plot_enquo(data, date, confirmed, "Confirmed")
  p2 <- plot_enquo(data, date, cases_by_day, "cases_by_day")  
  p3 <- plot_enquo(data, date, death, "Deaths")
  p4 <- plot_enquo(data, date, death_by_day, "death_by_day")
  p5 <- plot_enquo(data, date, CFR, "Case Fatality Ratio (%)")
  
# First case date
title_gg <- ggplot() + 
  labs(title = paste("Country:", Country),
       subtitle = paste("Report date:", Sys.Date(),
                        "\nFirst case date:", 
                        min(data$date[data$confirmed >= 1], na.rm = T),
                        "\nConfirmed.last.3.days:", 
                        round(mean(head(data$cases_by_day, 
                                  na.rm = T, 3)), 0)),
       caption = paste("Author: @PenaAndres"), 
       x = "", y = "") +
  theme_minimal_grid() +
  theme(legend.position = "none") 

  plot_grid(title_gg, p1, p2, p3, p4, p5, ncol = 3)     
}

#' @title Country Case Calculations
#' @param country -  input data frame
#' @param data -  input data frame
#' @param confirmed -  input data
#' @param recovered -  input data
#' @param death -  input data
#' @return country_calc
#' @export country_calc
#' @keywords country_calc
#' 
country_calc <- function(country, data, confirmed, recovered, death) {
  country <- enquo(country)
  confirmed <- enquo(confirmed)
  recovered <- enquo(recovered)
  death <- enquo(death)    
  
data %>% filter(country == !!country) %>%
  group_by(date) %>%
  filter(!!confirmed >= 1) %>%
  summarise(confirmed = sum(!!confirmed, na.rm = T),
            recovered = sum(!!recovered, na.rm = T),
            death = sum(!!death, na.rm = T), 
            RR = round(100 * recovered / confirmed, 1),
            CFR = round(100 * death / confirmed, 1)) %>%
  ungroup() %>%
  mutate(cases_by_day = (confirmed - lag(confirmed, 1L)),
         death_by_day = (death - lag(death, 1L)),
         days = 1:n()) %>%
  arrange(desc(date)) %>%
  select(date, days, confirmed, cases_by_day, 
         death, death_by_day, CFR, recovered, RR)
}    

#' @title resume Calculations
#' @param country -  input data frame
#' @return resume
#' @export resume
#' @keywords resume
#' 
resume <- function(Country) {
  
tidy_join %>% 
  filter(country == Country & date == max(date)) %>% 
  summarise(date = max(date),
            Confirmed = sum(confirmed, na.rm = T),
            Recovered = sum(recovered, na.rm = T),
            Death = sum(death, na.rm = T), 
            CFR = head(CFR, 1))
}

#' @title logistic_growth_data_prep calculations
#' @param country -  input data
#' @return logistic_growth_data_prep
#' @export logistic_growth_data_prep
#' @keywords logistic_growth_data_prep
#' 
logistic_growth_data_prep <- function(Country, cutoff) {
  
# Prepare data  
tidy_join %>% 
  filter(country == Country) %>% 
  group_by(country, date) %>% 
  summarise(confirmed = sum(confirmed, na.rm = T)) %>%
  dplyr::filter(confirmed > cutoff) %>%
  ungroup() %>%
  dplyr::mutate(t = 1:n())
}

#' @title logistic_growth_model Calculations
#' @param country -  input data
#' @param data -  input data
#' @param cutoff -  input data
#' @param trace -  input data trace model
#' @param tmax -  input data
#' @return logistic_growth_model
#' @export logistic_growth_model
#' @keywords logistic_growth_model
#' 
logistic_growth_model <- function(Country, cutoff, trace, tmax) {

# Prepare data
data <- logistic_growth_data_prep(Country, cutoff)  
  
# Set input model parameters      
set.seed(17)
maxiter <- 1024
parms <- c(K = max(data$confirmed, na.rm = T), 
           a = max(data$confirmed, na.rm = T), 
           n = 1)
control <- c(nls.control(maxiter = maxiter))    
    
# Run Logistic model   
tryCatch({
model <- minpack.lm::nlsLM(confirmed ~ (K * t ^ n) / (a + t ^ n), 
                           start = parms, 
                           control = control, 
                           trace = trace, 
                           model = TRUE, 
                           data = data)

# Store logistic parameter results
model_parm <- data.frame(country = Country, 
                         K = coef(model)[1],
                         a = coef(model)[2],
                         n = coef(model)[3],
                         stringsAsFactors = FALSE)

# Create time vector a slightly larger to real data 
t <- 1:tmax

# Calculate confirmed_LGM from model
Projected_LGM = (model_parm$K * t ^ model_parm$n) / 
                  (model_parm$a + t ^ model_parm$n)

# Create data to store LGM calculation
foo <- data_frame(t = t, 
                  Projected_LGM = Projected_LGM                 
)

# Join calculate data with real data
data <- left_join(foo, data, by = "t")

# Complete date column
data$date <- seq(as.Date(min(data$date, na.rm = T)), 
    as.Date(min(data$date, na.rm = T) + tmax - 1), "days")

# Complete country column
data$country <- Country

# Create label data frame
annotation <- data.frame(
  x = tmax + 5,
  y = max(data$Projected_LGM, na.rm = T),
  label = paste("Projected cases =", 
                round(model_parm$K, 0)),
# Projected - Confirmed Cases Ratio calculation  
  ratio = round(100 - (100 * 
                  (max(model_parm$K, na.rm = T) - 
                  max(data$confirmed, na.rm = T)) / 
                  round(max(model_parm$K, 0)))))

# Prepare output data frame
output <- list("model" = model, 
               "data" = data, 
               "annotation" = annotation)
# Output results
return(output)
}, error = function(e){cat("ERROR :",conditionMessage(e), "\n")})
}

#' @title logistic_growth_model_plot
#' @param country -  input data
#' @param data1 -  input data
#' @param t -  input data time
#' @param y_proy -  input y proyected
#' @param y_prof -  input data 
#' @param data2 -  input data
#' @param x -  input data x
#' @param y -  input data y
#' @param label -  input data label
#' @return logistic_growth_model
#' @export logistic_growth_model_plot
#' @keywords logistic_growth_model_plot
#'
logistic_growth_model_plot <- function(.data1, t, y_proy, y_conf, 
                                       .data2, x, y, label) {
t <- enquo(t)  
y_proy <- enquo(y_proy)
y_conf <- enquo(y_conf)
x <- enquo(x)
y <- enquo(y)
label <- enquo(label)

ggplot(data = .data1) +
  geom_line(aes(!!t, !!y_proy, colour = "Projected")) +  
  geom_point(aes(!!t, !!y_proy, colour = "Projected")) +
  geom_point(data = .data1, 
             aes(!!t, !!y_conf, colour = "Confirmed")) +
  geom_label(data = .data2, 
            aes( x = !!x, y = !!y, label = !!label), 
            fill = "lightblue",
            nudge_x = -25, 
            size = 5.0,
            fontface = "bold") +
  labs(title = paste(Country, "- Covid-19 - Logistic Growth Model (LGM)"),
       subtitle = paste("Confirmed / Projected Cases Ratio :",
                        .data2$ratio, "%"),
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "Days", 
       y = "Number of Confirmed Cases") +
  theme_minimal_grid(14) +
  theme(legend.position = "top")    
} 

#' @title bar_graph
#' @param tidy_join -  input data
#' @param y -  input data
#' @param title -  input data
#' @return bar_graph
#' @export bar_graph
#' @keywords bar_graph
#' 
bar_graph <- function(tidy_join, y, title, subtitle) {
y <- enquo(y)  
tidy_join %>% group_by(country) %>% 
  summarise(y = max(!!y)) %>% 
  top_n(10) %>% arrange(y) %>%
  ggplot(aes(x = as_factor(country), y = y)) +
  geom_bar(stat = "identity", 
           fill = "lightblue", 
           alpha = 0.6) + 
  geom_text(aes(label = round(y, 0)), 
            hjust = "rigth",
            size = 4.5,
            fontface = "bold") +
  labs(title = title,
       subtitle = subtitle,
       caption = paste("Source data: https://github.com/CSSEGISandData/COVID-19.git",
       "\nAuthor: @PenaAndres"), 
       x = "", y = "") +
  coord_flip() + theme_minimal_grid(14)  
}

#' @title plotly
#' @param tidy_join -  input data
#' @param y -  input data
#' @param title -  input data
#' @return plotly
#' @export plotly
#' @keywords plotly
#' 
plotly <- function(data, t, confirmed, Projected_LGM, title) {
fig <- plot_ly(data, x = t)
fig <- fig %>% add_trace(y = confirmed, 
                         name = 'confirmed',
                         mode = 'lines+markers')
fig %>% add_trace(y = Projected_LGM, 
                  name = 'Projected_LGM', 
                  mode = 'lines+markers') %>% 
  layout(title = title)
}

plot_comparison <- function(){
lim_y <- max(mo$data$Projected_LGM, na.rm = T)
# sum of squares
sum((mo$data$Projected_LGM - mo$data$confirmed)^2)
# the observed prevalences:
with(mo$data, plot(t, confirmed, pch = 19, col = "green", ylim = c(0, lim_y)))
# the model-predicted prevalences:
with(mo$data, lines(t, Projected_LGM, col = "red", type = "o"))
# the "errors":
segments(mo$data$t, mo$data$confirmed, mo$data$t, mo$data$Projected_LGM)
grid(col = "blue")  
}

#' @title country_resume
#' @param Counntry -  input data
#' @param cutoff -  input data
#' @param trace -  input data
#' @param tmax -  input data
#' @param comp -  input data
#' @return country_resume
#' @export country_resume
#' @keywords country_resume
#'
country_resume <- function(Country, cutoff, trace, tmax) {
# Print resume data by country 
print(resume(Country))
# Calculate additional country data
data <- country_calc(Country, tidy_join, confirmed, recovered, death)
print(data)
# Plot country data
plot1 <- plot_grid_country(Country, tidy_join)
print(plot1)
# Calculate LGM by couuntry
mo <- logistic_growth_model(Country, cutoff = cutoff, 
                            trace = trace, 
                            tmax = tmax)
# Print model results
foo <- tidy(mo$model)
print(foo)
# Print model results
bar <- glance(mo$model)
print(bar)
# Create "country_resume" data frame
country_resume <- data.frame(country = Country, 
                 actual = head(data$date, 1),
                 start = min(data$date[data$confirmed >= 1], na.rm = T),
                 case = head(data$confirmed, 1),
                 death = head(data$death, 1),
                 CFR = head(data$CFR,1), 
                 days = 1 + head(data$date, 1) - 
                   min(data$date[data$confirmed >= 1], na.rm = T),
                 isConv = bar$isConv,
                 K = round(foo$estimate[1], 0),
                 K2 = round(foo$estimate[1]/2, 0),  
                 K2.r = min(mo$data$date[mo$data$confirmed >= 
                                        foo$estimate[1]/2], na.rm = T),
                 K2.e = min(mo$data$date[mo$data$Projected_LGM >= 
                                        foo$estimate[1]/2], na.rm = T),                 
                 a = round(foo$estimate[2], 0),
                 n = round(foo$estimate[3], 2),
                 prog = round(100 - 100 * (foo$estimate[1] - 
                                             head(data$confirmed, 1)) /
                    foo$estimate[1], 0),
                 sigma = round(bar$sigma, 0),
                 deviance = round(bar$deviance, 0),
                 logLik = round(bar$logLik, 0),
                 df.residual = round(bar$df.residual, 0),
                 AIC = round(bar$AIC, 0),
                 BIC = round(bar$BIC, 0),
                 K.p.value  = foo$p.value[1],
                 a.p.value  = foo$p.value[2],
                 n.p.value  = foo$p.value[3],
                 K.std.error  = foo$std.error[1],
                 a.std.error  = foo$std.error[2],
                 n.std.error  = foo$std.error[3])
# Plot LGM results
print(logistic_growth_model_plot(mo$data, t, Projected_LGM, confirmed, 
                           mo$annotation, x, y, label))
print(plotly(mo$data, ~date, ~confirmed, ~Projected_LGM, 
       paste(Country, "- Model Results -", mo$annotation$label)))
# Print "country_resume" data frame
print(country_resume)
return(country_resume)
}
```


```{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 = 500, trace = F, tmax = 80)
```

## Korea, South    

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Korea, South"
sk <- country_resume("Korea, South", cutoff = 50, trace = F, tmax = 80)
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 = 25, trace = F, tmax = 70)
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 = 10, 
                     trace = F, tmax = 70)
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 = 2000, 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 = 50, trace = F, tmax = 100)
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 = 20, trace = F, tmax = 100)
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 = 5, 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 = 10, 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 = 10, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, per)
```

## Venezuela  

```{r echo=FALSE, fig.height=7, fig.width=10, message=FALSE, warning=FALSE}
Country <- "Venezuela"
ven <- country_resume("Venezuela", cutoff = 1, 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 = 100)
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 = 200, 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 = 100, 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 = 100, 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 = 100, trace = F, tmax = 100)
countries_resume <- full_join(countries_resume, isr)
```



```{r fig.height=8, fig.width=5, message=FALSE, warning=FALSE, include=FALSE}
# Countries Analysis
countries_resume %>% arrange(country)
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. 


