Start set up
Install packages
#install.packages(c("tidyverse","lme4","emmeans","ggplot2","DescTools","gtable","cowplot","grid","MuMIn","data.table","here","optimx","DT"))
Load libraries
rm(list=ls())
library(tidyverse)
library(lme4)
library(emmeans)
library(ggplot2)
library(DescTools)
library(gtable)# grob plot for figure 2
library(cowplot)# grob plot for figure 2
library(grid)
library(MuMIn) #r.square
library(data.table) #list to dataframe
library(here)
library(optimx)
library(DHARMa)
library(DT)
Read functions
#relocate to empty area in the plot
shift_legend <- function(p){
# check if p is a valid object
if(!"gtable" %in% class(p)){
if("ggplot" %in% class(p)){
gp <- ggplotGrob(p) # convert to grob
} else {
message("This is neither a ggplot object nor a grob generated from ggplotGrob. Returning original plot.")
return(p)
}
} else {
gp <- p
}
# check for unfilled facet panels
facet.panels <- grep("^panel", gp[["layout"]][["name"]])
empty.facet.panels <- sapply(facet.panels, function(i) "zeroGrob" %in% class(gp[["grobs"]][[i]]))
empty.facet.panels <- facet.panels[empty.facet.panels]
if(length(empty.facet.panels) == 0){
message("There are no unfilled facet panels to shift legend into. Returning original plot.")
return(p)
}
# establish extent of unfilled facet panels (including any axis cells in between)
empty.facet.panels <- gp[["layout"]][empty.facet.panels, ]
empty.facet.panels <- list(min(empty.facet.panels[["t"]]), min(empty.facet.panels[["l"]]),
max(empty.facet.panels[["b"]]), max(empty.facet.panels[["r"]]))
names(empty.facet.panels) <- c("t", "l", "b", "r")
# extract legend & copy over to location of unfilled facet panels
guide.grob <- which(gp[["layout"]][["name"]] == "guide-box")
if(length(guide.grob) == 0){
message("There is no legend present. Returning original plot.")
return(p)
}
gp <- gtable_add_grob(x = gp,
grobs = gp[["grobs"]][[guide.grob]],
t = empty.facet.panels[["t"]],
l = empty.facet.panels[["l"]],
b = empty.facet.panels[["b"]],
r = empty.facet.panels[["r"]],
name = "new-guide-box")
# squash the original guide box's row / column (whichever applicable)
# & empty its cell
guide.grob <- gp[["layout"]][guide.grob, ]
if(guide.grob[["l"]] == guide.grob[["r"]]){
gp <- gtable_squash_cols(gp, cols = guide.grob[["l"]])
}
if(guide.grob[["t"]] == guide.grob[["b"]]){
gp <- gtable_squash_rows(gp, rows = guide.grob[["t"]])
}
gp <- gtable_remove_grobs(gp, "guide-box")
return(gp)
}
## plot with 95% CI using lmer objects
lmer.predict<-function(mod, newdat, se.mult, binom=NULL, poisson=NULL, glmmTMB=NULL){
if(glmmTMB==T){
pvar1 <- diag(as.matrix(newdat) %*% tcrossprod(vcov(mod)[[1]],as.matrix(newdat)))
newdat$y<- as.matrix(newdat) %*% fixef(mod)[[1]]}
else{
pvar1 <- diag(as.matrix(newdat) %*% tcrossprod(vcov(mod),as.matrix(newdat)))
newdat$y<- as.matrix(newdat) %*% fixef(mod)}
newdat <- data.frame(newdat, plo = newdat$y-(se.mult*sqrt(pvar1)), phi = newdat$y+(se.mult*sqrt(pvar1)))
if(binom==T) {
newdat$y<-plogis(newdat$y); newdat$plo<-plogis(newdat$plo); newdat$phi<-plogis(newdat$phi)
} else
if(poisson==T) {
newdat$y<-exp(newdat$y); newdat$plo<-exp(newdat$plo); newdat$phi<-exp(newdat$phi)
}
return(with(newdat, data.frame(y, phi, plo)))
}
plot.CI.func<- function(x.for.plot, pred, upper, lower, env.colour, env.trans=NA, line.colour, line.weight, line.type){
colour.rgb<-col2rgb(col=env.colour)
polygon.coords<-data.frame(rbind(cbind(x.for.plot[1], lower[1]),
cbind(x.for.plot, upper),
cbind(x.for.plot, lower)[rev(order(x.for.plot)),]))
names(polygon.coords)<-c("x", "y")
polygon(polygon.coords$x, polygon.coords$y, col=rgb(red=colour.rgb["red",],blue=colour.rgb["blue",], green=colour.rgb["green",] , alpha=env.trans, maxColorValue = 255), border=NA)
lines(x.for.plot, pred, col=line.colour, lwd=line.weight, lty=line.type)
}
seq.func2<-function(x)(seq(min(x, na.rm=T), max(x, na.rm=T), length.out=150))
seq.func<-function(x)(seq(min(x, na.rm=T), max(x, na.rm=T), length.out=100))
Germination of fresh seeds
Data showing mean germination percentages for fresh seed. Also in
Table S1-Germination of fresh seeds at 6 (41 days) and 8 (56 days)
weeks. Species in the Dark treatment received 2 weeks of light (56 days
germination) after the first 6 weeks of dark. Cabinet conditions were
night cycle 7 C° and daylight cycle 18 C°, 50% relative humidity
base<-read_csv(here("Data","baseline.csv"))%>%mutate(day_41.p=(day_41/25)*100,
day_56.p=(day_56/25)*100)%>%group_by(species,treatment)%>%summarise(mean_41_days=mean(day_41.p),
mean_56_days=mean(day_56.p))
DT::datatable(base,height=100,options=(list(scrollX=FALSE,scrollY=TRUE)))
Read data for cumulative germination curve for the main
experiment
plote<-read_csv(here("Data", "cumulative_curve.csv"))%>%rowid_to_column(var="plate")%>%pivot_longer(-(1:7),
names_to="time",values_to="germination_day",
values_transform = list(germination_day = as.numeric))%>%
mutate(total_nongerm=total_seeds_dish-germination_day)%>%mutate(time=as.numeric(time))%>%
separate_wider_delim(species, delim = ".",
names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)%>%
group_by(species_names,total_seeds,temp, time)%>%
summarise(count_germ=sum(germination_day))%>%mutate(cumulative_count=cumsum(count_germ),
cumulative_percentage=(cumulative_count/total_seeds)*100)
Plot cumulative germination curves
pdf(here("Outputs","FigureS1.pdf"), width = 15, height = 11)
plote%>%ggplot(aes(x=time,y = cumulative_percentage, group=temp),show.legend = FALSE)+
geom_point(aes(color=temp,shape=temp))+
geom_line(aes(color=temp))+
scale_colour_manual(name="Treatment", values=c("blue","red"))+
scale_shape_manual(name="Treatment", values=c(19,22))+
facet_wrap(~species_names,ncol=4)+scale_y_continuous(breaks = seq(0,100, by = 15))+
ylab("Cumulative Germination (%)") + xlab("Days")+
theme(panel.background = element_blank(),
panel.border = element_rect(colour = "grey", fill=NA, linewidth=1))+
theme(strip.text.x= element_text(size=rel(1.8), face="italic"),
axis.title.x=element_text(size = rel(1.5),vjust=1),
axis.title.y=element_text(size = rel(1.5),vjust=1),
axis.text = element_text(size = rel(1.2)),
legend.title =element_text(size = rel(1.8)),
legend.text =element_text(size = rel(1.8)),
legend.key.size = unit(1.5, "cm"))
dev.off()
## png
## 2
Figure_S1 Cumulative germination for 19 winter
annual species from the understory of a York-gum jam Mediterranean
woodland in Western Australia under two temperature treatments: Cold
(7/18 °C, 12/12h light/dark, 50% relative humidity) and Warm (7/24 °C,
12/12h light/dark, 50% relative humidity).
Q1 Do species differ in their germination responses to different
temperature and light regimes?
Read data for Q1/Q2
cue_dat<-read_csv(here("Data","germ_cue.csv"))%>%
mutate(total_nongerm=total_seeds_dish-germination_total,
prop_germ =germination_total/total_seeds_dish)%>%rowid_to_column(var="plate")# plate is an unique id for random effects
Model containing all interactions and additive fixed effects
gres_mod<-glmer(cbind(germination_total,total_nongerm)~temp*light*species+(1|plate),family=binomial,data=cue_dat)
#model run with convergence warning
Eliminate convergence warning by removing random effects.
gres_mod2<-glm(cbind(germination_total,total_nongerm)~temp*light*species,family=binomial,data=cue_dat)
Check gres_mod assumptions
simulationOutput <- simulateResiduals(fittedModel = gres_mod2, plot = F)
plot(simulationOutput) #no major problems

TableS2-Estimated marginal probabilities for the winter annuals in
this study.
emmean_mod<-as.data.frame(emmeans(gres_mod2, ~temp*light|species, type="response"))
emmean_mod[,4:8]<-round(emmean_mod[,4:8],3)
print(emmean_mod)
## species = Calandrinia.eremaea:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.010 0.010 Inf 0.001 0.068
## Warm Dark 0.000 0.000 Inf 0.000 1.000
## Cold Light 0.020 0.014 Inf 0.005 0.076
## Warm Light 0.020 0.014 Inf 0.005 0.076
##
## species = Calotis.hispidula:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.040 0.020 Inf 0.015 0.102
## Warm Dark 0.010 0.010 Inf 0.001 0.068
## Cold Light 0.160 0.037 Inf 0.100 0.245
## Warm Light 0.120 0.032 Inf 0.069 0.200
##
## species = Chthonocephalus.pseudevax:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.200 0.040 Inf 0.133 0.290
## Warm Dark 0.020 0.014 Inf 0.005 0.076
## Cold Light 0.260 0.044 Inf 0.184 0.355
## Warm Light 0.220 0.041 Inf 0.149 0.312
##
## species = Crassula.colorata:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.000 0.000 Inf 0.000 1.000
## Warm Dark 0.000 0.000 Inf 0.000 1.000
## Cold Light 0.556 0.050 Inf 0.457 0.650
## Warm Light 0.360 0.048 Inf 0.272 0.458
##
## species = Goodenia.berardiana:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.060 0.024 Inf 0.027 0.127
## Warm Dark 0.080 0.027 Inf 0.041 0.152
## Cold Light 0.130 0.034 Inf 0.077 0.211
## Warm Light 0.050 0.022 Inf 0.021 0.115
##
## species = Goodenia.rosea:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.050 0.022 Inf 0.021 0.115
## Warm Dark 0.070 0.026 Inf 0.034 0.140
## Cold Light 0.270 0.044 Inf 0.192 0.365
## Warm Light 0.090 0.029 Inf 0.047 0.164
##
## species = Hyalosperma.glutinosum:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.000 0.000 Inf 0.000 1.000
## Warm Dark 0.000 0.000 Inf 0.000 1.000
## Cold Light 0.040 0.020 Inf 0.015 0.102
## Warm Light 0.000 0.000 Inf 0.000 1.000
##
## species = Medicago.minima:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.130 0.034 Inf 0.077 0.211
## Warm Dark 0.160 0.037 Inf 0.100 0.245
## Cold Light 0.150 0.036 Inf 0.092 0.234
## Warm Light 0.150 0.036 Inf 0.092 0.234
##
## species = Monoculus.monstrosus:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.000 0.000 Inf 0.000 1.000
## Warm Dark 0.000 0.000 Inf 0.000 1.000
## Cold Light 0.000 0.000 Inf 0.000 1.000
## Warm Light 0.000 0.000 Inf 0.000 1.000
##
## species = Pentameris.airoides:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.190 0.039 Inf 0.125 0.279
## Warm Dark 0.130 0.034 Inf 0.077 0.211
## Cold Light 0.460 0.050 Inf 0.365 0.558
## Warm Light 0.420 0.049 Inf 0.327 0.519
##
## species = Plantago.debilis:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.040 0.020 Inf 0.015 0.102
## Warm Dark 0.000 0.000 Inf 0.000 1.000
## Cold Light 0.340 0.047 Inf 0.254 0.438
## Warm Light 0.130 0.034 Inf 0.077 0.211
##
## species = Podolepis.aristata:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.380 0.049 Inf 0.290 0.479
## Warm Dark 0.250 0.043 Inf 0.175 0.344
## Cold Light 0.930 0.026 Inf 0.860 0.966
## Warm Light 0.890 0.031 Inf 0.812 0.938
##
## species = Pogonolepis.muelleriana:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.100 0.030 Inf 0.055 0.176
## Warm Dark 0.070 0.026 Inf 0.034 0.140
## Cold Light 0.320 0.047 Inf 0.236 0.417
## Warm Light 0.160 0.037 Inf 0.100 0.245
##
## species = Ptilotus.gaudichaudii:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.033 0.023 Inf 0.008 0.124
## Warm Dark 0.017 0.017 Inf 0.002 0.109
## Cold Light 0.150 0.036 Inf 0.092 0.234
## Warm Light 0.130 0.034 Inf 0.077 0.211
##
## species = Spergula.arvensis:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.110 0.031 Inf 0.062 0.188
## Warm Dark 0.060 0.024 Inf 0.027 0.127
## Cold Light 0.230 0.042 Inf 0.158 0.322
## Warm Light 0.400 0.049 Inf 0.309 0.499
##
## species = Stenopetalum.filifolium:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.140 0.035 Inf 0.085 0.223
## Warm Dark 0.080 0.027 Inf 0.041 0.152
## Cold Light 0.330 0.047 Inf 0.245 0.428
## Warm Light 0.260 0.044 Inf 0.184 0.355
##
## species = Trachymene.cyanopetala:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.150 0.036 Inf 0.092 0.234
## Warm Dark 0.110 0.031 Inf 0.062 0.188
## Cold Light 0.620 0.049 Inf 0.521 0.710
## Warm Light 0.420 0.049 Inf 0.327 0.519
##
## species = Trachymene.ornata:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.000 0.000 Inf 0.000 1.000
## Warm Dark 0.040 0.020 Inf 0.015 0.102
## Cold Light 0.020 0.014 Inf 0.005 0.076
## Warm Light 0.010 0.010 Inf 0.001 0.068
##
## species = Waitzia.acuminata:
## temp light prob SE df asymp.LCL asymp.UCL
## Cold Dark 0.200 0.040 Inf 0.133 0.290
## Warm Dark 0.130 0.034 Inf 0.077 0.211
## Cold Light 0.680 0.047 Inf 0.583 0.764
## Warm Light 0.690 0.046 Inf 0.593 0.773
##
## Confidence level used: 0.95
## Intervals are back-transformed from the logit scale
Table S3- Within-species differences in the probability of
germination under two temperature regimes (Cold: 7/18 °C and Warm: 7/24
°C) and two light regimes (12h/12h light/dark or continuous dark).
Significant differences (p ≤ 0.05) are in bold. For some species,
germination was insufficient to test any pairwise contrasts and for
others only those listed could be tested.
pa_mod<-as.data.frame(pairs(emmeans(gres_mod2, ~temp*light|species), type="response"))
DT::datatable(pa_mod,height=60,options=(list(scrollX=TRUE,scrollY=TRUE)))%>%formatRound(columns=c('odds.ratio', 'SE',"z.ratio","p.value"), digits=3)
Data for plotting
plot_box<-cue_dat%>%mutate(percent_germ=(germination_total/total_seeds_dish)*100)%>%
unite("Treatment", temp,light,sep= "+",remove=F)%>%unite("id",Treatment,species,remove=F)%>%
group_by(species, Treatment,dish)%>%
separate_wider_delim(species, delim = ".",
names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)
prob<-emmean_mod%>%
unite("Treatment",temp,light, sep= "+", remove=F)%>%
unite("id",Treatment,species, remove=F)%>%select(id,prob,species)
plot_point<-merge(plot_box,prob,by.x="id",by.y="id")
legend_point<-read_csv(here("Data","legend_point.csv"))%>%separate_wider_delim(species, delim = ".",
names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)
Plotting germination responses to experimental treatments
p1.2<-ggplot(plot_point,aes(x=Treatment,y=percent_germ,fill=Treatment))+geom_jitter(aes(color=Treatment),size=12,width=0.3,height=0.5)+
scale_fill_manual(values =c("Cold+Dark"="#1E88E5","Cold+Light"="#B8E0D9","Warm+Dark"= "#D81B60","Warm+Light"="#FFC107"))+
scale_color_manual(values =c("Cold+Dark"="#1E88E5","Cold+Light"="#B8E0D9","Warm+Dark"= "#D81B60","Warm+Light"="#FFC107"))+
scale_y_continuous(limits=c(0,110), breaks=c(0,20,40,60,80,100),
name="Probability of germination (%)")+
geom_point(mapping=aes(x=Treatment, y=prob*100, group=Treatment), size=14, shape=23, colour="black")+facet_wrap(.~species_names,ncol=5)+
theme(panel.background = element_blank(),
panel.border = element_rect(colour = "grey", fill=NA, linewidth=1))+
theme(axis.title.x=element_blank(),
axis.text.x=element_blank(),
axis.ticks.x=element_blank())+
theme(strip.text.x= element_text(size=rel(6), face="italic"),
plot.title = element_text(size = rel(5),color="black"),
axis.title.y=element_text(size = rel(6),vjust=1),
axis.text = element_text(size = rel(4)),
legend.title =element_text(size = rel(5)),
legend.text =element_text(size = rel(5)),
legend.key.size = unit(3, "cm"))+theme(plot.margin=unit(c(1,1.5,1,1.5), 'cm'))+
geom_text(data=legend_point, aes(x=x, y=y, label=label),colour="black",size=17)
pdf(here("Outputs","Figure_3.pdf"), width = 51, height = 29, useDingbats=F)
grid.draw(shift_legend(p1.2))
dev.off()
## png
## 2
Figure_3 Estimated marginal means (EMMs) from a
binomial generalized linear mixed model containing all interactions
between treatments and species. This plot shows the response to each
treatment combination. Diamonds are mean estimated probabilities for 19
winter annuals in the study (Table S2). Probabilities were multiplied by
100 to be given in percentages. Points are observed mean germination
percentages for each petri dish. Points were jittered to show
overlapping values more clearly.
Mean germination under the preferred conditions.
#filter out species that did not germinate and treatments that decreased germination
germ_t2<-plot_point%>%dplyr::filter(species!="Calandrinia.eremaea",species!="Hyalosperma.glutinosum",species!="Monoculus.monstrosus",species!="Trachymene.ornata")%>%
dplyr::filter(id!="Cold+Dark_Calotis.hispidula",id!= "Warm+Dark_Calotis.hispidula")%>%
dplyr::filter(id!="Warm+Dark_Chthonocephalus.pseudevax")%>%
dplyr::filter(id!="Cold+Dark_Crassula.colorata",id!="Warm+Dark_Crassula.colorata",id!="Warm+Light_Crassula.colorata")%>%
dplyr::filter(id!="Warm+Light_Goodenia.rosea",id!="Cold+Dark_Goodenia.rosea",id!="Warm+Dark_Goodenia.rosea")%>%
dplyr::filter(id!="Cold+Dark_Pentameris.airoides",id!="Warm+Dark_Pentameris.airoides")%>%
dplyr::filter(id!="Warm+Light_Plantago.debilis",id!="Cold+Dark_Plantago.debilis",id!="Warm+Dark_Plantago.debilis")%>%
dplyr::filter(id!="Cold+Dark_Podolepis.aristata",id!="Warm+Dark_Podolepis.aristata")%>%
dplyr::filter(id!="Warm+Light_Pogonolepis.muelleriana",id!="Cold+Dark_Pogonolepis.muelleriana",id!="Warm+Dark_Pogonolepis.muelleriana")%>%
dplyr::filter(id!="Cold+Light_Spergula.arvensis",id!="Cold+Dark_Spergula.arvensis",id!="Warm+Dark_Spergula.arvensis")%>%
dplyr::filter(id!="Cold+Dark_Stenopetalum.filifolium",id!="Warm+Dark_Stenopetalum.filifolium")%>%
dplyr::filter(id!="Warm+Light_Trachymene.cyanopetala",id!="Cold+Dark_Trachymene.cyanopetala",id!="Warm+Dark_Trachymene.cyanopetala")%>%
dplyr::filter(id!="Cold+Dark_Waitzia.acuminata",id!="Warm+Dark_Waitzia.acuminata")%>%
dplyr::filter(id!="Cold+Dark_Ptilotus.gaudichaudii", id!="Warm+Dark_Ptilotus.gaudichaudii")%>%mutate(species=as.character(species))%>%
as.data.frame()
Summarize germination percentages for species in the treatment
combination with the highest germination
mean_germination<-t(as.matrix(tapply(germ_t2$percent_germ, germ_t2$species, mean)))
Range
apply(mean_germination,1,range)
## [,1]
## [1,] 8
## [2,] 91
Table 2 Mean germination percentages for species
under treatment combinations with the highest germination identified on
Figure 3.
mean_germination2<-as.data.frame(mean_germination)
mean_germination2<-mean_germination2%>%pivot_longer(cols=1:15,names_to="species",values_to="mean")%>%mutate(mean=round(mean,1))
print(mean_germination2)
## # A tibble: 15 × 2
## species mean
## <chr> <dbl>
## 1 Calotis.hispidula 14
## 2 Chthonocephalus.pseudevax 22.7
## 3 Crassula.colorata 55.4
## 4 Goodenia.berardiana 8
## 5 Goodenia.rosea 27
## 6 Medicago.minima 14.8
## 7 Pentameris.airoides 44
## 8 Plantago.debilis 34
## 9 Podolepis.aristata 91
## 10 Pogonolepis.muelleriana 32
## 11 Ptilotus.gaudichaudii 14
## 12 Spergula.arvensis 40
## 13 Stenopetalum.filifolium 29.5
## 14 Trachymene.cyanopetala 62
## 15 Waitzia.acuminata 68.5
Q2 Question 2: Do species’ germination responses to experimental
temperature and light regimes correspond to their microhabitat
associations in the field?
Extract species’ experimental responses to light and temperature
species_data<-data.frame(species=unique(cue_dat$species))%>%
arrange(species)
temp<-emmean_mod[,4:8]
Calculate light and temperature germination responses
species_data$cold_light_effect<-temp[seq(3,76, 4),1] - temp[seq(1,76, 4),1]
species_data$warm_light_effect<-temp[seq(4,76, 4),1] - temp[seq(2,76, 4),1]
species_data$max_light_effect<- ifelse(species_data$cold_light_effect>species_data$warm_light_effect, species_data$cold_light_effect, species_data$warm_light_effect)
species_data$light_cool_effect<-temp[seq(3,76, 4),1] - temp[seq(4,76, 4),1]
species_data$dark_cool_effect<-temp[seq(1,76, 4),1] - temp[seq(2,76, 4),1]
species_data$max_cool_effect<- ifelse(species_data$light_cool_effect>species_data$dark_cool_effect, species_data$light_cool_effect, species_data$dark_cool_effect)
Read occurrence data
occ<-read_csv(here("Data","occurrence.csv"))%>%group_by(block)%>%mutate(mean_canopy=mean(canopy_cover))%>%ungroup()%>%mutate(std_mean_canopy= scale(mean_canopy)[,1],
std_sqrt_litter = scale(sqrt(litter_percent))[,1])%>%
left_join(species_data, by = "species")
Species with insufficient germination
insufficient_germ_species<-c("Calandrinia.eremaea","Hyalosperma.glutinosum","Monoculus.monstrosus","Trachymene.ornata")
Remove species with insufficient germination
occ_sufficient_germ<-occ%>%
filter(!species%in%insufficient_germ_species)
Do species’ experimental cool responses explain their occurrence
trends with shade?
cool_effect_mod<-glmer(occurrence~std_mean_canopy*max_cool_effect +(1|block)+(std_mean_canopy|species),data=occ_sufficient_germ, family="binomial")
summary(cool_effect_mod)
## Generalized linear mixed model fit by maximum likelihood (Laplace
## Approximation) [glmerMod]
## Family: binomial ( logit )
## Formula: occurrence ~ std_mean_canopy * max_cool_effect + (1 | block) +
## (std_mean_canopy | species)
## Data: occ_sufficient_germ
##
## AIC BIC logLik deviance df.resid
## 2174.3 2220.1 -1079.2 2158.3 2242
##
## Scaled residuals:
## Min 1Q Median 3Q Max
## -1.1491 -0.5162 -0.4108 -0.2838 3.8941
##
## Random effects:
## Groups Name Variance Std.Dev. Corr
## species (Intercept) 0.29148 0.5399
## std_mean_canopy 0.16519 0.4064 0.49
## block (Intercept) 0.07153 0.2675
## Number of obs: 2250, groups: species, 15; block, 10
##
## Fixed effects:
## Estimate Std. Error z value Pr(>|z|)
## (Intercept) -1.6612 0.2936 -5.658 1.53e-08 ***
## std_mean_canopy 0.0690 0.2383 0.290 0.772
## max_cool_effect 1.3765 2.1511 0.640 0.522
## std_mean_canopy:max_cool_effect -1.3077 1.6959 -0.771 0.441
## ---
## Signif. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
##
## Correlation of Fixed Effects:
## (Intr) std_m_ mx_cl_
## std_mn_cnpy 0.362
## max_cl_ffct -0.807 -0.322
## std_mn_c:__ -0.331 -0.788 0.418
Check cool_effect_mod assumptions
simulationOutput3 <- simulateResiduals(fittedModel = cool_effect_mod, plot = F)
plot(simulationOutput3) #no major problems

Do species’ experimental light responses explain their occurrence
trends with litter?
light_effect_mod<-glmer(occurrence~std_sqrt_litter*max_light_effect +(1|block)+(std_sqrt_litter|species),data=occ_sufficient_germ, family="binomial")
summary(light_effect_mod)
## Generalized linear mixed model fit by maximum likelihood (Laplace
## Approximation) [glmerMod]
## Family: binomial ( logit )
## Formula: occurrence ~ std_sqrt_litter * max_light_effect + (1 | block) +
## (std_sqrt_litter | species)
## Data: occ_sufficient_germ
##
## AIC BIC logLik deviance df.resid
## 2180.7 2226.4 -1082.3 2164.7 2242
##
## Scaled residuals:
## Min 1Q Median 3Q Max
## -1.2065 -0.5115 -0.4132 -0.2971 3.9239
##
## Random effects:
## Groups Name Variance Std.Dev. Corr
## species (Intercept) 0.29559 0.5437
## std_sqrt_litter 0.14614 0.3823 0.31
## block (Intercept) 0.05885 0.2426
## Number of obs: 2250, groups: species, 15; block, 10
##
## Fixed effects:
## Estimate Std. Error z value Pr(>|z|)
## (Intercept) -1.60405 0.29161 -5.501 3.78e-08 ***
## std_sqrt_litter 0.02155 0.21387 0.101 0.920
## max_light_effect 0.34604 0.81702 0.424 0.672
## std_sqrt_litter:max_light_effect -0.47689 0.61249 -0.779 0.436
## ---
## Signif. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
##
## Correlation of Fixed Effects:
## (Intr) std_s_ mx_lg_
## std_sqrt_lt 0.244
## mx_lght_ffc -0.811 -0.213
## std_sqr_:__ -0.207 -0.832 0.261
Check light_effect_mod assumptions
simulationOutput2 <- simulateResiduals(fittedModel = light_effect_mod, plot = F)
plot(simulationOutput2) #no major problems

Occurrences explained by either canopy cover or litter for each of
the 19 species
Probability of occurrence explained by litter cover
Models in a loop. One model for each species
species_names1<-sort(unique(occ$species))
litter_dat<-data.frame(species=species_names1,
intercept=vector(mode="numeric",length=length(species_names1)),
std_intercept=vector(mode="numeric",length=length(species_names1)),
z_intercept=vector(mode="numeric",length=length(species_names1)),
pvalue_intercept=vector(mode="numeric",length=length(species_names1)),
coef_litter=vector(mode="numeric",length=length(species_names1)),
std_litter=vector(mode="numeric",length=length(species_names1)),
z_litter=vector(mode="numeric",length=length(species_names1)),
pvalue_litter=vector(mode="numeric",length=length(species_names1)),
CI_2.5=vector(mode="numeric",length=length(species_names1)),
CI_97.5=vector(mode="numeric",length=length(species_names1)),
block_intercept=vector(mode="numeric",length=length(species_names1)),
r2_marginal=vector(mode="numeric",length=length(species_names1)),
r2_conditional=vector(mode="numeric",length=length(species_names1)))
spec_mod.2<-list()
loop_pred_litter<-list()
spec_datlitter_list<-list()
x_litter_list<-list()
for (i in 1:length(species_names1)){
spec_data<-subset(occ, species==species_names1[i])
spec_datlitter_list[[i]]<-subset(occ, species==species_names1[i])
spec_mod.2[[i]]<-glmer(occurrence ~ std_sqrt_litter+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
mood<-glmer(occurrence ~ std_sqrt_litter+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
summar<-summary(mood)
litter_dat$intercept[i]<-round(summar$coefficients[1,1],digits=4)#intercept
litter_dat$std_intercept[i]<-round(summar$coefficients[1,2], digits=4)#std_intercept
litter_dat$pvalue_intercept[i]<-round(summar$coefficients[1,4],digits=4)#p-value_intercept
litter_dat$coef_litter[i]<-round(summar$coefficients[2,1],digits=4)#coef_canopy
litter_dat$std_litter[i]<-round(summar$coefficients[2,2],digits=4)#std_canopy
litter_dat$pvalue_litter[i]<-round(summar$coefficients[2,4],digits=4)#pvalue_canopy
litter_dat$z_intercept[i]<-round(summar$coefficients[1,3],digits=4)#z_intercept
litter_dat$z_litter[i]<-round(summar$coefficients[2,3],digits=4)#z_canopy
litter_dat$block_intercept[i]<-summar$varcor$block[1,1]
confin<-confint(mood,method="Wald")
r2<-r.squaredGLMM(mood)
litter_dat$CI_2.5[i]<-confin[3]#lower confidence interval
litter_dat$CI_97.5[i]<-confin[6]#upper confidence interval
litter_dat$r2_marginal[i]<-r2[1]#theoretical R2
litter_dat$r2_conditional[i]<-r2[3]#theoretical R2
#data for plotting
loop_newdata<-data.frame(1, seq.func2(spec_data$std_sqrt_litter))
loop_pred_litter[[i]]<-lmer.predict(mod =mood,newdat = loop_newdata, se.mult = 1.96, binom=T, poisson = F, glmmTMB=F)
x_litter_list[[i]]<-data.frame(x_for_plot=seq.func2(spec_data$std_sqrt_litter))
}
Table s4 Probability of occurrence for the 19 winter annual species
along a gradient of litter cover in a York gum and jam woodland in
Western Australia. CI = confidence interval. Significant litter effects
(p<0.05) are in bold.
litter_table<-litter_dat%>%dplyr::select(species,intercept,pvalue_intercept,coef_litter,pvalue_litter,CI_2.5,CI_97.5,block_intercept, r2_marginal,r2_conditional)%>%mutate(intercept=round(intercept,3),
pvalue_intercept=round(pvalue_intercept,3),
coef_litter=round(coef_litter,3),
pvalue_litter=round(pvalue_litter,3),
CI_2.5=round(CI_2.5,2),
CI_97.5=round(CI_97.5,2), block_intercept=round(block_intercept,2),
r2_marginal=round(r2_marginal,2),
r2_conditional=round(r2_conditional,2))
DT::datatable(litter_table,height=100,options=(list(scrollX=TRUE,scrollY=TRUE)))
Plotting models for litter cover
####data from loop for litter plot
litter_list <- Map(as.data.frame,spec_datlitter_list)
spec_litterdat_plot<-rbindlist(litter_list)
list_litter_loop<-Map(as.data.frame,loop_pred_litter)
predict_litter_dat<-rbindlist(list_litter_loop)
list_litter_x<-Map(as.data.frame, x_litter_list)
x_litter_dat<-rbindlist(list_litter_x)
dat_litter_plot<-cbind(spec_litterdat_plot,predict_litter_dat,x_litter_dat)%>%
separate_wider_delim(species, delim = ".",
names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)%>%
mutate(line_color=if_else(species_names=="Chthonocephalus pseudevax","grey6","grey49"),
line_color=if_else(species_names=="Hyalosperma glutinosum","grey6",line_color),
line_color=if_else(species_names=="Podolepis aristata","grey6",line_color),
line_color=if_else(species_names=="Pogonolepis muelleriana","grey6",line_color),
line_color=if_else(species_names=="Medicago minima","grey6",line_color),
line_color=if_else(species_names=="Trachymene ornata","grey6",line_color),
ci_color=if_else(species_names=="Chthonocephalus pseudevax","grey26","grey74"),
ci_color=if_else(species_names=="Hyalosperma glutinosum","grey26",ci_color),
ci_color=if_else(species_names=="Podolepis aristata","grey26",ci_color),
ci_color=if_else(species_names=="Pogonolepis muelleriana","grey26",ci_color),
ci_color=if_else(species_names=="Medicago minima","grey26",ci_color),
ci_color=if_else(species_names=="Trachymene ornata","grey26",ci_color))
#Sup. litter plot#
litter_plot<-ggplot(dat_litter_plot, aes(x =std_sqrt_litter , y = occurrence)) +facet_wrap(.~species_names,ncol=4)+
geom_jitter(width=0.2, height=0.05, size=4, color=dat_litter_plot$line_color)+
geom_line(aes(x=x_for_plot, y=y, size=2), color=dat_litter_plot$line_color)+
labs(x="Litter cover (square root transformed and standardized)", y="Probability of occurrence")+
geom_ribbon(aes(x=x_for_plot, ymin =plo, ymax =phi, alpha = 0.05), fill=dat_litter_plot$ci_color, color=dat_litter_plot$ci_color)+
theme(panel.background = element_blank())+
theme(strip.text.x= element_text(size=rel(6), face="italic"),
plot.title = element_text(size = rel(5),color="black"),
axis.title.y=element_text(size = rel(5),vjust=1),
axis.title.x=element_text(size = rel(5)),
axis.text = element_text(size = rel(4)),
axis.line = element_line(size = 1, colour = "grey74", linetype=1),
axis.ticks = element_line(size = 1.5, colour = "grey74"),
axis.ticks.length = unit(.3, "cm"),
legend.position = "none")
## Warning: Using `size` aesthetic for lines was deprecated in ggplot2 3.4.0.
## ℹ Please use `linewidth` instead.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.
## Warning: The `size` argument of `element_line()` is deprecated as of ggplot2 3.4.0.
## ℹ Please use the `linewidth` argument instead.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.
pdf(here("Outputs","FigureS2.pdf"), width = 45, height = 35, useDingbats=F)
litter_plot
dev.off()
## png
## 2
FigureS2 Bivariate plots from GLMMs for
probability of occurrence in response to litter cover. Shaded areas
represent ± 95% confidence intervals. Points were jittered to show
overlapping values more clearly. Significant results are shown in dark
grey.
Probability of occurrence explained by canopy cover
Models in a loop. One model per species.
species_names<-sort(unique(occ$species))
canopy_dat<-data.frame(species=species_names,
intercept=vector(mode="numeric",length=length(species_names)),
std_intercept=vector(mode="numeric",length=length(species_names)),
z_intercept=vector(mode="numeric",length=length(species_names)),
pvalue_intercept=vector(mode="numeric",length=length(species_names)),
coef_canopy=vector(mode="numeric",length=length(species_names)),
std_canopy=vector(mode="numeric",length=length(species_names)),
z_canopy=vector(mode="numeric",length=length(species_names)),
pvalue_canopy=vector(mode="numeric",length=length(species_names)),
CI_2.5=vector(mode="numeric",length=length(species_names)),
CI_97.5=vector(mode="numeric",length=length(species_names)),
block_intercept=vector(mode="numeric",length=length(species_names)),
r2_marginal=vector(mode="numeric",length=length(species_names)),
r2_conditional=vector(mode="numeric",length=length(species_names)))
loop_pred_canopy<-list()
spec_mod.1<-list()
spec_datcanopy_list<-list()
x_canopy_list<-list()
for (i in 1:length(species_names)){
spec_data<-subset(occ, species==species_names[i])
spec_datcanopy_list[[i]]<-subset(occ, species==species_names[i])
spec_mod.1[[i]]<-glmer(occurrence ~ std_mean_canopy+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
mood<-glmer(occurrence ~ std_mean_canopy+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
summar<-summary(mood)
canopy_dat$intercept[i]<-round(summar$coefficients[1,1],digits=4)#intercept
canopy_dat$std_intercept[i]<-round(summar$coefficients[1,2], digits=4)#std_intercept
canopy_dat$pvalue_intercept[i]<-round(summar$coefficients[1,4],digits=4)#p-value_intercept
canopy_dat$coef_canopy[i]<-round(summar$coefficients[2,1],digits=4)#coef_canopy
canopy_dat$std_canopy[i]<-round(summar$coefficients[2,2],digits=4)#std_canopy
canopy_dat$pvalue_canopy[i]<-round(summar$coefficients[2,4],digits=4)#pvalue_canopy
canopy_dat$z_intercept[i]<-round(summar$coefficients[1,3],digits=4)#z_intercept
canopy_dat$z_canopy[i]<-round(summar$coefficients[2,3],digits=4)#z_canopy
canopy_dat$block_intercept[i]<-summar$varcor$block[1,1]
confin<-confint(mood,method="Wald")
r2<-r.squaredGLMM(mood)
canopy_dat$CI_2.5[i]<-confin[3]#lower confidence interval
canopy_dat$CI_97.5[i]<-confin[6]#upper confidence interval
canopy_dat$r2_marginal[i]<-r2[1]#theoretical R2
canopy_dat$r2_conditional[i]<-r2[3]#theoretical R2
#predict dat
loop_newdata<-data.frame(1, seq.func2(spec_data$std_mean_canopy))
loop_pred_canopy[[i]]<-lmer.predict(mod =mood,newdat = loop_newdata, se.mult = 1.96, binom=T, poisson = F, glmmTMB=F)
x_canopy_list[[i]]<-data.frame(x_for_plot=seq.func2(spec_data$std_mean_canopy))
}
Table S5 Probability of occurrence for the 19 winter annual species
along a gradient of canopy cover in a York gum and jam woodland in
Western Australia. CI = confidence interval.
canopy_table<-canopy_dat%>%dplyr::select(species,intercept,pvalue_intercept,coef_canopy,pvalue_canopy,CI_2.5,CI_97.5,block_intercept, r2_marginal,r2_conditional)%>%mutate(intercept=round(intercept,3),
pvalue_intercept=round(pvalue_intercept,3),
coef_canopy=round(coef_canopy,3),
pvalue_canopy=round(pvalue_canopy,3),
CI_2.5=round(CI_2.5,2),
CI_97.5=round(CI_97.5,2), block_intercept=round(block_intercept,2),
r2_marginal=round(r2_marginal,2),
r2_conditional=round(r2_conditional,2))
DT::datatable(canopy_table,height=100,options=(list(scrollX=TRUE,scrollY=TRUE)))
Plot models for canopy
cover
####data from loop for canopy plot
canopy_list <- Map(as.data.frame,spec_datcanopy_list)
spec_canopydat_plot<-rbindlist(canopy_list)
list_canopy_loop<-Map(as.data.frame,loop_pred_canopy)
predict_canopy_dat<-rbindlist(list_canopy_loop)
list_canopy_x<-Map(as.data.frame, x_canopy_list)
x_canopy_dat<-rbindlist(list_canopy_x)
dat_canopy_plot<-cbind(spec_canopydat_plot,predict_canopy_dat,x_canopy_dat)%>%
separate_wider_delim(species, delim = ".",
names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)
canopy_plot<-ggplot(dat_canopy_plot, aes(x =std_mean_canopy , y = occurrence)) +facet_wrap(.~species_names,ncol=4)+
geom_jitter(width=0.2, height=0.05, size=4, color="grey49")+
geom_line(aes(x=x_for_plot, y=y, size=2), color="grey49")+
labs(x="Mean canopy cover (standardized)", y="Probability of occurrence")+
geom_ribbon(aes(x=x_for_plot, ymin =plo, ymax =phi, alpha = 0.05), fill="grey74", color="grey74")+
theme(panel.background = element_blank())+
theme(strip.text.x= element_text(size=rel(6), face="italic"),
plot.title = element_text(size = rel(5),color="black"),
axis.title.y=element_text(size = rel(5),vjust=1),
axis.title.x=element_text(size = rel(5)),
axis.text = element_text(size = rel(4)),
axis.line = element_line(size = 1, colour = "grey74", linetype=1),
axis.ticks = element_line(size = 1.5, colour = "grey74"),
axis.ticks.length = unit(.3, "cm"),
legend.position = "none")
pdf(here("Outputs","FigureS3.pdf"), width = 45, height = 35, useDingbats=F)
canopy_plot
dev.off()
## png
## 2
FigureS3 Bivariate plots from GLMMs for
probability of occurrence in response to mean canopy cover. Shaded areas
represent ± 95% confidence intervals. Points were jittered to show
overlapping values more clearly. There were no significant
effects.
Seed mass supplementary analyses
Read seed mass data
seed_mass<-read_csv(here("data","seed_mass.csv"))%>%mutate(std_log_mean_sm=scale(log(mean_SM))[,1])
## Rows: 19 Columns: 2
## ── Column specification ────────────────────────────────────────────────────────
## Delimiter: ","
## chr (1): species
## dbl (1): mean_SM
##
## ℹ Use `spec()` to retrieve the full column specification for this data.
## ℹ Specify the column types or set `show_col_types = FALSE` to quiet this message.
Can seed mass explain species’ germination in response to light?
cue_dat2<-occ_sufficient_germ%>%left_join(seed_mass, by="species")
lightsm_dat<-cue_dat2%>%select(species,max_light_effect,std_log_mean_sm)%>%distinct()
lightsm_mod<-lm(max_light_effect~std_log_mean_sm,data=lightsm_dat)
summary(lightsm_mod)
##
## Call:
## lm(formula = max_light_effect ~ std_log_mean_sm, data = lightsm_dat)
##
## Residuals:
## Min 1Q Median 3Q Max
## -0.20321 -0.11696 -0.06376 0.07806 0.31585
##
## Coefficients:
## Estimate Std. Error t value Pr(>|t|)
## (Intercept) 0.27559 0.04583 6.014 4.35e-05 ***
## std_log_mean_sm -0.08864 0.04750 -1.866 0.0848 .
## ---
## Signif. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
##
## Residual standard error: 0.1757 on 13 degrees of freedom
## Multiple R-squared: 0.2113, Adjusted R-squared: 0.1506
## F-statistic: 3.482 on 1 and 13 DF, p-value: 0.08475
Model Assumptions
simulationOutput5 <- simulateResiduals(fittedModel = lightsm_mod, plot = F)
plot(simulationOutput5)

pdf(here("Outputs","Figure_S4.pdf"), width = 12, height = 8, useDingbats=F)
par(mar = c(8, 7, 5, 2),
bty="l")
Mgp(title= 4,
labels = 2)
with(lightsm_dat, plot(max_light_effect ~ std_log_mean_sm, cex=2,
ylab = "Relative germination response to light", xlab = "log Seed mass (Standardised)",
cex.axis=2.5, cex.lab=2.5, pch=16),ylim=c(-2,1))
new.dat<-data.frame(intercept=1,std_log_mean_sm=seq.func(lightsm_dat$std_log_mean_sm))
pvar1<-diag(as.matrix(new.dat) %*% tcrossprod(vcov(lightsm_mod), as.matrix(new.dat)))
y<- as.matrix(new.dat) %*% coef(lightsm_mod)
predicted.data<-data.frame(new.dat, plo = y-(1.96*sqrt(pvar1)), phi = y+(1.96*sqrt(pvar1)))
plot.CI.func(x.for.plot=seq.func(lightsm_dat$std_log_mean_sm),
y, predicted.data$phi,predicted.data$plo, env.colour="gray30", env.trans=40, line.colour="gray30", line.type=1, line.weight=3)
dev.off()
## png
## 2
FigureS4 Species’ germination responses to light
versus ln(seed mass) for 15 annual species with sufficient germination
to calculate germination responses. The line is from a simple linear
regression and the shaded envelope represents 95% confidence intervals.
Refer to Table S7 for the model summary table.
---
title: "CODE-Annual species’ experimental germination responses to light and temperature do not correspond with their microhabitat associations in the field. Journal of Vegetation Science"
author: "Isis A. da Silva, David J. Merritt, Todd E. Erickson, Margaret M. Mayfield, and John M. Dwyer"
date:  "`r format(Sys.time(), '%d %B, %Y')`"
output:
   html_document:
    code_download: true
    
    code_folding: hide
---

```{r setup, include=FALSE} 
knitr::opts_chunk$set(echo = TRUE)
devtools::source_gist("c83e078bf8c81b035e32c3fc0cf04ee8",
                      filename = 'render_toc.R')
```


```{r toc, echo=FALSE} 
render_toc("Germination_Occurrence.Rmd", toc_depth=2)
```


#  Start set up
Install packages
```{r}
#install.packages(c("tidyverse","lme4","emmeans","ggplot2","DescTools","gtable","cowplot","grid","MuMIn","data.table","here","optimx","DT"))
```




Load libraries
```{r,results="hide",message=FALSE,warning=FALSE}
rm(list=ls())
library(tidyverse)
library(lme4)
library(emmeans)
library(ggplot2)
library(DescTools)
library(gtable)# grob plot for figure 2
library(cowplot)# grob plot for figure 2
library(grid)
library(MuMIn) #r.square
library(data.table) #list to dataframe
library(here)
library(optimx)
library(DHARMa)
library(DT)
```

Read functions

```{r,results="hide",message=FALSE,warning=FALSE}
#relocate to empty area in the plot
shift_legend <- function(p){
  
  # check if p is a valid object
  if(!"gtable" %in% class(p)){
    if("ggplot" %in% class(p)){
      gp <- ggplotGrob(p) # convert to grob
    } else {
      message("This is neither a ggplot object nor a grob generated from ggplotGrob. Returning original plot.")
      return(p)
    }
  } else {
    gp <- p
  }
  
  # check for unfilled facet panels
  facet.panels <- grep("^panel", gp[["layout"]][["name"]])
  empty.facet.panels <- sapply(facet.panels, function(i) "zeroGrob" %in% class(gp[["grobs"]][[i]]))
  empty.facet.panels <- facet.panels[empty.facet.panels]
  if(length(empty.facet.panels) == 0){
    message("There are no unfilled facet panels to shift legend into. Returning original plot.")
    return(p)
  }
  
  # establish extent of unfilled facet panels (including any axis cells in between)
  empty.facet.panels <- gp[["layout"]][empty.facet.panels, ]
  empty.facet.panels <- list(min(empty.facet.panels[["t"]]), min(empty.facet.panels[["l"]]),
                             max(empty.facet.panels[["b"]]), max(empty.facet.panels[["r"]]))
  names(empty.facet.panels) <- c("t", "l", "b", "r")
  
  # extract legend & copy over to location of unfilled facet panels
  guide.grob <- which(gp[["layout"]][["name"]] == "guide-box")
  if(length(guide.grob) == 0){
    message("There is no legend present. Returning original plot.")
    return(p)
  }
  gp <- gtable_add_grob(x = gp,
                        grobs = gp[["grobs"]][[guide.grob]],
                        t = empty.facet.panels[["t"]],
                        l = empty.facet.panels[["l"]],
                        b = empty.facet.panels[["b"]],
                        r = empty.facet.panels[["r"]],
                        name = "new-guide-box")
  
  # squash the original guide box's row / column (whichever applicable)
  # & empty its cell
  guide.grob <- gp[["layout"]][guide.grob, ]
  if(guide.grob[["l"]] == guide.grob[["r"]]){
    gp <- gtable_squash_cols(gp, cols = guide.grob[["l"]])
  }
  if(guide.grob[["t"]] == guide.grob[["b"]]){
    gp <- gtable_squash_rows(gp, rows = guide.grob[["t"]])
  }
  gp <- gtable_remove_grobs(gp, "guide-box")
  
  return(gp)
}


## plot with 95% CI using lmer objects
lmer.predict<-function(mod, newdat, se.mult, binom=NULL, poisson=NULL, glmmTMB=NULL){
  if(glmmTMB==T){
    pvar1 <- diag(as.matrix(newdat) %*% tcrossprod(vcov(mod)[[1]],as.matrix(newdat)))
    newdat$y<- as.matrix(newdat) %*% fixef(mod)[[1]]}
  else{
    pvar1 <- diag(as.matrix(newdat) %*% tcrossprod(vcov(mod),as.matrix(newdat)))
    newdat$y<- as.matrix(newdat) %*% fixef(mod)}
  
  newdat <- data.frame(newdat, plo = newdat$y-(se.mult*sqrt(pvar1)), phi = newdat$y+(se.mult*sqrt(pvar1)))
  
  
  if(binom==T) {
    newdat$y<-plogis(newdat$y); newdat$plo<-plogis(newdat$plo); newdat$phi<-plogis(newdat$phi)
  } else 
    
    
    if(poisson==T) {
      newdat$y<-exp(newdat$y); newdat$plo<-exp(newdat$plo); newdat$phi<-exp(newdat$phi)
    } 
  return(with(newdat, data.frame(y, phi, plo)))
}




plot.CI.func<- function(x.for.plot, pred, upper, lower, env.colour, env.trans=NA, line.colour, line.weight, line.type){
  colour.rgb<-col2rgb(col=env.colour)  
  polygon.coords<-data.frame(rbind(cbind(x.for.plot[1], lower[1]), 
                                   cbind(x.for.plot, upper), 
                                   cbind(x.for.plot, lower)[rev(order(x.for.plot)),]))
  names(polygon.coords)<-c("x", "y")							
  polygon(polygon.coords$x, polygon.coords$y, col=rgb(red=colour.rgb["red",],blue=colour.rgb["blue",], green=colour.rgb["green",] , alpha=env.trans, maxColorValue = 255), border=NA)
  lines(x.for.plot, pred, col=line.colour, lwd=line.weight, lty=line.type)         
} 


seq.func2<-function(x)(seq(min(x, na.rm=T), max(x, na.rm=T), length.out=150))
seq.func<-function(x)(seq(min(x, na.rm=T), max(x, na.rm=T), length.out=100))
```





# Germination of fresh seeds

Data showing mean germination percentages for fresh seed. Also in Table S1-Germination of fresh seeds at 6 (41 days) and 8 (56 days) weeks. Species in the Dark treatment received 2 weeks of light (56 days germination) after the first 6 weeks of dark. Cabinet conditions were night cycle 7 C° and daylight cycle 18 C°, 50% relative humidity
```{r,message=FALSE,warning=FALSE}
base<-read_csv(here("Data","baseline.csv"))%>%mutate(day_41.p=(day_41/25)*100,
                                             day_56.p=(day_56/25)*100)%>%group_by(species,treatment)%>%summarise(mean_41_days=mean(day_41.p),
                                     mean_56_days=mean(day_56.p))
DT::datatable(base,height=100,options=(list(scrollX=FALSE,scrollY=TRUE)))
```
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>


Read data for cumulative germination curve for the main experiment

```{r,message=FALSE,warning=FALSE}
plote<-read_csv(here("Data", "cumulative_curve.csv"))%>%rowid_to_column(var="plate")%>%pivot_longer(-(1:7),
                                              names_to="time",values_to="germination_day",
                                              values_transform = list(germination_day = as.numeric))%>%
  mutate(total_nongerm=total_seeds_dish-germination_day)%>%mutate(time=as.numeric(time))%>%
  separate_wider_delim(species, delim = ".",
                       names = c("genus", "species.1")
  )%>%unite("species_names", genus,species.1, sep=" ", remove=T)%>%
group_by(species_names,total_seeds,temp, time)%>%
  summarise(count_germ=sum(germination_day))%>%mutate(cumulative_count=cumsum(count_germ),
                                                      cumulative_percentage=(cumulative_count/total_seeds)*100)

```


Plot cumulative germination curves

```{r}
pdf(here("Outputs","FigureS1.pdf"), width = 15, height = 11)

plote%>%ggplot(aes(x=time,y = cumulative_percentage, group=temp),show.legend = FALSE)+
  geom_point(aes(color=temp,shape=temp))+
  geom_line(aes(color=temp))+
  scale_colour_manual(name="Treatment", values=c("blue","red"))+
  scale_shape_manual(name="Treatment", values=c(19,22))+
  facet_wrap(~species_names,ncol=4)+scale_y_continuous(breaks = seq(0,100, by = 15))+
  ylab("Cumulative Germination (%)") + xlab("Days")+
  theme(panel.background = element_blank(),
        panel.border = element_rect(colour = "grey", fill=NA, linewidth=1))+
  theme(strip.text.x= element_text(size=rel(1.8), face="italic"),
        axis.title.x=element_text(size = rel(1.5),vjust=1),
        axis.title.y=element_text(size = rel(1.5),vjust=1),
        axis.text = element_text(size = rel(1.2)),
        legend.title =element_text(size = rel(1.8)),
        legend.text =element_text(size = rel(1.8)),
        legend.key.size = unit(1.5, "cm"))

dev.off()
```
![Figure_S1 Cumulative germination for 19 winter annual species from the understory of a York-gum jam Mediterranean woodland in Western Australia under two temperature treatments: Cold (7/18 °C, 12/12h light/dark, 50% relative humidity) and Warm (7/24 °C, 12/12h light/dark, 50% relative humidity).](Outputs/FigureS1.pdf){width=80% height=400}






# Q1 Do species differ in their germination responses to different temperature and light regimes?

Read data for Q1/Q2
```{r,message=FALSE,warning=FALSE}
cue_dat<-read_csv(here("Data","germ_cue.csv"))%>%
  mutate(total_nongerm=total_seeds_dish-germination_total,
        prop_germ =germination_total/total_seeds_dish)%>%rowid_to_column(var="plate")# plate is an unique id for random effects
```

Model containing all interactions and additive fixed effects

```{r,message=FALSE,warning=FALSE, error=FALSE, evaluate=FALSE}
gres_mod<-glmer(cbind(germination_total,total_nongerm)~temp*light*species+(1|plate),family=binomial,data=cue_dat)
#model run with convergence warning
```

Eliminate convergence warning by removing random effects.

```{r,message=FALSE,warning=FALSE, error=FALSE}
gres_mod2<-glm(cbind(germination_total,total_nongerm)~temp*light*species,family=binomial,data=cue_dat)
```

Check gres_mod assumptions

```{r}
simulationOutput <- simulateResiduals(fittedModel = gres_mod2, plot = F)

plot(simulationOutput) #no major problems

```

TableS2-Estimated marginal probabilities for the winter annuals in this study.
```{r,message=FALSE,warning=FALSE}
emmean_mod<-as.data.frame(emmeans(gres_mod2, ~temp*light|species, type="response"))

emmean_mod[,4:8]<-round(emmean_mod[,4:8],3)
print(emmean_mod)
```
<br>
<br>
<br>
<br>
<br>


Table S3- Within-species differences in the probability of germination under two temperature regimes (Cold: 7/18 °C and Warm: 7/24 °C) and two light regimes (12h/12h light/dark or continuous dark). Significant differences (p ≤ 0.05) are in bold. For some species, germination was insufficient to test any pairwise contrasts and for others only those listed could be tested.
```{r,message=FALSE,warning=FALSE}
pa_mod<-as.data.frame(pairs(emmeans(gres_mod2, ~temp*light|species), type="response"))


DT::datatable(pa_mod,height=60,options=(list(scrollX=TRUE,scrollY=TRUE)))%>%formatRound(columns=c('odds.ratio', 'SE',"z.ratio","p.value"), digits=3)
```
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
Data for plotting
```{r,message=FALSE,warning=FALSE}
plot_box<-cue_dat%>%mutate(percent_germ=(germination_total/total_seeds_dish)*100)%>%
  unite("Treatment", temp,light,sep= "+",remove=F)%>%unite("id",Treatment,species,remove=F)%>%
  group_by(species, Treatment,dish)%>%
  separate_wider_delim(species, delim = ".",
    names = c("genus", "species.1")
  )%>%unite("species_names", genus,species.1, sep=" ", remove=T)

prob<-emmean_mod%>%
  unite("Treatment",temp,light, sep= "+", remove=F)%>%
  unite("id",Treatment,species, remove=F)%>%select(id,prob,species)

plot_point<-merge(plot_box,prob,by.x="id",by.y="id")
legend_point<-read_csv(here("Data","legend_point.csv"))%>%separate_wider_delim(species, delim = ".",
                                                                        names = c("genus", "species.1")
)%>%unite("species_names", genus,species.1, sep=" ", remove=T)
```


Plotting germination responses to experimental treatments
```{r,message=FALSE,warning=FALSE}
p1.2<-ggplot(plot_point,aes(x=Treatment,y=percent_germ,fill=Treatment))+geom_jitter(aes(color=Treatment),size=12,width=0.3,height=0.5)+
  scale_fill_manual(values =c("Cold+Dark"="#1E88E5","Cold+Light"="#B8E0D9","Warm+Dark"= "#D81B60","Warm+Light"="#FFC107"))+
  scale_color_manual(values =c("Cold+Dark"="#1E88E5","Cold+Light"="#B8E0D9","Warm+Dark"= "#D81B60","Warm+Light"="#FFC107"))+
  scale_y_continuous(limits=c(0,110), breaks=c(0,20,40,60,80,100),
                     name="Probability of germination (%)")+
  geom_point(mapping=aes(x=Treatment, y=prob*100, group=Treatment), size=14, shape=23, colour="black")+facet_wrap(.~species_names,ncol=5)+
  theme(panel.background = element_blank(),
        panel.border = element_rect(colour = "grey", fill=NA, linewidth=1))+
  theme(axis.title.x=element_blank(),
        axis.text.x=element_blank(),
        axis.ticks.x=element_blank())+
  theme(strip.text.x= element_text(size=rel(6), face="italic"),
        plot.title = element_text(size = rel(5),color="black"),
        axis.title.y=element_text(size = rel(6),vjust=1),
        axis.text = element_text(size = rel(4)),
        legend.title =element_text(size = rel(5)),
        legend.text =element_text(size = rel(5)),
        legend.key.size = unit(3, "cm"))+theme(plot.margin=unit(c(1,1.5,1,1.5), 'cm'))+

  geom_text(data=legend_point, aes(x=x, y=y, label=label),colour="black",size=17)

pdf(here("Outputs","Figure_3.pdf"), width = 51, height = 29, useDingbats=F)
grid.draw(shift_legend(p1.2))
dev.off()
```


![Figure_3 Estimated marginal means (EMMs) from a binomial generalized linear mixed model containing all interactions between treatments and species. This plot shows the response to each treatment combination. Diamonds are mean estimated probabilities for 19 winter annuals in the study (Table S2). Probabilities were multiplied by 100 to be given in percentages. Points are observed mean germination percentages for each petri dish. Points were jittered to show overlapping values more clearly.](Outputs/Figure_3.pdf){width=100% height=600}

<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>

Mean germination under the preferred conditions. 

```{r}
#filter out species that did not germinate and treatments that decreased germination
germ_t2<-plot_point%>%dplyr::filter(species!="Calandrinia.eremaea",species!="Hyalosperma.glutinosum",species!="Monoculus.monstrosus",species!="Trachymene.ornata")%>%
  dplyr::filter(id!="Cold+Dark_Calotis.hispidula",id!= "Warm+Dark_Calotis.hispidula")%>%
  dplyr::filter(id!="Warm+Dark_Chthonocephalus.pseudevax")%>%
  dplyr::filter(id!="Cold+Dark_Crassula.colorata",id!="Warm+Dark_Crassula.colorata",id!="Warm+Light_Crassula.colorata")%>%
  dplyr::filter(id!="Warm+Light_Goodenia.rosea",id!="Cold+Dark_Goodenia.rosea",id!="Warm+Dark_Goodenia.rosea")%>%
  dplyr::filter(id!="Cold+Dark_Pentameris.airoides",id!="Warm+Dark_Pentameris.airoides")%>%
  dplyr::filter(id!="Warm+Light_Plantago.debilis",id!="Cold+Dark_Plantago.debilis",id!="Warm+Dark_Plantago.debilis")%>%
  dplyr::filter(id!="Cold+Dark_Podolepis.aristata",id!="Warm+Dark_Podolepis.aristata")%>%
  dplyr::filter(id!="Warm+Light_Pogonolepis.muelleriana",id!="Cold+Dark_Pogonolepis.muelleriana",id!="Warm+Dark_Pogonolepis.muelleriana")%>%
  dplyr::filter(id!="Cold+Light_Spergula.arvensis",id!="Cold+Dark_Spergula.arvensis",id!="Warm+Dark_Spergula.arvensis")%>%
  dplyr::filter(id!="Cold+Dark_Stenopetalum.filifolium",id!="Warm+Dark_Stenopetalum.filifolium")%>%
  dplyr::filter(id!="Warm+Light_Trachymene.cyanopetala",id!="Cold+Dark_Trachymene.cyanopetala",id!="Warm+Dark_Trachymene.cyanopetala")%>%
  dplyr::filter(id!="Cold+Dark_Waitzia.acuminata",id!="Warm+Dark_Waitzia.acuminata")%>%
  dplyr::filter(id!="Cold+Dark_Ptilotus.gaudichaudii", id!="Warm+Dark_Ptilotus.gaudichaudii")%>%mutate(species=as.character(species))%>%
                                                                                                         as.data.frame()
```

Summarize germination percentages for species in the treatment combination with the highest germination
```{r}
mean_germination<-t(as.matrix(tapply(germ_t2$percent_germ, germ_t2$species, mean)))
```
Range
```{r}
apply(mean_germination,1,range)
```
<br>
<br>
<br>
<br>
Table 2 Mean germination percentages for species under treatment combinations with the highest germination identified on Figure 3.
```{r}
mean_germination2<-as.data.frame(mean_germination) 
mean_germination2<-mean_germination2%>%pivot_longer(cols=1:15,names_to="species",values_to="mean")%>%mutate(mean=round(mean,1))
print(mean_germination2)
```
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>


# Q2 Question 2: Do species’ germination responses to experimental temperature and light regimes correspond to their microhabitat associations in the field?


Extract species' experimental responses to light and temperature

```{r}
species_data<-data.frame(species=unique(cue_dat$species))%>%
  arrange(species)

temp<-emmean_mod[,4:8]

```


Calculate light and temperature germination responses

```{r}

species_data$cold_light_effect<-temp[seq(3,76, 4),1] - temp[seq(1,76, 4),1]

species_data$warm_light_effect<-temp[seq(4,76, 4),1] - temp[seq(2,76, 4),1]
species_data$max_light_effect<- ifelse(species_data$cold_light_effect>species_data$warm_light_effect, species_data$cold_light_effect, species_data$warm_light_effect)

species_data$light_cool_effect<-temp[seq(3,76, 4),1] - temp[seq(4,76, 4),1]
species_data$dark_cool_effect<-temp[seq(1,76, 4),1] - temp[seq(2,76, 4),1]
species_data$max_cool_effect<- ifelse(species_data$light_cool_effect>species_data$dark_cool_effect, species_data$light_cool_effect, species_data$dark_cool_effect)
```



Read occurrence data
```{r,message=FALSE,warning=FALSE}
occ<-read_csv(here("Data","occurrence.csv"))%>%group_by(block)%>%mutate(mean_canopy=mean(canopy_cover))%>%ungroup()%>%mutate(std_mean_canopy= scale(mean_canopy)[,1],
         std_sqrt_litter = scale(sqrt(litter_percent))[,1])%>%
  left_join(species_data, by = "species")

```

Species with insufficient germination

```{r}
insufficient_germ_species<-c("Calandrinia.eremaea","Hyalosperma.glutinosum","Monoculus.monstrosus","Trachymene.ornata")

```

Remove species with insufficient germination
```{r}
occ_sufficient_germ<-occ%>%
  filter(!species%in%insufficient_germ_species)

```



## Do species' experimental cool responses explain their occurrence trends with shade?


```{r}
cool_effect_mod<-glmer(occurrence~std_mean_canopy*max_cool_effect +(1|block)+(std_mean_canopy|species),data=occ_sufficient_germ, family="binomial")
summary(cool_effect_mod)
```

Check cool_effect_mod assumptions
```{r}
simulationOutput3 <- simulateResiduals(fittedModel = cool_effect_mod, plot = F)

plot(simulationOutput3) #no major problems

```





## Do species' experimental light responses explain their occurrence trends with litter?

```{r}
light_effect_mod<-glmer(occurrence~std_sqrt_litter*max_light_effect +(1|block)+(std_sqrt_litter|species),data=occ_sufficient_germ, family="binomial")
summary(light_effect_mod)

```


Check light_effect_mod assumptions
```{r}
simulationOutput2 <- simulateResiduals(fittedModel = light_effect_mod, plot = F)

plot(simulationOutput2) #no major problems

```


## Occurrences explained by either canopy cover or litter for each of the 19 species




### Probability of occurrence explained by litter cover

Models in a loop. One model for each species
```{r,message=FALSE, warning=FALSE,error=FALSE}

species_names1<-sort(unique(occ$species))

litter_dat<-data.frame(species=species_names1,
                       intercept=vector(mode="numeric",length=length(species_names1)),
                       std_intercept=vector(mode="numeric",length=length(species_names1)),
                       z_intercept=vector(mode="numeric",length=length(species_names1)),
                       pvalue_intercept=vector(mode="numeric",length=length(species_names1)),
                       coef_litter=vector(mode="numeric",length=length(species_names1)),
                       std_litter=vector(mode="numeric",length=length(species_names1)),
                       z_litter=vector(mode="numeric",length=length(species_names1)),
                       pvalue_litter=vector(mode="numeric",length=length(species_names1)),
                       CI_2.5=vector(mode="numeric",length=length(species_names1)),
                       CI_97.5=vector(mode="numeric",length=length(species_names1)),
                       block_intercept=vector(mode="numeric",length=length(species_names1)),
                       r2_marginal=vector(mode="numeric",length=length(species_names1)),
                       r2_conditional=vector(mode="numeric",length=length(species_names1)))




spec_mod.2<-list()
loop_pred_litter<-list()
spec_datlitter_list<-list()
x_litter_list<-list()

for (i in 1:length(species_names1)){
  spec_data<-subset(occ, species==species_names1[i])
  spec_datlitter_list[[i]]<-subset(occ, species==species_names1[i])
  spec_mod.2[[i]]<-glmer(occurrence ~ std_sqrt_litter+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
  mood<-glmer(occurrence ~ std_sqrt_litter+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
  summar<-summary(mood)
  
  litter_dat$intercept[i]<-round(summar$coefficients[1,1],digits=4)#intercept
  litter_dat$std_intercept[i]<-round(summar$coefficients[1,2], digits=4)#std_intercept
  litter_dat$pvalue_intercept[i]<-round(summar$coefficients[1,4],digits=4)#p-value_intercept
  litter_dat$coef_litter[i]<-round(summar$coefficients[2,1],digits=4)#coef_canopy
  litter_dat$std_litter[i]<-round(summar$coefficients[2,2],digits=4)#std_canopy
  litter_dat$pvalue_litter[i]<-round(summar$coefficients[2,4],digits=4)#pvalue_canopy
  litter_dat$z_intercept[i]<-round(summar$coefficients[1,3],digits=4)#z_intercept
  litter_dat$z_litter[i]<-round(summar$coefficients[2,3],digits=4)#z_canopy
  litter_dat$block_intercept[i]<-summar$varcor$block[1,1]
  
  confin<-confint(mood,method="Wald")
  r2<-r.squaredGLMM(mood)
  
  litter_dat$CI_2.5[i]<-confin[3]#lower confidence interval
  litter_dat$CI_97.5[i]<-confin[6]#upper confidence interval
  litter_dat$r2_marginal[i]<-r2[1]#theoretical R2
  litter_dat$r2_conditional[i]<-r2[3]#theoretical R2
  
  
  
  #data for plotting
  
  loop_newdata<-data.frame(1, seq.func2(spec_data$std_sqrt_litter))
  
  loop_pred_litter[[i]]<-lmer.predict(mod =mood,newdat = loop_newdata, se.mult = 1.96, binom=T, poisson = F, glmmTMB=F)
  
  x_litter_list[[i]]<-data.frame(x_for_plot=seq.func2(spec_data$std_sqrt_litter))
  
}
```


Table s4 Probability of occurrence for the 19 winter annual species along a gradient of litter cover in a York gum and jam woodland in Western Australia. CI = confidence interval. Significant litter effects (p<0.05) are in bold.
```{r}
litter_table<-litter_dat%>%dplyr::select(species,intercept,pvalue_intercept,coef_litter,pvalue_litter,CI_2.5,CI_97.5,block_intercept, r2_marginal,r2_conditional)%>%mutate(intercept=round(intercept,3),
                                        pvalue_intercept=round(pvalue_intercept,3),
                                        coef_litter=round(coef_litter,3),
                                        pvalue_litter=round(pvalue_litter,3),
                                        CI_2.5=round(CI_2.5,2),
                                        CI_97.5=round(CI_97.5,2),                                                                                                          block_intercept=round(block_intercept,2),
                                        r2_marginal=round(r2_marginal,2),
                                        r2_conditional=round(r2_conditional,2))
DT::datatable(litter_table,height=100,options=(list(scrollX=TRUE,scrollY=TRUE)))
```
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>

Plotting models for litter cover
```{r}
####data from loop for litter plot

litter_list <- Map(as.data.frame,spec_datlitter_list)
spec_litterdat_plot<-rbindlist(litter_list)

list_litter_loop<-Map(as.data.frame,loop_pred_litter)
predict_litter_dat<-rbindlist(list_litter_loop)

list_litter_x<-Map(as.data.frame, x_litter_list)
x_litter_dat<-rbindlist(list_litter_x)

dat_litter_plot<-cbind(spec_litterdat_plot,predict_litter_dat,x_litter_dat)%>%
  separate_wider_delim(species, delim = ".",
                       names = c("genus", "species.1")
  )%>%unite("species_names", genus,species.1, sep=" ", remove=T)%>%
  mutate(line_color=if_else(species_names=="Chthonocephalus pseudevax","grey6","grey49"),
         line_color=if_else(species_names=="Hyalosperma glutinosum","grey6",line_color),
         line_color=if_else(species_names=="Podolepis aristata","grey6",line_color),
         line_color=if_else(species_names=="Pogonolepis muelleriana","grey6",line_color),
         line_color=if_else(species_names=="Medicago minima","grey6",line_color),
         line_color=if_else(species_names=="Trachymene ornata","grey6",line_color),
         
         
         ci_color=if_else(species_names=="Chthonocephalus pseudevax","grey26","grey74"),
         ci_color=if_else(species_names=="Hyalosperma glutinosum","grey26",ci_color),
         ci_color=if_else(species_names=="Podolepis aristata","grey26",ci_color),
         ci_color=if_else(species_names=="Pogonolepis muelleriana","grey26",ci_color),
         ci_color=if_else(species_names=="Medicago minima","grey26",ci_color),
         ci_color=if_else(species_names=="Trachymene ornata","grey26",ci_color))


#Sup. litter plot#


litter_plot<-ggplot(dat_litter_plot, aes(x =std_sqrt_litter , y = occurrence)) +facet_wrap(.~species_names,ncol=4)+
  geom_jitter(width=0.2, height=0.05, size=4, color=dat_litter_plot$line_color)+
  geom_line(aes(x=x_for_plot, y=y, size=2), color=dat_litter_plot$line_color)+
  labs(x="Litter cover (square root transformed and standardized)", y="Probability of occurrence")+
  
  geom_ribbon(aes(x=x_for_plot, ymin =plo, ymax =phi, alpha = 0.05), fill=dat_litter_plot$ci_color, color=dat_litter_plot$ci_color)+
  theme(panel.background = element_blank())+
  theme(strip.text.x= element_text(size=rel(6), face="italic"),
        plot.title = element_text(size = rel(5),color="black"),
        axis.title.y=element_text(size = rel(5),vjust=1),
        axis.title.x=element_text(size = rel(5)),
        axis.text = element_text(size = rel(4)),
        axis.line = element_line(size = 1, colour = "grey74", linetype=1),
        axis.ticks = element_line(size = 1.5, colour = "grey74"),
        axis.ticks.length = unit(.3, "cm"),
        legend.position = "none")


pdf(here("Outputs","FigureS2.pdf"), width = 45, height = 35, useDingbats=F)
litter_plot
dev.off()
```
![FigureS2 Bivariate plots from GLMMs for probability of occurrence in response to litter cover. Shaded areas represent ± 95% confidence intervals. Points were jittered to show overlapping values more clearly. Significant results are shown in dark grey.](Outputs/FigureS2.pdf){width=100% height=600}




### Probability of occurrence explained by canopy cover

Models in a loop. One model per species.
```{r, message=FALSE, warning=FALSE,error=FALSE}
species_names<-sort(unique(occ$species))

canopy_dat<-data.frame(species=species_names,
                 intercept=vector(mode="numeric",length=length(species_names)),
                 std_intercept=vector(mode="numeric",length=length(species_names)),
                 z_intercept=vector(mode="numeric",length=length(species_names)),
                 pvalue_intercept=vector(mode="numeric",length=length(species_names)),
                 coef_canopy=vector(mode="numeric",length=length(species_names)),
                 std_canopy=vector(mode="numeric",length=length(species_names)),
                 z_canopy=vector(mode="numeric",length=length(species_names)),
                 pvalue_canopy=vector(mode="numeric",length=length(species_names)),
                 CI_2.5=vector(mode="numeric",length=length(species_names)),
                 CI_97.5=vector(mode="numeric",length=length(species_names)),
                 block_intercept=vector(mode="numeric",length=length(species_names)),
                 r2_marginal=vector(mode="numeric",length=length(species_names)),
                 r2_conditional=vector(mode="numeric",length=length(species_names)))



loop_pred_canopy<-list()
spec_mod.1<-list()
spec_datcanopy_list<-list()
x_canopy_list<-list()

for (i in 1:length(species_names)){
  spec_data<-subset(occ, species==species_names[i])
  spec_datcanopy_list[[i]]<-subset(occ, species==species_names[i])
  spec_mod.1[[i]]<-glmer(occurrence ~ std_mean_canopy+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
  mood<-glmer(occurrence ~ std_mean_canopy+ (1|block), family=binomial(link="logit"), data = spec_data,control=glmerControl(optimizer ='optimx', optCtrl=list(method='L-BFGS-B')))
  summar<-summary(mood)

  canopy_dat$intercept[i]<-round(summar$coefficients[1,1],digits=4)#intercept
  canopy_dat$std_intercept[i]<-round(summar$coefficients[1,2], digits=4)#std_intercept
  canopy_dat$pvalue_intercept[i]<-round(summar$coefficients[1,4],digits=4)#p-value_intercept
  canopy_dat$coef_canopy[i]<-round(summar$coefficients[2,1],digits=4)#coef_canopy
  canopy_dat$std_canopy[i]<-round(summar$coefficients[2,2],digits=4)#std_canopy
  canopy_dat$pvalue_canopy[i]<-round(summar$coefficients[2,4],digits=4)#pvalue_canopy
  canopy_dat$z_intercept[i]<-round(summar$coefficients[1,3],digits=4)#z_intercept
  canopy_dat$z_canopy[i]<-round(summar$coefficients[2,3],digits=4)#z_canopy
  canopy_dat$block_intercept[i]<-summar$varcor$block[1,1]
  
  confin<-confint(mood,method="Wald")
  r2<-r.squaredGLMM(mood)
  
  canopy_dat$CI_2.5[i]<-confin[3]#lower confidence interval
  canopy_dat$CI_97.5[i]<-confin[6]#upper confidence interval
  canopy_dat$r2_marginal[i]<-r2[1]#theoretical R2
  canopy_dat$r2_conditional[i]<-r2[3]#theoretical R2
  
#predict dat
  
  loop_newdata<-data.frame(1, seq.func2(spec_data$std_mean_canopy))
  
  loop_pred_canopy[[i]]<-lmer.predict(mod =mood,newdat = loop_newdata, se.mult = 1.96, binom=T, poisson = F, glmmTMB=F)
  
  x_canopy_list[[i]]<-data.frame(x_for_plot=seq.func2(spec_data$std_mean_canopy))
  
  }

```
<br>
<br>
<br>
<br>
<br>


Table S5 Probability of occurrence for the 19 winter annual species along a gradient of canopy cover in a York gum and jam woodland in Western Australia. CI = confidence interval.  

```{r}
canopy_table<-canopy_dat%>%dplyr::select(species,intercept,pvalue_intercept,coef_canopy,pvalue_canopy,CI_2.5,CI_97.5,block_intercept, r2_marginal,r2_conditional)%>%mutate(intercept=round(intercept,3),
                                        pvalue_intercept=round(pvalue_intercept,3),
                                        coef_canopy=round(coef_canopy,3),
                                        pvalue_canopy=round(pvalue_canopy,3),
                                        CI_2.5=round(CI_2.5,2),
                                        CI_97.5=round(CI_97.5,2),                                                                                                          block_intercept=round(block_intercept,2),
                                        r2_marginal=round(r2_marginal,2),
                                        r2_conditional=round(r2_conditional,2))
DT::datatable(canopy_table,height=100,options=(list(scrollX=TRUE,scrollY=TRUE)))
```
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
Plot models for canopy cover 

```{r,message=FALSE, warning=FALSE}
####data from loop for canopy plot
canopy_list <- Map(as.data.frame,spec_datcanopy_list)
spec_canopydat_plot<-rbindlist(canopy_list)

list_canopy_loop<-Map(as.data.frame,loop_pred_canopy)
predict_canopy_dat<-rbindlist(list_canopy_loop)

list_canopy_x<-Map(as.data.frame, x_canopy_list)
x_canopy_dat<-rbindlist(list_canopy_x)

dat_canopy_plot<-cbind(spec_canopydat_plot,predict_canopy_dat,x_canopy_dat)%>%
  separate_wider_delim(species, delim = ".",
                       names = c("genus", "species.1")
  )%>%unite("species_names", genus,species.1, sep=" ", remove=T)


canopy_plot<-ggplot(dat_canopy_plot, aes(x =std_mean_canopy , y = occurrence)) +facet_wrap(.~species_names,ncol=4)+
  geom_jitter(width=0.2, height=0.05, size=4, color="grey49")+
  geom_line(aes(x=x_for_plot, y=y, size=2), color="grey49")+
   labs(x="Mean canopy cover (standardized)", y="Probability of occurrence")+
  
  geom_ribbon(aes(x=x_for_plot, ymin =plo, ymax =phi, alpha = 0.05), fill="grey74", color="grey74")+
  theme(panel.background = element_blank())+
  theme(strip.text.x= element_text(size=rel(6), face="italic"),
        plot.title = element_text(size = rel(5),color="black"),
        axis.title.y=element_text(size = rel(5),vjust=1),
        axis.title.x=element_text(size = rel(5)),
        axis.text = element_text(size = rel(4)),
        axis.line = element_line(size = 1, colour = "grey74", linetype=1),
        axis.ticks = element_line(size = 1.5, colour = "grey74"),
        axis.ticks.length = unit(.3, "cm"),
        legend.position = "none")


pdf(here("Outputs","FigureS3.pdf"), width = 45, height = 35, useDingbats=F)
canopy_plot
dev.off()
```
![FigureS3 Bivariate plots from GLMMs for probability of occurrence in response to mean canopy cover. Shaded areas represent ± 95% confidence intervals. Points were jittered to show overlapping values more clearly. There were no significant effects.](Outputs/FigureS3.pdf){width=100% height=600}



# Seed mass supplementary analyses

Read seed mass data

```{r}
seed_mass<-read_csv(here("data","seed_mass.csv"))%>%mutate(std_log_mean_sm=scale(log(mean_SM))[,1])
```

Can seed mass explain species' germination in response to light?


```{r}
cue_dat2<-occ_sufficient_germ%>%left_join(seed_mass, by="species")

lightsm_dat<-cue_dat2%>%select(species,max_light_effect,std_log_mean_sm)%>%distinct()

lightsm_mod<-lm(max_light_effect~std_log_mean_sm,data=lightsm_dat)

summary(lightsm_mod)
```


Model Assumptions
```{r, message=FALSE,warning=FALSE}
simulationOutput5 <- simulateResiduals(fittedModel = lightsm_mod, plot = F)

plot(simulationOutput5) 
```



```{r}

pdf(here("Outputs","Figure_S4.pdf"), width = 12, height = 8, useDingbats=F)

par(mar = c(8, 7, 5, 2),
    bty="l")
Mgp(title= 4,
      labels = 2)
with(lightsm_dat, plot(max_light_effect ~ std_log_mean_sm, cex=2,
                    ylab = "Relative germination response to light", xlab = "log Seed mass (Standardised)",
                    cex.axis=2.5, cex.lab=2.5, pch=16),ylim=c(-2,1))

new.dat<-data.frame(intercept=1,std_log_mean_sm=seq.func(lightsm_dat$std_log_mean_sm))

pvar1<-diag(as.matrix(new.dat) %*% tcrossprod(vcov(lightsm_mod), as.matrix(new.dat)))

y<- as.matrix(new.dat) %*% coef(lightsm_mod)

predicted.data<-data.frame(new.dat, plo = y-(1.96*sqrt(pvar1)), phi = y+(1.96*sqrt(pvar1)))

plot.CI.func(x.for.plot=seq.func(lightsm_dat$std_log_mean_sm),
             y, predicted.data$phi,predicted.data$plo, env.colour="gray30", env.trans=40, line.colour="gray30", line.type=1, line.weight=3)


dev.off()

```

![FigureS4 Species’ germination responses to light versus ln(seed mass) for 15 annual species with sufficient germination to calculate germination responses. The line is from a simple linear regression and the shaded envelope represents 95% confidence intervals. Refer to Table S7 for the model summary table.](Outputs/Figure_S4.pdf){width=100% height=600}



