-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.Rmd
244 lines (162 loc) · 9.76 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>"
)
```
<!-- badges: start -->
[![R-CMD-check](https://github.com/AngelosPsy/multifear/workflows/R-CMD-check/badge.svg)](https://github.com/AngelosPsy/multifear/actions)
[![R-CMD-check](https://github.com/AngelosPsy/multifear/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/AngelosPsy/multifear/actions/workflows/R-CMD-check.yaml)
<!-- badges: end -->
# Multifear
Multifear is an R package designed to perform multiverse analyses for human conditioning data.
## Installing and loading the package
You can install via CRAN with the following command:
```{r, eval = FALSE}
install.packages("multifear")
```
For the development version, you can use the following command:
```{r, eval = FALSE}
# Install devtools package in case it is not yet installed
install.packages("devtools")
devtools::install_github("AngelosPsy/multifear")
```
The package can be loaded with the following code:
```{r}
library(multifear)
```
## Example 1 (within-subject design)
We will start with a basic example of how the package works. This example includes a single group. After that, we will see how we can run the same analyses when we want to test between group effects.
First let's load some additional packages that we need for our example.
```{r}
suppressPackageStartupMessages(library(dplyr))
suppressPackageStartupMessages(library(ggplot2))
```
Now we will use some simulated data set that are included as example data in the
`multifear` package. In principle, you can use any data including conditioned
responses (e.g., skin conductance). You can load the simulated data in your R environment as follows:
```{r}
data("example_data")
```
From these data we are going to select only the 10 first lines -- it saves a lot of time for computation for this example. Here are the first 10 rows of the data set:
```{r}
head(example_data, 10)
```
A bit of explanation of the column names. With the column name 'id' we denote the participant number. Columns that contain the conditioned responses for conditioned stimulus plus (CS+) are denoted with column names starting with 'CSP'. The number next to this name (1, 2, ..., 10) is the trial number. The same goes for columns starting with 'CSM' but these denote conditioned responses in CS- trials. At this point the package only supports a single CS+ and a single CS-. Also, the package assumes that trials are following each other -- so trial 2 comes after trial 1 etc.
Let's visualize the data (such visualizations are not available in the package but they can be carried out easily using the `graphics` or the `ggplot2` packages):
```{r}
datmelt <- example_data %>%
select(-id) %>%
colMeans() %>%
reshape2::melt(dat) %>%
mutate(variable = rownames(.)) %>%
mutate(cs = stringr::str_sub(variable, 1, 3),
time = stringr::str_sub(variable, 4, 5))
ggplot(data = datmelt, aes(x = time, y = value, group = cs)) +
geom_line(aes(linetype = cs)) +
geom_point(aes(shape = cs))
```
We see the basic learning pattern where CS+ responses end up being higher than CS- responses.
Now we need to analyse the data. For this we will use the *multifear::universe_cs* function. In order for this function to work, we need to provide the following arguments.
+ CS1: This will be the column names that contain the conditioned responses for the CS+ (i.e., CSP1 until CSP10).
+ CS2: This will be the column names that contain the conditioned response for the CS- (i.e., CSM1 until CSM10).
+ data: This is our data frame that contain that data for the CS+, CS-, as well as the column with the participant number.
+ group. In case of a group, then we need to specify the column with the group name. The default option is that there are no groups. In this first example we do not use any groups but we will do that in our second example -- see below.
+ phase. Here we define the conditioning phase that the data were collected in (e.g., acquisition phase, extinction phase, etc). Please note that in case the user has multiple phases, she/he needs to run the function separately for each phases.
There are some other options in the function, such as defining the type of conditioning response. However, these are not necessary for now. So, let's now run the function:
```{r, warning= FALSE}
cs1 <- paste0("CSP", 1:10)
cs2 <- paste0("CSM", 1:10)
example_data <- example_data[1:10, ]
res <- multifear::universe_cs(cs1 = cs1, cs2 = cs2, data = example_data,
subj = "id", group = NULL, phase = "acquisition", include_bayes = FALSE)
```
And here are the results:
```{r}
res
```
Let's go through each column separately
+ x : is the effect that you are testing. For example, the cs means that you are testing cs differences. cs:time the cs X time interaction is tested. Be careful: when testing interactions, we only report the highest order interaction. That means that if you have a cs x time interaction, you do not get the results of the cs or the time main effect.
+ y: the dependent variable. In the example this is the _scr_ responses.
+ exclusion: This columns reports as to what data were included in the data set. For example, here you see that we have only full data sets -- no exclusion. This is because the multifear::universe_cs() only analyses full data sets. If we want to apply some exclusion criteria, we need to run the multifear::multiverse_cs() function -- see later on.
+ model: What model was used. For example, here we see t-tests, and rep ANOVA (which means repeated measures ANOVA).
+ controls: This column is left empty. I included it because the specs R package had it so we may need to use it later on.
+ method: The method is a combination of the _model_ and _x_ column. Not really necessary if the other two columns exist.
+ p.value: The p-value of the test
+ estimate: The estimate that is returned from the test. Keep in mind though that this applies only for the t-test at the moment. We need to see what we can do for the ANOVA,
+ statistic. The statistic of the test
+ conf.low and conf.high In case you have an estimate, this returns the low and high levels of it
+ framework were the data analysed within a NHST or Bayesian framework?
+ data_used Here you have a data frame with the data used for the performed analyses. This is because someone maybe wants to recreate the results and also as a check that nothing went wrong.
Now, we want to perform the same analyses but for different data reduction procedures (see below). We can do it simply by:
```{r, warning = FALSE}
res_multi <- multifear::multiverse_cs(cs1 = cs1, cs2 = cs2, data = example_data,
subj = "id", group = NULL,
phase = "acquisition",
include_bayes = TRUE, include_mixed = TRUE)
res_multi
```
In terms of calling the function, we see that we need exactly the same
arguments as before. Internally, the function actually applies the
`multifear::universe_cs` but now apart from the full data set, also for the data sets with different data inclusion procedures. Whether each
line refers to the full data set or any of the exclusion criteria, we
can see on the column exclusion criteria or in the data_used column,
although there it is difficult to see what happened and it serves only
reproduction criteria. So, the easiest thing to do is to see the
exclusion column. Now, it has the following levels:
```{r}
res_multi$exclusion %>% unique()
```
The explanation of each level is the following:
1) fl2trials: first and last two trials.
2) fltrials: first and last trial
3) full_data: full data set
4) halves: use the first and last half of the trial. So, if you have 10 trials, you will have the first 5 and last 5 trials
5) min_first: take all trials apart from the first one
6) separate trials per 2
7) separate trials per 10%
8) separate trials per 33%
9) separate trials per 20%
## Inferences
This is the most challenging part. For now you can use the following function
and you will get:
1) A histogram will all the p value and a red line showing the significance
limit -- by default alpha = 0.05
2) A histogram will all the Bayes factors and a red line showing the limit of
inconclusive evidence -- by default this is 0
3) Mean and median p values
4) the number of p values below the significance level
5) Mean and median of Bayes factors
3) the proportion of Bayes factors above 1
```{r}
multifear::inference_cs(res_multi, na.rm = TRUE)
```
And here we have a barplot of the results:
```{r}
multifear::inference_plot(res_multi, add_line = FALSE)
```
Lastly, to plot the effect sizes, you can use the following function for the within-subjects effects:
```{r}
multifear::forestplot_mf(res_multi)
```
## Example 2 (within*between -subject design)
Importantly, `multifear` is able to run the same analyses as in example 1 even when groups are included. This can be simply done by defining the name of the column that includes the group levels (in the example data set that name is "group" but you can use any other name). Then, you can just run the same line of code as in example 1, after defying the group parameter, as follows:
```{r, warning = FALSE}
res_multi_group <- multifear::multiverse_cs(cs1 = cs1, cs2 = cs2,
data = example_data, subj = "id",
group = "group", phase = "acquisition",
include_bayes = TRUE, include_mixed = TRUE)
res_multi_group
```
Accordingly, the inference plots look as follows:
```{r}
multifear::inference_plot(res_multi_group, add_line = FALSE)
```
Lastly, here are the forestoplot for the second example:
```{r}
multifear::forestplot_mf(res_multi_group)
```