NEW analyses 12/02

CogState scores by group: Linear models (2 groups w/premorbid IQ & remote/non-remote)

2 groups: Non-PTSD (low-exposed controls & resilient); PTSD

Reference group = Non-PTSD

NO participants in the PTSD group completed the CogState remotely so cannot look at interaction

We see effects of PTSD vs non-PTSD on GML, GMR, ISRL (but only when standarized IQ is in model)

Groton maze learning test (Executive function)


Call:
lm(formula = score ~ group_2grp * wtar_standard + cogState_remote, 
    data = gml)

Residuals:
    Min      1Q  Median      3Q     Max 
-23.188 -11.051  -2.282   8.155  44.707 

Coefficients:
                             Estimate Std. Error t value Pr(>|t|)   
(Intercept)                  104.9436    32.0552   3.274  0.00213 **
group_2grpPTSD               -95.1573    52.6810  -1.806  0.07804 . 
wtar_standard                 -0.4688     0.2865  -1.637  0.10921   
cogState_remote1               5.8503     6.1573   0.950  0.34748   
group_2grpPTSD:wtar_standard   0.9285     0.4962   1.871  0.06828 . 
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Residual standard error: 15.15 on 42 degrees of freedom
  (6 observations deleted due to missingness)
Multiple R-squared:  0.112, Adjusted R-squared:  0.02746 
F-statistic: 1.325 on 4 and 42 DF,  p-value: 0.2766
`geom_smooth()` using formula 'y ~ x'

(In the above plot, TRUE = standardized WTAR is above the sample mean)

Groton maze learning test - delayed recall (Memory)


Call:
lm(formula = score ~ group_2grp * wtar_standard + cogState_remote, 
    data = gmr)

Residuals:
    Min      1Q  Median      3Q     Max 
-5.3581 -2.9329  0.1011  2.2804  7.9636 

Coefficients:
                              Estimate Std. Error t value Pr(>|t|)   
(Intercept)                   25.78259    7.56086   3.410   0.0015 **
group_2grpPTSD               -29.20027   12.25624  -2.382   0.0220 * 
wtar_standard                 -0.15747    0.06758  -2.330   0.0249 * 
cogState_remote1              -2.82138    1.59295  -1.771   0.0842 . 
group_2grpPTSD:wtar_standard   0.26307    0.11534   2.281   0.0280 * 
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Residual standard error: 3.496 on 40 degrees of freedom
  (8 observations deleted due to missingness)
Multiple R-squared:  0.2076,    Adjusted R-squared:  0.1284 
F-statistic: 2.621 on 4 and 40 DF,  p-value: 0.04903
`geom_smooth()` using formula 'y ~ x'

(In the above plot, TRUE = standardized WTAR is above the sample mean)

International shopping list - delayed recall (Verbal memory)


Call:
lm(formula = score ~ group_2grp * wtar_standard + cogState_remote, 
    data = isrl)

Residuals:
    Min      1Q  Median      3Q     Max 
-4.2657 -0.9958  0.2083  1.0347  2.8018 

Coefficients:
                              Estimate Std. Error t value Pr(>|t|)    
(Intercept)                   13.21375    3.39601   3.891 0.000369 ***
group_2grpPTSD               -12.91514    5.52466  -2.338 0.024491 *  
wtar_standard                 -0.03374    0.03038  -1.111 0.273267    
cogState_remote1               0.42271    0.67874   0.623 0.536960    
group_2grpPTSD:wtar_standard   0.12402    0.05202   2.384 0.021945 *  
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Residual standard error: 1.579 on 40 degrees of freedom
  (8 observations deleted due to missingness)
Multiple R-squared:  0.1333,    Adjusted R-squared:  0.04664 
F-statistic: 1.538 on 4 and 40 DF,  p-value: 0.2096
`geom_smooth()` using formula 'y ~ x'

(In the above plot, TRUE = standardized WTAR is above the sample mean)

 

 

 

 

 

 

 

  # 11/30/21

Number of exposures and CogState

New analyses 11/28/21

NEW: Premorbid IQ (WTAR)

3 groups

2 groups

NEW: CogState scores by group: Linear models (2 groups w/premorbid IQ & REMOTE)

2 groups: Non-PTSD (low-exposed controls & resilient); PTSD

Reference group = Non-PTSD

NO participants in the PTSD group completed the CogState remotely so cannot look at interaction

Detection test (Psychomotor function)

(not administered remotely)

Groton maze learning test (Executive function)

Groton maze learning - delayed recall test (Memory)

Identification test (Attention)

(not administered remotely)

International shopping list test (Verbal learning)

International shopping list - delayed recall test (Memory)

One-card learning test (Visual memory)

One-back test (Working memory)

(not administered remotely)

Composite score

---
title: "Cogstate for grant submission"
output:
  html_notebook:
    toc: yes
  html_document:
    toc: yes
    df_print: paged
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE)
rm(list = ls())
setwd("/Volumes/External/WTC_resilience_imaging/analysis")
library(dplyr)
library(ggplot2)
library(ggcorrplot)
library(tidyr)
library(ggrepel)
```


```{r, echo=FALSE, include=FALSE}
#import scored CogState data from dataset w/o missing imputed
csdat<-read.csv('/Volumes/External/WTC_resilience_imaging/data/cogstate_data/cogstate_output_scored_112721.csv')[-c(1)]
data<-read.csv('/Volumes/External/WTC_resilience_imaging/data/clinical_data/master_clinical_demog_indiv_112421.csv')[-c(1)] 

# for group variable
grp<-read.table("/Volumes/External/WTC_resilience_imaging/data/BIDS_data/participantscurrent.tsv", sep = "\t", header = TRUE)
grp <- dplyr::rename(grp, bids_id = BIDS_ID, group = group.factor.y)
grp<-dplyr::select(grp, c(bids_id , group)) %>% mutate(group = as.factor(group),
                                                       group_PTSDref = relevel(group, "Symptomatic (PTSD)"))


#merge together
data1<-left_join(csdat, data, by="record_id")
data<-left_join(data1, grp, by="bids_id")

data$group[data$record_id=="NWTC-034"]<-"Low-Exposed Control"
data$group_PTSDref[data$record_id=="NWTC-034"]<-"Low-Exposed Control"
data <- data %>% mutate(group_2grp = ifelse(group=="Symptomatic (PTSD)", "PTSD","Non-PTSD")) %>% filter(!group %in% c(NA))

## add in remote vs. in-person CogState completion
remotes <- c("NWTC-059",	
"NWTC-060",
"NWTC-062",
"NWTC-067",
"NWTC-068",
"NWTC-070",
"NWTC-072",
"NWTC-073",	
"NWTC-074",
"NWTC-078",
"NWTC-082")

data$WTCexposure_score[data$record_id=="NWTC-034"]<-2
data$WTCexposure_score[data$record_id=="NWTC-068"]<-4
data$WTCexposure_score[data$record_id=="NWTC-073"]<-5
data$WTCexposure_score[data$record_id=="NWTC-074"]<-4
data$WTCexposure_score[data$record_id=="NWTC-076"]<-2
data$WTCexposure_score[data$record_id=="NWTC-078"]<-4

data <- data %>% mutate(cogState_remote = if_else(record_id %in% remotes, 1,0),
                        low_exposed = if_else(WTCexposure_score<=3, 1,0)) # create variable for who completed cogstate remotely & high/low exposed

#data %>% dplyr::filter(is.na(WTCexposure_score)) %>% select(record_id,WTCexposure_score)




# how many in each group?
# data %>% dplyr::filter(!group %in% c(NA)) %>% count(group, cogState_remote) 
# 7 low exposed control, 30 resilient, 16 ptsd
```


# NEW analyses 12/02

## CogState scores by group: Linear models (2 groups w/premorbid IQ & remote/non-remote)

2 groups: Non-PTSD (low-exposed controls & resilient); PTSD

Reference group = Non-PTSD

<font color="red">**NO participants in the PTSD group completed the CogState remotely so cannot look at interaction**</font>

<font color="blue">**We see effects of PTSD vs non-PTSD on GML, GMR, ISRL (but only when standarized IQ is in model)**</font>



```{r, echo=FALSE,include=FALSE}
# get rid of duplicate vars (use non-imputed vs. imputed)
scoresW <- data %>% select_at(vars(starts_with("score") & !ends_with("inv") | starts_with("group") | starts_with("record") | starts_with("age") | starts_with("gender") | starts_with("edu") | starts_with("cogState_remote") | starts_with("wtar"))) 
colnames(scoresW)<-gsub(".x","",colnames(scoresW))
#scoresW <-scoresW %>% select(!matches('1$|2$|3$|4$|5$'))
use.scoresW<-scoresW %>% select_at(vars(starts_with("score")|starts_with("group")|starts_with("cogState_")))
colnames(use.scoresW)<-gsub("score.","",colnames(use.scoresW))

# # use imputed
# scores_imp <- data %>% select_at(vars(starts_with("use") & !ends_with(".x") | starts_with("group") | starts_with("record") | starts_with("age") | starts_with("gender") | starts_with("edu") | starts_with("wtar"))) 
# colnames(scores_imp)<-gsub(".y","",colnames(scores_imp))
# #colnames(scores_imp)<-gsub("use.","",colnames(scores))
# scores_imp <-scores_imp %>% select(!matches('1$|2$|3$|4$|5$'))
# use.scores.imp<-scores_imp %>% select_at(vars(starts_with("use")|starts_with("group")))

# wide to long
scoresL<-gather(scoresW, key="test", value="score", -c(record_id, group,group_PTSDref,group_2grp,age,gender,gender_1isM,gender_1isF,educationLevel,wtar_standard,cogState_remote))
scoresL<-scoresL %>% mutate(test = as.factor(test),
                           cogState_remote = as.factor(cogState_remote))
use.scoresL<-gather(use.scoresW,key="test", value="score", -c(group,group_PTSDref,group_2grp)) %>% filter(!is.na(score))

det <- scoresL %>% filter(test=="score.DET")
gml <- scoresL %>% filter(test=="score.GML")
gmr <- scoresL %>% filter(test=="score.GMR")
idn <- scoresL %>% filter(test=="score.IDN")
isl <- scoresL %>% filter(test=="score.ISL")
isrl <- scoresL %>% filter(test=="score.ISRL")
ocl <- scoresL %>% filter(test=="score.OCL")
onb <- scoresL %>% filter(test=="score.ONB")

data <- data%>% mutate(group_2grpBinary = ifelse(group_2grp=="PTSD",1,0))
data <- data%>% mutate(grp_x_wtar = (group_2grpBinary*wtar_standard))
```

### Groton maze learning test (Executive function)
```{r}
m2 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, gml)
summary(m2)

 p1 <- ggplot(m2[["model"]], aes(color=group_2grp, x=(wtar_standard-mean(wtar_standard)), y=score)) + 
   geom_point() + geom_smooth(method="lm")+ xlab("IQ estimate (mean-centered)") + ylab("GML performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
 
   p1 <- ggplot(m2[["model"]], aes(color=group_2grp, x=group_2grp, y=score)) + 
   geom_boxplot()+ geom_point() + xlab("group") + ylab("GML performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ wtar_standard>=mean(wtar_standard)) 
 p1
```
(In the above plot, TRUE = standardized WTAR is above the sample mean)


### Groton maze learning test - delayed recall (Memory)

```{r}
m3 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, gmr)
summary(m3)

 p1 <- ggplot(m3[["model"]], aes(color=group_2grp, x=(wtar_standard-mean(wtar_standard)), y=score)) + 
   geom_point() + geom_smooth(method="lm")+ xlab("IQ estimate (mean-centered)") + ylab("GMR performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
 
   p1 <- ggplot(m3[["model"]], aes(color=group_2grp, x=group_2grp, y=score)) + 
   geom_boxplot()+ geom_point() +  xlab("group") + ylab("GMR performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ wtar_standard>=mean(wtar_standard)) 
 p1
```
(In the above plot, TRUE = standardized WTAR is above the sample mean)



### International shopping list - delayed recall (Verbal memory)
```{r}
m3 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, isrl)
summary(m3)

 p1 <- ggplot(m3[["model"]], aes(color=group_2grp, x=(wtar_standard-mean(wtar_standard)), y=score)) + 
   geom_point() + geom_smooth(method="lm")+ xlab("IQ estimate (mean-centered)") + ylab("ISRL performance (higher=better)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
 
   p1 <- ggplot(m3[["model"]], aes(color=group_2grp, x=group_2grp, y=score)) + 
   geom_boxplot()+ geom_point() +  xlab("group") + ylab("ISRL performance (higher=better)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ wtar_standard>=mean(wtar_standard)) 
 p1
```
(In the above plot, TRUE = standardized WTAR is above the sample mean)



<p>&nbsp;
<p>&nbsp;
<p>&nbsp;<p>&nbsp;
<p>&nbsp;<p>&nbsp;<p>&nbsp;<p>&nbsp;
# 11/30/21

## Number of exposures and CogState

```{r}
#fig.width=4, fig.height=8
dat <- data %>% select_at(vars(starts_with("use") & !ends_with(".y") | starts_with("age") | starts_with("WTCexposure_score") | starts_with("wtar") | starts_with("group"))) 
colnames(dat)<-gsub(".x","",colnames(dat))
datW <- dat %>% select(!matches('1$|2$|3$|4$|5$'))
datL<-gather(dat,key="test", value="score", -c(group,group_2grp,group_PTSDref,age,WTCposure_score,wtar_standard)) %>% filter(!is.na(score))

 p1 <- ggplot(datL, aes(color=test, y=WTCposure_score, x=score)) + 
   geom_point() + geom_smooth(method="lm")+ ylab("n exposures") + xlab("scores") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(. ~ test, ncol=2) 
 p1
```
 
```{r}
 summary(lm(use.GMR ~ WTCposure_score*group_2grp,datW))
 
  p1 <- ggplot(datW, aes(color=group_2grp, y=WTCposure_score, x=use.GMR)) + 
   geom_point() + geom_smooth(method="lm")+ ylab("n exposures") + xlab("scores") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
```

```{r}
 summary(lm(use.GML ~ WTCposure_score*group_2grp,datW))
 
  p1 <- ggplot(datW, aes(color=group_2grp, y=WTCposure_score, x=use.GML)) + 
   geom_point() + geom_smooth(method="lm")+ ylab("n exposures") + xlab("scores") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
```

```{r}
 summary(lm(use.IDN ~ WTCposure_score*group_2grp,datW))
 
  p1 <- ggplot(datW, aes(color=group_2grp, y=WTCposure_score, x=use.IDN)) + 
   geom_point() + geom_smooth(method="lm")+ ylab("n exposures") + xlab("scores") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
```

```{r}
 summary(lm(use.DET ~ WTCposure_score*group_2grp,datW))
 
  p1 <- ggplot(datW, aes(color=group_2grp, y=WTCposure_score, x=use.DET)) + 
   geom_point() + geom_smooth(method="lm")+ ylab("n exposures") + xlab("scores") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
```




# New analyses 11/28/21


## NEW: Premorbid IQ (WTAR)

### 3 groups
```{r}
# 3 groups, PTSD group is reference level
summary(lm(wtar_standard ~ group_PTSDref, data))

p1 <- ggplot(data, aes(color=group, y=wtar_standard, x=group)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#00BA38","#F8766D"),name="Group") + ylab("WTAR (higher=better)") + xlab("Group") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
```



### 2 groups
```{r}
 
# 2 groups, non-PTSD group is reference level
t.test(wtar_standard ~ group_2grp, data)

p1 <- ggplot(data, aes(color=group_2grp, y=wtar_standard, x=group_2grp)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#F8766D"),name="Group") + ylab("WTAR (higher=better)") + xlab("Group") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1

```





## NEW: CogState scores by group: Linear models (2 groups w/premorbid IQ & *REMOTE*)

2 groups: Non-PTSD (low-exposed controls & resilient); PTSD

Reference group = Non-PTSD

<font color="red">**NO participants in the PTSD group completed the CogState remotely so cannot look at interaction**</font>



```{r}
# get rid of duplicate vars (use non-imputed vs. imputed)
scoresW <- data %>% select_at(vars(starts_with("score") & !ends_with("inv") | starts_with("group") | starts_with("record") | starts_with("age") | starts_with("gender") | starts_with("edu") | starts_with("cogState_remote") | starts_with("wtar"))) 
colnames(scoresW)<-gsub(".x","",colnames(scoresW))
#scoresW <-scoresW %>% select(!matches('1$|2$|3$|4$|5$'))
use.scoresW<-scoresW %>% select_at(vars(starts_with("score")|starts_with("group")|starts_with("cogState_")))
colnames(use.scoresW)<-gsub("score.","",colnames(use.scoresW))

# # use imputed
# scores_imp <- data %>% select_at(vars(starts_with("use") & !ends_with(".x") | starts_with("group") | starts_with("record") | starts_with("age") | starts_with("gender") | starts_with("edu") | starts_with("wtar"))) 
# colnames(scores_imp)<-gsub(".y","",colnames(scores_imp))
# #colnames(scores_imp)<-gsub("use.","",colnames(scores))
# scores_imp <-scores_imp %>% select(!matches('1$|2$|3$|4$|5$'))
# use.scores.imp<-scores_imp %>% select_at(vars(starts_with("use")|starts_with("group")))

# wide to long
scoresL<-gather(scoresW, key="test", value="score", -c(record_id, group,group_PTSDref,group_2grp,age,gender,gender_1isM,gender_1isF,educationLevel,wtar_standard,cogState_remote))
scoresL<-scoresL %>% mutate(test = as.factor(test),
                           cogState_remote = as.factor(cogState_remote))
use.scoresL<-gather(use.scoresW,key="test", value="score", -c(group,group_PTSDref,group_2grp)) %>% filter(!is.na(score))

det <- scoresL %>% filter(test=="score.DET")
gml <- scoresL %>% filter(test=="score.GML")
gmr <- scoresL %>% filter(test=="score.GMR")
idn <- scoresL %>% filter(test=="score.IDN")
isl <- scoresL %>% filter(test=="score.ISL")
isrl <- scoresL %>% filter(test=="score.ISRL")
ocl <- scoresL %>% filter(test=="score.OCL")
onb <- scoresL %>% filter(test=="score.ONB")

data <- data%>% mutate(group_2grpBinary = ifelse(group_2grp=="PTSD",1,0))
data <- data%>% mutate(grp_x_wtar = (group_2grpBinary*wtar_standard))
```

### Detection test (Psychomotor function)

(not administered remotely)
```{r}
m1 <- lm(score ~ group_2grp*wtar_standard, det)
summary(m1)
```

### Groton maze learning test (Executive function)
```{r}
m2 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, gml)
summary(m2)

 p1 <- ggplot(m2[["model"]], aes(color=group_2grp, x=(wtar_standard-mean(wtar_standard)), y=score)) + 
   geom_point() + geom_smooth(method="lm")+ xlab("IQ estimate (mean-centered)") + ylab("GML performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ group_2grp) 
 p1
 
  p1 <- ggplot(m2[["model"]], aes(color=group_2grp, x=group_2grp, y=score)) + 
   geom_point() + geom_boxplot()+ xlab("IQ estimate (mean-centered)") + ylab("GML performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ wtar_standard>111) 
 p1
 
   p1 <- ggplot(m2[["model"]], aes(color=group_2grp, x=group_2grp, y=score)) + 
   geom_point() + geom_boxplot()+ xlab("IQ estimate (mean-centered)") + ylab("GML performance (higher=worse)") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16)) + facet_wrap(~ wtar_standard>111) 
 p1
```

### Groton maze learning - delayed recall test (Memory)
```{r}
m3 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, gmr)
summary(m3)

```

### Identification test (Attention)

(not administered remotely)

```{r}
m4 <- lm(score ~ group_2grp*wtar_standard, idn)
summary(m4)
```

### International shopping list test (Verbal learning)

```{r}
m5 <- lm(score ~ group_2grp*wtar_standard+cogState_remote, isl)
summary(m5)
```

### International shopping list - delayed recall test (Memory)
```{r}
m6 <- lm(score ~ group_2grp*wtar_standard + cogState_remote, isrl)
summary(m6)
```

### One-card learning test (Visual memory)

```{r}
m7 <- lm(score ~ group_2grp*wtar_standard + cogState_remote, ocl)
summary(m7)
```

### One-back test (Working memory)

(not administered remotely)

```{r}
m8 <- lm(score ~ group_2grp*wtar_standard, onb)
summary(m8)
```

### Composite score 

```{r}
m9 <- lm(compScore ~ group_2grp*wtar_standard + cogState_remote, data)
summary(m9)
```









# Previous
## CogState Mean/SD by group
### 3 groups
```{r}
scoreMeans<-scoresL %>% 
  group_by(test,group) %>%
  summarize(mean_score = mean(score, na.rm = TRUE), sd = sd(score,na.rm = TRUE))
print(scoreMeans,n=48)
```

### 2 groups
Non-PTSD = Low-exposed controls & Resilient
```{r}
scoreMeans2<-scoresL %>%
  group_by(test,group_2grp) %>%
  summarize(mean_score = mean(score, na.rm = TRUE), sd = sd(score,na.rm = TRUE))
print(scoreMeans2,n=32)
```

## Plots for CogState scores by group

### Plot all scores on same plot: 3 groups
 
```{r,fig.width = 10,fig.height = 20}
use.scores<-data %>% select_at(vars(starts_with("use") & ends_with("x")|starts_with("group")))
colnames(use.scores)<-gsub("use.","",colnames(use.scores))
colnames(use.scores)<-gsub(".x","",colnames(use.scores))
use.scores <- use.scores %>% select(!matches('1$|2$|3$|4$|5$'))
use.scores<-gather(use.scores,key="test", value="score", -c(group,group_PTSDref,group_2grp)) %>% filter(!is.na(score))



 p1 <- ggplot(use.scores, aes(color=group_PTSDref, y=score, x=group_PTSDref)) + 
   geom_boxplot() + geom_point() + 
  geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),name="Group") + ylab("(higher = better performance)") + xlab("Group") + facet_wrap(. ~ test, ncol=2) + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
# ggsave("/Volumes/External/WTC_resilience_imaging/data/cogstate_data/cogstate_by_group.png", plot = p1, dpi=600, width = 14, height = 10)
 
 # as a loop:
 # scorenames <- scoresW[, grep('^score', names(scoresW))] 
 #Z_cols=grepl("^score", names(scorenamesZ))
 #scorenamesZ[Z_cols]<-scale(scorenamesZ[Z_cols])
# for(i in 1:length(scorenames)) {
#   print(ggplot(scoresW, aes(y = scorenames[ , i], x=group, color=group)) +
#                                     geom_point() + scale_fill_manual(values=c("#619CFF", #"#00BA38", "#F8766D"), name="Group") +
#                                       xlab("Group") +
#                                       ylab(names(scorenames[ , i])))}

```

### Plot all scores on same plot: 2 groups (including Low-exposed)

```{r,fig.width = 10,fig.height = 20}

 p1 <- ggplot(use.scores, aes(color=group_2grp, y=score, x=group_2grp)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#F8766D"),name="Group") + ylab("Z-scaled score") + xlab("Group") + facet_wrap(. ~ test, ncol=2) + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
```

### Plot all scores on same plot: 2 groups (NOT including Low-exposed)

```{r,fig.width = 10,fig.height = 20}
use.scores.noLEC <- use.scores %>% filter(!group=="Low-Exposed Control")
 p1 <- ggplot(use.scores.noLEC, aes(color=group, y=score, x=group)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#F8766D"),name="Group") + ylab("Z-scaled score") + xlab("Group (NOT including low-exposed)") + facet_wrap(. ~ test, ncol=2) + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
```





```{r}
det <- scoresL %>% filter(test=="score.DET")
gml <- scoresL %>% filter(test=="score.GML")
gmr <- scoresL %>% filter(test=="score.GMR")
idn <- scoresL %>% filter(test=="score.IDN")
isl <- scoresL %>% filter(test=="score.ISL")
isrl <- scoresL %>% filter(test=="score.ISRL")
ocl <- scoresL %>% filter(test=="score.OCL")
onb <- scoresL %>% filter(test=="score.ONB")
```

### Detection
```{r}
p1 <- ggplot(det, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="group") + ylab("(lower = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>2.7|score<2.5,as.character(record_id),'')),hjust=0,vjust=0)
p1
print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))


```
 
### Groton maze learning
```{r}
 p1 <- ggplot(gml, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),name="Group") + ylab("(lower = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>80|score<30,as.character(record_id),'')),hjust=0,vjust=0)
 p1
print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```

### Groton maze learning - delayed recall
```{r}
 p1 <- ggplot(gmr, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(lower = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>=15|score<2.5,as.character(record_id),'')),hjust=0,vjust=0)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```
 
### Identification
```{r}
 p1 <- ggplot(idn, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(lower = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>2.81|score<2.65,as.character(record_id),'')),hjust=0,vjust=0)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```
 
### International shopping list
```{r}
 p1 <- ggplot(isl, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(higher = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>33|score<20,as.character(record_id),'')),hjust=0,vjust=0)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```
 
### International shopping list - delayed recall
```{r}
 p1 <- ggplot(isrl, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(higher = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>11|score<7,as.character(record_id),'')),hjust=0,vjust=0)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```
 
### One-card learning
```{r}
 p1 <- ggplot(ocl, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(higher = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>1.1|score<.85,as.character(record_id),'')),hjust=1,vjust=1)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```


### One-back test
```{r}
 p1 <- ggplot(onb, aes(color=group_PTSDref, y=score, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),
                     name="Group") + ylab("(lower = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(score>3|score<2.83,as.character(record_id),'')),hjust=0,vjust=0, max.overlaps = 15)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["score"]]))))
```
### Composite score

```{r}
 p1 <- ggplot(data, aes(color=group_PTSDref, y=compScore, x=group_PTSDref,label=record_id)) + 
       geom_boxplot() + geom_point() + scale_color_manual(values=c("#F8766D","#619CFF","#00BA38"),name="Group") + ylab("(higher = better performance)") + xlab("Group") +
                         geom_label_repel(aes(label=ifelse(compScore>.6|compScore<(-1),as.character(record_id),'')),hjust=0,vjust=0, max.overlaps = 12)
 p1
 print(paste0('n = ',sum(!is.na(p1[["data"]][["compScore"]]))))
```

## CogState scores by group: Linear models (3 groups)

3 groups: Low-exposed controls; Resilient; PTSD
Reference group = PTSD


### Detection test (Psychomotor function)
```{r}
det <- scoresL %>% filter(test=="score.DET")
gml <- scoresL %>% filter(test=="score.GML")
gmr <- scoresL %>% filter(test=="score.GMR")
idn <- scoresL %>% filter(test=="score.IDN")
isl <- scoresL %>% filter(test=="score.ISL")
isrl <- scoresL %>% filter(test=="score.ISRL")
ocl <- scoresL %>% filter(test=="score.OCL")
onb <- scoresL %>% filter(test=="score.ONB")

m1 <- lm(score ~ group_PTSDref, det)
summary(m1)
```

### Groton maze learning test (Executive function)
```{r}
m2 <- lm(score ~ group_PTSDref, gml)
summary(m2)
```

### Groton maze learning - delayed recall test (Memory)
```{r}
m3 <- lm(score ~ group_PTSDref, gmr)
summary(m3)
```

### Identification test (Attention)
```{r}
m4 <- lm(score ~ group_PTSDref, idn)
summary(m4)
```

### International shopping list test (Verbal learning)
```{r}
m5 <- lm(score ~ group_PTSDref, isl)
summary(m5)
```

### International shopping list - delayed recall test (Memory)
```{r}
m6 <- lm(score ~ group_PTSDref, isrl)
summary(m6)
```

### One-card learning test (Visual memory)
```{r}
m7 <- lm(score ~ group_PTSDref, ocl)
summary(m7)
```

### One-back test (Working memory)
```{r}
m8 <- lm(score ~ group_PTSDref, onb)
summary(m8)
```

### Composite score 
```{r}
m9 <- lm(compScore ~ group_PTSDref, data)
summary(m9)
```


## CogState scores by group: T-tests (2 groups)

2 groups: Non-PTSD (i.e, Low-exposed controls & Resilient); PTSD

### Detection test (Psychomotor function)
```{r}
t.test(score ~ group_2grp, det)
```

### Groton maze learning test (Executive function)
```{r}
t.test(score ~ group_2grp, gml)
```

### Groton maze learning - delayed recall test (Memory)
```{r}
t.test(score ~ group_2grp, gml)
```

### Identification test (Attention)
```{r}
t.test(score ~ group_2grp, idn)
```

### International shopping list test (Verbal learning)
```{r}
t.test(score ~ group_2grp, isl)
```

### International shopping list - delayed recall test (Memory)
```{r}
t.test(score ~ group_2grp, isrl)
```

### One-card learning test (Visual memory)
```{r}
t.test(score ~ group_2grp, ocl)
```

### One-back test (Working memory)
```{r}
t.test(score ~ group_2grp, onb)
```

### Composite score 
```{r}
t.test(compScore ~ group_2grp, data)
```




## MOCA

### MOCA score (3 groups)
```{r}

 p1 <- ggplot(data, aes(color=group, y=moca_score, x=group)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#00BA38","#F8766D"),name="Group") + ylab("MOCA (higher=better)") + xlab("Group") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
```


### MOCA score (2 groups)

Non-PTSD = resilient & low-exposed controls.

```{r}

 p1 <- ggplot(data, aes(color=group_2grp, y=moca_score, x=group_2grp)) + 
   geom_boxplot() + geom_point() + geom_jitter(width = 0.1) +
   scale_color_manual(values=c("#619CFF","#F8766D"),name="Group") + ylab("MOCA (higher=better)") + xlab("Group") + theme_bw(base_size = 16) + theme(legend.text = element_text(size=16), axis.ticks = element_blank(),axis.text.x=element_text(size=16, angle=90, hjust = 0.95))
 p1
 
```
