Redox Lab
Markdown Author: Jessie Bell
Download this Rmd: Top right corner → Code →
Download Rmd
1
Where might you expect to see the lowest and highest redox
values? Explain your answer.
I anticipated observing elevated glucose levels in the sediments
(~1-10 cm) due to the presence of rhizomes in the eelgrass. I thought
that with increased glucose concentration, deeper sediment layers would
exhibit the lowest redox values, as unused glucose would be pushed
further down. Conversely, I expected mudflats, devoid of glucose, to
display the highest redox values due to the absence of microbial
activity prompted by glucose availability.
However, the data revealed no statistically significant differences
among locations in terms of redox reactions. This lack of variance is
likely attributable to the limited number of measurements. With a more
extensive dataset, I think that my original hypotheses would have been
confirmed. Notably, the recorded values ranged from 249 mV at a depth of
15 cm in a mudflat to 165 mV at the same depth beneath Z.
japonica. All areas measured electron acceptors of both Manganese
III and Iron III.
2
Perform a 2 factor ANOVA (depth x habitat) to determine if
there is any significant depth or habitat effect. If there are
differences and, if you know how, use a post-hoc test (i.e. Bonferonni),
to detect differences between each combination of factors. You can also
use multiple t-tests instead of ANOVA, but beware of Type 1 errors. Show
you work.
The redox dataset collected by Dr. Rybczyk’s ESCI 522 course on May
9, 2024 at Padilla Bay Estuary shows no evidence that mean
reduction/oxidation (eH) differed among either of the 4 habitat types:
Mudflat 1 cm depth, Mudflat 15 cm depth, Z. japonica 1 cm
depth, and Z. japonica 15 cm depth (\(F_{1, 18}\) = 1.651, p>0.05).
All work can be found below.
redox2 <- read.csv("redox_take2.csv")
redox <- read.csv("redox.csv")
ggplot()+
geom_boxplot(redox, mapping=aes(Habitat, correctedEH, color=Habitat))
ggplot(redox2, aes(Habitat, correctedEH, color=Habitat))+
geom_boxplot()
Data Exploration
gt(redox)%>%
tab_options(table.font.size = px(10L))%>%
cols_label(
Habitat=md("**Habitat**"),
depth_cm = md("**Depth (cm)**"),
uncorrectedEH = md("**Uncorrected Eh**"),
correctedEH = md("**Corrected Eh**"))%>%
opt_table_font("Corbel")%>%
opt_interactive(
page_size_default = 5
)
Summary Statistics
mudflat <- subset(redox, Habitat=="Mudflat")
japonica <- subset(redox, Habitat=="Zostera japonica")
mudflat_surface <- subset(mudflat, depth_cm=="1")
mudflat_15 <- subset(mudflat, depth_cm=="15")
japonica_surface <- subset(japonica, depth_cm=="1")
japonica_15 <- subset(japonica, depth_cm=="15")
ms <- mean(mudflat_surface$correctedEH)
sems <- sd(mudflat_surface$correctedEH)/(sqrt(length(mudflat_surface$correctedEH)))
m15 <- mean(mudflat_15$correctedEH)
sem15 <- sd(mudflat_15$correctedEH)/(sqrt(length(mudflat_15$correctedEH)))
js <- mean(japonica_surface$correctedEH)
sejs <- sd(japonica_surface$correctedEH)/(sqrt(length(japonica_surface$correctedEH)))
j15 <- mean(japonica_15$correctedEH)
sej15 <- sd(japonica_15$correctedEH)/(sqrt(length(japonica_15$correctedEH)))
Mean <- rbind(ms, m15, js, j15)
sd <- rbind(sems, sem15, sejs, sej15)
Habitat <- cbind(c("Zostera japonica", "", "Mudflat", ""))
Depth <- cbind(c("1", "15", "1", "15"))
e_acceptor <- rbind("Fe +++", "Fe+++", "Fe+++", "Mn+++")
summarystats <- as.data.frame(cbind(Habitat, Depth, Mean, sd, e_acceptor))
summarystats <- type.convert(summarystats, as.is = TRUE)
colnames(summarystats) <- c("Habitat","Depth (cm)", "Mean Eh", "SE Eh", "e- Acceptor")
gt(summarystats)|>
tab_options(table.font.size = px(10L))%>%
opt_table_font("Corbel")%>%
opt_stylize(style=4)%>%
fmt_number(columns = where(is.numeric), n_sigfig = 3, drop_trailing_zeros = T)
| Habitat |
Depth (cm) |
Mean Eh |
SE Eh |
e- Acceptor |
| Zostera japonica |
1.00 |
189 |
33.9 |
Fe +++ |
|
15.0 |
165 |
45.1 |
Fe+++ |
| Mudflat |
1.00 |
205 |
38.4 |
Fe+++ |
|
15.0 |
249 |
25.5 |
Mn+++ |
Assumptions
Normality
Zostera japonica has a left skew and I attempted to do a
square root transformation on the data to no avail. I am assuming that
if we would have sampled more, our data would follow the assumption of
normality better. I think that the mudflat data looks
normal enough.
par(mfrow = c(1,2))
hist(mudflat$correctedEH, col="steelblue", main="Mudflat Eh", xlab="Oxidation Reduction Potential (Eh)")
hist((japonica$correctedEH), col="plum", main="Z. japonica Eh", xlab="Oxidation Reduction Potential (Eh)") #skewed left...might need to correct this.

Homoscedasticity
Data follows the rules and seems to have close to equal variance.
par(mfrow = c(1,2))
boxplot(mudflat$correctedEH, col="steelblue", main="Mudflat Eh", ylab="Oxidation Reduction Potential (Eh)")
boxplot(japonica$correctedEH, col="plum", main="Z. japonica Eh", ylab="Oxidation Reduction Potential (Eh)")

Two-way ANOVA
Statistical Hypotheses
\(H_0\): \(\mu_{mf1}\) = \(\mu_{mf15}\) = \(\mu_{zj1}\) = \(\mu_{zj15}\)
\(H_a\): At least one mean above is
not equal to the others.
\(\alpha=0.5\)
#with interaction
redox.aov.interaction <- aov(correctedEH ~Habitat*as.factor(depth_cm), data=redox)
summary(redox.aov.interaction)
## Df Sum Sq Mean Sq F value Pr(>F)
## Habitat 1 12149 12149 1.651 0.215
## as.factor(depth_cm) 1 519 519 0.070 0.794
## Habitat:as.factor(depth_cm) 1 6411 6411 0.871 0.363
## Residuals 18 132424 7357
#no interaction
redox.aov.nointeraction <- aov(correctedEH ~Habitat+ as.factor(depth_cm), data=redox)
summary(redox.aov.nointeraction)
## Df Sum Sq Mean Sq F value Pr(>F)
## Habitat 1 12149 12149 1.663 0.213
## as.factor(depth_cm) 1 519 519 0.071 0.793
## Residuals 19 138835 7307
The redox dataset collected by Dr. Rybczyk’s ESCI 522 course on May
9, 2024 at Padilla Bay Estuary shows no evidence that mean
reduction/oxidation (eH) differed among either of the 4 habitat types:
Mudflat 1 cm depth, Mudflat 15 cm depth, Z. japonica 1 cm
depth, and Z. japonica 15 cm depth (\(F_{1, 18}\) = 1.651, p>0.05).
T-test
I am using a one-sided two sample t-test because if we expect that
there is a higher EH in the mudflats, there is increased power and we
can assume that EH will be greater under the mudflats. Especially if our
goal is to determine whether eelgrass is better for redox reactions than
mudflats.
Statistical Hypotheses
## [1] 201.6818
\(H_0: \mu \leq 201.68\)
\(H_A: \mu > 201.68\)
## [1] 7673.764
var(japonica$correctedEH)
## [1] 6261.564
x = mudflat$correctedEH
y = japonica$correctedEH
t.test(x,
y,
alternative = "greater",
var.equal = F)
##
## Welch Two Sample t-test
##
## data: x and y
## t = -1.3205, df = 19.797, p-value = 0.8991
## alternative hypothesis: true difference in means is greater than 0
## 95 percent confidence interval:
## -108.4182 Inf
## sample estimates:
## mean of x mean of y
## 178.1818 225.1818
Again, we fail to reject \(H_0\) and
there is not enough evidence (\(t_{2,
19.8}\) = -1.3205; two-tailed P > 0.05) that the \(\mu\) mudflat is greater than \(H_0\): \(\mu\) = 201.68.
---
title: " "
output:
  html_document:
    toc: yes
    toc_float:
      collapsed: false
    highlight: zenburn
    code_download: true
    code_folding: hide
    css: style.css
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, warning = F, cache = T, size="small")
library(gstat)
library(sp)
library(gtExtras)
library(svglite)
library(ggplot2)
library(tidyverse)
library(terra)
library(tidyterra)
library(sf)
library(rspat)
library(stringr)
library(dplyr)
library(tmap)
library(gt)
```

## Redox Lab

<br>

**Markdown Author:** Jessie Bell

| 

**Download this Rmd:** Top right corner → Code → Download Rmd

## 1 

**Where might you expect to see the lowest and highest redox values?  Explain your answer.**

I anticipated observing elevated glucose levels in the sediments (~1-10 cm) due to the presence of rhizomes in the eelgrass. I thought that with increased glucose concentration, deeper sediment layers would exhibit the lowest redox values, as unused glucose would be pushed further down. Conversely, I expected mudflats, devoid of glucose, to display the highest redox values due to the absence of microbial activity prompted by glucose availability.

However, the data revealed no statistically significant differences among locations in terms of redox reactions. This lack of variance is likely attributable to the limited number of measurements. With a more extensive dataset, I think that my original hypotheses would have been confirmed. Notably, the recorded values ranged from 249 mV at a depth of 15 cm in a mudflat to 165 mV at the same depth beneath *Z. japonica*. All areas measured electron acceptors of both Manganese III and Iron III. 

 
## 2

**Perform a 2 factor ANOVA (depth x habitat) to determine if there is any significant depth or habitat effect.  If there are differences and, if you know how, use a post-hoc test (i.e. Bonferonni), to detect differences between each combination of factors.  You can also use multiple t-tests instead of ANOVA, but beware of Type 1 errors. Show you work.** 

The redox dataset collected by Dr. Rybczyk's ESCI 522 course on May 9, 2024 at Padilla Bay Estuary  shows no evidence that mean reduction/oxidation (eH) differed among either of the 4 habitat types: Mudflat 1 cm depth, Mudflat 15 cm depth, *Z. japonica* 1 cm depth, and *Z. japonica* 15 cm depth ($F_{1, 18}$ = 1.651, p>0.05). 

All work can be found below.

```{r fig, fig.cap="**Figure 1:** Showing redox (mV) for two habitat types, mudflat and eelgrass at Padilla Bay Estuary (5/9/24). A two sample t-test provides insufficient evidence that the mean redox values are different enough and we fail to reject H0 (t2,19.8 = -1.3205; two-tailed P > 0.05) that the μ mudflat is greater than H0: μ = 201.68."}

redox2 <- read.csv("redox_take2.csv")

redox <- read.csv("redox.csv")


ggplot()+
  geom_boxplot(redox, mapping=aes(Habitat, correctedEH, color=Habitat))

```

```{r anova, fig.cap="**Figure 2:** Showing redox (mV) for two habitat types and depths, mudflat and eelgrass at 1 cm and 15 cm for both at Padilla Bay Estuary (5/9/24). The redox dataset shows no evidence that mean reduction/oxidation (EH) differed among either of the 4 habitat types: Mudflat 1 cm depth, Mudflat 15 cm depth, *Z. japonica* 1 cm depth, and *Z. japonica* 15 cm depth ($F_{1, 18}$ = 1.651, p>0.05)."}

ggplot(redox2, aes(Habitat, correctedEH, color=Habitat))+
  geom_boxplot()
```

### Data Exploration

```{r data}


gt(redox)%>%
  tab_options(table.font.size = px(10L))%>%
  cols_label(
    Habitat=md("**Habitat**"),
    depth_cm = md("**Depth (cm)**"),
    uncorrectedEH = md("**Uncorrected Eh**"),
    correctedEH = md("**Corrected Eh**"))%>%
  opt_table_font("Corbel")%>%
  opt_interactive(
    page_size_default = 5 
  )

```

### Summary Statistics

```{r summary}
mudflat <- subset(redox, Habitat=="Mudflat")

japonica <- subset(redox, Habitat=="Zostera japonica")

mudflat_surface <- subset(mudflat, depth_cm=="1")
mudflat_15 <- subset(mudflat, depth_cm=="15")
japonica_surface <- subset(japonica, depth_cm=="1")
japonica_15 <- subset(japonica, depth_cm=="15")

ms <- mean(mudflat_surface$correctedEH)
sems <- sd(mudflat_surface$correctedEH)/(sqrt(length(mudflat_surface$correctedEH)))
m15 <- mean(mudflat_15$correctedEH)
sem15 <- sd(mudflat_15$correctedEH)/(sqrt(length(mudflat_15$correctedEH)))

js <- mean(japonica_surface$correctedEH)
sejs <- sd(japonica_surface$correctedEH)/(sqrt(length(japonica_surface$correctedEH)))
j15 <- mean(japonica_15$correctedEH)
sej15 <- sd(japonica_15$correctedEH)/(sqrt(length(japonica_15$correctedEH)))

Mean <- rbind(ms, m15, js, j15)
sd <- rbind(sems, sem15, sejs, sej15)
Habitat <- cbind(c("Zostera japonica", "", "Mudflat", ""))

Depth <- cbind(c("1", "15", "1", "15"))

e_acceptor <- rbind("Fe +++", "Fe+++", "Fe+++", "Mn+++")

summarystats <- as.data.frame(cbind(Habitat, Depth, Mean, sd, e_acceptor))
summarystats <- type.convert(summarystats, as.is = TRUE)

colnames(summarystats) <- c("Habitat","Depth (cm)", "Mean Eh", "SE Eh", "e- Acceptor")


gt(summarystats)|>
  tab_options(table.font.size = px(10L))%>%
  opt_table_font("Corbel")%>%
  opt_stylize(style=4)%>%
  fmt_number(columns = where(is.numeric), n_sigfig = 3, drop_trailing_zeros = T)


```

### Assumptions

#### Normality

*Zostera japonica* has a left skew and I attempted to do a square root transformation on the data to no avail. I am assuming that if we would have sampled more, our data would follow the assumption of normality better. I think that the ```mudflat``` data looks normal enough. 


```{r normality}

par(mfrow = c(1,2))


hist(mudflat$correctedEH, col="steelblue", main="Mudflat Eh", xlab="Oxidation Reduction Potential (Eh)")

hist((japonica$correctedEH), col="plum", main="Z. japonica Eh", xlab="Oxidation Reduction Potential (Eh)") #skewed left...might need to correct this. 



```

#### Homoscedasticity

Data follows the rules and seems to have close to equal variance. 

```{r homosced}

par(mfrow = c(1,2))

boxplot(mudflat$correctedEH, col="steelblue", main="Mudflat Eh", ylab="Oxidation Reduction Potential (Eh)")

boxplot(japonica$correctedEH, col="plum", main="Z. japonica Eh", ylab="Oxidation Reduction Potential (Eh)")
```


### Two-way ANOVA

#### Statistical Hypotheses

$H_0$: $\mu_{mf1}$ = $\mu_{mf15}$ = $\mu_{zj1}$ = $\mu_{zj15}$

$H_a$: At least one mean above is not equal to the others.

$\alpha=0.5$



```{r two way}
#with interaction
redox.aov.interaction <- aov(correctedEH ~Habitat*as.factor(depth_cm), data=redox)
summary(redox.aov.interaction)

#no interaction
redox.aov.nointeraction <- aov(correctedEH ~Habitat+ as.factor(depth_cm), data=redox)
summary(redox.aov.nointeraction)


```

The redox dataset collected by Dr. Rybczyk's ESCI 522 course on May 9, 2024 at Padilla Bay Estuary  shows no evidence that mean reduction/oxidation (eH) differed among either of the 4 habitat types: Mudflat 1 cm depth, Mudflat 15 cm depth, *Z. japonica* 1 cm depth, and *Z. japonica* 15 cm depth ($F_{1, 18}$ = 1.651, p>0.05).


### T-test

I am using a one-sided two sample t-test because if we expect that there is a higher EH in the mudflats, there is increased power and we can assume that EH will be greater under the mudflats. Especially if our goal is to determine whether eelgrass is better for redox reactions than mudflats.

#### Statistical Hypotheses

```{r mean}

mean(redox$correctedEH)

```


$H_0: \mu \leq 201.68$ 

$H_A: \mu >  201.68$

```{r ttest}
var(mudflat$correctedEH)
var(japonica$correctedEH)

x = mudflat$correctedEH
y = japonica$correctedEH
t.test(x, 
       y, 
       alternative = "greater",
       var.equal = F)

```

Again, we fail to reject $H_0$ and there is not enough evidence ($t_{2, 19.8}$ = -1.3205; two-tailed P > 0.05) that the $\mu$ mudflat is greater than $H_0$: $\mu$ = 201.68.


<div class="tocify-extend-page" data-unique="tocify-extend-page" style="height: 0;"></div>