-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.R
208 lines (168 loc) · 9.69 KB
/
app.R
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
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
#Temp Data Source:
#Kaufman DS, Schneider DP, McKay NP, et al. 2009. Recent warming reverses long-term arctic cooling. Science 325: 1236–1239.
#CO2 Data Source:
#C. D. Keeling, S. C. Piper, R. B. Bacastow, M. Wahlen, T. P. Whorf, M. Heimann, and H. A. Meijer, Exchanges of atmospheric CO2 and 13CO2 with the terrestrial biosphere and oceans from 1978 to 2000. I. Global aspects, SIO Reference Series, No. 01-06, Scripps Institution of Oceanography, San Diego, 88 pages, 2001.
library(shiny);require(ggplot2);require(reshape2);require(DT)
temp<-read.csv("Kaufman Temp data.csv")
temprangeyrs<-range(temp$Year,na.rm=T)
CO2<-read.csv("Keeling CO2 data.csv")[,-13]
CO2$my<-paste(CO2$Mn,CO2$Yr,sep="-")
CO2rangeyrs<-range(CO2$Yr,na.rm=T)
#Temperature data sources
dfnames<-c("01-Glacial Sediments_Alaska_yr 730-2000","02-Sediments_Alaska_yr 1-2000","03-Tree Rings_Alaska_yr 720-2000","04-Glacial Sediments_Alaska_yr 460-2000","05-Ice Isotopes_Devon Island_yr 1-1980","06-Glacial Sediments_Ellesmere Island_yr 1-2000","07-Ice Isotopes_Baffin Island_yr 1-1980","08-Glacial Sediments_Ellesmere Island_yr 1-2000","09-Glacial Sediments_Baffin Island_yr 980-2000","10-Glacial Sediments_Baffin Island_750-2000","11-Sediments_Greenland_yr 1-1940","12-Ice Isotopes_Greenland_yr 1-1980","13-Ice Isotopes_Greenland_yr 1-2000","14-Ice Isotopes_Greenland_yr 1-1990","15-Ice Isotopes_Greenland_yr 550-1980","16-Ice Isotopes_Greenland_yr 1-1990","17-Sediments_Iceland_yr 1-2000","18-Tree Rings_yr 1-2000","19-Glacial Sediments OC_Finland_yr 1-1800","20-Glacial Sediments x-ray_Finland_yr 1-1800","21-Glacial Sediments Thickness_Finland_yr 1-1800","22-Tree Rings_NW Siberia_yr 1-2000","23-Tree Rings_Siberia_yr 1-2000","24-Overall Average")
#CO2 data sources
#from
dfnames.CO2<-c("American Samoa_yr 1981-2017"="SAM", "Baja California_yr 1997-2009"="BCS","Baring Head, New Zealand_yr 1977-2017"="NZD","Christmas Island_yr 1974-2015"="CHR", "Mauna Loa Observatory, Hawaii_yr 1958-2017"="MLO", "Pt. Barrow, Alaska_yr 1974-2017"="PTB", "South Pole_yr 1957-2016"="SPO","Ice Core Data_yr 13-1957"="ice")
# Define UI for application that draws a histogram
ui <- fluidPage(
#tags$head(tags$style(type="text/css","#map img {max-width: 400%")),
# Application title
titlePanel(windowTitle="SeeClimate",h1("SeeClimate: Exploring Long-Term Climate Change Datasets",style="font-family: 'Courier New';color: #444444;")),
p("Choose a dataset and start exploring!",style="font-family: 'Courier New';color: #444444;"),
tabsetPanel(
##########
### Temp Panel
tabPanel("Temperature",
# Sidebar with a slider input for number of bins
sidebarLayout(
sidebarPanel(
selectInput("datachoice","Choose Temperature Dataset(s)",dfnames,multiple=T,selected="") ,
radioButtons("whatplot","What to Plot?",c("Points","Smoother","Points + Smoother"),"Points") ,
checkboxInput("locReg","Fit A Line?",FALSE),
conditionalPanel("input.locReg",
numericInput(inputId="Tmin",label=("Minimum Year for Line"),min=temprangeyrs[1],max=temprangeyrs[2],value=temprangeyrs[1],step=1,width="50%"),
numericInput(inputId="Tmax",label=("Maximum Year for Line"),min=temprangeyrs[1],max=temprangeyrs[2],value=temprangeyrs[2],step=1,width="50%"),
DT::dataTableOutput("lineEq")) ),
# Show a plot of the generated distribution
mainPanel(fluidRow(
plotOutput("tempgraf")
))
)#end sidebarLayout
),#end tabPanel
#####################
#CO2 Panel
tabPanel("CO2",
# Sidebar with a slider input for number of bins
sidebarLayout(
sidebarPanel(
selectInput("datachoice.CO2","Choose CO2 Dataset(s)",dfnames.CO2,multiple=T,selected="") ,
radioButtons("whatplot.CO2","What to Plot?",c("Points","Smoother","Points + Smoother"),"Points") ,
checkboxInput("locReg_CO2","Fit A Line?",FALSE),#.CO2 was throwing off the next line bc . = $ in .js
conditionalPanel("input.locReg_CO2",
# sliderInput(inputId="rng.CO2",label=("Year Range for Line"),min=0,max=2017,value=c(0,2017),timeFormat = "%Y",step=1),
numericInput(inputId="Cmin",label=("Minimum Year for Line"),min=CO2rangeyrs[1],max=CO2rangeyrs[2],value=CO2rangeyrs[1],step=1,width="50%"),
numericInput(inputId="Cmax",label=("Maximum Year for Line"),min=CO2rangeyrs[1],max=CO2rangeyrs[2],value=CO2rangeyrs[2],step=1,width="50%"),
DT::dataTableOutput("lineEq.CO2")) ),
# Show a plot of the generated distribution
mainPanel(fluidRow(
plotOutput("CO2graf"),
HTML("<br><br>"),
column(3,imageOutput("map"))
))
)#end sidebarLayout
)#end tabPanel
)#end tabsetpanel
)#End fluidPage
#SSSSSSSSSSSSSSSSSSSSSSSSSSSSSS
## SERVER SIDE
server <- function(input, output) {
#Watch user range values (for local regression)
vals<-reactiveValues()
observe(if(is.null(input$datachoice)){vals$usrdf_melt<-temp;vals$colindx<-"";vals$df.rng<-temp
}else{
vals$echo<-T
vals$colindx<-as.numeric(sort(gsub("-(.+)","",input$datachoice)))+1
vals$usrdf_melt<-melt(temp[,c(1,vals$colindx)],value.name="Temp",id="Year",variable.name="Dataset" )
vals$df.rng<-subset(vals$usrdf_melt,Year>=input$Tmin&Year<=input$Tmax)
})
#Temp plot
output$tempgraf <- renderPlot({
if(is.null(input$datachoice)){ggplot(data.frame())+geom_blank()+theme_bw()}
else{ #Begin BIG ELSE
#Global plot params (before plotting)
g<-ggplot(vals$usrdf_melt,aes(x=Year,y=Temp,col=Dataset))+theme_linedraw()+xlim(0,2000)+theme(axis.text=element_text(size=13),axis.title=element_text(size=18,face="bold"))+ylab("Temperature Anomoly (ºC)")+geom_hline(yintercept=0,col="gray60",linetype="dashed")+annotate("text",x=2,y=0.15,label="Average Temp for 980-1800",col="gray60",hjust=0)
# How to Plot (Radio Buttons)
if(input$whatplot=="Points"){
G<-g+geom_point()
}else{if(input$whatplot=="Smoother"){
G<-g+geom_smooth(method="loess")
}else{
G<-g+geom_point()+geom_smooth(se=F,method="loess")} }
G
# # Fitting a line
if(input$locReg==T){
G<-G+geom_smooth(method="lm",data=vals$df.rng,se=F,size=3)
G
}else{G}
}#end BIG ELSE
})#End renderPlot
#Output data table
output$lineEq<- DT::renderDataTable(
if(input$locReg==F){data.frame()
}else{
datasets<-unique(vals$df.rng$Dataset)
model<-data.frame(Dataset=datasets,t(sapply(datasets,function(x){
coeffs<-coef(lm(Temp~Year,data=subset(vals$df.rng,Dataset==x)))
})))
names(model)[2:3]<-c("Intercept","Slope")
model<-format(model,digits=4,scientific=T)
},options=list(#iDisplayLength=5, # initial number of records
#aLengthMenu=c(5,10),# records/page options
bPaginate=F,#Don't paginate
bLengthChange=F, # show/hide records per page dropdown
bFilter=F, # global search box on/off
bInfo=F# information on/off (how many records filtered, etc)
))#End RenderDataTable
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#CO2 Plot
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Watch user range values (for local regression)
vals.CO2<-reactiveValues()
observe(if(is.null(input$datachoice.CO2)){vals.CO2$usrdf_melt<-CO2;vals.CO2$df.rng<-CO2
}else{
vals.CO2$usrdf_melt<-subset(CO2,Dataset%in%input$datachoice.CO2)
vals.CO2$df.rng<-subset(vals.CO2$usrdf_melt,Date2>=input$Cmin & Date2<=input$Cmax)
print(vals.CO2$df.rng)
}#end else
)#end observe
#Carbon Dioxide plot
output$CO2graf <- renderPlot({
if(is.null(input$datachoice.CO2)){ggplot(data.frame())+geom_blank()+theme_bw()}
else{ #Begin BIG ELSE
#Global plot params (before plotting)
g.CO2<-ggplot(vals.CO2$usrdf_melt,aes(x=Date2,y=CO2,col=Dataset))+theme_linedraw()+theme(axis.text=element_text(size=13),axis.title=element_text(size=18,face="bold"))+ylab(expression("CO"[2]*" Concentration (ppm)"))+xlab("Year")#+geom_hline(yintercept=0,col="gray60",linetype="dashed")+annotate("text",x=2,y=0.2,label="2k Year Average Temp",col="gray60",hjust=0)
# How to Plot (Radio Buttons)
if(input$whatplot.CO2=="Points"){
G.CO2<-g.CO2+geom_point()
}else{if(input$whatplot.CO2=="Smoother"){
G.CO2<-g.CO2+geom_smooth(method="loess")
}else{
G.CO2<-g.CO2+geom_point()+geom_smooth(se=F,method="loess")} }
G.CO2
# # Fitting a line
if(input$locReg_CO2==T){
G.CO2<-G.CO2+geom_smooth(method="lm",data=vals.CO2$df.rng,se=F,size=3)
G.CO2
}else{G.CO2}
}#end BIG ELSE
})#End renderPlot
#Output data table
output$lineEq.CO2<- DT::renderDataTable(
{datasets.CO2<-unique(vals.CO2$df.rng$Dataset)
model.CO2<-data.frame(Dataset=datasets.CO2,t(sapply(datasets.CO2,function(x){
coeffs.CO2<-coef(lm(CO2~Date2,data=subset(vals.CO2$df.rng,Dataset==x),na.action="na.omit"))
})))
names(model.CO2)[2:3]<-c("Intercept","Slope")
model.CO2<-format(model.CO2,digits=4,scientific=T)
},options=list(#iDisplayLength=5, # initial number of records
aLengthMenu=c(5,10),# records/page options
bPaginate=F,#Don't paginate
bLengthChange=F, # show/hide records per page dropdown
bFilter=F, # global search box on/off
bInfo=F# information on/off (how many records filtered, etc)
#aoColumnDefs = list(list(sWidth="300px", aTargets=c(list(0),list(1)))) # custom column size
))
output$map<-renderImage({return(list(src="images/SeeClimate_map.jpg", filetype = "image/jpeg",alt="Map of CO2 logger sites") )},deleteFile = F)
}#End Server
# Run the application
shinyApp(ui = ui, server = server)