-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtidyweek3.md
119 lines (98 loc) · 4.72 KB
/
tidyweek3.md
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
---
title: "Tidy Week 3"
output:
html_document:
df_print: paged
keep_md: true
md_document:
variant: markdown_github
---
```r
library(readxl)
library(tidyverse)
owid <- read_excel("global_mortality.xlsx")
names(owid) <- str_trim(str_remove_all(names(owid), "[[:punct:]]"))
names(owid)[names(owid) == 'HIVAIDS'] = 'HIV/AIDS'
colnames(owid)[c(-1, -2, -3)] <- paste("rates",
colnames(owid[,c(-1, -2, -3)]),
sep = ".")
owid %>%
as.data.frame %>% # if not, throws up error about renaming rows in tibbles
reshape(timevar = 'disease',
varying = colnames(owid)[c(-1, -2, -3)],
direction = 'l') %>% na.omit -> a
rownames(a) <- NULL
```
```r
ggplot(a[a$country == 'World' & a$year == 2016,],
aes(x = reorder(disease, rates), y = rates, fill = disease)) +
geom_bar(stat = 'identity') + geom_text(aes(label = paste0(round(rates,1), '%')),
position = position_dodge(width = .9),
hjust = "left", vjust = "center", size = 2.5)+
coord_flip() +
theme_minimal() + theme(legend.position = 'none',
plot.title = element_text(hjust = 1, face = 'bold'),
plot.subtitle = element_text(hjust = 1),
axis.title.x=element_blank(),
axis.title.y=element_blank(),
panel.grid.major.y = element_blank(),
panel.grid.minor = element_blank()) +
scale_y_continuous(breaks = c(0,5,10,15,20,25,30),
labels = c('0%', '5%', '10%', '15%', '20%', '25%', '30%')) +
labs(title = 'Share of deaths by cause, World, 2016',
subtitle = 'Data refers to the specific cause of death, which is distinguished from risk factors for death, such as air \npollution, diet and other lifestyle factors. See sources for further details on definitions of specific cause categories.',
caption = 'Source: Institute for Health Metrics and Evaluation (IHME); Global Terrorism Database (GTD); Amnesty International')
```
![](tidyweek3_files/figure-html/unnamed-chunk-2-1.png)<!-- -->
```r
ggsave('owid.pdf')
```
```
## Saving 7 x 5 in image
```
```r
library(shiny)
ui <- fluidPage(
titlePanel("Share of deaths by cause"),
sidebarLayout(
sidebarPanel(
selectInput(inputId = "country", label = "Country:", choices = unique(owid$country),
selected = "World"),
sliderInput(inputId = "year", label = "Year:",
min = min(owid$year), max = max(owid$year),value = min(owid$year),
animate = TRUE, sep = ""),
p("Source: Institute for Health Metrics and Evaluation (IHME); Global Terrorism Database (GTD); Amnesty International")
),
mainPanel(
plotOutput(outputId = "barplot"),
p("Data refers to the specific cause of death, which is distinguished from risk factors for death, such as air pollution, diet and other lifestyle factors. See sources for further details on definitions of specific cause categories.")
)
)
)
server <- function(input, output) {
output$barplot <- renderPlot({
ggplot(a[a$country == input$country & a$year == input$year & a$rates > 0,],
aes(x = reorder(disease, rates), y = rates, fill = disease)) +
geom_bar(stat = 'identity') + geom_text(aes(label = paste0(round(rates,1), '%')),
position = position_dodge(width = .9),
hjust = "left", vjust = "center", size = 2.5)+
coord_flip() +
theme_minimal() + theme(legend.position = 'none',
plot.title = element_text(hjust = 1),
plot.subtitle = element_text(hjust = 1),
axis.title.x=element_blank(),
axis.title.y=element_blank(),
panel.grid.major.y = element_blank(),
panel.grid.minor = element_blank()) +
scale_y_continuous(breaks = c(0,5,10,15,20,25,30),
labels = c('0%', '5%', '10%', '15%', '20%', '25%', '30%'))
}
)
}
shinyApp(ui = ui, server = server)
```
```
## PhantomJS not found. You can install it with webshot::install_phantomjs(). If it is installed, please make sure the phantomjs executable can be found via the PATH variable.
```
<!--html_preserve--><div style="width: 100% ; height: 400px ; text-align: center; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-box-sizing: border-box;" class="muted well">Shiny applications not supported in static R Markdown documents</div><!--/html_preserve-->
[Link to Shiny document](https://philipk.shinyapps.io/Tidy3/)