-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsalmon.Rmd
60 lines (50 loc) · 1.71 KB
/
salmon.Rmd
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
```
#Set your working directory
setwd('~/Documents/GitHub/RWorkflow-NWFSC-2021/')
#setwd('C:Users/Eli.Holmes/Workshops/RWorkflow-NWFSC-2021/')
#-----Read in salmon data----
fil <- "data/salmon.csv"
saldat <- read.csv(fil)
colnames(saldat) <- c("year", "wild", "flow", "temp")
fil <- "steelhead.csv"
steeldat <- as.matrix(read.csv(fil))
#Create training and testing data frames
dat1 <- saldat[saldat$year<=2010,]
dat2 <- saldat[saldat$year>2010,]
# gam fit
library(mgcv)
fit1 <- gam(wild ~ s(flow), data=dat1)
fit2 <- lm(steeldat[1,1:30] ~ steeldat[2,1:30])
library(forecast)
dat <- dat1$wild
fit3 <- auto.arima(dat)
#Save data
save(fit1, fit2, fit3, file="Sim_6_5_2020_wild.RData") #save data
#Make some plots
plot(fit1)
plot(fit2)
pred1 <- predict(fit1, newdata=data.frame(dat2))
plot(dat1$year, dat1$wild, xlim=c(1980,2020), type="l")
lines(dat2$year, dat2$wild, col="blue")
lines(dat2$year, pred1, col="red", lty=2)
pred2 <- predict(fit2, newdata=data.frame(dat2))
plot(dat1$year, dat1$wild, xlim=c(1980,2020), type="l")
lines(dat2$year, dat2$wild, col="blue")
lines(dat2$year, pred2, col="red", lty=2)
pred3 <- forecast(fit3, h=9)
plot(dat1$year, dat1$wild, xlim=c(1980,2020), type="l")
lines(dat2$year, dat2$wild, col="blue")
lines(dat2$year, pred3$mean, col="red", lty=2)
```
Let's take the fitting lines and make a function.
```
fitfun <- function(x, max.train.year=2010, fun="gam", response.var="wild", covariate="flow"){
subx <- subset(x, year<max.train.year)
subx$resp <- subx[[response.var]]
subx$cov <- subx[[covariate]]
if(fun=="gam") fit <- mgcv::gam(resp ~ s(cov), data=subx)
if(fun=="lm") fit <- stats::lm(resp ~ cov, data=subx)
if(fun=="auto.arima") fit <- forecast::auto.arima(subx$resp)
return(fit)
}
```