-
Notifications
You must be signed in to change notification settings - Fork 0
/
Q10.R
121 lines (105 loc) · 4.5 KB
/
Q10.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
#####
# N.D. McTigue, Q.A. Walker, and C.A. Currin 2021
# Refining estimates of greenhouse gas emissions from salt marsh “blue carbon” erosion and decomposition
# email: quentin.walker@noaa.gov, mctigue@utexas.edu
#####
##### Run this script second #####
# this script assumes that output from DecompExpt.R is in the global environment
# This script takes the summarized decomp expt data and calculates temp sensitivity
# for the shallow and deep depth horizons
# temperature sensitivity is measured with traditional Q10 and Q10q
##### Calculate Temperature Sensitivity #####
# load required packages
library(reshape2)
# load in function to propagate error
source(file.path(getwd(),"mutate_with_error.R"))
# Function that calculates the time where we estimate each group of bottles crossed the threshold
TimeAtGivenPortion <- function(Portion, BeforeXY, AfterXY){
m = (AfterXY[2]-BeforeXY[2])/(AfterXY[1]-BeforeXY[1]) #calculate slope (rise over run)
b = AfterXY[2]-m*AfterXY[1] #calculate the intercept by substituting the calculated slope into y=mx+b
Time = (Portion - b)/m #calculate the time the linear model intercepts the threshold value
return(Time) #return Time
}
## 'Traditional' Q10 ####
Q10 <- decompRate.summary %>%
dcast(day + Depth ~ Treatment) %>%
left_join(.,
decompRate %>%
group_by(day, Depth, Treatment) %>%
summarise(dSlope = sd(slope, na.rm = T)) %>%
dcast(day + Depth ~ Treatment),
suffix = c(".slope", ".sd"), by = c("day", "Depth")) %>%
rename("slope.20" = "IB 20.slope",
"dslope.20" = "IB 20.sd",
"slope.30" = "IB 30.slope",
"dslope.30" = "IB 30.sd") %>%
mutate_with_error(Q10 ~ slope.30/slope.20) %>%
ungroup() %>%
mutate(seQ10 = dQ10/sqrt(6)) %>%
select(day, Depth, dplyr::contains("Q"))
# Plot Q10 by day
ggplot(Q10, aes(day, Q10, color = Depth))+
geom_line()+
geom_errorbar(aes(min = Q10 - seQ10, max = Q10 + seQ10))+
geom_point()+
theme_bw()
#####
# Q10q
# Q10 at each nth percent of sediment C respired
#
# This method of calculating Q10 uses the ratio of time to respire a given portion of sediment C at temperatures 10 degrees apart
# rather than the ratio of rates at a the same time after experiment start.
# See Conant et al. 2008
###
for (q in seq(0, round(max(decomp.data$PercentCRespired), 2), by=0.01)) {
temp <- decomp.data %>%
filter(PercentCRespired <= q) %>%
group_by(Treatment, Depth, Bottle = Rep) %>%
summarize(PortionC = q,
TimeBefore = max(day, na.rm = T),
ValueBefore = max(PercentCRespired, na.rm = T))
temp <- decomp.data %>%
filter(PercentCRespired > q) %>%
group_by(Treatment, Depth, Bottle = Rep) %>%
summarize(PortionC = q,
TimeAfter = min(day, na.rm = T),
ValueAfter = min(PercentCRespired, na.rm = T)) %>%
left_join(temp, ., by = c("Treatment", "Depth", "Bottle", "PortionC"))
if(!exists("ElapsedTime")){
ElapsedTime <- temp
}else{
ElapsedTime <- bind_rows(ElapsedTime, temp)
}
}
for (i in 1:nrow(ElapsedTime)) {
ElapsedTime[i, "CalcTime"] <- with(ElapsedTime[i, ], TimeAtGivenPortion(PortionC, c(TimeBefore, ValueBefore), c(TimeAfter, ValueAfter)))
}
ElapsedTime <- ElapsedTime %>%
group_by(Treatment, Depth, Bottle) %>%
arrange(Treatment, Depth, Bottle, PortionC) %>%
mutate(ElapsedTime = CalcTime - lag(CalcTime, default = 0))
ElapsedTime.summary <- ElapsedTime %>%
group_by(PortionC, Depth, Treatment) %>%
summarize(mean = mean(ElapsedTime, na.rm = T),
sd = sd(ElapsedTime, na.rm = T),
N = n(),
se = sd/sqrt(N)) %>%
rename(ElapsedTime = mean) %>%
filter(PortionC != 0)
Q10q <- left_join(filter(ElapsedTime.summary, Treatment == "IB 20")[,c("PortionC", "Depth", "N", "ElapsedTime", "sd", "se")],
filter(ElapsedTime.summary, Treatment == "IB 30")[,c("PortionC", "Depth", "N", "ElapsedTime", "sd", "se")],
by = c("Depth", "PortionC"),
suffix = c(".20", ".30")) %>%
as_tibble() %>%
rename(dElapsedTime.30 = sd.30, dElapsedTime.20 = sd.20) %>%
mutate_with_error(Q10q ~ ElapsedTime.20/ElapsedTime.30) %>%
mutate(N = N.30 + N.20,
se = dQ10q / sqrt(N)) %>%
select("PortionC", "Depth", "Q10q", "sd" = "dQ10q", "N", "se")
# Plot the Q10-q by portion respired
filter(Q10q, PortionC<0.06) %>%
ggplot(aes(PortionC, Q10q, color = Depth))+
geom_line()+
geom_errorbar(aes(min = Q10q - se, max = Q10q + se))+
geom_point()+
theme_bw()