Grades were reported for 679 students.

Exam Score

Mean exam score: 14.4

Gender was reported for 676 students.

Gender Number of Students Percent of Class (%) Mean Exam Score
Female 212 31 13.3
Male 464 68 14.8
NA 3 <1 14.4

Violins are scaled to number of observations in each group.

Exam Percent

Mean exam percent: 71.8 %

Gender Number of Students Percent of Class (%) Mean Exam Percent (%)
Female 212 31 66.4
Male 464 68 74.2
NA 3 <1 71.8


Exam Wrapper Questions

Responses, Performance, and Group Differences

Question 21

  1. What is the highest physics course you have taken before this class?
  1. None
  2. High school mechanics
  3. High school electricity and magnetism
  4. AP mechanics
  5. AP electricity and magnetism, or above
450 responses

Note that 2 students selected B and C, 1 student selected C and E, and 2 students selected D and E. These are not included in the figure below.

Also note that students that report their parents’ highest level of education at Elementary, Less th HS, or HS diploma are recorded as first-generation students. The others are recorded as non-first-generation students. Not including students who did not report or responded “Don’t Know.”

Students that self-report as white or asian are recorded as non-underrepresented minority students. The others are recorded as underrepresented minorities. Not including students who did not indicate a race/ethnicity.

Question 22

  1. How much of the content for this exam do you feel you already knew before this class?
  1. None of it
  2. Very little of it
  3. Some of it
  4. Most of it
  5. All of it
449 responses

Question 23

  1. What do you like most about having extra time on the exam?
  1. I took time with each question
  2. I checked my work thoroughly at the end
  3. I revisited problems I was not sure about
  4. I felt less stress/pressure during this exam
  5. Nothing, I did not need extra time and did not use it
445 responses

Note that 1 student selected A, B, C, and D and 1 student selected A, B, and C. These are not included in the figure below.

Question 24

  1. Rate how you felt during the exam, with 5 being the best and 1 being the worst.
  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
444 responses

Note that 1 student selected C and D. These are not included in the figure below.

Question 25

  1. Looking to the next exam, how do you plan to change your study strategies?
  1. I will start studying earlier
  2. I will be studying regularly throughout the next month
  3. I will solve more practice problems (from the Problem Roulette or from the textbook)
  4. I will use more of the resources available (Physics Help Room, office hours, Piazza, etc)
  5. I do not plan to change my study strategies
439 responses

Note that 3 students selected A, B, C, and D, 1 student selected B and C, 1 student selected A and B, 1 student selected C and D, 1 student selected A and C, and 1 student selected A, B, and D. These are not included in the figure below.


ECoach Exam 1 Playbook

By Gender

Students that haven’t taken high school physics

Students that checked their work

Time data

---
title: "FA 2018 Physics 140 Midterm 1"
output: html_notebook
---

```{r, echo = FALSE, message = FALSE}
library(tidyverse)
library(RColorBrewer)
library(knitr)
library(boot)
```

```{r, echo = FALSE}
theme_pub <- 
    theme(plot.title = element_text(face = "bold",
                                      size = rel(1.2), hjust = 0.5),
            text = element_text(),
            panel.background = element_blank(),
            plot.background = element_rect(colour = "white"),
            axis.title = element_text(face = "bold",size = 14),
            axis.title.y = element_text(angle=90,vjust =2,size=12),
            axis.title.x = element_text(vjust = -0.2,size=12),
            axis.text = element_text(size=10), 
            axis.line = element_line(colour="black"),
            axis.ticks = element_line(),
            panel.grid.major = element_line(colour="grey90"),
            panel.grid.minor = element_blank(),
            legend.key = element_rect(colour = NA),
            legend.position = "bottom",
            legend.direction = "horizontal",
            legend.key.size= unit(0.2, "cm"),
            legend.title = element_text(face="italic"),
            plot.margin=unit(c(10,5,5,5),"mm"),
            strip.background=element_rect(colour="#f0f0f0",fill="#f0f0f0"),
            strip.text = element_text(face="bold"),
          aspect.ratio=.65
    )
```

```{r, echo = FALSE, message = FALSE}
answers <- read_csv("Midterm1_answers.csv")
grades <- read_csv("Midterm1_scores.csv")
demographics <- read_csv("physics_140_demos_2210.csv")
```

```{r, echo = FALSE}
# add leading zeros to student ID numbers
student_id <- c()
for(i in 1:nrow(demographics)) {
  if(ceiling(log10(demographics$account_id[i]+1)) == 6) {
    student_id[i] = paste0("00", demographics$account_id[i])
  }
  else if (ceiling(log10(demographics$account_id[i]+1)) == 7) {
    student_id[i] = paste0("0", demographics$account_id[i])
  } else {
    student_id[i] = demographics$account_id[i]
  }
}
demographics <- mutate(demographics, studentID = student_id)
```

```{r, echo = FALSE}
student_id_grades <- c()
for(i in 1:nrow(grades)) {
  if(ceiling(log10(grades$student_id[i]+1)) == 6) {
    student_id_grades[i] = paste0("00", grades$student_id[i])
  }
  else if (ceiling(log10(grades$student_id[i]+1)) == 7) {
    student_id_grades[i] = paste0("0", grades$student_id[i])
  }
  else if (ceiling(log10(grades$student_id[i]+1)) == 1) {
    student_id_grades[i] = paste0("0000000", grades$student_id[i])
  }
  else {
    student_id_grades[i] = grades$student_id[i]
  }
}
```

```{r, echo = FALSE}
grades <- mutate(grades, studentID = student_id_grades) %>%
  filter(first_name != "0")
```

### Grades were reported for 679 students.

### Exam Score
#### **Mean exam score:** 14.4
```{r, echo = FALSE}
## First order - exam grades of F vs. M
gradesGender <- right_join(demographics[c(7,3)], grades[c(39,5,6)], by = "studentID")
colnames(gradesGender) <- c("studentID", "Gender", "Exam Score", "Exam Percent")
```

```{r, echo = FALSE}
ggplot(gradesGender) + geom_bar(aes(`Exam Score`), fill = "gray30") + 
  ggtitle("Exam Score Distribution - Physics 140 Midterm 1 FA 2018") +
  theme_pub
```

### Gender was reported for 676 students.  
```{r, echo = FALSE}
info <- data_frame(Gender = c("Female", "Male", "NA"),
                   `Number of Students` = c(212,464, 3),
                   `Percent of Class (%)` = c(31, 68, "<1"),
                   `Mean Exam Score` = c(13.3, 14.8, 14.4))
```

| Gender | Number of Students | Percent of Class (%) | Mean Exam Score |
|:-------|:-------------------|:---------------------|:----------------|
| Female |         212        |          31          |      13.3       |
|  Male  |         464        |          68          |      14.8       |
|   NA   |          3         |          <1          |      14.4       |

```{r, echo = FALSE}
ggplot(filter(gradesGender, Gender == "F" | Gender == "M")) + 
         geom_density(aes(`Exam Score`, fill = Gender), alpha = .7) +
  geom_vline(xintercept = mean(filter(gradesGender, Gender == "F")$`Exam Score`), 
             color = "#66c2a5") +
  geom_vline(xintercept = mean(filter(gradesGender, Gender == "M")$`Exam Score`),
             color = "#fc8d62") +
  scale_fill_brewer(palette = "Set2") +
  ggtitle("Exam Score Distribution by Gender") + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(gradesGender, Gender == "M" | Gender == "F")) + geom_boxplot(aes(Gender, `Exam Score`, fill = Gender)) +
  scale_fill_brewer(palette = "Set2") +
  ggtitle("Exam Score Distribution by Gender") + labs(fill = "") +
  theme_pub
```
Violins are scaled to number of observations in each group.
```{r, echo = FALSE}
ggplot(filter(gradesGender, Gender == "M" | Gender == "F")) + geom_violin(aes(Gender, `Exam Score`, fill = Gender), scale = "count") +
  scale_fill_brewer(palette = "Set2") +
  ggtitle("Exam Score Distribution by Gender (Violin plot)") + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
bootfunc <- function(d,i) {
  d1 <- d[i]
  return(mean(d1))
}
```

```{r, echo = FALSE}
femaleError <- sd(boot(filter(gradesGender, Gender == "F")$`Exam Score`, bootfunc, 10000)$t)
maleError <- sd(boot(filter(gradesGender, Gender == "M")$`Exam Score`, bootfunc, 10000)$t)
```

```{r, echo = FALSE}
gradeTable <- data_frame(c("F", "M"), c(mean(filter(gradesGender, Gender == "F")$`Exam Score`),
                                        mean(filter(gradesGender, Gender == "M")$`Exam Score`)),
                         c(femaleError, maleError))
colnames(gradeTable) <- c("Gender", "Mean Exam Score", "Error")
```

```{r, echo = FALSE}
ggplot(gradeTable, aes(Gender, `Mean Exam Score`, color = Gender)) + 
  geom_point(size = 2) +
  geom_errorbar(aes(ymin = `Mean Exam Score` - Error, 
                    ymax = `Mean Exam Score` + Error), 
                width = .1) + 
  scale_color_brewer(palette = "Set2") +
  ggtitle("Exam Score Gendered Performance Difference") + labs(color = "") +
  theme_pub

```

### Exam Percent
#### **Mean exam percent:** 71.8 %

```{r, echo = FALSE}
info2 <- data_frame(Gender = c("Female", "Male", "NA"),
                   `Number of Students` = c(212,464,3),
                   `Percent of Class (%)` = c(31, 69,"<1"),
                   `Mean Exam Percent (%)` = c(66.4, 74.2,71.8))
```

| Gender | Number of Students | Percent of Class (%) | Mean Exam Percent (%) |
|:-------|:-------------------|:---------------------|:----------------------|
| Female |         212        |          31          |          66.4         |
|  Male  |         464        |          68          |          74.2         |
|   NA   |          3         |          <1          |          71.8         |


```{r, echo = FALSE}
femaleErrorPct <- sd(boot(filter(gradesGender, Gender == "F")$`Exam Percent`, bootfunc, 10000)$t)
maleErrorPct <- sd(boot(filter(gradesGender, Gender == "M")$`Exam Percent`, bootfunc, 10000)$t)
```

```{r, echo = FALSE}
gradeTablePct <- data_frame(c("F", "M"), 
                            c(mean(filter(gradesGender, Gender == "F")$`Exam Percent`),
                              mean(filter(gradesGender, Gender == "M")$`Exam Percent`)),
                            c(femaleErrorPct, maleErrorPct))
colnames(gradeTablePct) <- c("Gender", "Mean Exam Percent", "Error")
```

```{r, echo = FALSE}
ggplot(gradeTablePct, aes(Gender, `Mean Exam Percent`, color = Gender)) + 
  geom_point(size = 2) +
  geom_errorbar(aes(ymin = `Mean Exam Percent` - Error, 
                    ymax = `Mean Exam Percent` + Error), 
                width = .1) + 
  scale_color_manual(values = c("#d8b365", "#5ab4ac")) +
  ggtitle("Exam Score Gendered Performance Difference") + labs(color = "") +
  theme_pub

```

***
### Exam Wrapper Questions  
##### Responses, Performance, and Group Differences    

```{r, echo = FALSE}
answers <- mutate(answers, studentID = answers$student_id)
```

```{r, echo = FALSE}
answersDemo <- right_join(demographics[c(7,3:6)], answers[c(144,9,10,34:38)], by = "studentID")
```

```{r, echo = FALSE}
firstgen <- c()
answersDemo2 <- filter(answersDemo, prnt_max_ed_lvl_des != "NA")
for(i in 1:nrow(answersDemo2)){
  if(answersDemo2$prnt_max_ed_lvl_des[i] == "Elementary") firstgen[i] = "firstgen"
  else if(answersDemo2$prnt_max_ed_lvl_des[i] == "Less th HS") firstgen[i] = "firstgen"
  else if(answersDemo2$prnt_max_ed_lvl_des[i] == "HS diploma") firstgen[i] = "firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Some Coll") firstgen[i] = "not firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Associate") firstgen[i] = "not firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Bachelor's") firstgen[i] = "not firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Master's") firstgen[i] = "not firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Doctorate") firstgen[i] = "not firstgen"
  else if (answersDemo2$prnt_max_ed_lvl_des[i] == "Prof Doc") firstgen[i] = "not firstgen"
  else firstgen[i] = "NA"
}
answersDemo2 <- mutate(answersDemo2, firstgen = firstgen) %>% filter(firstgen != "NA") %>%
  filter(sex != "NA")
```

```{r, echo = FALSE}
urm <- c()
answersDemo3 <- filter(answersDemo, races != "NA")
for (i in 1:nrow(answersDemo3)) {
  if (answersDemo3$races[i] == "white") urm[i] = "not URM"
  else if (answersDemo3$races[i] == "asian") urm[i] = "not URM"
  else if (answersDemo3$races[i] == "noindic") urm[i] = "NA"
  else urm[i] = "URM"
}
answersDemo3 <- mutate(answersDemo3, urm = urm) %>% filter(urm != "NA")
```

#### Question 21  
21. What is the highest physics course you have taken before this class?
  A) None
  B) High school mechanics
  C) High school electricity and magnetism
  D) AP mechanics
  E) AP electricity and magnetism, or above  
  
##### 450 responses  
Note that 2 students selected B and C, 1 student selected C and E, and 2 students selected D and E. These are not included in the figure below.  

Also note that students that report their parents' highest level of education at Elementary, Less th HS, or HS diploma are recorded as first-generation students. The others are recorded as non-first-generation students. Not including students who did not report or responded "Don't Know."  

Students that self-report as white or asian are recorded as non-underrepresented minority students. The others are recorded as underrepresented minorities. Not including students who did not indicate a race/ethnicity.

```{r, echo = FALSE}
ggplot(filter(answersDemo, `21`=="A"|`21`=="B"|`21`=="C"|`21`=="D"|`21`=="E")) + 
         geom_bar(aes(`21`, fill = `21`)) + labs(fill = "") + 
  ggtitle("Highest Physics Course Before Physics 140") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `21`=="A"|`21`=="B"|`21`=="C"|`21`=="D"|`21`=="E")) +
  geom_boxplot(aes(`21`, score, fill = `21`)) + labs(fill = "") +
  ggtitle("Highest Physics Course vs. Exam 1 Score") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop21 <- answersDemo2 %>%
  group_by(sex,`21`) %>% summarise(count = n()) %>%
  mutate(`Percent of Gender` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop21, `21`=="A"|`21`=="B"|`21`=="C"|`21`=="D"|`21`=="E")) + 
         geom_col(aes(`21`,`Percent of Gender`, fill = sex), position = position_dodge()) + 
  facet_wrap(~sex) +
  labs(fill = "") + 
  ggtitle("Highest Physics Course before Physics 140 (Gender)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop21FG <- answersDemo2 %>%
  group_by(firstgen,`21`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop21FG, `21`=="A"|`21`=="B"|`21`=="C"|`21`=="D"|`21`=="E")) + 
         geom_col(aes(`21`,`Percent of Group`, fill = firstgen), position = position_dodge()) +
  facet_wrap(~firstgen) +
  labs(fill = "") + 
  ggtitle("Highest Physics Course before Physics 140 (First-Generation)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo3prop21URM <- answersDemo3 %>%
  group_by(urm,`21`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo3prop21URM, `21`=="A"|`21`=="B"|`21`=="C"|`21`=="D"|`21`=="E")) + 
         geom_col(aes(`21`,`Percent of Group`, fill = urm), position = position_dodge()) +
  facet_wrap(~urm) +
  labs(fill = "") + 
  ggtitle("Highest Physics Course before Physics 140 (URM)") +
  theme_pub
```

#### Question 22  
22. How much of the content for this exam do you feel you already knew before this class?
  A) None of it
  B) Very little of it
  C) Some of it
  D) Most of it
  E) All of it  

##### 449 responses  
```{r, echo = FALSE}
ggplot(filter(answersDemo, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) + 
         geom_bar(aes(`22`, fill = `22`)) + labs(fill = "") + 
  ggtitle("Prior Knowledge of Exam 1 Content") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) +
  geom_boxplot(aes(`22`, score, fill = `22`)) + labs(fill = "") +
  ggtitle("Prior Knowledge vs. Exam 1 Score") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) +
  geom_boxplot(aes(`22`, score, fill = sex)) + labs(fill = "") +
  ggtitle("Prior Knowledge vs. Exam 1 Score by Gender") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop22 <- answersDemo2 %>%
  group_by(sex,`22`) %>% summarise(count = n()) %>%
  mutate(`Percent of Gender` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop22, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) + 
         geom_col(aes(`22`, `Percent of Gender`, fill = sex), position = position_dodge()) + 
  facet_wrap(~sex) +
  labs(fill = "") + 
  ggtitle("Prior Knowledge of Exam 1 Content (Gender)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop22FG <- answersDemo2 %>%
  group_by(firstgen,`22`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop22FG, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) + 
         geom_col(aes(`22`,`Percent of Group`, fill = firstgen), position = position_dodge()) +
  facet_wrap(~firstgen) +
  labs(fill = "") + 
  ggtitle("Prior Knowledge of Exam 1 Content (First-Generation)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo3prop22URM <- answersDemo3 %>%
  group_by(urm,`22`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo3prop22URM, `22`=="A"|`22`=="B"|`22`=="C"|`22`=="D"|`22`=="E")) + 
         geom_col(aes(`22`,`Percent of Group`, fill = urm), position = position_dodge()) +
  facet_wrap(~urm) +
  labs(fill = "") + 
  ggtitle("Prior Knowledge of Exam 1 Content (URM)") +
  theme_pub
```

#### Question 23  
23. What do you like most about having extra time on the exam?
  A) I took time with each question
  B) I checked my work thoroughly at the end
  C) I revisited problems I was not sure about
  D) I felt less stress/pressure during this exam
  E) Nothing, I did not need extra time and did not use it  

##### 445 responses  
Note that 1 student selected A, B, C, and D and 1 student selected A, B, and C. These are not included in the figure below.
```{r, echo = FALSE}
ggplot(filter(answersDemo, `23`=="A"|`23`=="B"|`23`=="C"|`23`=="D"|`23`=="E")) + 
         geom_bar(aes(`23`, fill = `23`)) + labs(fill = "") + 
  ggtitle("Postives About Having Extra Time") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `23`=="A"|`23`=="B"|`23`=="C"|`23`=="D"|`23`=="E")) +
  geom_boxplot(aes(`23`, score, fill = `23`)) + labs(fill = "") +
  ggtitle("Positives About Extra Time vs. Exam 1 Score") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop23 <- answersDemo2 %>%
  group_by(sex,`23`) %>% summarise(count = n()) %>%
  mutate(`Percent of Gender` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop23, `23`=="A"|`23`=="B"|`23`=="C"|`23`=="D"|`23`=="E")) + 
         geom_col(aes(`23`, `Percent of Gender`, fill = sex), position = position_dodge()) + 
  facet_wrap(~sex) +
  labs(fill = "") + 
  ggtitle("Positives About Having Extra Time (Gender)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop23FG <- answersDemo2 %>%
  group_by(firstgen,`23`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop23FG, `23`=="A"|`23`=="B"|`23`=="C"|`23`=="D"|`23`=="E")) + 
         geom_col(aes(`23`,`Percent of Group`, fill = firstgen), position = position_dodge()) +
  facet_wrap(~firstgen) +
  labs(fill = "") + 
  ggtitle("Positives About Having Extra Time (First-Generation)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo3prop23URM <- answersDemo3 %>%
  group_by(urm,`23`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo3prop23URM, `23`=="A"|`23`=="B"|`23`=="C"|`23`=="D"|`23`=="E")) + 
         geom_col(aes(`23`,`Percent of Group`, fill = urm), position = position_dodge()) +
  facet_wrap(~urm) +
  labs(fill = "") + 
  ggtitle("Positives About Having Extra Time (URM)") +
  theme_pub
```

#### Question 24  
24. Rate how you felt during the exam, with 5 being the best and 1 being the worst.
  A) 1
  B) 2
  C) 3
  D) 4
  E) 5  
  
##### 444 responses  
Note that 1 student selected C and D. These are not included in the figure below.
```{r, echo = FALSE}
ggplot(filter(answersDemo, `24`=="A"|`24`=="B"|`24`=="C"|`24`=="D"|`24`=="E")) + 
         geom_bar(aes(`24`, fill = `24`)) + labs(fill = "") + 
  ggtitle("Feelings During Exam") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `24`=="A"|`24`=="B"|`24`=="C"|`24`=="D"|`24`=="E")) +
  geom_boxplot(aes(`24`, score, fill = `24`)) + labs(fill = "") +
  ggtitle("Feelings During Exam vs. Exam 1 Score") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop24 <- answersDemo2 %>%
  group_by(sex,`24`) %>% summarise(count = n()) %>%
  mutate(`Percent of Gender` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop24, `24`=="A"|`24`=="B"|`24`=="C"|`24`=="D"|`24`=="E")) + 
         geom_col(aes(`24`, `Percent of Gender`, fill = sex), position = position_dodge()) + 
  facet_wrap(~sex) +
  labs(fill = "") + 
  ggtitle("Feelings During Exam (Gender)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop24FG <- answersDemo2 %>%
  group_by(firstgen,`24`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop24FG, `24`=="A"|`24`=="B"|`24`=="C"|`24`=="D"|`24`=="E")) + 
         geom_col(aes(`24`,`Percent of Group`, fill = firstgen), position = position_dodge()) +
  facet_wrap(~firstgen) +
  labs(fill = "") + 
  ggtitle("Feelings During Exam (First-Generation)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo3prop24URM <- answersDemo3 %>%
  group_by(urm,`24`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo3prop24URM, `24`=="A"|`24`=="B"|`24`=="C"|`24`=="D"|`24`=="E")) + 
         geom_col(aes(`24`,`Percent of Group`, fill = urm), position = position_dodge()) +
  facet_wrap(~urm) +
  labs(fill = "") + 
  ggtitle("Feelings During Exam (URM)") +
  theme_pub
```

#### Question 25  
25. Looking to the next exam, how do you plan to change your study strategies?
  A) I will start studying **earlier**
  B) I will be studying **regularly** throughout the next month
  C) I will solve **more** practice problems (from the Problem Roulette or from the textbook)
  D) I will use more of the resources available (Physics Help Room, office hours, Piazza, etc)
  E) I do **not** plan to change my study strategies  
  
##### 439 responses  
Note that 3 students selected A, B, C, and D, 1 student selected B and C, 1 student selected A and B, 1 student selected C and D, 1 student selected A and C, and 1 student selected A, B, and D. These are not included in the figure below.
```{r, echo = FALSE}
ggplot(filter(answersDemo, `25`=="A"|`25`=="B"|`25`=="C"|`25`=="D"|`25`=="E")) + 
         geom_bar(aes(`25`, fill = `25`)) + labs(fill = "") + 
  ggtitle("Plans for Changing Study Strategies") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(filter(answersDemo, `25`=="A"|`25`=="B"|`25`=="C"|`25`=="D"|`25`=="E")) +
  geom_boxplot(aes(`25`, score, fill = `25`)) + labs(fill = "") +
  ggtitle("Plans for Changing Study Strategies vs. Exam 1 Score") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop25 <- answersDemo2 %>%
  group_by(sex,`25`) %>% summarise(count = n()) %>%
  mutate(`Percent of Gender` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop25, `25`=="A"|`25`=="B"|`25`=="C"|`25`=="D"|`25`=="E")) + 
         geom_col(aes(`25`, `Percent of Gender`, fill = sex), position = position_dodge()) + 
  facet_wrap(~sex) +
  labs(fill = "") + 
  ggtitle("Plans for Changing Study Strategies (Gender)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo2prop25FG <- answersDemo2 %>%
  group_by(firstgen,`25`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo2prop25FG, `25`=="A"|`25`=="B"|`25`=="C"|`25`=="D"|`25`=="E")) + 
         geom_col(aes(`25`, `Percent of Group`, fill = firstgen), position = position_dodge()) +
  facet_wrap(~firstgen) +
  labs(fill = "") + 
  ggtitle("Plans for Changing Study Strategies (First-Generation)") +
  theme_pub
```

```{r, echo = FALSE}
answersDemo3prop25URM <- answersDemo3 %>%
  group_by(urm,`25`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(filter(answersDemo3prop25URM, `25`=="A"|`25`=="B"|`25`=="C"|`25`=="D"|`25`=="E")) + 
         geom_col(aes(`25`,`Percent of Group`, fill = urm), position = position_dodge()) +
  facet_wrap(~urm) +
  labs(fill = "") + 
  ggtitle("Plans for Changing Study Strategies (URM)") +
  theme_pub
```

***
### ECoach Exam 1 Playbook
```{r, echo = FALSE, message = FALSE}
playbook <- read_csv("physics140_playbook1_fall_18.csv")[c(4,6)]
colnames(playbook) <- c("uniqname", "Playbook")
playbookGrades <- right_join(playbook,answers, by = "uniqname")[c(1,2,3,10,11)]
```

```{r, echo = FALSE}
playbook <- c()
for (i in 1:nrow(playbookGrades)) {
  if(is.na(playbookGrades$Playbook[i])) playbook[i] = "No"
  else playbook[i] = "Yes"
}
playbookGrades <- mutate(playbookGrades, playbook = playbook)
```

```{r, echo = FALSE}
ggplot(playbookGrades) + 
  geom_boxplot(aes(playbook, score, fill = playbook)) +
  ggtitle("Playbook Usage vs. Exam 1 Score") +
  labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
ggplot(playbookGrades) + 
  geom_violin(aes(playbook, score, fill = playbook), scale = "count") +
  ggtitle("Playbook Usage vs. Exam 1 Score") +
  labs(fill = "") +
  theme_pub
```

#### By Gender
```{r, echo = FALSE}
colnames(playbookGrades) <- c("uniqname", "Playbook","studentID", "score", "percent","playbook")
playbookGradesDemo <- right_join(playbookGrades, demographics, by = "studentID")[c(4,6,9)]%>%
  na.omit()
```

```{r, echo = FALSE}
ggplot(playbookGradesDemo) + 
  geom_boxplot(aes(playbook, score, fill = playbook)) +
  ggtitle("Playbook Usage vs. Exam 1 Score") +
  facet_wrap(~sex) +
  labs(fill = "") +
  theme_pub
```

### Students that haven't taken high school physics
```{r, echo = FALSE}
noHS <- filter(answersDemo, `21` == "A")
yesHS <- filter(answersDemo, `21` == "B" | `21` == "C" | `21` == "D" | `21` == "E")
```

```{r, echo = FALSE}
noHSprop <- noHS %>%
  group_by(score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Experience = "No high school")
```

```{r, echo = FALSE}
HSprop <- yesHS %>%
  group_by(score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Experience = "High school")
```

```{r, echo = FALSE}
HSproptotal <- rbind(HSprop, noHSprop)
```

```{r, echo = FALSE}
ggplot(HSproptotal) + 
  geom_col(aes(score, `Percent of Group`, fill = Experience)) +
  ggtitle("Comparison of scores - High school experience",
          subtitle = "High school = 44, No high school = 404") +
  facet_wrap(~Experience) + labs(fill = "") + theme_pub
```

```{r, echo = FALSE}
noHSpropgender <- filter(noHS, sex == "F" | sex == "M") %>%
  group_by(sex,score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Experience = "No high school")
```

```{r, echo = FALSE}
HSpropgender <- filter(yesHS, sex == "F" | sex == "M") %>%
  group_by(sex,score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Experience = "High school")
```

```{r, echo = FALSE}
HSpropgendertotal <- rbind(HSpropgender, noHSpropgender)
```

```{r, echo = FALSE}
ggplot(HSpropgendertotal) + 
  geom_col(aes(score, `Percent of Group`, fill = sex)) +
  ggtitle("Comparison of scores and gender - High school experience") +
  facet_grid(Experience~sex) + labs(fill = "") + theme_pub
```

### Students that checked their work
```{r, echo = FALSE}
checkWork <- filter(answersDemo, `23` == "B")
noCheckWork <- filter(answersDemo, `23` == "A" | `23` == "C" | `23` == "D" | `23` == "E")
```

```{r, echo = FALSE}
checkWorkProp <- checkWork %>%
  group_by(score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Strategy = "Checked work")
```

```{r, echo = FALSE}
noCheckWorkProp <- noCheckWork %>%
  group_by(score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Strategy = "Did not check work")
```

```{r, echo = FALSE}
checkWorkPropTotal <- rbind(checkWorkProp, noCheckWorkProp)
```

```{r, echo = FALSE}
ggplot(checkWorkPropTotal) + 
  geom_col(aes(score, `Percent of Group`, fill = Strategy)) +
  ggtitle("Comparison of scores - Checking work",
          subtitle = "checked work = 46, did not check work = 397") +
  facet_wrap(~Strategy) + labs(fill = "") + theme_pub
```

```{r, echo = FALSE}
noCheckWorkPropGender <- filter(noCheckWork, sex == "F" | sex == "M") %>%
  group_by(sex,score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Strategy = "Did not check work")
```

```{r, echo = FALSE}
checkWorkPropGender <- filter(checkWork, sex == "F" | sex == "M") %>%
  group_by(sex,score) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Strategy = "Checked work")
```

```{r, echo = FALSE}
checkWorkPropGenderTotal <- rbind(noCheckWorkPropGender, checkWorkPropGender)
```

```{r, echo = FALSE}
ggplot(checkWorkPropGenderTotal) + 
  geom_col(aes(score, `Percent of Group`, fill = sex)) +
  ggtitle("Comparison of scores and gender - Checking work") +
  facet_grid(Strategy~sex) + labs(fill = "") + theme_pub
```

### Time data
```{r, echo = FALSE, message = FALSE}
Exam1time <- list()
Exam1time[[1]] <- read_csv("Exam 1_time/Exam1_Lost_Students_clean.csv")
colnames(Exam1time[[1]]) <- c("IDnumber", "Name", "exam", "term", "timespent")
Exam1time[[2]] <- read_csv("Exam 1_time/Exam1_Weiser170_clean.csv")
Exam1time[[3]] <- read_csv("Exam 1_time/Exam1_Weiser182_clean.csv")
Exam1time[[4]] <- read_csv("Exam 1_time/Exam1_AngellAudA_clean.csv")
Exam1time[[5]] <- read_csv("Exam 1_time/Exam1_AngellAudB_clean.csv")
Exam1time[[6]] <- read_csv("Exam 1_time/Exam1_AngellAudC_clean.csv")
Exam1time[[7]] <- read_csv("Exam 1_time/Exam1_AngellAudD_clean.csv")
```

```{r, echo = FALSE}
ExamTimeAll <- rbind(Exam1time[[1]], Exam1time[[2]], Exam1time[[3]],
                     Exam1time[[4]], Exam1time[[5]], Exam1time[[6]], Exam1time[[7]])[c(1,2,5)]
colnames(ExamTimeAll) <- c("studentID", "name", "timespent")
```

```{r, echo = FALSE}
TimeAnswers <- left_join(answersDemo, ExamTimeAll, by = "studentID") %>% unique()
TimeAnswersUnique <- TimeAnswers[!(duplicated(TimeAnswers$studentID)),]
```

```{r, echo = FALSE}
time <- c()
for(i in 1:nrow(TimeAnswersUnique)) {
  if(is.na(TimeAnswersUnique$timespent[i]) == TRUE) time[i] = "No recorded time"
  else time[i] = "Recorded time"
}
TimeAnswersUnique <- mutate(TimeAnswersUnique, Time = time)
```

```{r, echo = FALSE}
answer25 <- filter(TimeAnswersUnique, `25` == "A"|`25` == "B"|`25` == "C"|`25` == "D"|`25` == "E"|
                     `25` == "ABCD"|`25` == "BC"|`25` == "CD"|`25` == "AC"|`25` == "ABD"|`25` == "AB")
noanswer25 <- subset(TimeAnswersUnique, is.na(TimeAnswersUnique$`25`))
```

```{r, echo = FALSE}
answer25prop <- answer25 %>%
  group_by(Time) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Response = "Answered Q25")
```

```{r, echo = FALSE}
noanswer25prop <- noanswer25 %>%
  group_by(Time) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100, Response = "Did not answer Q25")
```

```{r, echo = FALSE}
answer25propTotal <- rbind(answer25prop, noanswer25prop)
```

```{r, echo = FALSE}
ggplot(answer25propTotal) + 
  geom_col(aes(Time, `Percent of Group`, fill = Response)) +
  ggtitle("Who Answered the Wrapper Questions, and Did They Leave Early?",
          subtitle = "answered = 439, did not answer = 240") +
  facet_wrap(~Response) + labs(fill = "") + theme_pub
```

```{r, echo = FALSE}
timeanswer21 <- TimeAnswersUnique %>%
  group_by(Time,`21`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(timeanswer21) + 
  geom_col(aes(`21`, `Percent of Group`, fill = Time)) + labs(fill = "") + 
  ggtitle("Q21 Responses") +
  facet_wrap(~Time) + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
timeanswer22 <- TimeAnswersUnique %>%
  group_by(Time,`22`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(timeanswer22) + 
  geom_col(aes(`22`, `Percent of Group`, fill = Time)) + labs(fill = "") + 
  ggtitle("Q22 Responses") +
  facet_wrap(~Time) + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
timeanswer23 <- TimeAnswersUnique %>%
  group_by(Time,`23`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(timeanswer23) + 
  geom_col(aes(`23`, `Percent of Group`, fill = Time)) + labs(fill = "") + 
  ggtitle("Q23 Responses") +
  facet_wrap(~Time) + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
timeanswer24 <- TimeAnswersUnique %>%
  group_by(Time,`24`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(timeanswer24) + 
  geom_col(aes(`24`, `Percent of Group`, fill = Time)) + labs(fill = "") + 
  ggtitle("Q24 Responses") +
  facet_wrap(~Time) + labs(fill = "") +
  theme_pub
```

```{r, echo = FALSE}
timeanswer25 <- TimeAnswersUnique %>%
  group_by(Time,`25`) %>% summarise(count = n()) %>%
  mutate(`Percent of Group` = count/sum(count)*100)
```

```{r, echo = FALSE}
ggplot(timeanswer25) + 
  geom_col(aes(`25`, `Percent of Group`, fill = Time)) + labs(fill = "") + 
  ggtitle("Q25 Responses") +
  facet_wrap(~Time) + labs(fill = "") +
  theme_pub
```




