1. Basic Setup
Yuki Atsusaka and Seo-young Silvia Kim
Source:vignettes/v1-basic-setup.Rmd
v1-basic-setup.Rmd
In this vignette, we show what the typical input data look like for
the rankingQ
package using the identity
dataset.
rankingQ
assumes a dataset that contains (1) responses
to ranking questions with J
items and (2) a binary
indicator for whether each respondent provides the correct answer to an
anchor-ranking question—an auxiliary ranking question whose correct
answer(s) are known to researchers. For example, the package features a
dataset identity
, which stores real-world survey responses
to a question that asks 1,082 respondents to rank four sources of
identity (partisanship, race, gender, and religion) based on their
relative importance to them.
library(rankingQ)
#> Error in get(paste0(generic, ".", class), envir = get_method_env()) :
#> object 'type_sum.accel' not found
#> Registered S3 method overwritten by 'GGally':
#> method from
#> +.gg ggplot2
data("identity")
Target ranking question
Ranking data are expected to be in the wide format, where multiple columns are used to represent different items and their values represent the items’ marginal ranks.
For example, in identity
, the four sources of identity
are app_party
, app_religion
,
app_gender
, and app_race.
For example, the
first respondent ranked party first, gender second, race third, and
religion fourth—i.e., “1423” is the respondent’s outcome, given the
reference choice set of party-religion-gender-race/ethnicity.
head(identity)
#> # A tibble: 6 × 16
#> s_weight app_identity app_identity_1 app_identity_2 app_identity_3
#> <dbl> <chr> <dbl> <dbl> <dbl>
#> 1 0.844 1423 1 4 2
#> 2 0.886 1423 1 4 2
#> 3 2.96 3412 3 4 1
#> 4 0.987 1423 1 4 2
#> 5 1.76 4132 4 1 3
#> 6 0.469 3124 3 1 2
#> # ℹ 11 more variables: app_identity_4 <dbl>, anc_identity <chr>,
#> # anc_identity_1 <dbl>, anc_identity_2 <dbl>, anc_identity_3 <dbl>,
#> # anc_identity_4 <dbl>, anc_correct_identity <dbl>,
#> # app_identity_recorded <chr>, anc_identity_recorded <chr>,
#> # app_identity_row_rnd <chr>, anc_identity_row_rnd <chr>
Anchor ranking question
To perform bias correction, the data must have what we call the
anchor ranking question. The anchor question is an auxiliary ranking
question that looks similar to the target question, whose “correct”
answer is known to researchers. For example, identity
has
responses to the anchor question that asked respondents to rank order
four levels of government: house, state, municipal, and school board.
These responses are included in anc_house
,
anc_neighborhood
, anc_city
, and
anc_state.
Here, the correct answer is assumed to be
“1234.” Based on theses responses, we code an indicator variable
(anc_correct_identity
) that takes 1 if respondents offer
the correct answer and 0 otherwise.
For example, in the following dataset, the first and third respondent has provided a “wrong” answer for the anchor question, whereas the rest of them have provided the correct answer.
identity[, c(paste0("anc_identity_", seq(4)), "anc_correct_identity")] |>
tail()
#> # A tibble: 6 × 5
#> anc_identity_1 anc_identity_2 anc_identity_3 anc_identity_4
#> <dbl> <dbl> <dbl> <dbl>
#> 1 3 1 2 4
#> 2 1 2 3 4
#> 3 4 3 2 1
#> 4 1 2 3 4
#> 5 1 2 3 4
#> 6 1 2 3 4
#> # ℹ 1 more variable: anc_correct_identity <dbl>