Plotting Likert Scales
Daniel Lüdecke
2024-11-29
library(dplyr)
library(sjPlot)
library(sjmisc)
library(parameters)
data(efc)
# find all variables from COPE-Index, which all have a "cop" in their
# variable name, and then plot that subset as likert-plot
mydf <- find_var(efc, pattern = "cop", out = "df")
plot_likert(mydf)
data:image/s3,"s3://crabby-images/7fe19/7fe194ed753935b3484e27e58cbcaf0cf00d3cff" alt=""
plot_likert(
mydf,
grid.range = c(1.2, 1.4),
expand.grid = FALSE,
values = "sum.outside",
show.prc.sign = TRUE
)
data:image/s3,"s3://crabby-images/7bdb0/7bdb048615949dc19e1d6abe110f61ff6301a898" alt=""
# Plot in groups
plot_likert(mydf, groups = c(2, 1, 1, 1, 1, 2, 2, 2, 1))
data:image/s3,"s3://crabby-images/43469/43469eb062e9634bca4363a903b5f1d49e089f4a" alt=""
pca <- parameters::principal_components(mydf)
groups <- parameters::closest_component(pca)
plot_likert(mydf, groups = groups)
data:image/s3,"s3://crabby-images/34d63/34d6325a3e2dd5b8e2870c561869b7c41cf62857" alt=""
plot_likert(
mydf,
c(rep("B", 4), rep("A", 5)),
sort.groups = FALSE,
grid.range = c(0.9, 1.1),
geom.colors = "RdBu",
rel_heights = c(6, 8),
wrap.labels = 40,
reverse.scale = TRUE
)
data:image/s3,"s3://crabby-images/17ec0/17ec06afb46e3034759a78fb8a35582b9e7ff7f5" alt=""
# control legend items
six_cat_example = data.frame(
matrix(sample(1:6, 600, replace = TRUE), ncol = 6)
)
six_cat_example <-
six_cat_example %>%
dplyr::mutate_all( ~ ordered(., labels = c("+++", "++", "+", "-", "--", "---")))
# Old default
plot_likert(
six_cat_example,
groups = c(1, 1, 1, 2, 2, 2),
group.legend.options = list(nrow = 2, byrow = FALSE)
)
data:image/s3,"s3://crabby-images/cee99/cee99f6e7a188b68b54e310486541291a8499f5c" alt=""
# New default
plot_likert(six_cat_example, groups = c(1, 1, 1, 2, 2, 2))
data:image/s3,"s3://crabby-images/47aa0/47aa09b4974460839bd1e12366d01ecb0a2fa6db" alt=""