Homework: Phorids {#hw-phorid}

Required Reading

This homework will prepare you to analyze the data from the Phorid lab. You should read over that the material to properly understand the data you'll be working with here. You will need to be familiar with the chapters \@ref(r-intro) \@ref(r-ggplot), \@ref(r-dplyr), and \@ref(r-stats-lm); additionally, you should read \@ref(r-stats-ancova)).

Objectives (and what's due)

Getting started

You should download the dataset phorid_data_f18.csv from Canvas and put it in your data folder

Begin your script with the following:

# Heterogeneity Lab Analysis
#### Setup ####
library(tidyverse)
theme_set(theme_classic()) # Removes gridlines from ggplot

# Data file locations: Change these when analyzing the current dataset
phorid_data <- read_csv("data/phorid_data_f18.csv")

Save the R file as R/phorid_homework.R.

The data

The columns of these data frames that are relevant are:

Standardizing ant counts

Since each bait attracts ants to a different degree, we want to standardize the ant counts to account for this. One way to do so is by calculating the mean number of ants at each for each experimental arena during the baseline period, then dividing the number of ants at other periods by this number.

baseline_means = phorid_data |> 
  # Only include rows with "Baseline" in timestep
  filter(str_detect(Time_Step, "Baseline")) |> 
  # group by arena
  group_by(Treatment, Team) |> 
  # Calculate means
  summarize(baseline_mean = mean(Number_Ants))
baseline_means

Now, we want to combine this mean with the observation period data. We'll use a join function for this, which is a useful way to combine datasets by value (instead of by row or column). We'll also do the standardization and change the treatment column to be more descriptive.

standardized_data = phorid_data |> 
  filter(Time >= 0) |> # Let's remove the first two baselines
  # Combine w/ baseline_means, matching up the Treatment & Team columns
  left_join(baseline_means, by = c("Treatment", "Team")) |>  # This adds the baseline_mean column
  # Standardize the data
  mutate(Relative_ant_activity = Number_Ants / baseline_mean,
         # Re-code the Treatment column to make it more self-explanatory in the figure legend
         Treatment = recode(Treatment, Control = "Phorids Absent", Experimental = "Phorids Present"))

Run ANCOVAS

You'll be running two ANCOVAs on these data; For the first, you'll be testing the effects of phorids on the change in relative ant activity over time. For the second, you'll be testing how phorids and relative temperature affect the number of ants. Follow the guide in the Section \@ref(r-stats-ancova) on ANCOVAs.

For each ANCOVA, include a figure (example below), the regression line/lines (depending on whether there is a significant interaction), the $R^2$, and the p-values of the main and interaction coefficients. You should also include biological interpretations.

standardized_data |> 
  ggplot(aes(x = Time, y = Relative_ant_activity, color = Treatment)) + 
  geom_point() + geom_smooth(method = 'lm', fill = alpha('grey80', .1)) + 
  scale_color_viridis_d(begin = .2 )


Christopher-Peterson/Bio373L-Book documentation built on Oct. 26, 2022, 8:36 a.m.