Great job, Lillian! I did a bit of basic coding and data cleaning to
prep for our meeting tomorrow. Im going to share that with you. We can
adapt this in any way that you want, this was just to get us thinking
about your results. We will go over it line by line together as well.
Feel free to do more if you would like. Coding isnt really part of the
SMP, so it’s not something I make you do, but you should understand what
was done.
You should be really excited about these results because you didn’t
just show that bacteria become resistant… you actually captured how that
process happens over time. Your data clearly show that resistance
evolves in very different ways depending on the antibiotic. Ampicillin
resistance appeared almost immediately, jumping to very high levels,
while kanamycin resistance increased more gradually and was much more
variable. That contrast is not something everyone gets, and it points to
real biological differences in how these drugs interact with cells and
how bacteria adapt to them.
What makes your project especially strong is that all of your
measurements tell the same story from different angles. The MIC data,
growth scores, dose-response curves, and disk diffusion assays all line
up and reinforce each other, which is exactly what you want in a solid
scientific study. You also captured the process of adaptation, not just
the endpoint, which is a much deeper level of analysis. This puts you in
a great position to not only explain what happened, but to start asking
why it happened.
Data Cleansing
names(disc)
[1] "Timepoint" "Plate" "Disc" "Radius"
[5] "Radius.1"
Figure 1 (MOST IMPORTANT): Resistance Trajectories “Amp resistance
evolved extremely rapidly, exceeding our measurement range within one
week”
p1 <- ggplot(mic, aes(x = Week, y = `log2(MIC)`, color = `Culture`, group = `Culture`)) +
geom_line(linewidth = 1) +
geom_point(aes(shape = Censored), size = 3) +
scale_shape_manual(values = c(`FALSE` = 16, `TRUE` = 17)) +
labs(
title = "Resistance trajectories over time",
x = "Week",
y = expression(log[2]*"(MIC90, µg/mL)"),
color = "Culture",
shape = "At assay ceiling"
) +
theme_classic(base_size = 14)
p1

Figure 3: Growth Under Selection
p3 <- ggplot(pass, aes(x = Passage, y = Growth.Score, color = Antibiotic, group = Line)) +
geom_line(alpha = 0.8, linewidth = 0.9) +
geom_point(size = 2) +
labs(
title = "Growth scores during serial passaging",
x = "Passage",
y = "Growth score",
color = "Antibiotic"
) +
theme_classic(base_size = 14)
p3

Figure 4: Antibiotic Concentration Over Time
p4 <- ggplot(pass, aes(x = Passage, y = Conc.Num, color = Antibiotic, group = Line)) +
geom_step(alpha = 0.8, linewidth = 0.9) +
geom_point(size = 2) +
scale_y_log10() +
labs(
title = "Selection pressure during serial passaging",
x = "Passage",
y = expression("Concentration ("*mu*"g/mL, log scale)"),
color = "Antibiotic"
) +
theme_classic(base_size = 14)
p4

Figure 6: Disk Diffusion X-axis: Strain (Ancestor vs Evolved) Y-axis:
Zone diameter (mm) Points = individual disks
p6 <- ggplot(disc, aes(x = Timepoint, y = Zone_diameter_mm, fill = Timepoint)) +
geom_boxplot(alpha = 0.6, outlier.shape = NA) +
geom_jitter(width = 0.1, size = 2.5) +
labs(
title = "Disk diffusion zones",
x = "Timepoint",
y = "Zone diameter (mm)"
) +
theme_classic(base_size = 14) +
theme(legend.position = "none")
p6

Figure 7: Heatmap of MIC curves X-axis: concentration Y-axis:
timepoint Color: OD
p7 <- ggplot(od_long, aes(x = Timepoint, y = factor(Concentration, levels = sort(unique(Concentration), decreasing = TRUE)), fill = OD)) +
geom_tile(color = "white") +
facet_wrap(~Culture) +
labs(
title = "Heatmap of OD across concentration and time",
x = "Week",
y = expression("Concentration ("*mu*"g/mL)"),
fill = expression(OD[600])
) +
theme_classic(base_size = 14)
p7

Figure 8: OD vs concentration curves (per week)
Plot dose-response curves: W0 vs W5 vs W10 etc. Very strong for
showing: rightward shift = resistance
p8 <- ggplot(od_long, aes(x = Concentration, y = OD, color = Timepoint, group = Timepoint)) +
geom_line(linewidth = 1) +
geom_point(size = 2) +
scale_x_log10() +
facet_wrap(~Culture) +
labs(
title = "Dose-response curves across time",
x = expression("Concentration ("*mu*"g/mL, log scale)"),
y = expression(OD[600]),
color = "Week"
) +
theme_classic(base_size = 14)
p8
Key takeaways to consider:
- Resistance does not evolve in a single uniform way — it depends
strongly on the antibiotic and underlying mechanism.
- Resistance can evolve extremely fast (Amp Log2 from 7-9 in one
week). Ampicillin resistance can arise through large-effect mutations
that rapidly confer high-level resistance. 3.Resistance can evolve
gradually and unstably. Kanamycin resistance likely requires multiple or
smaller-effect changes, leading to slower and more variable evolutionary
trajectories.
- Adaptation happens before full resistance. Cells survive and
fluctuate before MIC increases. Populations first undergo physiological
adaptation, followed by stable genetic resistance.
- Phenotype matches quantitative data. Resistance observed in MIC
assays translates directly into clinically relevant phenotypic
resistance.
Discussion Points (tie to above)
This study demonstrates how bacterial populations adapt to
sub-lethal antibiotic exposure, with distinct evolutionary trajectories
depending on the antibiotic.
The rapid evolution of ampicillin resistance suggests selection
of large-effect mutations (e.g., porin loss or efflux regulation), while
the gradual trajectory of kanamycin resistance indicates a more complex
adaptive pathway. I would read into this more as you’re writing your
thesis.
These results highlight that antibiotic resistance is not a
uniform process and that different drugs can drive fundamentally
different evolutionary dynamics, which has implications for treatment
strategies and resistance management.
For your conclusion, consider a figure that depicts a future
direction. Even just a diagram with text explanation:
Amp → efflux / porin mutation Kan → multi-step adaptation
---
title: "R Notebook"
output: html_notebook
---
Great job, Lillian! I did a bit of basic coding and data cleaning to prep for our meeting tomorrow. Im going to share that with you. We can adapt this in any way that you want, this was just to get us thinking about your results. We will go over it line by line together  as well. Feel free to do more if you would like. Coding isnt really part of the SMP, so it's not something I make you do, but you should understand what was done. 

You should be really excited about these results because you didn’t just show that bacteria become resistant... you actually captured how that process happens over time. Your data clearly show that resistance evolves in very different ways depending on the antibiotic. Ampicillin resistance appeared almost immediately, jumping to very high levels, while kanamycin resistance increased more gradually and was much more variable. That contrast is not something everyone gets, and it points to real biological differences in how these drugs interact with cells and how bacteria adapt to them.

What makes your project especially strong is that all of your measurements tell the same story from different angles. The MIC data, growth scores, dose-response curves, and disk diffusion assays all line up and reinforce each other, which is exactly what you want in a solid scientific study. You also captured the process of adaptation, not just the endpoint, which is a much deeper level of analysis. This puts you in a great position to not only explain what happened, but to start asking why it happened.

# Data Cleansing

```{r}

library(dplyr)
mic <- read.csv("MICSummary.csv", check.names = FALSE)
od  <- read.csv("ODSummary.csv", check.names = FALSE)
disc <- read.csv("DiscDiff.csv", check.names = FALSE)
pass <- read.csv("Passages.csv", check.names = FALSE)

names(mic)  <- trimws(names(mic))
names(od)   <- trimws(names(od))
names(disc) <- trimws(names(disc))
names(disc) <- make.unique(names(disc))
names(disc)
names(pass) <- trimws(names(pass))

week_levels <- c("W0","W1","W2","W3","W4","W5")

mic$Week <- factor(mic$Week, levels = week_levels)
od$Timepoint <- factor(od$Timepoint, levels = week_levels)

# passaging
pass$Antibiotic <- trimws(pass$Antibiotic)
pass$Line <- paste(pass$Antibiotic, pass$`Culture ID`, sep = "_")

# disc diffusion
disc$Timepoint <- trimws(disc$Timepoint)

# use the 5th column, which is the numeric radius column
disc$Radius_mm <- as.numeric(disc[[5]])
disc$Zone_diameter_mm <- disc$Radius_mm * 2

# Add censored flag for MICs that hit assay ceiling
max_tested <- 512
mic$Censored <- mic$MIC90 >= max_tested

library(tidyverse)


od_long <- od %>%
  pivot_longer(
    cols = c(`OD Kan`, `OD Amp`),
    names_to = "Culture",
    values_to = "OD"
  ) %>%
  mutate(
    Culture = recode(Culture,
                     `OD Kan` = "Kan",
                     `OD Amp` = "Amp"),
    Concentration = `Concentration (ug/mL)`
  )

```

Figure 1 (MOST IMPORTANT): Resistance Trajectories
“Amp resistance evolved extremely rapidly, exceeding our measurement range within one week”

```{r}
p1 <- ggplot(mic, aes(x = Week, y = `log2(MIC)`, color = `Culture`, group = `Culture`)) +
  geom_line(linewidth = 1) +
  geom_point(aes(shape = Censored), size = 3) +
  scale_shape_manual(values = c(`FALSE` = 16, `TRUE` = 17)) +
  labs(
    title = "Resistance trajectories over time",
    x = "Week",
    y = expression(log[2]*"(MIC90, µg/mL)"),
    color = "Culture",
    shape = "At assay ceiling"
  ) +
  theme_classic(base_size = 14)

p1

```

Figure 3: Growth Under Selection 

```{r}
p3 <- ggplot(pass, aes(x = Passage, y = Growth.Score, color = Antibiotic, group = Line)) +
  geom_line(alpha = 0.8, linewidth = 0.9) +
  geom_point(size = 2) +
  labs(
    title = "Growth scores during serial passaging",
    x = "Passage",
    y = "Growth score",
    color = "Antibiotic"
  ) +
  theme_classic(base_size = 14)

p3

```
Figure 4: Antibiotic Concentration Over Time

```{r}
p4 <- ggplot(pass, aes(x = Passage, y = Conc.Num, color = Antibiotic, group = Line)) +
  geom_step(alpha = 0.8, linewidth = 0.9) +
  geom_point(size = 2) +
  scale_y_log10() +
  labs(
    title = "Selection pressure during serial passaging",
    x = "Passage",
    y = expression("Concentration ("*mu*"g/mL, log scale)"),
    color = "Antibiotic"
  ) +
  theme_classic(base_size = 14)

p4

```


Figure 6: Disk Diffusion 
X-axis: Strain (Ancestor vs Evolved)
Y-axis: Zone diameter (mm)
Points = individual disks

```{r}

p6 <- ggplot(disc, aes(x = Timepoint, y = Zone_diameter_mm, fill = Timepoint)) +
  geom_boxplot(alpha = 0.6, outlier.shape = NA) +
  geom_jitter(width = 0.1, size = 2.5) +
  labs(
    title = "Disk diffusion zones",
    x = "Timepoint",
    y = "Zone diameter (mm)"
  ) +
  theme_classic(base_size = 14) +
  theme(legend.position = "none")

p6
```

Figure 7: Heatmap of MIC curves
X-axis: concentration
Y-axis: timepoint
Color: OD

```{r}

p7 <- ggplot(od_long, aes(x = Timepoint, y = factor(Concentration, levels = sort(unique(Concentration), decreasing = TRUE)), fill = OD)) +
  geom_tile(color = "white") +
  facet_wrap(~Culture) +
  labs(
    title = "Heatmap of OD across concentration and time",
    x = "Week",
    y = expression("Concentration ("*mu*"g/mL)"),
    fill = expression(OD[600])
  ) +
  theme_classic(base_size = 14)

p7
```


Figure 8: OD vs concentration curves (per week)

Plot dose-response curves:
W0 vs W5 vs W10 etc.
Very strong for showing:
rightward shift = resistance


```{r}

p8 <- ggplot(od_long, aes(x = Concentration, y = OD, color = Timepoint, group = Timepoint)) +
  geom_line(linewidth = 1) +
  geom_point(size = 2) +
  scale_x_log10() +
  facet_wrap(~Culture) +
  labs(
    title = "Dose-response curves across time",
    x = expression("Concentration ("*mu*"g/mL, log scale)"),
    y = expression(OD[600]),
    color = "Week"
  ) +
  theme_classic(base_size = 14)

p8

```


## Key takeaways to consider: 

1. Resistance does not evolve in a single uniform way — it depends strongly on the antibiotic and underlying mechanism.
2. Resistance can evolve extremely fast (Amp Log2 from 7-9 in one week). Ampicillin resistance can arise through large-effect mutations that rapidly confer high-level resistance.
3.Resistance can evolve gradually and unstably. Kanamycin resistance likely requires multiple or smaller-effect changes, leading to slower and more variable evolutionary trajectories.
4. Adaptation happens before full resistance. Cells survive and fluctuate before MIC increases. Populations first undergo physiological adaptation, followed by stable genetic resistance.
5. Phenotype matches quantitative data. Resistance observed in MIC assays translates directly into clinically relevant phenotypic resistance. 

## Discussion Points (tie to above)

1. This study demonstrates how bacterial populations adapt to sub-lethal antibiotic exposure, with distinct evolutionary trajectories depending on the antibiotic.

2. The rapid evolution of ampicillin resistance suggests selection of large-effect mutations (e.g., porin loss or efflux regulation), while the gradual trajectory of kanamycin resistance indicates a more complex adaptive pathway. I would read into this more as you're writing your thesis. 

3. These results highlight that antibiotic resistance is not a uniform process and that different drugs can drive fundamentally different evolutionary dynamics, which has implications for treatment strategies and resistance management.


For your conclusion, consider a figure that depicts a future direction. 
Even just a diagram with text explanation:

Amp → efflux / porin mutation
Kan → multi-step adaptation