-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGAMs_Growth Rate.R
160 lines (116 loc) · 9.06 KB
/
GAMs_Growth Rate.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
### GAMs applied on netto-reproduction-rate, including explanatory variables one by one
library(mgcv)
AllMeans <- read.csv("AllMeans.csv")
#sink("GAM_results_RepRate.txt", type=c("output","message"))
###effect of population density (=Density-Dependence)
gam_dens <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") , data=AllMeans)
gam_dens <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)
# proving non-linear shape by glm-structure once linear one 2nd polynom
glm_dens <- gam(RepRateFall_mean ~ MDperKMsqFall_mean, data=AllMeans)#R² 0.124 Dev.expl=12.8%,AIC:284.6896
glm_dens_poly <- gam(RepRateFall_mean ~ MDperKMsqFall_mean + I(MDperKMsqFall_mean^2), data=AllMeans)#R² 0.201 Dev.expl=20.9%,AIC:268.161
summary(glm_dens_poly)
gam_denspred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean, macrounit=AllMeans$macrounit)
gam_denspred <- cbind(gam_denspred, predict(gam_dens, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit), type="response"))
# in order to display lines dataframe needs to be sorted
macrounits <- levels(AllMeans$macrounit)
par(mfrow=c(2,2))
for (i in 1:length(macrounits)){
cond = which(AllMeans$macrounit==macrounits[i])
ord <- order(gam_denspred[cond,1])
print(ord)
ord2 <- ord + cond[1] - 1
print(ord2)
d <- gam_denspred[ord2,]
plot(AllMeans$RepRateFall_mean[cond]~AllMeans$MDperKMsqFall_mean[cond], main=macrounits[i], type="p",cex=0.5,xlab="Observed Population Density",ylab="Observed Reproduction rate")
lines(d$fit~d$MDperKMsqFall_mean, lwd=1.2, col="red")
}
legend("topright", legend=c("Observed", "GAM"), col=c("black", "red"), lty=c(1,1))
title("Observed and Predicted Density Dependences GAM", outer=TRUE)
summary(gam_dens)
AIC(gam_dens)
plot(gam_dens)
par(oma=c(2,0,2,0))
gam.check(gam_dens)
###Effect of Average Minimum Winter Temperature
gam_temp <- gam(RepRateFall_mean ~ s(AvrgWinterMinTemp, bs="cs"), data=AllMeans)#1
gam_temp <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(AvrgWinterMinTemp, by=macrounit, bs="cs") + macrounit, data=AllMeans)#2
gam_temp <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") +s(AvrgWinterMinTemp, bs="cs") + macrounit, data=AllMeans)#3
g#am_temppred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean)
#gam_temppred <- cbind(gam_temppred, predict(gam_temp, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit), type="response"))
macrounitplots(glmobject = gam_temppred,xcol="AvrgWinterMinTemp",title="gam_temp fall - effect of Mean Winter Minimum Temperature",colour="red")
macrounitplots(glmobject = gam_temppred,title="gam_temp fall - effect of Mean Winter Minimum Temperature",colour="red")
summary(gam_temp)
AIC(gam_temp)
par(oma=c(2,0,2,0))
gam.check(gam_temp)
# Check Residuals for temporal autocorrelation
gam_tempres <- residuals(gam_temp, type = "deviance")
plot(gam_tempres ~AllMeans$MDperKMsqFall_mean[which(!is.na(AllMeans$RepRateFall_mean))]) #
acf(gam_tempres, na.action = na.pass,main = "Auto-correlation plot for residuals gam_temp fall")
###Effect of hunting Density on each macrounit
gam_hunt <- gam(RepRateFall_mean ~ s(HuntDen_All_mean, bs="cs"), data=AllMeans)#1
gam_hunt <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(HuntDen_All_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)#2
gam_hunt <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + s(HuntDen_All_mean, bs="cs") + macrounit, data=AllMeans)#3
gam_huntpred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean, macrounit=AllMeans$macrounit, HuntDen_All_mean=AllMeans$HuntDen_All_mean)
gam_huntpred <- cbind(gam_huntpred, predict(gam_hunt, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit, "HuntDen_All_mean"=AllMeans$HuntDen_All_mean), type="response"))
macrounitplots(glmobject = gam_huntpred,xcol="HuntDen_All_mean",title="gam_hunt fall - effect of Hunting Density",colour="red")
macrounitplots(glmobject = gam_huntpred,title="gam_hunt fall - effect of Hunting Density",colour="red")
summary(gam_hunt)
AIC(gam_hunt)
gam_huntres <- residuals(gam_hunt, type = "deviance")
plot(gam_huntres ~AllMeans$MDperKMsqFall_mean[which(!is.na(AllMeans$RepRateFall_mean))]) #
acf(gam_huntres, na.action = na.pass,main = "Auto-correlation plot for residuals gam_hunt fall")
gam.check(gam_hunt)
###Effect of Oil Well Density on each macrounit
gam_oil <- gam(RepRateFall_mean ~ s(WellDen_mean, bs="cs"), data=AllMeans)#1
gam_oil <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(WellDen_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)#2
gam_oil <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + s(WellDen_mean, bs="cs") + macrounit, data=AllMeans)#3
gam_oilpred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean, macrounit=AllMeans$macrounit, WellDen_meann=AllMeans$WellDen_mean)
gam_oilpred <- cbind(gam_oilpred, predict(gam_oil, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit, "WellDen_mean"=AllMeans$WellDen_mean), type="response"))
macrounitplots(glmobject = gam_oilpred,xcol="WellDen_mean",title="gam_oil fall - effect of Oil Well Density",colour="red")
macrounitplots(glmobject = gam_oilpred,title="gam_oil fall - effect of Oil Well Density",colour="red")
summary(gam_oil)
AIC(gam_oil)
gam_oilres <- residuals(gam_oil, type = "deviance")
plot(gam_oilres ~AllMeans$MDperKMsqFall_mean[which(!is.na(AllMeans$RepRateFall_mean))]) #
acf(gam_oilres, na.action = na.pass,main = "Auto-correlation plot for residuals Oil Well Density")
gam.check(gam_oil)
###Effect of Coyote Density on each macrounit
gam_coyote <- gam(RepRateFall_mean ~ s(CoyoteDen_mean, bs="cs"), data=AllMeans)
gam_coyote <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(CoyoteDen_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)
gam_coyote <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + s(CoyoteDen_mean, bs="cs") + macrounit, data=AllMeans)
gam_coyotepred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean, macrounit=AllMeans$macrounit, CoyoteDen_meann=AllMeans$CoyoteDen_mean)
gam_coyotepred <- cbind(gam_coyotepred, predict(gam_coyote, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit, "CoyoteDen_mean"=AllMeans$CoyoteDen_mean), type="response"))
macrounitplots(glmobject = gam_coyotepred,xcol="CoyoteDen_mean",title="gam_coyote fall - effect of Coyote Density",colour="red")
macrounitplots(glmobject = gam_coyotepred,title="gam_coyote fall - effect of Coyote Density",colour="red")
summary(gam_coyote)
AIC(gam_coyote)
gam_coyoteres <- residuals(gam_coyote, type = "deviance")
plot(gam_coyoteres ~AllMeans$MDperKMsqFall_mean[which(!is.na(AllMeans$RepRateFall_mean))]) #
acf(gam_coyoteres, na.action = na.pass,main = "Auto-correlation plot for residuals Coyote Density")
gam.check(gam_coyote)
###Effect of Woody Vegetation on each macrounit
gam_woodyveg <- gam(RepRateFall_mean ~ s(WoodyVeg_mean, bs="cs"), data=AllMeans)
gam_woodyveg <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(WoodyVeg_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)
gam_woodyveg <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + s(WoodyVeg_mean, bs="cs") + macrounit, data=AllMeans)
gam_woodyvegpred <- data.frame(MDperKMsqFall_mean=AllMeans$MDperKMsqFall_mean, macrounit=AllMeans$macrounit, WoodyVeg_meann=AllMeans$WoodyVeg_mean)
gam_woodyvegpred <- cbind(gam_woodyvegpred, predict(gam_woodyveg, se.fit=T, newdata=data.frame("MDperKMsqFall_mean"=AllMeans$MDperKMsqFall_mean, "macrounit"=AllMeans$macrounit, "WoodyVeg_mean"=AllMeans$WoodyVeg_mean), type="response"))
macrounitplots(glmobject = gam_woodyvegpred,xcol="WoodyVeg_mean",title="gam_woodyveg fall - effect of Woody Vegetation",colour="red")
macrounitplots(glmobject = gam_woodyvegpred,title="gam_woodyveg fall - effect of Woody Vegetation",colour="red")
summary(gam_woodyveg)
AIC(gam_woodyveg)
plot(gam_woodyveg)
gam_woodyvegres <- residuals(gam_woodyveg, type = "deviance")
plot(gam_woodyvegres ~AllMeans$MDperKMsqFall_mean[which(!is.na(AllMeans$RepRateFall_mean))]) #
acf(gam_woodyvegres, na.action = na.pass,main = "Auto-correlation plot for residuals Woody Vegetation")
gam.check(gam_woodyveg)
###Effect of Fawn:Female Ratio on each macrounit
gam_ffratio <- gam(RepRateFall_mean ~ s(FawnFemaleRatio_mean, bs="cs"), data=AllMeans)
gam_ffratio <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(FawnFemaleRatio_mean, by=macrounit, bs="cs") + macrounit, data=AllMeans)
gam_ffratio <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, by=macrounit, bs="cs") + s(FawnFemaleRatio_mean, bs="cs") + macrounit, data=AllMeans)
summary(gam_ffratio)
AIC(gam_ffratio)
#Combined model
gam_combine <- gam(RepRateFall_mean ~ s(MDperKMsqFall_mean, bs="cs") + s(AvrgWinterMinTemp, bs="cs") + s(HuntDen_All_mean, bs="cs") + s(WellDen_mean, bs="cs") + s(CoyoteDen_mean, bs="cs")+s(WoodyVeg_mean, bs="cs"), data=AllMeans)
summary(gam_combine)
AIC(gam_combine)