-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreport.Rmd
420 lines (317 loc) · 49.1 KB
/
report.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
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
---
title: Assessing the Impact of Exclusive Extreme Response Style on Estimation of the
Treatment Effect in Randomized Control Group Designs
author: "Emily Mo"
bibliography: 'bibliography.bib'
header-includes:
- \usepackage{placeins}
output: pdf_document
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, message = FALSE, warning = FALSE)
knitr::knit_hooks$set(plot = function(x, options) {
paste0(knitr::hook_plot_tex(x, options), "\n\\FloatBarrier\n")
})
library(stringr)
library(knitr)
library(xtable)
library(float)
library(cowplot)
library(tidyverse)
options(xtable.comment = FALSE)
mdf5r <- as.data.frame(read.csv('mdf.05.18.csv'))
mdf5r <- mdf5r[,(2:ncol(mdf5r))]
mdf5r <- mdf5r[rowSums(is.na(mdf5r)) != ncol(mdf5r),]
# CHANGED MDF5 TO EXCLUDE PCT GREATER THAN 0.4
mdf5 <- mdf5r[mdf5r$pct <= 0.4,]
# Transform variables for easier interpretation
mdf5$pct_10 <- mdf5$pct * 10 # unit increase = increase pct by 10%
mdf5$shift_0.2 <- mdf5$shift / 0.2 # unit increase = increase skew by 0.2
```
# Abstract
Respondents to Likert-type surveys tend to interpret or respond to the levels of the Likert scale differently depending on factors such as cultural background or different personality traits. One common type of response style is the Exclusive Extreme pattern, in which respondents only select the extreme options on the Likert-type response scale. Data was simulated to mimic a balanced research design in which participants are randomly assigned to a treatment or control condition and respond to pre- and post-intervention surveys. Data was simulated to mimic a moderate treatment effect size. Using structural equation modeling to estimate the treatment effect on the latent variable measured by the survey instrument, an increased proportion of respondents using the Exclusive Extreme response style has a minimal effect on the statistical estimation of the treatment effect. However, as skewness increases in distributions of manifest item responses (on the ordinal response scale), an increased presence of the Exclusive Extreme response style has an increasingly depressive effect on the estimation of the treatment effect. Additionally, an increased number of items on the Likert scale intensifies the negative effect of response style contamination on the treatment effect. Thus, high proportions of the Exclusive Extreme response style in survey respondents may cause treatments to appear less powerful than they actually are, which can lead to the mistaken rejection of effective treatments in domains such as education, psychology, and medicine.
# Introduction
The Likert scale is an ordinal response system commonly used on survey measures, and it can have two or more items on the scale, most commonly representing a range of agreement from “strongly disagree” to “strongly agree”. The responses to each question help to quantify an unobservable quality in respondents, which is referred to as a *construct*: for instance, a respondent’s self-reported understanding of an academic concept, or the extent to which a respondent is open to new experiences. This construct is associated, to a varying degree per question, with an individual’s responses to each question. The construct is assumed to be Normally distributed across the population. To generate a response to a particular question, we envision that the construct is multiplied by a constant corresponding to the question’s degree of association with the construct, and then displaced by a random Normally distributed error, producing a numeric value on a continuous scale. Then, responses to Likert-type survey questions can be viewed as a transformation from this value on a continuous scale—which represents the theoretical true extent to which the respondent agrees with the question’s prompt—to an ordinal value on the Likert scale. An individual’s raw continuous response to a question is considered to be an objective Normally distributed score that would be comparable across different individuals if it were observable; however, this response cannot possibly be observed because there are no objective and absolutely comparable means of self-reporting the extent to which one agrees with a survey question. The process of transforming an unobservable continuous response into an observable ordinal response is considered to be modeleable by partitioning the continuous response scale into the same number of sections as the number of items on the question’s Likert scale. We refer to the cutoff points of the partitions as *Tau cuts*.
Typically, we assume Tau cuts divide the Normal distribution symmetrically such that the lowest partition of the continuous scale translates to the lowest Likert scale item, the second-lowest partition of the continuous scale translates to the second-lowest Likert scale item, and so on. Such a partitioning style lacks a response style, or can be called a “neutral” response style, because it represents the way in which respondents are expected to answer Likert-type questions. However, the manner in which respondents answer survey questions often deviates from the neutral response style. For instance, some respondents may select the same item on the Likert scale for all questions regardless of their true latent continuous response. Under what is called the Exclusive Extreme response style, which we focus on in this study, a respondent only selects one of the two most extreme items on the Likert scale. Responding in such a manner increases the variation in Likert-type responses compared to a neutral response style, and essentially compresses the information from the respondent’s true unobserved continuous responses, so the presence of the response style may affect the statistical inference of associative measures based on the survey’s responses. Use of the Exclusive Extreme response style was found to be more prevalent among more individualist cultures and dominant personality types [@johnson_relation_2005], or in the presence of economic or climactic instability [@he_extreme_2016]. Therefore, if the response style majorly impacts statistical estimates based on survey data, then two groups that are fundamentally identical in terms of the construct that a survey is measuring could come across as different simply because one group has a higher proportion of exclusively extreme-responding respondents than the other.
Structural Equation Modeling (SEM), which defines directional relationships between multiple variables that can be either latent and observed, is a common statistical modeling framework used to analyze survey data in the social sciences. In SEM, relationships between variables are represented by parameters that indicate the strength of the relationships. When survey data is assumed to be generated by a certain system of structural equations, models can be used to estimate the true parameters of that system based on the data. The results returned through SEM inference are affected by the function that transforms a respondent’s true unobserved responses into observed discrete Likert-type responses. Therefore, a large presence of the Exclusive Extreme response style in survey data may blur the apparent relationship between treatment group assignment and post-survey outcomes. Given existing literature about the prominence of the Exclusive Extreme response style and our understanding of how the response style may affect SEM outputs, we specifically hypothesized that an increasing presence of Exclusive Extreme response style introduces an increasing amount of bias into a treatment effect estimated through SEM from pre- and post-intervention survey data in a randomized control study.
Furthermore, previous studies have discussed the commonly asymmetric shape of ordinal distributions of Likert-type questions, particularly respondents’ bias towards the options near the left side of the scale [@friedman_biasing_1993]. This bias can be envisioned as the distribution of continuous responses, which is typically Gaussian in shape, getting mapped to an ordinal scale by Tau cuts that are asymmetrically distributed about that continuous distribution’s mean. Because a high-skew ordinal scale fails to carry the symmetry of its underlying continuous distribution, we also hypothesized that an increase in skewness leads to heightened bias in the estimation of the treatment effect in the presence of the Exclusive Extreme response style.
Since the transformation between continuous response and ordinal Likert-type response is unobservable, and since the true treatment effect parameter is impossible to know in real life and can only be estimated with statistical methods, there is no way to detect bias in treatment effect estimation using real survey data. In order to evaluate the accuracy of statistical inference in estimating an unobservable parameter, it is necessary to simulate many randomized control experiments with the same design, whose treatment effects were gauged through analyzing a pre- and post-intervention survey. This simulation process included the random generation of numeric values that represent the constructs that underlie each respondent’s responses, as well as creation of a basic structural equation model that uses a predetermined treatment effect to transform the constructs into responses for the two surveys. Each simulation represents a survey response body of a large fixed sample size. Certain parameters of choice can be held constant across all simulations (in our case, for instance, the treatment effect parameter is held constant), while other features of either the survey or the respondents can be varied in each simulation. After the generation of a large number of simulations, we use the method of confirmatory factor analysis (CFA) on our structural equation model for each simulation, which returns an estimate for the coefficient corresponding to the intervention’s effect on the post-intervention construct. Path coefficients returned through CFA indicate the estimated magnitude and direction of associations between factors in the structural equation model. Because the true population-wide treatment effect coefficient is known under this simulated survey, and because it is controlled across all simulations, a linear regression can then be run to evaluate how the estimated treatment effect varies with different survey data features.
# Methods
All simulations^[Code to generate these simulations can be found at https://github.com/emilymo008/survresponsestyles .] were based on a structural equation model involving a pre-intervention survey and a post-intervention survey with identical questions, and a treatment administered during the time between the two surveys. Path coefficients were drawn from pre-intervention survey construct to post-intervention survey construct, from treatment assignment to post-intervention survey construct, and from each survey to its respective survey items. The path coefficient from the pre-intervention construct to post-intervention construct was held at 0.5, and represents a moderate treatment effect that we focus on for our study. The path coefficient from the pre-intervention construct to the post-intervention construct was held at 0.3, and the variance of the post-intervention survey was held at 1 to use as a reference point. The number of respondents per simulation was held at 250, and the number of the items on both pre- and post-intervention surveys was held at 15.
We chose to manipulate the following experimental variables across simulations: percentage of respondents using Exclusive Extreme responses, number of items on the Likert scale, skewness of ordinal distribution. We will henceforth refer to the percentage of respondents who used Exclusive Extreme response style as *percent contamination*. The percent contamination in the pool ranged from 0 to 39 in increments of 3. The number of items on the Likert scale varied throughout the values 4, 5, 6, 7, and 11. The amount of skew in the cutoff points ranged from -1 to 1 in increments of 0.2—with no skew, the cutoff points are symmetrically distributed about the mean. For each combination of experimental variables, we generated 1000 simulation iterations. This resulted in a total of 770,000 randomized control group simulations that were perfectly balanced across our experimental variables.
In each simulation iteration, using probability distribution functions in R, we first randomly generated values from a standard Normal distribution to represent a construct for the 250 respondents. For each of the 15 items on the survey, we randomly generated moderate factor loadings ranging from 0.45 to 0.85 from a Uniform distribution, as well as Normally distributed random errors, and used these values to generate each respondent’s true continuous response values based on our structural equation model.
Next, we assigned Tau cuts to partition the continuous distribution of survey responses into an ordinal scale representing the items on a Likert scale. The Tau cuts were determined by the number of items on the surveys’ Likert scales, the response style that an individual respondent used (either neutral or Exclusive Extreme), and the amount of skewness assigned to the ordinal distribution. Using these Tau cuts, we created Likert-type survey data for each of the respondents.
# Results
## Influence of the Response Style and Likert Skewness on Estimated Treatment Effect
After generating the data set, we first ran a regression of estimated treatment effect based on percent contamination and skewness using the following model structure, where *Y* represents estimated treatment effect, *p* represents percent contamination in increments of 10, *s* represents Tau cut skew in increments of 0.2, $\epsilon$ represents random error, and $\beta$s represent regression coefficients:
\[
\makebox[\linewidth]{$Y = \beta_0 + \beta_1p + \beta_2s + \beta_3s^2 + \epsilon$}
\]
```{r}
#### Preliminary model assessing percent contamination and skewness ####
pm1 <- lm(post.trt ~ pct_10 + shift_0.2 + I(shift_0.2^2), data = mdf5)
#### Add interaction to ^ ####
pm2 <- lm(post.trt ~ pct_10 + shift_0.2 + I(shift_0.2^2) + pct_10*I(shift_0.2^2), data = mdf5)
```
The linear term of percent contamination and the quadratic term of skewness both had a moderate negative effect on the estimated treatment effect, while the linear term of skewness did not appear to have a contribution to the estimated treatment effect. This output suggests that both presence of the Exclusive Extreme response style and skewness of the ordinal response distribution individually can lead to underestimation of the estimated treatment effect. After adding an interaction term, $(s^2)*p$, to the model between the quadratic term of skewness and percent contamination (see Table 1 in appendix), the coefficient of this term also had a moderate negative effect on the treatment effect estimate, suggesting that as skewness increases, the negative influence of percent contamination on estimated treatment effect is compounded at an increasingly higher rate. After observing an upward-facing parabolic pattern in the plot of fitted values vs. residuals, we decided that adding a quadratic term of percent contamination would be useful, since it would capture this remaining pattern in the residuals. This parabolic pattern suggested that the estimated treatment effect decreases at a progressively slower rate as percent contamination increases constantly and skewness is held constant.
Next, we fit individual models (see Table 2 in appendix) on the data for each level of skewness (from -1 to 1 in increments of 0.2, resulting in 11 total models), with terms for percent contamination up to the third degree. This way, we can compare the coefficients of each model in order to more easily assess percent contamination’s changing impact on estimated treatment effect as skewness increases. These models are represented by the following structure, in which *Y* represents estimated treatment effect, *p* represents percent contamination in increments of 10, *j* represents one of the skewness levels in the simulation, $\epsilon$ represents error, and $\beta$s represent regression coefficients:
\[
\makebox[\linewidth]{$Y_j = \beta_{0j} + \beta_{1j}p + \beta_{2j}p^2 + \beta_{3j}p^3 + \epsilon$}
\]
```{r}
#### Individual models by skew, with just percent contamination as predictor ####
skew1a <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == -1,])
skew1b <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == -0.8,])
skew1c <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == -0.6,])
skew1d <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == -0.4,])
skew1e <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == -0.2,])
skew1f <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 0,])
skew1g <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 0.2,])
skew1h <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 0.4,])
skew1i <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 0.6,])
skew1j <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 0.8,])
skew1k <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5[mdf5$shift == 1,])
#### Coefficient table for above models ###
skew1_coeff <- rbind(skew1a$coefficients, skew1b$coefficients, skew1c$coefficients, skew1d$coefficients, skew1e$coefficients, skew1f$coefficients, skew1g$coefficients, skew1h$coefficients, skew1i$coefficients, skew1j$coefficients, skew1k$coefficients) %>% data.frame()
skew1_coeff <- cbind(seq(-1, 1, 0.2), skew1_coeff)
colnames(skew1_coeff) <- c('skew', 'int', 'lin', 'quad', 'cub')
#### Coefficient and standard error table for above models ####
skew1_se <- rbind(summary(skew1a)$coefficients[,2], summary(skew1b)$coefficients[,2], summary(skew1c)$coefficients[,2], summary(skew1d)$coefficients[,2], summary(skew1e)$coefficients[,2], summary(skew1f)$coefficients[,2], summary(skew1g)$coefficients[,2], summary(skew1h)$coefficients[,2], summary(skew1i)$coefficients[,2], summary(skew1j)$coefficients[,2], summary(skew1k)$coefficients[,2]) %>% data.frame
skew1_se <- cbind(seq(-1, 1, 0.2), skew1_se)
colnames(skew1_se) <- c('skew', 'int', 'lin', 'quad', 'cub')
skew1_tbl <- cbind(seq(-1, 1, 0.2), (paste(as.matrix(skew1_coeff[,2:ncol(skew1_coeff)]) %>% formatC(digits = 3), ' (',
as.matrix(skew1_se[2:ncol(skew1_coeff)]) %>% formatC(digits = 3), ')', sep = '') %>%
matrix(nrow = nrow(skew1_coeff)))) %>% as.data.frame()
colnames(skew1_tbl) <- c('Skewness', 'Intercept', '10\\% Contamination', '10\\% Contamination$^2$', '10\\% Contamination$^3$')
```
The coefficients of these models reinforce the earlier finding that percent contamination has a negative impact on estimated treatment effect even when Likert-type survey data is not skewed. Even for the data in which the ordinal distribution of responses was completely symmetric, the corresponding model suggests that the estimated treatment effect still decreases as percent contamination increases—however, the estimated treatment effect begins to plateau around a percent contamination level of 0.4, by then already having fallen to 0.49. Such a bias is displayed in Figure 1: when the original tau cuts are skewed by a magnitude of 1, a percent contamination of 0.4 lowers the estimated treatment effect by more than 10%, whereas in the lack of a response style, a percent contamination of 0.4 only lowers the estimated treatment effect by a bit more than 2%. Skewness in the ordinal response distribution further impacts estimated treatment effect—models corresponding to greater magnitudes of skewness tend to have lower estimated treatment effects for uncontaminated data. Altogether, skewness of the ordinal response distribution combined with a high presence of the Exclusive Extreme response style can greatly bias a treatment effect approximated through SEM.
```{r, fig.cap = 'Smooth Curve of Effect of Percent Contamination on Estimated Treatment Effect, Grouped by Skewness', out.height = "40%", fig.align = 'center'}
#### Graphics for those first set of by-skew models ^ ####
# graph 1
main1 <- ggplot() +
geom_smooth(data = mdf5[mdf5$shift >= 0 & mdf5$shift <= 1,], aes(x = pct, y = post.trt, color = as.factor(shift)), method = lm, alpha = 0.2, formula = y ~ x + I(x^2) + I(x^3)) +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'greenyellow')) +
xlab('Percent Contamination') + ylab('Estimated Treatment Effect')
# graph 2
main2 <- ggplot() +
geom_smooth(data = mdf5[mdf5$shift >= -1 & mdf5$shift <= 0,], aes(x = pct, y = post.trt, color = as.factor(shift)), method = lm, alpha = 0.2, formula = y ~ x + I(x^2) + I(x^3)) +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'greenyellow'))) +
xlab('Percent Contamination') + ylab('Estimated Treatment Effect')
plot_grid(main1, main2, align = 'h')
```
## Influence of Likert Granularity on Estimated Treatment Effect
We next sought to understand whether Likert scale granularity had an effect on the estimated treatment effect, or whether there existed an interaction with the observed effects of percent contamination and skewness. We fit a preliminary model (see Table 3 in appendix) of the following structure, where Y represents treatment effect estimate, *p* represents percent contamination in increments of 10, *s* represents skewness in increments of 0.2, *g* represents Likert scale granularity as a factor, $\epsilon$ represents error, and $\beta$s represent regression coefficients:
\[
\makebox[\linewidth]{$Y = \beta_0 + \beta_1s + \beta_2p + \beta_3g + \epsilon$}
\]
```{r}
#### Granularity models ####
mdf5$gran <- as.factor(mdf5$gran)
pm5 <- lm(post.trt ~ shift_0.2 + pct_10 + gran, data = mdf5)
```
The outputs of these models show no clear monotonic pattern from increasing the granularity of the Likert scale: the granularity coefficients suggest that when the values of percent contamination and squared skewness are held constant, we can expect the estimated treatment effect of a 5-granularity survey to be lower than that of a 4-granularity survey, that of a 6-granularity survey to be lower than that of a 5-granularity survey, that of a 7-granularity survey to be higher than that of a 6-granularity survey, and that of an 11-granularity survey to be lower than even that of a 6-granularity survey. Although the p-values of these coefficients are all very low, it is common to obtain near-zero p-values given such a high sample size, and there was no obvious explanation for the coefficients’ lack of monotonicity as granularity increases, so it was inconclusive from this model whether Likert granularity has a clear effect on the estimated treatment effect.
To better examine how the influence of granularity varies at different levels of skewness, we again fit individual models (see Table 4 in appendix) on the data for each skewness level, but this time predicted estimated treatment effect with percent contamination and Likert scale granularity, including an interaction term between granularity and percent contamination. This model structure is represented below, where *Y* represents estimated treatment effect, *p* represents percent contamination, *g* represents Likert scale granularity, *j* represents a skewness level, $\epsilon$ represents error, and $\beta$s represent regression coefficients:
\[
\makebox[\linewidth]{$Y_j = \beta_{0j} + \beta_{1j}p + \beta_{2j}p^2 + \beta_{3j}p^3 + \beta_{4j}g + \beta_{5j}p_j*g_j + \epsilon$}
\]
```{r}
# By-skew models with gran
skew2a <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == -1,])
skew2b <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == -0.8,])
skew2c <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == -0.6,])
skew2d <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == -0.4,])
skew2e <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == -0.2,])
skew2f <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 0,])
skew2g <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 0.2,])
skew2h <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 0.4,])
skew2i <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 0.6,])
skew2j <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 0.8,])
skew2k <- lm(post.trt ~ pct_10 + I(pct_10^2) + I(pct_10^3) + gran + pct_10*gran, data = mdf5[mdf5$shift == 1,])
# Coefficient table for gran models
skew2_coeff <- rbind(skew2a$coefficients, skew2b$coefficients, skew2c$coefficients, skew2d$coefficients, skew2e$coefficients, skew2f$coefficients, skew2g$coefficients, skew2h$coefficients, skew2i$coefficients, skew2j$coefficients, skew2k$coefficients) %>% data.frame()
skew2_coeff <- cbind(seq(-1, 1, 0.2), skew2_coeff)
colnames(skew2_coeff) <- c('skew', 'int', 'pct_lin', 'pct_quad', 'pct_cub', 'gran5', 'gran6', 'gran7', 'gran11', 'pctXgran5', 'pctXgran6', 'pctXgran7', 'pctXgran11')
# Coefficient and standard error table for gran models
skew2_se <- rbind(summary(skew2a)$coefficients[,2], summary(skew2b)$coefficients[,2], summary(skew2c)$coefficients[,2], summary(skew2d)$coefficients[,2], summary(skew2e)$coefficients[,2], summary(skew2f)$coefficients[,2], summary(skew2g)$coefficients[,2], summary(skew2h)$coefficients[,2], summary(skew2i)$coefficients[,2], summary(skew2j)$coefficients[,2], summary(skew2k)$coefficients[,2]) %>% data.frame
skew2_se <- cbind(seq(-1, 1, 0.2), skew2_se)
colnames(skew2_se) <- c('skew', 'int', 'pct_lin', 'pct_quad', 'pct_cub', 'gran5', 'gran6', 'gran7', 'gran11', 'pctXgran5', 'pctXgran6', 'pctXgran7', 'pctXgran11')
skew2_tbl <- cbind(seq(-1, 1, 0.2), (paste(as.matrix(skew2_coeff[,2:ncol(skew2_coeff)]) %>% round(5), ' (',
as.matrix(skew2_se[2:ncol(skew2_coeff)]) %>% round(5), ')', sep = '') %>%
matrix(nrow = nrow(skew2_coeff))))
colnames(skew2_tbl) <- c('Skewness' , 'Intercept', '10\\% Contamination', '10\\% Contamination$^2$', '10\\% Contamination$^3$',
'Likert Granularity = 5', 'Likert Granularity = 6', 'Likert Granularity = 7', 'Likert Granularity = 11',
'10\\% Contam. $\\times$ Gran. 5', '10\\% Contam. $\\times$ Gran. 6', '10\\% Contam. $\\times$ Gran. 7',
'10\\% Contam. $\\times$ Gran. 11')
```
Figure 2 is a visualization of the coeffcients in these models which decomposes the complex interactions between percent contamination, Likert granularity, and skewness represented in this set of models. Each subplot is conditioned on a different value of percent contamination—for simplicity, there is a subplot for 0, 10, 20, 30, and 40 percent contamination. Within each subplot, the horizontal axis represents a Likert granularity level of either 5, 6, 7, or 11, and the vertical axis represents the term for the corresponding granularity level added to the interaction term under the specified percent contamination level, which is equal to the expected change in estimated treatment effect from a granularity level of 4 to the specified level. This effect size is plotted as a separate point for each combination of skewness level and granularity level greater than 4, and colored based on skewness.
Based on Figure 2, the models’ estimated difference in treatment effect compared to a granularity level of 4 generally becomes more negative as percent contamination increases, under a constant granularity level. This can be seen by the dots generally moving down as percent contamination increases. This observation may suggest that with an increasingly high presence of the Exclusive Extreme response style in the survey results, a Likert granularity of 4 is expected to have an increasingly smaller negative bias in estimated treatment effect compared to higher granularity levels. Furthermore, the coefficients for each of the granularity levels seem more grouped together around zero when there is zero percent contamination, suggesting that when there is no response style present, there may be a negligible difference between different granularity levels in terms of bias on the treatment effect estimate. However, despite the evidence that different granularity levels have different effects from one another when the response style is present, there is still no consistent pattern in the effect size among the different granularity levels, so we cannot claim that the bias in estimated treatment effect becomes steadily more severe as percent contamination increases.
From Figure 2, we can also see that within each granularity level, the influence of skewness on the effect of granularity appears to reverse as percent contamination increases: at low contamination levels, models fitted on higher-skewed data tend to identify a fixed granularity level of 5, 6, 7, or 11 as being associated with a less negative expected difference in estimated treatment effect from a granularity level of 4, compared to the models fitted on lower-skewed data. However, once percent contamination increases past a certain point (in this case, around 30% contamination), that relationship seems to get inverted due to an apparent interaction between skewness and percent contamination, and so models fitted on higher-skewed data now begin to identify a fixed granularity level of 5, 6, 7, or 11 as being associated with a more negative expected difference in estimated treatment effect from a granularity level of 4, compared to the models fitted on lower-skewed data. Therefore, at lower skewness magnitudes, there appears to be less of a difference in the effects of different granularity levels.
```{r}
#### Plot of effect of gran for various pct levels, grouped color-wise by shift
# transform table so there's a row per gran level (5, 6, 7, 11) per skew model
skew2_tbl_pivot <- pivot_longer(skew2_coeff, cols = starts_with('gran'), names_to = 'gran', values_to = 'gran_coef',
names_prefix = 'gran') %>%
pivot_longer(cols = starts_with('pctXgran'), names_to = 'gran2', values_to = 'pctXgran_coef', names_prefix = 'pctXgran') %>%
filter(gran == gran2) %>% select(-gran2) %>%
mutate(
effect_pct40 = gran_coef + pctXgran_coef*4,
effect_pct30 = gran_coef + pctXgran_coef*3,
effect_pct20 = gran_coef + pctXgran_coef*2,
effect_pct10 = gran_coef + pctXgran_coef*1,
effect_pct0 = gran_coef + pctXgran_coef*0
)
# Positive skews only
## PCT = 0.4
pct40 <- ggplot(data = skew2_tbl_pivot %>% filter(skew >= 0), # only looking at one side of the skew
aes(x = as.integer(gran), y = effect_pct40, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 40 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4')) +
ylim(-0.05, 0.01)
## PCT = 0.3
pct30 <- ggplot(data = skew2_tbl_pivot %>% filter(skew >= 0),
aes(x = as.integer(gran), y = effect_pct30, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 30 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4')) +
ylim(-0.05, 0.01)
## PCT = 0.2
pct20 <- ggplot(data = skew2_tbl_pivot %>% filter(skew >= 0),
aes(x = as.integer(gran), y = effect_pct20, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 20 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4')) +
ylim(-0.05, 0.01)
## PCT = 0.1
pct10 <- ggplot(data = skew2_tbl_pivot %>% filter(skew >= 0),
aes(x = as.integer(gran), y = effect_pct10, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.5, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 10 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4')) +
ylim(-0.05, 0.01)
## PCT = 0
pct0 <- ggplot(data = skew2_tbl_pivot %>% filter(skew >= 0),
aes(x = as.integer(gran), y = effect_pct0, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.5, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 0 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4')) +
ylim(-0.05, 0.01)
# Negative skews only
## PCT = 0.4
pct40neg <- ggplot(data = skew2_tbl_pivot %>% filter(skew <= 0),
aes(x = as.integer(gran), y = effect_pct40, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 40 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4'))) +
ylim(-0.05, 0.01)
## PCT = 0.3
pct30neg <- ggplot(data = skew2_tbl_pivot %>% filter(skew <= 0),
aes(x = as.integer(gran), y = effect_pct30, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 30 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4'))) +
ylim(-0.05, 0.01)
## PCT = 0.2
pct20neg <- ggplot(data = skew2_tbl_pivot %>% filter(skew <= 0),
aes(x = as.integer(gran), y = effect_pct20, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 20 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4'))) +
ylim(-0.05, 0.01)
## PCT = 0.1
pct10neg <- ggplot(data = skew2_tbl_pivot %>% filter(skew <= 0),
aes(x = as.integer(gran), y = effect_pct10, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 10 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4'))) +
ylim(-0.05, 0.01)
## PCT = 0
pct0neg <- ggplot(data = skew2_tbl_pivot %>% filter(skew <= 0),
aes(x = as.integer(gran), y = effect_pct0, color = as.factor(skew))) +
geom_point(size = 5, alpha = 0.4, stroke = 0) +
ylab(str_wrap('Effect of Granularity with 0 Percent Contamination', width = 30)) + xlab('Granularity') +
scale_colour_manual(name="Skew", values = rev(c('orangered', 'coral', 'orange', 'darkgoldenrod1', 'gold1', 'springgreen4'))) +
ylim(-0.05, 0.01)
#### plot together:
granmtxplot <- plot_grid(pct0, pct10, pct20, pct30, pct40, pct0neg, pct10neg, pct20neg, pct30neg, pct40neg, ncol = 5, nrow = 2)
```
```{r, out.height = '50%', fig.width = 14, fig.cap = 'Effect Size of Various Likert Granularity Levels at Various Skewness Levels, Grouped by Percent Contamination'}
granmtxplot
```
## Influence of the Response Style on Standard Error of the Estimated Treatment Effect
The standard error of the estimated treatment effect is also computed within the confirmatory factor analysis. For our final investigation using this simulation data, we examine how this standard error is impacted by the presence of the Exclusive Extreme response style. We fit a model (see Table 5 in appendix) of the following form, where *S* represents standard error of the estimated treatment effect, *p* represents percent contamination, and $\epsilon$ represents error:
\[
\makebox[\linewidth]{$S = \beta_0 + \beta_1p + \beta_2p^2 + \beta_3p^3 + \epsilon$}
\]
```{r}
#### SE models ####
stde2 <- lm(post.trt.se ~ pct_10 + I(pct_10^2) + I(pct_10^3), data = mdf5)
```
The results of this model suggest that without controlling for other factors such as skewness and granularity, the standard error of the estimated treatment effect generally widens as percent contamination increases—for our data, the model’s expected standard error grew from about 0.045 under no contamination to about 0.048 under 40% contamination. Although the cubic model fits a slight curve to the data, the trajectory of the expected standard error as percent contamination increases is roughly linear. The residuals of this model appeared trendless, and adding terms for skewness and Likert granularity to the model yielded relatively small effect sizes despite low p-values, so we did not further consider models with these additional terms. A general increase in standard error is unsurprising as the response style becomes more prominent, because the response style brings an increased variation in the Likert-type responses resulting from the response style, which is expected to negatively impact the certainty of the treatment’s effect on the post-intervention survey. Combining this result with our analysis of the Exclusive Extreme response style’s impact on treatment effect estimate itself, we find that as the response style becomes more prominent, we become increasingly uncertain of the estimated treatment effect, which itself becomes increasingly biased.
# Discussion
Once a Likert-type survey response has been codified through the Exclusive Extreme response style, it is impossible to recover the response that would have resulted if the neutral response style was used. Because the Exclusive Extreme response style is so commonly used and we cannot necessarily prevent respondents from using this response style, it is useful to be aware of its biasing properties that this study highlights. Our simulations demonstrate that a heavy presence of the Exclusive Extreme response style in a group of respondents can make treatment coefficient estimates from structural equation models less trustworthy, because the response style binarizes the Likert scale and greatly reduces its precision in measuring continuous constructs. Our simulations also demonstrate that a more skewed underlying distribution of the target population’s ordinal responses can cause structural equation modeling methods to underestimate a treatment effect based on pre- and post- treatment surveys in a randomized control trial, and even more so in the presence of the Exclusive Extreme response style. Additionally, a higher presence of the Exclusive Extreme response style may lead to greater differences between different Likert scale granularity levels’ impacts on the estimated treatment effect. A higher presence of the response style can also modulate the direction of the effect that skewness has on each granularity level’s impact on the estimated treatment effect. Finally, we posit that the presence of the Exclusive Extreme Response Style in survey data steadily decreases the level of confidence that an estimated treatment effect lies within an arbitrary interval. While an increase in percent contamination augmented the standard error at a moderate rate under the chosen initial circumstances that we used to generate our data set, we avoid extrapolating effects beyond the domain of our data, and thus we cannot rule out the possibility of this impact on the standard error being more drastic under varying circumstances—for instance, under different survey lengths or sample sizes.
The most concerning limitation to this analysis is that we were unable to clearly define or justify the estimated change in the differences between different Likert scale granularity levels as percent contamination increased. Although the p-values for the coefficients of each granularity level were near zero across all of the models fitted on data of different skewness levels, the changes in these coefficients were not monotonic, and in fact very erratic, in relation to an increasing granularity level. It is possible that there is a complex tradeoff between compression and clarification of response information as the number of items on the Likert scale increases, which may result in a decrease and subsequent increase in bias of the estimated treatment effect. There is also the less likely possibility that the patterns observed in the differences between the granularity resulted from random chance. In order to better understand this relationship, further simulation studies can be conducted in which more levels of Likert granularity are explored, perhaps under a different random seed. If many simulations are run using different specified treatment effects, it may also be possible to formulate a model for the “tipping point” in percent contamination level, i.e. the point at which the influence of skewness on the effect of granularity is directionally reversed.
Another limitation of our analysis is that we cannot necessarily expect our models’ projections to be accurate upon extrapolating them beyond the percent contamination, skewness, and granularity levels present in the data on which the models were based. For instance, when other variables are held constant, the fitted values of estimated treatment effect decrease and then eventually increase again as percent contamination increases from 0, as is characteristic of its polynomial structure—however, in real life, we would expect the values to monotonically decrease, for it would be unlikely for the estimated treatment effect to recover its unbiasedness as percent contamination increases. Such monotonicity is expected because the Exclusive Extreme response style is a multiple-to-two mapping; thus, as the response style becomes more prevalent, more variation is introduced into the ordinal data, making it an increasingly imprecise representation of the respondents’ unobserved continuous responses, which consequently makes SEM estimation less able to detect a treatment effect.
Although this study brings forward the impact of the Exclusive Extreme response style on the structural equation modeling estimation of a moderate treatment effect, it does not consider scenarios with much stronger treatment effect sizes, in which a strong presence of the response style could possibly have a penalizing effect that is greater in magnitude, or scenarios with much weaker treatment effect sizes, in which a strong presence of the response style could possibly render the estimated treatment effect negligibly small. Additionally, the down-biasing effect of the response style, as well as its interactions with skewness and Likert scale granularity, may be exacerbated when the underlying treatment effect is larger.
Future research would ideally devise a correction for the bias in estimated treatment effect based on the detected presence of the Exclusive Extreme response style, Likert scale granularity, and estimated skewness of the ordinal response distribution. It may also be beneficial to devise a means of widening the confidence band about the treatment effect estimate in order to reflect our confidence in the presence of the response style and the skewness of the ordinal response distribution. The task of creating a compensatory method for the bias is complicated by the lack of reliable means of detecting the Exclusive Extreme response style and ordinal response skewness. Detection of the Exclusive Extreme response style can vary in difficulty depending on length of survey and number of extreme responses, and is a strictly subjective judgment. There also remains the possibility that all of a respondent’s unobserved continuous responses on a survey are genuinely extreme. Additionally, even if such a robust compensatory method existed, the amount of skewness of the tau cuts that transform the unobserved continuous response into the ordinal Likert-type response must be assumed in the survey’s target population based on empirical data, and a poorly estimated skew may result in over- or under-compensation. Discarding Exclusive Extreme responses altogether is not recommended because it may reduce the generalizability of survey results, especially since response styles can be correlated with cultural, social, or psychological traits. Overall, this simulated study is a great oversimplification of real-life survey scenarios because it creates an unrealistically controlled setting with very few non-constant variables, whereas in real life, for instance, there can be multiple response styles within a survey body, or we may not be able to assume uniform Tau cuts across the entire survey population. Such intricacies can make it even more difficult to detect the Exclusive Extreme response style or begin to understand how it may have affected the results of statistical analyses.
We assert that in a randomized control study setting that utilizes pre- and post-intervention surveys, a greater prominence of the Exclusive Extreme response style in a survey's responses leads to underestimation, and more uncertain estimation, of an intervention effect that the survey seeks to statistically estimate through confirmatory factor analysis. This underestimation is exacerbated when the distribution of the respondents’ underlying construct is asymmetric. Such a bias can lead to inequalities in survey result interpretation across demographics, since use of the Exclusive Extreme response style cannot be assumed to be independent from respondents’ cultural or social conditions. The amount of underestimation that occurs cannot be retrieved through examination of the survey responses, due to the unobservability of certain latent characteristics of the respondent body. Further research may explore attempts to harness the observable characteristics of the survey data to correct this bias. Survey researchers should pay close attention to the potential use of the Exclusive Extreme response style in their survey answers, and recognize that the true treatment effect may be higher than estimated if there is a large proportion of respondents who used this response style.
\newpage
# Appendix
## Table 1: Output of preliminary model of estimated treatment effect using percent contamination, skewness
```{r, results = "asis"}
names(pm2$coefficients) <- c('(Intercept)', '10\\% Contamination', 'Skewness (by 0.2)', 'Skewness (by 0.2)$^2$',
'Skewness (by 0.2)$^2 \\times$ 10\\% Contam.')
pm2tbl <- summary(pm2)$coefficients %>% round(4)
pm2tbl[pm2tbl == 0] <- '<2e-16'
print(xtable(pm2tbl), sanitize.text.function = function(x) {x})
```
## Table 2: Coefficients of individual models of estimated treatment effect using percent contamination, by skewness
Standard errors are parenthesized.
```{r, results = "asis"}
print(xtable(skew1_tbl, type = 'latex'),
sanitize.text.function = function(x) {x},
include.rownames = FALSE)
```
## Table 3: Output of preliminary model of estimated treatment effect using percent contamination, skewness, Likert granularity
```{r, results = "asis"}
names(pm5$coefficients) <- c('(Intercept)', 'Skewness (by 0.2)', '10\\% Contamination', 'Likert Granularity = 5',
'Likert Granularity = 6', 'Likert Granularity = 7', 'Likert Granularity = 11')
pm5tbl <- summary(pm5)$coefficients %>% round(4)
pm5tbl[pm5tbl == 0] <- '<2e-16'
print(xtable(pm5tbl), sanitize.text.function = function(x) {x})
```
## Table 4: Coefficients of individual models of estimated treatment effect using percent contamination and Likert granularity, by skewness
Standard errors are parenthesized.
```{r, results = "asis"}
print(xtable(skew2_tbl[,1:5], type = 'latex'),
sanitize.text.function = function(x) {x},
include.rownames = FALSE)
```
```{r, results = "asis"}
print(xtable(skew2_tbl[,c(1, 6:9)], type = 'latex'),
sanitize.text.function = function(x) {x},
include.rownames = FALSE)
```
```{r, results = "asis"}
print(xtable(skew2_tbl[,c(1, 9:12)], type = 'latex'),
sanitize.text.function = function(x) {x},
include.rownames = FALSE)
```
```{r, results = "asis"}
print(xtable(skew2_tbl[,c(1, 13)], type = 'latex'),
sanitize.text.function = function(x) {x},
include.rownames = FALSE)
```
\pagebreak
\FloatBarrier
## Table 5: Output of model of treatment effect standard error using percent contamination
```{r, results = "asis"}
names(stde2$coefficients) <- c('(Intercept)', '10\\% Contamination', '10\\% Contamination$^2$', '10\\% Contamination$^3$')
stde2tbl <- summary(stde2)$coefficients %>% round(4)
stde2tbl[stde2tbl == 0] <- '<2e-16'
print(xtable(stde2tbl), sanitize.text.function = function(x) {x})
```
\pagebreak
# Acknowledgements
Great thanks to Professor Allen G. Harbaugh of the Boston University Mathematics and Statistics department for supervising this project and introducing me to the complicated world of survey response styles.
# References