-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain-int-tmax-GRSP.R
50 lines (44 loc) · 1.77 KB
/
main-int-tmax-GRSP.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
# main-int-tmax-GRSP.R: script to fit the maximum temperature interaction
# model for the Grasshopper Sparrow case study.
# Author: Jeffrey W. Doser
rm(list = ls())
library(spOccupancy)
# Load data ---------------------------------------------------------------
load("data/case-study-2/GRSP-spOcc-data.rda")
# Set values for running the model ----------------------------------------
n.batch <- 4000
n.burn <- 50000
n.thin <- 50
n.chains <- 3
# Restricting prior bound on phi
dist.bbs <- dist(data.GRSP$coords)
low.dist <- quantile(dist.bbs, .1)
high.dist <- quantile(dist.bbs, 0.99)
priors <- list(phi.unif = c(a = 3 / high.dist, b = 3 / low.dist))
tuning.list <- list(phi = c(0.5), rho = 0.5, sigma.sq = 1)
inits.list <- list(beta = 0, sigma.sq = 1)
out <- stPGOcc(occ.formula = ~ scale(grass.dev) + scale(crop.dev) +
scale(tmax) + I(scale(tmax)^2) +
scale(grass.mean) + scale(crop.mean) +
scale(grass.dev):scale(tmax) +
scale(crop.dev):scale(tmax),
det.formula = ~ scale(day) + I(scale(day)^2) +
factor(replicate) + (1 | year.det),
ar1 = TRUE,
data = data.GRSP,
n.batch = n.batch,
batch.length = 25,
priors = priors,
inits = inits.list,
accept.rate = 0.43,
cov.model = "exponential",
tuning = tuning.list,
n.omp.threads = 3,
verbose = TRUE,
NNGP = TRUE,
n.neighbors = 5,
n.report = 1,
n.burn = n.burn,
n.thin = n.thin,
n.chains = n.chains)
save(out, file = 'results/case-study-2/int-tmax-GRSP-model-results.rda')