Title: | Bayesian Inference for Multinomial Models with Inequality Constraints |
---|---|
Description: | Implements Gibbs sampling and Bayes factors for multinomial models with linear inequality constraints on the vector of probability parameters. As special cases, the model class includes models that predict a linear order of binomial probabilities (e.g., p[1] < p[2] < p[3] < .50) and mixture models assuming that the parameter vector p must be inside the convex hull of a finite number of predicted patterns (i.e., vertices). A formal definition of inequality-constrained multinomial models and the implemented computational methods is provided in: Heck, D.W., & Davis-Stober, C.P. (2019). Multinomial models with linear inequality constraints: Overview and improvements of computational methods for Bayesian inference. Journal of Mathematical Psychology, 91, 70-87. <doi:10.1016/j.jmp.2019.03.004>. Inequality-constrained multinomial models have applications in the area of judgment and decision making to fit and test random utility models (Regenwetter, M., Dana, J., & Davis-Stober, C.P. (2011). Transitivity of preferences. Psychological Review, 118, 42–56, <doi:10.1037/a0021150>) or to perform outcome-based strategy classification to select the decision strategy that provides the best account for a vector of observed choice frequencies (Heck, D.W., Hilbig, B.E., & Moshagen, M. (2017). From information processing to decisions: Formalizing and comparing probabilistic choice models. Cognitive Psychology, 96, 26–40. <doi:10.1016/j.cogpsych.2017.05.003>). |
Authors: | Daniel W. Heck [aut, cre] |
Maintainer: | Daniel W. Heck <[email protected]> |
License: | GPL-3 |
Version: | 0.2.6 |
Built: | 2024-12-17 06:53:58 UTC |
Source: | CRAN |
Implements Gibbs sampling and Bayes factors for multinomial models with convex, linear-inequality constraints on the probability parameters. This includes models that predict a linear order of binomial probabilities (e.g., p1 < p2 < p3 < .50) and mixture models, which assume that the parameter vector p must be inside the convex hull of a finite number of vertices.
A formal definition of inequality-constrained multinomial models and the implemented computational methods for Bayesian inference is provided in:
Heck, D. W., & Davis-Stober, C. P. (2019). Multinomial models with linear inequality constraints: Overview and improvements of computational methods for Bayesian inference. Manuscript under revision. https://arxiv.org/abs/1808.07140
Inequality-constrained multinomial models have applications in multiple areas in psychology, judgement and decision making, and beyond:
Testing choice axioms such as transitivity and random utility theory
(Regenwetter et al., 2012, 2014). See regenwetter2012
Testing deterministic axioms of measurement and choice (Karabatsos, 2005; Myung et al., 2005).
Multiattribute decisions for probabilistic inferences involving strategies such as
Take-the-best (TTB) vs. weighted additive (WADD; Bröder & Schiffer, 2003; Heck et al., 2017)
See heck2017
and hilbig2014
Fitting and testing nonparametric item response theory models (Karabatsos & Sheu, 2004).
See karabatsos2004
Statistical inference for order-constrained contingency tables (Klugkist et al., 2007, 2010).
See bf_nonlinear
Testing stochastic dominance of response time distributions (Heathcote et al., 2010).
See stochdom_bf
Cognitive diagnostic assessment (Hoijtink et al., 2014).
Daniel W. Heck
Bröder, A., & Schiffer, S. (2003). Bayesian strategy assessment in multi-attribute decision making. Journal of Behavioral Decision Making, 16(3), 193-213. doi:10.1002/bdm.442
Bröder, A., & Schiffer, S. (2003). Take The Best versus simultaneous feature matching: Probabilistic inferences from memory and effects of reprensentation format. Journal of Experimental Psychology: General, 132, 277-293. doi:10.1037/0096-3445.132.2.277
Heck, D. W., Hilbig, B. E., & Moshagen, M. (2017). From information processing to decisions: Formalizing and comparing probabilistic choice models. Cognitive Psychology, 96, 26-40. doi:10.1016/j.cogpsych.2017.05.003
Hilbig, B. E., & Moshagen, M. (2014). Generalized outcome-based strategy classification: Comparing deterministic and probabilistic choice models. Psychonomic Bulletin & Review, 21(6), 1431-1443. doi:10.3758/s13423-014-0643-0
Regenwetter, M., & Davis-Stober, C. P. (2012). Behavioral variability of choices versus structural inconsistency of preferences. Psychological Review, 119(2), 408-416. doi:10.1037/a0027372
Regenwetter, M., Davis-Stober, C. P., Lim, S. H., Guo, Y., Popova, A., Zwilling, C., … Messner, W. (2014). QTest: Quantitative testing of theories of binary choice. Decision, 1(1), 2-34. doi:10.1037/dec0000007
Karabatsos, G. (2005). The exchangeable multinomial model as an approach to testing deterministic axioms of choice and measurement. Journal of Mathematical Psychology, 49(1), 51-69. doi:10.1016/j.jmp.2004.11.001
Myung, J. I., Karabatsos, G., & Iverson, G. J. (2005). A Bayesian approach to testing decision making axioms. Journal of Mathematical Psychology, 49, 205-225. doi:10.1016/j.jmp.2005.02.004
Karabatsos, G., & Sheu, C.-F. (2004). Order-constrained Bayes inference for dichotomous models of unidimensional nonparametric IRT. Applied Psychological Measurement, 28(2), 110-125. doi:10.1177/0146621603260678
Hoijtink, H. (2011). Informative Hypotheses: Theory and Practice for Behavioral and Social Scientists. Boca Raton, FL: Chapman & Hall/CRC.
Hoijtink, H., Béland, S., & Vermeulen, J. A. (2014). Cognitive diagnostic assessment via Bayesian evaluation of informative diagnostic hypotheses. Psychological Methods, 19(1), 21–38. doi:10.1037/a0034176
Klugkist, I., & Hoijtink, H. (2007). The Bayes factor for inequality and about equality constrained models. Computational Statistics & Data Analysis, 51(12), 6367-6379. doi:10.1016/j.csda.2007.01.024
Klugkist, I., Laudy, O., & Hoijtink, H. (2010). Bayesian evaluation of inequality and equality constrained hypotheses for contingency tables. Psychological Methods, 15(3), 281-299. doi:10.1037/a0020137
Heathcote, A., Brown, S., Wagenmakers, E. J., & Eidels, A. (2010). Distribution-free tests of stochastic dominance for small samples. Journal of Mathematical Psychology, 54(5), 454-463. doi:10.1016/j.jmp.2010.06.005
Useful links:
Often inequalities refer to all probability parameters of a multinomial distribution.
This function allows to transform the inequalities into the appropriate format
A * x <b
with respect to the free parameters only.
Ab_drop_fixed(A, b, options)
Ab_drop_fixed(A, b, options)
A |
a matrix defining the convex polytope via |
b |
a vector of the same length as the number of rows of |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
# p1 < p2 < p3 < p4 A4 <- matrix( c( 1, -1, 0, 0, 0, 1, -1, 0, 0, 0, 1, -1 ), nrow = 3, byrow = TRUE ) b4 <- c(0, 0, 0) # drop the fixed column for: p4 = (1-p1-p2-p3) Ab_drop_fixed(A4, b4, options = c(4))
# p1 < p2 < p3 < p4 A4 <- matrix( c( 1, -1, 0, 0, 0, 1, -1, 0, 0, 0, 1, -1 ), nrow = 3, byrow = TRUE ) b4 <- c(0, 0, 0) # drop the fixed column for: p4 = (1-p1-p2-p3) Ab_drop_fixed(A4, b4, options = c(4))
Constructs the matrix A
and vector b
of the Ab-representation
A*x < b
for common inequality constraints such as "the probability j is
larger than all others (Ab_max
)" or "the probabilities are ordered
(Ab_monotonicity
)").
Ab_max( which_max, options, exclude = c(), exclude_fixed = FALSE, drop_fixed = TRUE )
Ab_max( which_max, options, exclude = c(), exclude_fixed = FALSE, drop_fixed = TRUE )
which_max |
vector of indices refering to probabilities that are
assumed to be larger than the remaining probabilities
(e.g., |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
exclude |
vector of indices refering to probabilities that are excluded from the construction of the order constraints (including the fixed probabilities). |
exclude_fixed |
whether to exclude the fixed probabilities (i.e., the
last probability within each multinomial) from the construction of the
order constraints. For example, if |
drop_fixed |
whether to drop columns of |
a list with the matrix A
and the vectors b
and options
# Example 1: Multinomial with 5 categories # Hypothesis: p1 is larger than p2,p3,p4,p5 Ab_max(which_max = 1, options = 5) # Example 2: Four binomial probabilities # Hypothesis: p1 is larger than p2,p3,p4 Ab_max(which_max = 1, options = c(2, 2, 2, 2), exclude_fixed = TRUE)
# Example 1: Multinomial with 5 categories # Hypothesis: p1 is larger than p2,p3,p4,p5 Ab_max(which_max = 1, options = 5) # Example 2: Four binomial probabilities # Hypothesis: p1 is larger than p2,p3,p4 Ab_max(which_max = 1, options = c(2, 2, 2, 2), exclude_fixed = TRUE)
Get or add inequality constraints (or vertices) to ensure that multinomial probabilities are positive and sum to one for all choice options within each item type.
Ab_multinom(options, A = NULL, b = NULL, nonneg = FALSE)
Ab_multinom(options, A = NULL, b = NULL, nonneg = FALSE)
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
A |
a matrix defining the convex polytope via |
b |
a vector of the same length as the number of rows of |
nonneg |
whether to add constraints that probabilities must be nonnegative |
If A
and b
are provided, the constraints are added to these inequality constraints.
# three binary and two ternary choices: options <- c(2, 2, 2, 3, 3) Ab_multinom(options) Ab_multinom(options, nonneg = TRUE)
# three binary and two ternary choices: options <- c(2, 2, 2, 3, 3) Ab_multinom(options) Ab_multinom(options, nonneg = TRUE)
Uses samples from the prior/posterior to order the inequalities by the acceptance rate.
Ab_sort(A, b, k = 0, options, M = 1000, drop_irrelevant = TRUE)
Ab_sort(A, b, k = 0, options, M = 1000, drop_irrelevant = TRUE)
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
k |
optional: number of observed frequencies (only for posterior sampling). |
options |
optional: number of options per item type/category system. Uniform sampling on [0,1] for each parameter is used if omitted. |
M |
number of samples. |
drop_irrelevant |
whether to drop irrelevant constraints for probabilities such as
|
Those constraints that are rejected most often are placed at the first positions.
This can help when computing the encompassing Bayes factor and counting how many samples
satisfy the constraints (e.g., count_binom
or bf_multinom
).
Essentially, it becomes more likely that the while-loop for testing
whether the inequalities hold can stop earlier, thus making the computation faster.
The function could also be helpful to improve the efficiency of the stepwise
sampling implemented in count_binom
and count_multinom
.
First, one can use accept-reject sampling to test the first few, rejected
inequalities. Next, one can use a Gibbs sampler to draw samples conditional on the
first constraints.
### Binomial probabilities b <- c(0, 0, .30, .70, 1) A <- matrix( c( -1, 1, 0, # p1 >= p2 0, 1, -1, # p2 <= p3 1, 0, 0, # p1 <=.30 0, 1, 0, # p2 <= .70 0, 0, 1 ), # p3 <= 1 (redundant) ncol = 3, byrow = 2 ) Ab_sort(A, b) ### Multinomial probabilities # prior sampling: Ab_sort(A, b, options = 4) # posterior sampling: Ab_sort(A, b, k = c(10, 3, 2, 14), options = 4)
### Binomial probabilities b <- c(0, 0, .30, .70, 1) A <- matrix( c( -1, 1, 0, # p1 >= p2 0, 1, -1, # p2 <= p3 1, 0, 0, # p1 <=.30 0, 1, 0, # p2 <= .70 0, 0, 1 ), # p3 <= 1 (redundant) ncol = 3, byrow = 2 ) Ab_sort(A, b) ### Multinomial probabilities # prior sampling: Ab_sort(A, b, options = 4) # posterior sampling: Ab_sort(A, b, k = c(10, 3, 2, 14), options = 4)
Computes the Bayes factor for product-binomial/-multinomial models with
linear order-constraints (specified via: A*x <= b
or the convex hull V
).
bf_binom(k, n, A, b, V, map, prior = c(1, 1), log = FALSE, ...) bf_multinom( k, options, A, b, V, prior = rep(1, sum(options)), log = FALSE, ... )
bf_binom(k, n, A, b, V, map, prior = c(1, 1), log = FALSE, ...) bf_multinom( k, options, A, b, V, prior = rep(1, sum(options)), log = FALSE, ... )
k |
vector of observed response frequencies. |
n |
the number of choices per item type.
If |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
map |
optional: numeric vector of the same length as |
prior |
a vector with two positive numbers defining the shape parameters of the beta prior distributions for each binomial rate parameter. |
log |
whether to return the log-Bayes factor instead of the Bayes factor |
... |
further arguments passed to |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
For more control, use count_binom
to specifiy how many samples
should be drawn from the prior and posterior, respectively. This is especially
recommended if the same prior distribution (and thus the same prior probability/integral)
is used for computing BFs for multiple data sets that differ only in the
observed frequencies k
and the sample size n
.
In this case, the prior probability/proportion of the parameter space in line
with the inequality constraints can be computed once with high precision
(or even analytically), and only the posterior probability/proportion needs
to be estimated separately for each unique vector k
.
a matrix with two columns (Bayes factor and SE of approximation) and three rows:
`bf_0u`
: constrained vs. unconstrained (saturated) model
`bf_u0`
: unconstrained vs. constrained model
`bf_00'`
: constrained vs. complement of inequality-constrained model
(e.g., pi>.2 becomes pi<=.2; this assumes identical equality constraints for both models)
Karabatsos, G. (2005). The exchangeable multinomial model as an approach to testing deterministic axioms of choice and measurement. Journal of Mathematical Psychology, 49(1), 51-69. doi:10.1016/j.jmp.2004.11.001
Regenwetter, M., Davis-Stober, C. P., Lim, S. H., Guo, Y., Popova, A., Zwilling, C., … Messner, W. (2014). QTest: Quantitative testing of theories of binary choice. Decision, 1(1), 2-34. doi:10.1037/dec0000007
count_binom
and count_multinom
for
for more control on the number of prior/posterior samples and
bf_nonlinear
for nonlinear order constraints.
k <- c(0, 3, 2, 5, 3, 7) n <- rep(10, 6) # linear order constraints: # p1 <p2 <p3 <p4 <p5 <p6 <.50 A <- matrix( c( 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1 ), ncol = 6, byrow = TRUE ) b <- c(0, 0, 0, 0, 0, .50) # Bayes factor: unconstrained vs. constrained bf_binom(k, n, A, b, prior = c(1, 1), M = 10000) bf_binom(k, n, A, b, prior = c(1, 1), M = 2000, steps = c(2, 4, 5)) bf_binom(k, n, A, b, prior = c(1, 1), M = 1000, cmin = 200)
k <- c(0, 3, 2, 5, 3, 7) n <- rep(10, 6) # linear order constraints: # p1 <p2 <p3 <p4 <p5 <p6 <.50 A <- matrix( c( 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1 ), ncol = 6, byrow = TRUE ) b <- c(0, 0, 0, 0, 0, .50) # Bayes factor: unconstrained vs. constrained bf_binom(k, n, A, b, prior = c(1, 1), M = 10000) bf_binom(k, n, A, b, prior = c(1, 1), M = 2000, steps = c(2, 4, 5)) bf_binom(k, n, A, b, prior = c(1, 1), M = 1000, cmin = 200)
To obtain the Bayes factor for the equality constraints C*x = d
, a
sequence of approximations abs(C*x - d) < delta
is used.
bf_equality( k, options, A, b, C, d, prior = rep(1, sum(options)), M1 = 1e+05, M2 = 20000, delta = 0.5^(1:8), return_Ab = FALSE, ... )
bf_equality( k, options, A, b, C, d, prior = rep(1, sum(options)), M1 = 1e+05, M2 = 20000, delta = 0.5^(1:8), return_Ab = FALSE, ... )
k |
the number of choices for each alternative ordered by item type (e.g.
|
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
C |
a matrix specifying the equality constraints |
d |
a vector with the same number of elements as the rows of |
prior |
the prior parameters of the Dirichlet-shape parameters.
Must have the same length as |
M1 |
number of independent samples from the encompassing model to test
whether |
M2 |
number of Gibbs-sampling iterations for each step of the approximation
of |
delta |
a vector of stepsizes that are used for the approximation. |
return_Ab |
if |
... |
further arguments passed to |
First, the encompassing Bayes factor for the equality constraint A*x<b
is computed using M1
independent Dirichlet samples. Next, the equality
constraint C*x=d
is approximated by drawing samples from the model
A*x<b
and testing whether abs(C*x - d) < delta[1]
. Similarly, the
stepsize delta
is reduced step by step until abs(C*x - d) < min(delta)
.
Klugkist et al. (2010) show that this procedure provides a valid approximation
of the exact equality constraints if the step size becomes sufficiently small.
Klugkist, I., Laudy, O., & Hoijtink, H. (2010). Bayesian evaluation of inequality and equality constrained hypotheses for contingency tables. Psychological Methods, 15(3), 281-299. doi:10.1037/a0020137
# Equality constraints: C * x = d d <- c(.5, .5, 0) C <- matrix( c( 1, 0, 0, 0, # p1 = .50 0, 1, 0, 0, # p2 = .50 0, 0, 1, -1 ), # p3 = p4 ncol = 4, byrow = TRUE ) k <- c(3, 7, 6, 4, 2, 8, 5, 5) options <- c(2, 2, 2, 2) bf_equality(k, options, C = C, d = d, delta = .5^(1:5), M1 = 50000, M2 = 5000 ) # only for CRAN checks # check against exact equality constraints (see ?bf_binom) k_binom <- k[seq(1, 7, 2)] bf_binom(k_binom, n = 10, A = matrix(0), b = 0, map = c(0, 0, 1, 1) )
# Equality constraints: C * x = d d <- c(.5, .5, 0) C <- matrix( c( 1, 0, 0, 0, # p1 = .50 0, 1, 0, 0, # p2 = .50 0, 0, 1, -1 ), # p3 = p4 ncol = 4, byrow = TRUE ) k <- c(3, 7, 6, 4, 2, 8, 5, 5) options <- c(2, 2, 2, 2) bf_equality(k, options, C = C, d = d, delta = .5^(1:5), M1 = 50000, M2 = 5000 ) # only for CRAN checks # check against exact equality constraints (see ?bf_binom) k_binom <- k[seq(1, 7, 2)] bf_binom(k_binom, n = 10, A = matrix(0), b = 0, map = c(0, 0, 1, 1) )
Computes the encompassing Bayes factor for a user-specified, nonlinear inequality
constraint. Restrictions are defined via an indicator function of the free parameters
c(p11,p12,p13, p21,p22,...)
(i.e., the multinomial probabilities).
bf_nonlinear( k, options, inside, prior = rep(1, sum(options)), log = FALSE, ... ) count_nonlinear( k = 0, options, inside, prior = rep(1, sum(options)), M = 5000, progress = TRUE, cpu = 1 )
bf_nonlinear( k, options, inside, prior = rep(1, sum(options)), log = FALSE, ... ) count_nonlinear( k = 0, options, inside, prior = rep(1, sum(options)), M = 5000, progress = TRUE, cpu = 1 )
k |
vector of observed response frequencies. |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
inside |
an indicator function that takes a vector with probabilities
|
prior |
a vector with two positive numbers defining the shape parameters of the beta prior distributions for each binomial rate parameter. |
log |
whether to return the log-Bayes factor instead of the Bayes factor |
... |
further arguments passed to |
M |
number of posterior samples drawn from the encompassing model |
progress |
whether a progress bar should be shown (if |
cpu |
either the number of CPUs used for parallel sampling, or a parallel
cluster (e.g., |
Inequality constraints are defined via an indicator function inside
which returns inside(x)=1
(or 0
) if the vector of free parameters
x
is inside (or outside) the model space. Since the vector x
must include only free (!) parameters, the last probability for each
multinomial must not be used in the function inside(x)
!
Efficiency can be improved greatly if the indicator function is defined as C++ code via the function cppXPtr in the package RcppXPtrUtils (see below for examples). In this case, please keep in mind that indexing in C++ starts with 0,1,2... (not with 1,2,3,... as in R)!
Klugkist, I., & Hoijtink, H. (2007). The Bayes factor for inequality and about equality constrained models. Computational Statistics & Data Analysis, 51(12), 6367-6379. doi:10.1016/j.csda.2007.01.024
Klugkist, I., Laudy, O., & Hoijtink, H. (2010). Bayesian evaluation of inequality and equality constrained hypotheses for contingency tables. Psychological Methods, 15(3), 281-299. doi:10.1037/a0020137
##### 2x2x2 continceny table (Klugkist & Hojtink, 2007) # # (defendant's race) x (victim's race) x (death penalty) # indexing: 0 = white/white/yes ; 1 = black/black/no # probabilities: (p000,p001, p010,p011, p100,p101, p110,p111) # Model2: # p000*p101 < p100*p001 & p010*p111 < p110*p011 # observed frequencies: k <- c(19, 132, 0, 9, 11, 52, 6, 97) model <- function(x) { x[1] * x[6] < x[5] * x[2] & x[3] * (1 - sum(x)) < x[7] * x[4] } # NOTE: "1-sum(x)" must be used instead of "x[8]"! # compute Bayes factor (Klugkist 2007: bf_0u=1.62) bf_nonlinear(k, 8, model, M = 50000) ##### Using a C++ indicator function (much faster) cpp_code <- "SEXP model(NumericVector x){ return wrap(x[0]*x[5] < x[4]*x[1] & x[2]*(1-sum(x)) < x[6]*x[3]);}" # NOTE: C++ indexing starts at 0! # define C++ pointer to indicator function: model_cpp <- RcppXPtrUtils::cppXPtr(cpp_code) bf_nonlinear( k = c(19, 132, 0, 9, 11, 52, 6, 97), M = 100000, options = 8, inside = model_cpp )
##### 2x2x2 continceny table (Klugkist & Hojtink, 2007) # # (defendant's race) x (victim's race) x (death penalty) # indexing: 0 = white/white/yes ; 1 = black/black/no # probabilities: (p000,p001, p010,p011, p100,p101, p110,p111) # Model2: # p000*p101 < p100*p001 & p010*p111 < p110*p011 # observed frequencies: k <- c(19, 132, 0, 9, 11, 52, 6, 97) model <- function(x) { x[1] * x[6] < x[5] * x[2] & x[3] * (1 - sum(x)) < x[7] * x[4] } # NOTE: "1-sum(x)" must be used instead of "x[8]"! # compute Bayes factor (Klugkist 2007: bf_0u=1.62) bf_nonlinear(k, 8, model, M = 50000) ##### Using a C++ indicator function (much faster) cpp_code <- "SEXP model(NumericVector x){ return wrap(x[0]*x[5] < x[4]*x[1] & x[2]*(1-sum(x)) < x[6]*x[3]);}" # NOTE: C++ indexing starts at 0! # define C++ pointer to indicator function: model_cpp <- RcppXPtrUtils::cppXPtr(cpp_code) bf_nonlinear( k = c(19, 132, 0, 9, 11, 52, 6, 97), M = 100000, options = 8, inside = model_cpp )
Converts the number of "hits" in the binary choice format to the observed frequencies across for all response categories (i.e., the multinomial format).
binom_to_multinom(k, n)
binom_to_multinom(k, n)
k |
vector of observed response frequencies. |
n |
the number of choices per item type.
If |
In multinomineq
, binary choice frequencies are represented by the number
of "hits" for each item type/condition (the vector k
) and by the total
number of responses per item type/condition (the scalar or vector n
).
In the multinomial format, the vector k
includes all response categories
(not only the number of "hits"). This requires to define a vector options
,
which indicates how many categories belong to one item type/condition (since
the total number of responses per item type is fixed).
k <- c(1, 5, 8, 10) n <- 10 binom_to_multinom(k, n)
k <- c(1, 5, 8, 10) n <- 10 binom_to_multinom(k, n)
Draws prior/posterior samples for product-binomial data and counts how many samples are
inside the convex polytope defined by
(1) the inequalities A*x <= b
or
(2) the convex hull over the vertices V
.
count_binom( k, n, A, b, V, map, prior = c(1, 1), M = 10000, steps, start, cmin = 0, maxiter = 500, burnin = 5, progress = TRUE, cpu = 1 )
count_binom( k, n, A, b, V, map, prior = c(1, 1), M = 10000, steps, start, cmin = 0, maxiter = 500, burnin = 5, progress = TRUE, cpu = 1 )
k |
vector of observed response frequencies. |
n |
the number of choices per item type.
If |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
map |
optional: numeric vector of the same length as |
prior |
a vector with two positive numbers defining the shape parameters of the beta prior distributions for each binomial rate parameter. |
M |
number of posterior samples drawn from the encompassing model |
steps |
an integer vector that indicates the row numbers at which the matrix |
start |
only relevant if |
cmin |
if |
maxiter |
if |
burnin |
number of burnin samples per step that are discarded. Since the
maximum-likelihood estimate is used as a start value (which is updated for each step in
the stepwise procedure in |
progress |
whether a progress bar should be shown (if |
cpu |
either the number of CPUs used for parallel sampling, or a parallel
cluster (e.g., |
Counts the number of random samples drawn from beta distributions that satisfy
the convex, linear-inequalitiy constraints. The function is useful to compute
the encompassing Bayes factor for testing inequality-constrained models
(see bf_binom
; Hojtink, 2011).
The stepwise computation of the Bayes factor proceeds as follows:
If the steps are defined as steps=c(5,10)
, the BF is computed in three steps by comparing:
(1) Unconstrained model vs. inequalities in A[1:5,]
;
(2) use posterior based on inequalities in A[1:5,]
and check inequalities A[6:10,]
;
(3) sample from A[1:10,] and check inequalities in A[11:nrow(A),]
(i.e., all inequalities).
a matrix with the columns
count
: number of samples in polytope / that satisfy order constraints
M
: the total number of samples in each step
steps
: the "steps"
used to sample from the polytope
(i.e., the row numbers of A
that were considered stepwise)
with the attributes:
proportion
: estimated probability that samples are in polytope
se
: standard error of probability estimate
const_map
: logarithm of the binomial constants that
have to be considered due to equality constraints
Hoijtink, H. (2011). Informative Hypotheses: Theory and Practice for Behavioral and Social Scientists. Boca Raton, FL: Chapman & Hall/CRC.
Fukuda, K. (2004). Is there an efficient way of determining whether a given point q is in the convex hull of a given finite set S of points in Rd? Retrieved from https://www.cs.mcgill.ca/~fukuda/soft/polyfaq/node22.html
### a set of linear order constraints: ### x1 < x2 < .... < x6 < .50 A <- matrix( c( 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1 ), ncol = 6, byrow = TRUE ) b <- c(0, 0, 0, 0, 0, .50) ### check whether a specific vector is inside the polytope: A %*% c(.05, .1, .12, .16, .19, .23) <= b ### observed frequencies and number of observations: k <- c(0, 3, 2, 5, 3, 7) n <- rep(10, 6) ### count prior samples and compare to analytical result prior <- count_binom(0, 0, A, b, M = 5000, steps = 1:4) prior # to get the proportion: attr(prior, "proportion") (.50)^6 / factorial(6) ### count posterior samples + get Bayes factor posterior <- count_binom(k, n, A, b, M = 2000, steps = 1:4) count_to_bf(posterior, prior) ### automatic stepwise algorithm prior <- count_binom(0, 0, A, b, M = 500, cmin = 200) posterior <- count_binom(k, n, A, b, M = 500, cmin = 200) count_to_bf(posterior, prior)
### a set of linear order constraints: ### x1 < x2 < .... < x6 < .50 A <- matrix( c( 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 1 ), ncol = 6, byrow = TRUE ) b <- c(0, 0, 0, 0, 0, .50) ### check whether a specific vector is inside the polytope: A %*% c(.05, .1, .12, .16, .19, .23) <= b ### observed frequencies and number of observations: k <- c(0, 3, 2, 5, 3, 7) n <- rep(10, 6) ### count prior samples and compare to analytical result prior <- count_binom(0, 0, A, b, M = 5000, steps = 1:4) prior # to get the proportion: attr(prior, "proportion") (.50)^6 / factorial(6) ### count posterior samples + get Bayes factor posterior <- count_binom(k, n, A, b, M = 2000, steps = 1:4) count_to_bf(posterior, prior) ### automatic stepwise algorithm prior <- count_binom(0, 0, A, b, M = 500, cmin = 200) posterior <- count_binom(k, n, A, b, M = 500, cmin = 200) count_to_bf(posterior, prior)
Draws prior/posterior samples for product-multinomial data and counts how many samples are
inside the convex polytope defined by
(1) the inequalities A*x <= b
or
(2) the convex hull over the vertices V.
count_multinom( k = 0, options, A, b, V, prior = rep(1, sum(options)), M = 5000, steps, start, cmin = 0, maxiter = 500, burnin = 5, progress = TRUE, cpu = 1 )
count_multinom( k = 0, options, A, b, V, prior = rep(1, sum(options)), M = 5000, steps, start, cmin = 0, maxiter = 500, burnin = 5, progress = TRUE, cpu = 1 )
k |
the number of choices for each alternative ordered by item type (e.g.
|
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
A |
a matrix defining the convex polytope via |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
prior |
the prior parameters of the Dirichlet-shape parameters.
Must have the same length as |
M |
number of posterior samples drawn from the encompassing model |
steps |
an integer vector that indicates the row numbers at which the matrix |
start |
only relevant if |
cmin |
if |
maxiter |
if |
burnin |
number of burnin samples per step that are discarded. Since the
maximum-likelihood estimate is used as a start value (which is updated for each step in
the stepwise procedure in |
progress |
whether a progress bar should be shown (if |
cpu |
either the number of CPUs used for parallel sampling, or a parallel
cluster (e.g., |
a list with the elements
a matrix with the columns
count
: number of samples in polytope / that satisfy order constraints
M
: the total number of samples in each step
steps
: the "steps"
used to sample from the polytope
(i.e., the row numbers of A
that were considered stepwise)
with the attributes:
proportion
: estimated probability that samples are in polytope
se
: standard error of probability estimate
Hoijtink, H. (2011). Informative Hypotheses: Theory and Practice for Behavioral and Social Scientists. Boca Raton, FL: Chapman & Hall/CRC.
### frequencies: # (a1,a2,a3, b1,b2,b3,b4) k <- c(1, 5, 9, 5, 3, 7, 8) options <- c(3, 4) ### linear order constraints # a1<a2<a3 AND b2<b3<.50 # (note: a2<a3 <=> a2 < 1-a1-a2 <=> a1+2*a2 < 1) # matrix A: # (a1,a2, b1,b2,b3) A <- matrix( c( 1, -1, 0, 0, 0, 1, 2, 0, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 1 ), ncol = sum(options - 1), byrow = TRUE ) b <- c(0, 1, 0, .50) # count prior and posterior samples and get BF prior <- count_multinom(0, options, A, b, M = 2e4) posterior <- count_multinom(k, options, A, b, M = 2e4) count_to_bf(posterior, prior) bf_multinom(k, options, A, b, M = 10000) bf_multinom(k, options, A, b, cmin = 5000, M = 1000)
### frequencies: # (a1,a2,a3, b1,b2,b3,b4) k <- c(1, 5, 9, 5, 3, 7, 8) options <- c(3, 4) ### linear order constraints # a1<a2<a3 AND b2<b3<.50 # (note: a2<a3 <=> a2 < 1-a1-a2 <=> a1+2*a2 < 1) # matrix A: # (a1,a2, b1,b2,b3) A <- matrix( c( 1, -1, 0, 0, 0, 1, 2, 0, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 1 ), ncol = sum(options - 1), byrow = TRUE ) b <- c(0, 1, 0, .50) # count prior and posterior samples and get BF prior <- count_multinom(0, options, A, b, M = 2e4) posterior <- count_multinom(k, options, A, b, M = 2e4) count_to_bf(posterior, prior) bf_multinom(k, options, A, b, M = 10000) bf_multinom(k, options, A, b, cmin = 5000, M = 1000)
Computes the encompassing Bayes factor (and standard error) defined as the ratio of posterior/prior samples that satisfy the order constraints (e.g., of a polytope).
count_to_bf( posterior, prior, exact_prior, log = FALSE, beta = c(1/2, 1/2), samples = 3000 )
count_to_bf( posterior, prior, exact_prior, log = FALSE, beta = c(1/2, 1/2), samples = 3000 )
posterior |
a vector (or matrix) with entries (or columns)
|
prior |
a vecotr or matrix similar as for |
exact_prior |
optional: the exact prior probabability of the order constraints.
For instance, |
log |
whether to return the log-Bayes factor instead of the Bayes factor |
beta |
prior shape parameters of the beta distributions used for approximating the standard errors of the Bayes-factor estimates. The default is Jeffreys' prior. |
samples |
number of samples from beta distributions used to compute standard errors. The unconstrained (encompassing) model is the saturated baseline model that assumes a separate, independent probability for each observable frequency. The Bayes factor is obtained as the ratio of posterior/prior samples within an order-constrained subset of the parameter space. The standard error of the (stepwise) encompassing Bayes factor is estimated by sampling ratios from beta distributions, with parameters defined by the posterior/prior counts (see Hoijtink, 2011; p. 211). |
a matrix with two columns (Bayes factor and SE of approximation) and three rows:
`bf_0u`
: constrained vs. unconstrained (saturated) model
`bf_u0`
: unconstrained vs. constrained model
`bf_00'`
: constrained vs. complement of inequality-constrained model
(e.g., pi>.2 becomes pi<=.2; this assumes identical equality constraints for both models)
Hoijtink, H. (2011). Informative Hypotheses: Theory and Practice for Behavioral and Social Scientists. Boca Raton, FL: Chapman & Hall/CRC.
# vector input post <- c(count = 1447, M = 5000) prior <- c(count = 152, M = 10000) count_to_bf(post, prior) # matrix input (due to nested stepwise procedure) post <- cbind(count = c(139, 192), M = c(200, 1000)) count_to_bf(post, prior) # exact prior probability known count_to_bf( posterior = c(count = 1447, M = 10000), exact_prior = 1 / factorial(4) )
# vector input post <- c(count = 1447, M = 5000) prior <- c(count = 152, M = 10000) count_to_bf(post, prior) # matrix input (due to nested stepwise procedure) post <- cbind(count = c(139, 192), M = c(200, 1000)) count_to_bf(post, prior) # exact prior probability known count_to_bf( posterior = c(count = 1447, M = 10000), exact_prior = 1 / factorial(4) )
Switches between two representation of polytopes for multinomial probabilities (whether the fixed parameters are included).
drop_fixed(x, options = 2) add_fixed(x, options = 2, sum = 1)
drop_fixed(x, options = 2) add_fixed(x, options = 2, sum = 1)
x |
a vector (typically |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
sum |
a vector that determines the fixed sum in each multinomial condition.
By default, probabilities are assumed that sum to one.
If frequencies |
######## bi- and trinomial (a1,a2, b1,b2,b3) # vectors with frequencies: drop_fixed(c(3, 7, 4, 1, 5), options = c(2, 3)) add_fixed(c(3, 4, 1), options = c(2, 3), sum = c(10, 10) ) # matrices with probabilities: V <- matrix(c( 1, 0, 0, 1, .5, .5, 0, 1, 0 ), 3, byrow = TRUE) V2 <- add_fixed(V, options = c(2, 3)) V2 drop_fixed(V2, c(2, 3))
######## bi- and trinomial (a1,a2, b1,b2,b3) # vectors with frequencies: drop_fixed(c(3, 7, 4, 1, 5), options = c(2, 3)) add_fixed(c(3, 4, 1), options = c(2, 3), sum = c(10, 10) ) # matrices with probabilities: V <- matrix(c( 1, 0, 0, 1, .5, .5, 0, 1, 0 ), 3, byrow = TRUE) V2 <- add_fixed(V, options = c(2, 3)) V2 drop_fixed(V2, c(2, 3))
Finds the center/a random point that is within the convex polytope defined by the
linear inequalities A*x <= b
or by the convex hull over the vertices in the matrix V
.
find_inside( A, b, V, options = NULL, random = FALSE, probs = TRUE, boundary = 1e-05 )
find_inside( A, b, V, options = NULL, random = FALSE, probs = TRUE, boundary = 1e-05 )
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
options |
optional: number of options per item type (only for |
random |
if |
probs |
only for |
boundary |
constant value |
If vertices V
are provided, a convex combination of the vertices is returned.
If random=TRUE
, the weights are drawn uniformly from a Dirichlet distribution.
If inequalities are provided via A
and b
, linear programming (LP) is used
to find the Chebyshev center of the polytope (i.e., the center of the largest ball that
fits into the polytope; the solution may not be unique). If random=TRUE
,
LP is used to find a random point (not uniformly sampled!) in the convex polytope.
# inequality representation (A*x <= b) A <- matrix( c( 1, -1, 0, 1, 0, 0, 0, -1, 0, 1, 0, 0, 0, 1, -1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, -1, 0, 0, 0, 0 ), ncol = 5, byrow = TRUE ) b <- c(0.5, 0, 0, .7, .4, -.2) find_inside(A, b) find_inside(A, b, random = TRUE) # vertex representation V <- matrix(c( # strict weak orders 0, 1, 0, 1, 0, 1, # a < b < c 1, 0, 0, 1, 0, 1, # b < a < c 0, 1, 0, 1, 1, 0, # a < c < b 0, 1, 1, 0, 1, 0, # c < a < b 1, 0, 1, 0, 1, 0, # c < b < a 1, 0, 1, 0, 0, 1, # b < c < a 0, 0, 0, 1, 0, 1, # a ~ b < c 0, 1, 0, 0, 1, 0, # a ~ c < b 1, 0, 1, 0, 0, 0, # c ~ b < a 0, 1, 0, 1, 0, 0, # a < b ~ c 1, 0, 0, 0, 0, 1, # b < a ~ c 0, 0, 1, 0, 1, 0, # c < a ~ b 0, 0, 0, 0, 0, 0 # a ~ b ~ c ), byrow = TRUE, ncol = 6) find_inside(V = V) find_inside(V = V, random = TRUE)
# inequality representation (A*x <= b) A <- matrix( c( 1, -1, 0, 1, 0, 0, 0, -1, 0, 1, 0, 0, 0, 1, -1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, -1, 0, 0, 0, 0 ), ncol = 5, byrow = TRUE ) b <- c(0.5, 0, 0, .7, .4, -.2) find_inside(A, b) find_inside(A, b, random = TRUE) # vertex representation V <- matrix(c( # strict weak orders 0, 1, 0, 1, 0, 1, # a < b < c 1, 0, 0, 1, 0, 1, # b < a < c 0, 1, 0, 1, 1, 0, # a < c < b 0, 1, 1, 0, 1, 0, # c < a < b 1, 0, 1, 0, 1, 0, # c < b < a 1, 0, 1, 0, 0, 1, # b < c < a 0, 0, 0, 1, 0, 1, # a ~ b < c 0, 1, 0, 0, 1, 0, # a ~ c < b 1, 0, 1, 0, 0, 0, # c ~ b < a 0, 1, 0, 1, 0, 0, # a < b ~ c 1, 0, 0, 0, 0, 1, # b < a ~ c 0, 0, 1, 0, 1, 0, # c < a ~ b 0, 0, 0, 0, 0, 0 # a ~ b ~ c ), byrow = TRUE, ncol = 6) find_inside(V = V) find_inside(V = V, random = TRUE)
Choice frequencies with multiattribute decisions across 4 item types (Heck, Hilbig & Moshagen, 2017).
heck2017
heck2017
A data frame 4 variables:
B1
Frequency of choosing Option B for Item Type 1
B2
Frequency of choosing Option B for Item Type 2
B3
Frequency of choosing Option B for Item Type 3
B4
Frequency of choosing Option B for Item Type 4
Each participant made 40 choices for each of 4 item types with four cues (with validities .9, .8, .7, and .6). The pattern of cue values of Option A and and B was as follows:
A = (-1, 1, 1, -1) vs. B = (-1, -1, -1, -1)
A = (1, -1, -1, 1) vs. B = (-1, 1, -1, 1)
A = (-1, 1, 1, 1) vs. B = (-1, 1, 1, -1)
A = (1, -1, -1, -1) vs. B = (-1, 1, 1, -1)
Raw data are available as heck2017_raw
Heck, D. W., Hilbig, B. E., & Moshagen, M. (2017). From information processing to decisions: Formalizing and comparing probabilistic choice models. Cognitive Psychology, 96, 26-40. doi:10.1016/j.cogpsych.2017.05.003
data(heck2017) head(heck2017) n <- rep(40, 4) # cue validities and values v <- c(.9, .8, .7, .6) cueA <- matrix( c( -1, 1, 1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, -1, -1, -1 ), ncol = 4, byrow = TRUE ) cueB <- matrix( c( -1, -1, -1, -1, -1, 1, -1, 1, -1, 1, 1, -1, -1, 1, 1, -1 ), ncol = 4, byrow = TRUE ) # get predictions strategies <- c( "baseline", "WADDprob", "WADD", "TTBprob", "TTB", "EQW", "GUESS" ) strats <- strategy_multiattribute(cueA, cueB, v, strategies) # strategy classification with Bayes factor strategy_postprob(heck2017[1:4, ], n, strats)
data(heck2017) head(heck2017) n <- rep(40, 4) # cue validities and values v <- c(.9, .8, .7, .6) cueA <- matrix( c( -1, 1, 1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, -1, -1, -1 ), ncol = 4, byrow = TRUE ) cueB <- matrix( c( -1, -1, -1, -1, -1, 1, -1, 1, -1, 1, 1, -1, -1, 1, 1, -1 ), ncol = 4, byrow = TRUE ) # get predictions strategies <- c( "baseline", "WADDprob", "WADD", "TTBprob", "TTB", "EQW", "GUESS" ) strats <- strategy_multiattribute(cueA, cueB, v, strategies) # strategy classification with Bayes factor strategy_postprob(heck2017[1:4, ], n, strats)
Raw data with multiattribute decisions (Heck, Hilbig & Moshagen, 2017).
heck2017_raw
heck2017_raw
A data frame with 21 variables:
vp
ID code of participant
trial
Trial index
pattern
Number of cue pattern
ttb
Prediction of take-the-best (TTB)
eqw
Prediction of equal weights (EQW)
wadd
Prediction of weighted additive (WADD)
logoddsdiff
Log-odds difference (WADDprob)
ttbsteps
Number of TTB steps (TTBprob)
itemtype
Item type as in paper
reversedorder
Whether item is reversed
choice
Choice
rt
Response time
choice.rev
Choice (reversed)
a1
Value of Cue 1 for Option A
a2
Value of Cue 2 for Option A
a3
Value of Cue 3 for Option A
a4
Value of Cue 4 for Option A
b1
Value of Cue 1 for Option B
b2
Value of Cue 2 for Option B
b3
Value of Cue 3 for Option B
b4
Value of Cue 4 for Option B
Each participant made 40 choices for each of 4 item types with four cues
(with validities .9, .8, .7, and .6).
Individual choice freqeuncies are available as heck2017
Heck, D. W., Hilbig, B. E., & Moshagen, M. (2017). From information processing to decisions: Formalizing and comparing probabilistic choice models. Cognitive Psychology, 96, 26-40. doi:10.1016/j.cogpsych.2017.05.003
heck2017
for the aggregated choice frequencies per item type.
data(heck2017_raw) head(heck2017_raw) # get cue values, validities, and predictions cueA <- heck2017_raw[, paste0("a", 1:4)] cueB <- heck2017_raw[, paste0("b", 1:4)] v <- c(.9, .8, .7, .6) strat <- strategy_multiattribute( cueA, cueB, v, c( "TTB", "TTBprob", "WADD", "WADDprob", "EQW", "GUESS" ) ) # get unique item types types <- strategy_unique(strat) types$unique # get table of choice frequencies for analysis freq <- with( heck2017_raw, table(vp, types$item_type, choice) ) freqB <- freq[, 4:1, 1] + # reversed items: Option A freq[, 5:8, 2] # non-rev. items: Option B head(40 - freqB) data(heck2017) head(heck2017) # same frequencies (different order) # strategy classification pp <- strategy_postprob( freqB[1:4, ], rep(40, 4), types$strategies ) round(pp, 3)
data(heck2017_raw) head(heck2017_raw) # get cue values, validities, and predictions cueA <- heck2017_raw[, paste0("a", 1:4)] cueB <- heck2017_raw[, paste0("b", 1:4)] v <- c(.9, .8, .7, .6) strat <- strategy_multiattribute( cueA, cueB, v, c( "TTB", "TTBprob", "WADD", "WADDprob", "EQW", "GUESS" ) ) # get unique item types types <- strategy_unique(strat) types$unique # get table of choice frequencies for analysis freq <- with( heck2017_raw, table(vp, types$item_type, choice) ) freqB <- freq[, 4:1, 1] + # reversed items: Option A freq[, 5:8, 2] # non-rev. items: Option B head(40 - freqB) data(heck2017) head(heck2017) # same frequencies (different order) # strategy classification pp <- strategy_postprob( freqB[1:4, ], rep(40, 4), types$strategies ) round(pp, 3)
Choice frequencies of multiattribute decisions across 3 item types (Hilbig & Moshagen, 2014).
hilbig2014
hilbig2014
A data frame 3 variables:
B1
Frequency of choosing Option B for Item Type 1
B2
Frequency of choosing Option B for Item Type 2
B3
Frequency of choosing Option B for Item Type 3
Each participant made 32 choices for each of 3 item types with four cues (with validities .9, .8, .7, and .6).
The pattern of cue values of Option A and and B was as follows:
A = (1, 1, 1, -1) vs. B = (-1, 1, -1, 1)
A = (1, -1, -1, -1) vs. B = (-1, 1, 1, -1)
A = (1, 1, 1, -1) vs. B = (-1, 1, 1, 1)
Hilbig, B. E., & Moshagen, M. (2014). Generalized outcome-based strategy classification: Comparing deterministic and probabilistic choice models. Psychonomic Bulletin & Review, 21(6), 1431-1443. doi:10.3758/s13423-014-0643-0
data(hilbig2014) head(hilbig2014) # validities and cue values v <- c(.9, .8, .7, .6) cueA <- matrix( c( 1, 1, 1, -1, 1, -1, -1, -1, 1, 1, 1, -1 ), ncol = 4, byrow = TRUE ) cueB <- matrix( c( -1, 1, -1, 1, -1, 1, 1, -1, -1, 1, 1, 1 ), ncol = 4, byrow = TRUE ) # get strategy predictions strategies <- c( "baseline", "WADDprob", "WADD", "TTB", "EQW", "GUESS" ) preds <- strategy_multiattribute(cueA, cueB, v, strategies) c <- c(1, rep(.5, 5)) # upper bound of probabilities # use Bayes factor for strategy classification n <- rep(32, 3) strategy_postprob(k = hilbig2014[1:5, ], n, preds)
data(hilbig2014) head(hilbig2014) # validities and cue values v <- c(.9, .8, .7, .6) cueA <- matrix( c( 1, 1, 1, -1, 1, -1, -1, -1, 1, 1, 1, -1 ), ncol = 4, byrow = TRUE ) cueB <- matrix( c( -1, 1, -1, 1, -1, 1, 1, -1, -1, 1, 1, 1 ), ncol = 4, byrow = TRUE ) # get strategy predictions strategies <- c( "baseline", "WADDprob", "WADD", "TTB", "EQW", "GUESS" ) preds <- strategy_multiattribute(cueA, cueB, v, strategies) c <- c(1, rep(.5, 5)) # upper bound of probabilities # use Bayes factor for strategy classification n <- rep(32, 3) strategy_postprob(k = hilbig2014[1:5, ], n, preds)
Determines whether a point x
is inside a convex poltyope by checking whether
(1) all inequalities A*x <= b
are satisfied or
(2) the point x
is in the convex hull of the vertices in V
.
inside(x, A, b, V)
inside(x, A, b, V)
x |
a vector of length equal to the number of columns of |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
Ab_to_V
and V_to_Ab
to change between A/b and V representation.
# linear order constraints: x1<x2<x3<.5 A <- matrix(c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE) b <- c(0, 0, .50) # vertices: admissible points (corners of polytope) V <- matrix(c( 0, 0, 0, 0, 0, .5, 0, .5, .5, .5, .5, .5 ), ncol = 3, byrow = TRUE) xin <- c(.1, .2, .45) # inside inside(xin, A, b) inside(xin, V = V) xout <- c(.4, .1, .55) # outside inside(xout, A, b) inside(xout, V = V)
# linear order constraints: x1<x2<x3<.5 A <- matrix(c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE) b <- c(0, 0, .50) # vertices: admissible points (corners of polytope) V <- matrix(c( 0, 0, 0, 0, 0, .5, 0, .5, .5, .5, .5, .5 ), ncol = 3, byrow = TRUE) xin <- c(.1, .2, .45) # inside inside(xin, A, b) inside(xin, V = V) xout <- c(.4, .1, .55) # outside inside(xout, A, b) inside(xout, V = V)
Computes relative choice frequencies and checks whether these are in the polytope defined
via (1) A*x <= b
or (2) by the convex hull of a set of vertices V
.
inside_binom(k, n, A, b, V) inside_multinom(k, options, A, b, V)
inside_binom(k, n, A, b, V) inside_multinom(k, options, A, b, V)
k |
choice frequencies.
For |
n |
only for |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
options |
only for |
############ binomial # x1<x2<x3<.50: A <- matrix(c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE) b <- c(0, 0, .50) k <- c(0, 1, 5) n <- c(10, 10, 10) inside_binom(k, n, A, b) ############ multinomial # two ternary choices: # (a1,a2,a3, b1,b2,b3) k <- c(1, 4, 10, 5, 9, 1) options <- c(3, 3) # a1<b1, a2<b2, no constraints on a3, b3 A <- matrix(c( 1, -1, 0, 0, 0, 0, 1, -1 ), ncol = 4, byrow = TRUE) b <- c(0, 0) inside_multinom(k, options, A, b) # V-representation: V <- matrix(c( 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1 ), 9, 4, byrow = TRUE) inside_multinom(k, options, V = V)
############ binomial # x1<x2<x3<.50: A <- matrix(c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE) b <- c(0, 0, .50) k <- c(0, 1, 5) n <- c(10, 10, 10) inside_binom(k, n, A, b) ############ multinomial # two ternary choices: # (a1,a2,a3, b1,b2,b3) k <- c(1, 4, 10, 5, 9, 1) options <- c(3, 3) # a1<b1, a2<b2, no constraints on a3, b3 A <- matrix(c( 1, -1, 0, 0, 0, 0, 1, -1 ), ncol = 4, byrow = TRUE) b <- c(0, 0) inside_multinom(k, options, A, b) # V-representation: V <- matrix(c( 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1 ), 9, 4, byrow = TRUE) inside_multinom(k, options, V = V)
The test was part of the 1992 Trial State Assessment in Reading at Grade 4, conducted by the National Assessments of Educational Progress (NAEP).
karabatsos2004
karabatsos2004
A list with 4 matrices:
k.M
: Number of correct responses for participants with rest scores j=0,...,5 (i.e., the sum score minus the score for item i)
n.M
: Total number of participants for each cell of matrix k.M
k.IIO
: Number of correct responses for participants with sum scores j=0,...,6
n.IIO
: Total number of participants for each cell of matrix k.IIO
Karabatsos, G., & Sheu, C.-F. (2004). Order-constrained Bayes inference for dichotomous models of unidimensional nonparametric IRT. Applied Psychological Measurement, 28(2), 110-125. doi:10.1177/0146621603260678
The polytope for the nonparametric item response theory can be obtained
using (see nirt_to_Ab
).
data(karabatsos2004) head(karabatsos2004) ###################################################### ##### Testing Monotonicity (M) ##### ##### (Karabatsos & Sheu, 2004, Table 3, p. 120) ##### IJ <- dim(karabatsos2004$k.M) monotonicity <- nirt_to_Ab(IJ[1], IJ[2], axioms = "W1") p <- sampling_binom( k = c(karabatsos2004$k.M), n = c(karabatsos2004$n.M), A = monotonicity$A, b = monotonicity$b, prior = c(.5, .5), M = 300 ) # posterior means (Table 4, p. 120) post.mean <- matrix(apply(p, 2, mean), IJ[1], dimnames = dimnames(karabatsos2004$k.M) ) round(post.mean, 2) # posterior predictive checks (Table 4, p. 121) ppp <- ppp_binom(p, c(karabatsos2004$k.M), c(karabatsos2004$n.M), by = 1:prod(IJ) ) ppp <- matrix(ppp[, 3], IJ[1], dimnames = dimnames(karabatsos2004$k.M)) round(ppp, 2) ###################################################### ##### Testing invariant item ordering (IIO) ##### ##### (Karabatsos & Sheu, 2004, Table 6, p. 122) ##### IJ <- dim(karabatsos2004$k.IIO) iio <- nirt_to_Ab(IJ[1], IJ[2], axioms = "W2") p <- sampling_binom( k = c(karabatsos2004$k.IIO), n = c(karabatsos2004$n.IIO), A = iio$A, b = iio$b, prior = c(.5, .5), M = 300 ) # posterior predictive checks (Table 6, p. 122) ppp <- ppp_binom(prob = p, k = c(karabatsos2004$k.IIO), n = c(karabatsos2004$n.IIO), by = 1:prod(IJ)) matrix(ppp[,3], 7, dimnames = dimnames(karabatsos2004$k.IIO)) # for each item: ppp <- ppp_binom(p, c(karabatsos2004$k.IIO), c(karabatsos2004$n.IIO), by = rep(1:IJ[2], each = IJ[1])) round(ppp[,3], 2)
data(karabatsos2004) head(karabatsos2004) ###################################################### ##### Testing Monotonicity (M) ##### ##### (Karabatsos & Sheu, 2004, Table 3, p. 120) ##### IJ <- dim(karabatsos2004$k.M) monotonicity <- nirt_to_Ab(IJ[1], IJ[2], axioms = "W1") p <- sampling_binom( k = c(karabatsos2004$k.M), n = c(karabatsos2004$n.M), A = monotonicity$A, b = monotonicity$b, prior = c(.5, .5), M = 300 ) # posterior means (Table 4, p. 120) post.mean <- matrix(apply(p, 2, mean), IJ[1], dimnames = dimnames(karabatsos2004$k.M) ) round(post.mean, 2) # posterior predictive checks (Table 4, p. 121) ppp <- ppp_binom(p, c(karabatsos2004$k.M), c(karabatsos2004$n.M), by = 1:prod(IJ) ) ppp <- matrix(ppp[, 3], IJ[1], dimnames = dimnames(karabatsos2004$k.M)) round(ppp, 2) ###################################################### ##### Testing invariant item ordering (IIO) ##### ##### (Karabatsos & Sheu, 2004, Table 6, p. 122) ##### IJ <- dim(karabatsos2004$k.IIO) iio <- nirt_to_Ab(IJ[1], IJ[2], axioms = "W2") p <- sampling_binom( k = c(karabatsos2004$k.IIO), n = c(karabatsos2004$n.IIO), A = iio$A, b = iio$b, prior = c(.5, .5), M = 300 ) # posterior predictive checks (Table 6, p. 122) ppp <- ppp_binom(prob = p, k = c(karabatsos2004$k.IIO), n = c(karabatsos2004$n.IIO), by = 1:prod(IJ)) matrix(ppp[,3], 7, dimnames = dimnames(karabatsos2004$k.IIO)) # for each item: ppp <- ppp_binom(p, c(karabatsos2004$k.IIO), c(karabatsos2004$n.IIO), by = rep(1:IJ[2], each = IJ[1])) round(ppp[,3], 2)
Get ML estimate for product-binomial/multinomial model with linear inequality constraints.
ml_binom(k, n, A, b, map, strategy, n.fit = 3, start, progress = FALSE, ...) ml_multinom(k, options, A, b, V, n.fit = 3, start, progress = FALSE, ...)
ml_binom(k, n, A, b, map, strategy, n.fit = 3, start, progress = FALSE, ...) ml_multinom(k, options, A, b, V, n.fit = 3, start, progress = FALSE, ...)
k |
vector of observed response frequencies. |
n |
the number of choices per item type.
If |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
map |
optional: numeric vector of the same length as |
strategy |
a list that defines the predictions of a strategy, see |
n.fit |
number of calls to constrOptim. |
start |
only relevant if |
progress |
whether a progress bar should be shown (if |
... |
further arguments passed to the function
|
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
First, it is checked whether the unconstrained maximum-likelihood estimator
(e.g., for the binomial: k/n
) is inside the constrained parameter space.
Only if this is not the case, nonlinear optimization with convex linear-inequality
constrained is used to estimate (A) the probability parameters
for the Ab-representation or (B) the mixture weights
for the V-representation.
the list returned by the optimizer constrOptim
,
including the input arguments (e.g., k
, options
, A
, V
, etc.).
If the Ab-representation was used, par
provides the ML estimate for
the probability vector .
If the V-representation was used, par
provides the estimates for the
(usually not identifiable) mixture weights that define the convex
hull of the vertices in
, while
p
provides the ML estimates for
the probability parameters. Because the weights must sum to one, the
-parameter for the last row of the matrix
is dropped.
If the unconstrained ML estimate is inside the convex hull, the mixture weights
are not estimated and replaced by missings (
NA
).
# predicted linear order: p1 < p2 < p3 < .50 # (cf. WADDprob in ?strategy_multiattribute) A <- matrix( c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE ) b <- c(0, 0, .50) ml_binom(k = c(4, 1, 23), n = 40, A, b)[1:2] ml_multinom( k = c(4, 36, 1, 39, 23, 17), options = c(2, 2, 2), A, b )[1:2] # probabilistic strategy: A,A,A,B [e1<e2<e3<e4<.50] strat <- list( pattern = c(-1, -2, -3, 4), c = .5, ordered = TRUE, prior = c(1, 1) ) ml_binom(c(7, 3, 1, 19), 20, strategy = strat)[1:2] # vertex representation (one prediction per row) V <- matrix(c( # strict weak orders 0, 1, 0, 1, 0, 1, # a < b < c 1, 0, 0, 1, 0, 1, # b < a < c 0, 1, 0, 1, 1, 0, # a < c < b 0, 1, 1, 0, 1, 0, # c < a < b 1, 0, 1, 0, 1, 0, # c < b < a 1, 0, 1, 0, 0, 1, # b < c < a 0, 0, 0, 1, 0, 1, # a ~ b < c 0, 1, 0, 0, 1, 0, # a ~ c < b 1, 0, 1, 0, 0, 0, # c ~ b < a 0, 1, 0, 1, 0, 0, # a < b ~ c 1, 0, 0, 0, 0, 1, # b < a ~ c 0, 0, 1, 0, 1, 0, # c < a ~ b 0, 0, 0, 0, 0, 0 # a ~ b ~ c ), byrow = TRUE, ncol = 6) ml_multinom( k = c(4, 1, 5, 1, 9, 0, 7, 2, 1), n.fit = 1, options = c(3, 3, 3), V = V )
# predicted linear order: p1 < p2 < p3 < .50 # (cf. WADDprob in ?strategy_multiattribute) A <- matrix( c( 1, -1, 0, 0, 1, -1, 0, 0, 1 ), ncol = 3, byrow = TRUE ) b <- c(0, 0, .50) ml_binom(k = c(4, 1, 23), n = 40, A, b)[1:2] ml_multinom( k = c(4, 36, 1, 39, 23, 17), options = c(2, 2, 2), A, b )[1:2] # probabilistic strategy: A,A,A,B [e1<e2<e3<e4<.50] strat <- list( pattern = c(-1, -2, -3, 4), c = .5, ordered = TRUE, prior = c(1, 1) ) ml_binom(c(7, 3, 1, 19), 20, strategy = strat)[1:2] # vertex representation (one prediction per row) V <- matrix(c( # strict weak orders 0, 1, 0, 1, 0, 1, # a < b < c 1, 0, 0, 1, 0, 1, # b < a < c 0, 1, 0, 1, 1, 0, # a < c < b 0, 1, 1, 0, 1, 0, # c < a < b 1, 0, 1, 0, 1, 0, # c < b < a 1, 0, 1, 0, 0, 1, # b < c < a 0, 0, 0, 1, 0, 1, # a ~ b < c 0, 1, 0, 0, 1, 0, # a ~ c < b 1, 0, 1, 0, 0, 0, # c ~ b < a 0, 1, 0, 1, 0, 0, # a < b ~ c 1, 0, 0, 0, 0, 1, # b < a ~ c 0, 0, 1, 0, 1, 0, # c < a ~ b 0, 0, 0, 0, 0, 0 # a ~ b ~ c ), byrow = TRUE, ncol = 6) ml_multinom( k = c(4, 1, 5, 1, 9, 0, 7, 2, 1), n.fit = 1, options = c(3, 3, 3), V = V )
Computes the posterior model probabilities based on the log-marginal likelihoods/negative NML values.
model_weights(x, prior)
model_weights(x, prior)
x |
vector or matrix of log-marginal probabilities or negative NML values (if matrix: one model per column) |
prior |
vector of prior model probabilities (default: uniform over models). The vector is normalized internally to sum to one. |
logmarginal <- c(-3.4, -2.0, -10.7) model_weights(logmarginal) nml <- matrix(c( 2.5, 3.1, 4.2, 1.4, 0.3, 8.2 ), nrow = 2, byrow = TRUE) model_weights(-nml)
logmarginal <- c(-3.4, -2.0, -10.7) model_weights(logmarginal) nml <- matrix(c( 2.5, 3.1, 4.2, 1.4, 0.3, 8.2 ), nrow = 2, byrow = TRUE) model_weights(-nml)
Provides the inequality constraints on choice probabilities implied by nonparametric item response theory (NIRT; Karabatsos, 2001).
nirt_to_Ab(N, M, options = 2, axioms = c("W1", "W2"))
nirt_to_Ab(N, M, options = 2, axioms = c("W1", "W2"))
N |
number of persons / rows in item-response table |
M |
number of items / columns in item-response table |
options |
number of item categories/response options. If |
axioms |
which axioms should be included in the polytope representation |
In contrast to parametric IRT models (e.g., the 1-parameter-logistic Rasch model), NIRT does not assume specific parametric shapes of the item-response and person-response functions. Instead, the necessary axioms for a unidimensional representation of the latent trait are tested directly.
The axioms are as follows:
"W1"
: Weak row/subject independence: Persons can be ordered on an ordinal scale independent of items.
"W2"
: Weak column/item independence: Items can be ordered on an ordinal scale independent of persons
"DC"
: Double cancellation: A necessary condition for a joint ordering of (person,item) pairs and an additive representation (i.e., an interval scale).
Note that axioms W1 and W2 jointly define the ISOP model by Scheiblechner (1995; isotonic ordinal probabilistic model) and the double homogeneity model by Mokken (1971). If DC is added, we obtain the ADISOP model by Scheiblechner (1999; ).
Karabatsos, G. (2001). The Rasch model, additive conjoint measurement, and new models of probabilistic measurement theory. Journal of Applied Measurement, 2(4), 389–423.
Karabatsos, G., & Sheu, C.-F. (2004). Order-constrained Bayes inference for dichotomous models of unidimensional nonparametric IRT. Applied Psychological Measurement, 28(2), 110-125. doi:10.1177/0146621603260678
Mokken, R. J. (1971). A theory and procedure of scale analysis: With applications in political research (Vol. 1). Berlin: Walter de Gruyter.
Scheiblechner, H. (1995). Isotonic ordinal probabilistic models (ISOP). Psychometrika, 60(2), 281–304. doi:10.1007/BF02301417
Scheiblechner, H. (1999). Additive conjoint isotonic probabilistic models (ADISOP). Psychometrika, 64(3), 295–316. doi:10.1007/BF02294297
# 5 persons, 3 items nirt_to_Ab(5, 3)
# 5 persons, 3 items nirt_to_Ab(5, 3)
Aggregation of multiple individual (N=1) Bayes factors to obtain the evidence for a hypothesis in a population of persons.
population_bf(bfs)
population_bf(bfs)
bfs |
a vector with individual Bayes factors,
a matrix with one type of Bayes-factor comparison per column,
or a list of matrices with a named column |
a vector or matrix with named elements/columns:
population_bf
: the product of individual BFs
geometric_bf
: the geometric mean of the individual BFs
evidence_rate
: the proportion of BFs>1 (BFs<1) if geometric_bf>1
(<1).
Values close to 1.00 indicate homogeneity.
stability_rate
: the proportion bfs>geometric_bf
(<) if geometric_bf>1
(<).
Values close to 0.50 indicate stability.
Klaassen, F., Zedelius, C. M., Veling, H., Aarts, H., & Hoijtink, H. (in press). All for one or some for all? Evaluating informative hypotheses using multiple N = 1 studies. Behavior Research Methods. https://doi.org/10.3758/s13428-017-0992-5
# consistent evidence across persons: bfs <- c(2.3, 1.8, 3.3, 2.8, 4.0, 1.9, 2.5) population_bf(bfs) # (A) heterogeneous, inconsistent evidence # (B) heterogeneous, inconsistent evidence bfs <- cbind( A = c(2.3, 1.8, 3.3, 2.8, 4.0, 1.9, 2.5), B = c(10.3, .7, 3.3, .8, 14.0, .9, 1.5) ) population_bf(bfs)
# consistent evidence across persons: bfs <- c(2.3, 1.8, 3.3, 2.8, 4.0, 1.9, 2.5) population_bf(bfs) # (A) heterogeneous, inconsistent evidence # (B) heterogeneous, inconsistent evidence bfs <- cbind( A = c(2.3, 1.8, 3.3, 2.8, 4.0, 1.9, 2.5), B = c(10.3, .7, 3.3, .8, 14.0, .9, 1.5) ) population_bf(bfs)
Computes posterior model probabilities based on Bayes factors.
postprob(..., prior, include_unconstr = TRUE)
postprob(..., prior, include_unconstr = TRUE)
... |
one or more Bayes-factor objects for different models as returned
by the functions |
prior |
a vector of prior model probabilities (default: uniform). The
order must be identical to that of the Bayes factors supplied via
|
include_unconstr |
whether to include the unconstrained, encompassing model without inequality constraints (i.e., the saturated model). |
# data: binomial frequencies in 4 conditions n <- 100 k <- c(59, 54, 74) # Hypothesis 1: p1 < p2 < p3 A1 <- matrix(c( 1, -1, 0, 0, 1, -1 ), 2, 3, TRUE) b1 <- c(0, 0) # Hypothesis 2: p1 < p2 and p1 < p3 A2 <- matrix(c( 1, -1, 0, 1, 0, -1 ), 2, 3, TRUE) b2 <- c(0, 0) # get posterior probability for hypothesis bf1 <- bf_binom(k, n, A = A1, b = b1) bf2 <- bf_binom(k, n, A = A2, b = b2) postprob(bf1, bf2, prior = c(bf1 = 1 / 3, bf2 = 1 / 3, unconstr = 1 / 3) )
# data: binomial frequencies in 4 conditions n <- 100 k <- c(59, 54, 74) # Hypothesis 1: p1 < p2 < p3 A1 <- matrix(c( 1, -1, 0, 0, 1, -1 ), 2, 3, TRUE) b1 <- c(0, 0) # Hypothesis 2: p1 < p2 and p1 < p3 A2 <- matrix(c( 1, -1, 0, 1, 0, -1 ), 2, 3, TRUE) b2 <- c(0, 0) # get posterior probability for hypothesis bf1 <- bf_binom(k, n, A = A1, b = b1) bf2 <- bf_binom(k, n, A = A2, b = b2) postprob(bf1, bf2, prior = c(bf1 = 1 / 3, bf2 = 1 / 3, unconstr = 1 / 3) )
Uses posterior samples to get posterior-predicted frequencies and compare the Pearson's X^2 statistic for (1) the observed frequencies vs. (2) the posterior-predicted frequencies.
ppp_binom(prob, k, n, by) ppp_multinom(prob, k, options, drop_fixed = TRUE)
ppp_binom(prob, k, n, by) ppp_multinom(prob, k, options, drop_fixed = TRUE)
prob |
vector with probabilities or a matrix with one probability vector per row.
For |
k |
vector of observed response frequencies. |
n |
integer vector, specifying the number of trials for each binomial/multinomial distribution
Note that this is the |
by |
optional: a vector of the same length as |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
drop_fixed |
whether the output matrix includes the last probability for each category (which is not a free parameter since probabilities must sum to one). |
Myung, J. I., Karabatsos, G., & Iverson, G. J. (2005). A Bayesian approach to testing decision making axioms. Journal of Mathematical Psychology, 49, 205-225. doi:10.1016/j.jmp.2005.02.004
sampling_binom
/sampling_multinom
to get
posterior samples and rpbinom
/rpmultinom
to
get posterior-predictive samples.
# uniform samples: p<.10 prob <- matrix(runif(300 * 3, 0, .1), 300) n <- rep(10, 3) ppp_binom(prob, c(1, 2, 0), n) # ok ppp_binom(prob, c(5, 4, 3), n) # misfit # multinomial (ternary choice) prob <- matrix(runif(300 * 2, 0, .05), 300) ppp_multinom(prob, c(1, 0, 9), 3) # ok
# uniform samples: p<.10 prob <- matrix(runif(300 * 3, 0, .1), 300) n <- rep(10, 3) ppp_binom(prob, c(1, 2, 0), n) # ok ppp_binom(prob, c(5, 4, 3), n) # misfit # multinomial (ternary choice) prob <- matrix(runif(300 * 2, 0, .05), 300) ppp_multinom(prob, c(1, 0, 9), 3) # ok
Raw data with choice frequencies for all 20 paired comparison of 5 gambles a, b, c, d, and e. Participants could either choose "Option 1", "Option 2", or "indifferent" (ternary choice). Each paired comparison (e.g., a vs. b) was repeated 45 times per participant. The data include 3 different gamble sets and aimed at testing whether people have transitive preferences (see Regenwetter & Davis-Stober, 2012).
regenwetter2012
regenwetter2012
A matrix with 22 columns:
participant
: Participant number
gamble_set
: Gamble set
a>b
: Number of times a preferred over b
b>a
: Number of times b preferred over a
a=b
: Number of times being indifferent between a and b
Regenwetter, M., & Davis-Stober, C. P. (2012). Behavioral variability of choices versus structural inconsistency of preferences. Psychological Review, 119(2), 408-416. doi:10.1037/a0027372
The substantive model of interest was the strict weak order polytope (see swop5
).
data(regenwetter2012) head(regenwetter2012) # check transitive preferences: strict weak order polytope (SWOP) data(swop5) tail(swop5$A, 3) # participant 1, gamble set 1: p1 <- regenwetter2012[1, -c(1:2)] inside_multinom(p1, swop5$options, swop5$A, swop5$b) # posterior samples p <- sampling_multinom(regenwetter2012[1, -c(1:2)], swop5$options, swop5$A, swop5$b, M = 100, start = swop5$start ) colMeans(p) apply(p[, 1:6], 2, plot, type = "l") ppp_multinom(p, p1, swop5$options) # Bayes factor bf_multinom(regenwetter2012[1, -c(1:2)], swop5$options, swop5$A, swop5$b, M = 10000 )
data(regenwetter2012) head(regenwetter2012) # check transitive preferences: strict weak order polytope (SWOP) data(swop5) tail(swop5$A, 3) # participant 1, gamble set 1: p1 <- regenwetter2012[1, -c(1:2)] inside_multinom(p1, swop5$options, swop5$A, swop5$b) # posterior samples p <- sampling_multinom(regenwetter2012[1, -c(1:2)], swop5$options, swop5$A, swop5$b, M = 100, start = swop5$start ) colMeans(p) apply(p[, 1:6], 2, plot, type = "l") ppp_multinom(p, p1, swop5$options) # Bayes factor bf_multinom(regenwetter2012[1, -c(1:2)], swop5$options, swop5$A, swop5$b, M = 10000 )
Generates random draws from independent multinomial distributions (= product-multinomial pmultinom
).
rpbinom(prob, n) rpmultinom(prob, n, options, drop_fixed = TRUE)
rpbinom(prob, n) rpmultinom(prob, n, options, drop_fixed = TRUE)
prob |
vector with probabilities or a matrix with one probability vector per row.
For |
n |
integer vector, specifying the number of trials for each binomial/multinomial distribution
Note that this is the |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
drop_fixed |
whether the output matrix includes the last probability for each category (which is not a free parameter since probabilities must sum to one). |
a matrix with one vector of frequencies per row. For rpbinom
, only
the frequencies of 'successes' are returned, whereas for rpmultinom
, the
complete frequency vectors (which sum to n
within each option) are returned.
# 3 binomials rpbinom(prob = c(.2, .7, .9), n = c(10, 50, 30)) # 2 and 3 options: [a1,a2, b1,b2,b3] rpmultinom( prob = c(a1 = .5, b1 = .3, b2 = .6), n = c(10, 20), options = c(2, 3) ) # or: rpmultinom( prob = c(a1 = .5, a2 = .5, b1 = .3, b2 = .6, b3 = .1), n = c(10, 20), options = c(2, 3), drop_fixed = FALSE ) # matrix with one probability vector per row: p <- rpdirichlet( n = 6, alpha = c(1, 1, 1, 1, 1), options = c(2, 3) ) rpmultinom(prob = p, n = c(20, 50), options = c(2, 3))
# 3 binomials rpbinom(prob = c(.2, .7, .9), n = c(10, 50, 30)) # 2 and 3 options: [a1,a2, b1,b2,b3] rpmultinom( prob = c(a1 = .5, b1 = .3, b2 = .6), n = c(10, 20), options = c(2, 3) ) # or: rpmultinom( prob = c(a1 = .5, a2 = .5, b1 = .3, b2 = .6, b3 = .1), n = c(10, 20), options = c(2, 3), drop_fixed = FALSE ) # matrix with one probability vector per row: p <- rpdirichlet( n = 6, alpha = c(1, 1, 1, 1, 1), options = c(2, 3) ) rpmultinom(prob = p, n = c(20, 50), options = c(2, 3))
Random samples from the prior/posterior (i.e., product-Dirichlet) of the unconstrained product-multinomial model (the encompassing model).
rpdirichlet(n, alpha, options, drop_fixed = TRUE)
rpdirichlet(n, alpha, options, drop_fixed = TRUE)
n |
number of samples |
alpha |
Dirichlet parameters concatenated across independent conditions (e.g., a1,a2, b1,b2,b3) |
options |
the number of choice options per item type, e.g., |
drop_fixed |
whether the output matrix includes the last probability for each category (which is not a free parameter since probabilities must sum to one). |
# standard uniform Dirichlet rpdirichlet(5, c(1,1,1,1), 4) rpdirichlet(5, c(1,1,1,1), 4, drop_fixed = FALSE) # two ternary outcomes: (a1,a2,a3, b1,b2,b3) rpdirichlet(5, c(9,5,1, 3,6,6), c(3,3)) rpdirichlet(5, c(9,5,1, 3,6,6), c(3,3), drop_fixed = FALSE)
# standard uniform Dirichlet rpdirichlet(5, c(1,1,1,1), 4) rpdirichlet(5, c(1,1,1,1), 4, drop_fixed = FALSE) # two ternary outcomes: (a1,a2,a3, b1,b2,b3) rpdirichlet(5, c(9,5,1, 3,6,6), c(3,3)) rpdirichlet(5, c(9,5,1, 3,6,6), c(3,3), drop_fixed = FALSE)
Uses Gibbs sampling to draw posterior samples for binomial and multinomial models with linear inequality-constraints.
sampling_multinom( k, options, A, b, V, prior = rep(1, sum(options)), M = 5000, start, burnin = 10, progress = TRUE, cpu = 1 ) sampling_binom( k, n, A, b, V, map = 1:ncol(A), prior = c(1, 1), M = 5000, start, burnin = 10, progress = TRUE, cpu = 1 )
sampling_multinom( k, options, A, b, V, prior = rep(1, sum(options)), M = 5000, start, burnin = 10, progress = TRUE, cpu = 1 ) sampling_binom( k, n, A, b, V, map = 1:ncol(A), prior = c(1, 1), M = 5000, start, burnin = 10, progress = TRUE, cpu = 1 )
k |
the number of choices for each alternative ordered by item type (e.g.
|
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
A |
a matrix with one row for each linear inequality constraint and one
column for each of the free parameters. The parameter space is defined
as all probabilities |
b |
a vector of the same length as the number of rows of |
V |
a matrix of vertices (one per row) that define the polytope of
admissible parameters as the convex hull over these points
(if provided, |
prior |
the prior parameters of the Dirichlet-shape parameters.
Must have the same length as |
M |
number of posterior samples |
start |
only relevant if |
burnin |
number of burnin samples that are discarded. Can be chosen to be small if the maxmimum-a-posteriori estimate is used as the (default) starting value. |
progress |
whether a progress bar should be shown (if |
cpu |
either the number of CPUs using separate MCMC chains in parallel,
or a parallel cluster (e.g., |
n |
the number of choices per item type.
If |
map |
optional: numeric vector of the same length as |
Draws posterior samples for binomial/multinomial random utility models that
assume a mixture over predefined preference orders/vertices that jointly define
a convex polytope via the set of inequalities A * x < b
or as the
convex hull of a set of vertices V
.
an mcmc
matrix (or an mcmc.list
if cpu>1
) with
posterior samples of the binomial/multinomial probability parameters.
See mcmc
) .
Myung, J. I., Karabatsos, G., & Iverson, G. J. (2005). A Bayesian approach to testing decision making axioms. Journal of Mathematical Psychology, 49, 205-225. doi:10.1016/j.jmp.2005.02.004
############### binomial ########################## A <- matrix( c( 1, 0, 0, # x1 < .50 1, 1, 1, # x1+x2+x3 < 1 0, 2, 2, # 2*x2+2*x3 < 1 0, -1, 0, # x2 > .2 0, 0, 1 ), # x3 < .1 ncol = 3, byrow = TRUE ) b <- c(.5, 1, 1, -.2, .1) samp <- sampling_binom(c(5, 12, 7), c(20, 20, 20), A, b) head(samp) plot(samp) ############### multinomial ########################## # binary and ternary choice: # (a1,a2 b1,b2,b3) k <- c(15, 9, 5, 2, 17) options <- c(2, 3) # columns: (a1, b1,b2) A <- matrix( c( 1, 0, 0, # a1 < .20 0, 2, 1, # 2*b1+b2 < 1 0, -1, 0, # b1 > .2 0, 0, 1 ), # b2 < .4 ncol = 3, byrow = TRUE ) b <- c(.2, 1, -.2, .4) samp <- sampling_multinom(k, options, A, b) head(samp) plot(samp)
############### binomial ########################## A <- matrix( c( 1, 0, 0, # x1 < .50 1, 1, 1, # x1+x2+x3 < 1 0, 2, 2, # 2*x2+2*x3 < 1 0, -1, 0, # x2 > .2 0, 0, 1 ), # x3 < .1 ncol = 3, byrow = TRUE ) b <- c(.5, 1, 1, -.2, .1) samp <- sampling_binom(c(5, 12, 7), c(20, 20, 20), A, b) head(samp) plot(samp) ############### multinomial ########################## # binary and ternary choice: # (a1,a2 b1,b2,b3) k <- c(15, 9, 5, 2, 17) options <- c(2, 3) # columns: (a1, b1,b2) A <- matrix( c( 1, 0, 0, # a1 < .20 0, 2, 1, # 2*b1+b2 < 1 0, -1, 0, # b1 > .2 0, 0, 1 ), # b2 < .4 ncol = 3, byrow = TRUE ) b <- c(.2, 1, -.2, .4) samp <- sampling_multinom(k, options, A, b) head(samp) plot(samp)
A Gibbs sampler that draws posterior samples of probability parameters conditional on a (possibly nonlinear) indicator function defining a restricted parameter space that is convex.
sampling_nonlinear( k, options, inside, prior = rep(1, sum(options)), M = 1000, start, burnin = 10, eps = 1e-06, progress = TRUE, cpu = 1 )
sampling_nonlinear( k, options, inside, prior = rep(1, sum(options)), M = 1000, start, burnin = 10, eps = 1e-06, progress = TRUE, cpu = 1 )
k |
vector of observed response frequencies. |
options |
number of observable categories/probabilities for each item
type/multinomial distribution, e.g., |
inside |
an indicator function that takes a vector with probabilities
|
prior |
a vector with two positive numbers defining the shape parameters of the beta prior distributions for each binomial rate parameter. |
M |
number of posterior samples drawn from the encompassing model |
start |
only relevant if |
burnin |
number of burnin samples that are discarded. Can be chosen to be small if the maxmimum-a-posteriori estimate is used as the (default) starting value. |
eps |
precision of the bisection algorithm |
progress |
whether a progress bar should be shown (if |
cpu |
either the number of CPUs used for parallel sampling, or a parallel
cluster (e.g., |
Inequality constraints are defined via an indicator function inside
which returns inside(x)=1
(or 0
) if the vector of free parameters
x
is inside (or outside) the model space. Since the vector x
must include only free (!) parameters, the last probability for each
multinomial must not be used in the function inside(x)
!
Efficiency can be improved greatly if the indicator function is defined as C++ code via the function cppXPtr in the package RcppXPtrUtils (see below for examples). In this case, please keep in mind that indexing in C++ starts with 0,1,2... (not with 1,2,3,... as in R)!
For each parameter, the Gibbs sampler draws a sample from the conditional posterior distribution (a scaled, truncated beta). The conditional truncation boundaries are computed with a bisection algorithm. This requires that the restricted parameteter space defined by the indicator function is convex.
# two binomial success probabilities: x = c(x1, x2) # restriction to a circle: model <- function(x) { (x[1] - .50)^2 + (x[2] - .50)^2 <= .15 } # draw prior samples mcmc <- sampling_nonlinear( k = 0, options = c(2, 2), inside = model, M = 1000 ) head(mcmc) plot(c(mcmc[, 1]), c(mcmc[, 2]), xlim = 0:1, ylim = 0:1) ##### Using a C++ indicator function (much faster) cpp_code <- "SEXP inside(NumericVector x){ return wrap( sum(pow(x-.50, 2)) <= .15);}" # NOTE: Uses Rcpp sugar syntax (vectorized sum & pow) # define function via C++ pointer: model_cpp <- RcppXPtrUtils::cppXPtr(cpp_code) mcmc <- sampling_nonlinear( k = 0, options = c(2, 2), inside = model_cpp ) head(mcmc) plot(c(mcmc[, 1]), c(mcmc[, 2]), xlim = 0:1, ylim = 0:1)
# two binomial success probabilities: x = c(x1, x2) # restriction to a circle: model <- function(x) { (x[1] - .50)^2 + (x[2] - .50)^2 <= .15 } # draw prior samples mcmc <- sampling_nonlinear( k = 0, options = c(2, 2), inside = model, M = 1000 ) head(mcmc) plot(c(mcmc[, 1]), c(mcmc[, 2]), xlim = 0:1, ylim = 0:1) ##### Using a C++ indicator function (much faster) cpp_code <- "SEXP inside(NumericVector x){ return wrap( sum(pow(x-.50, 2)) <= .15);}" # NOTE: Uses Rcpp sugar syntax (vectorized sum & pow) # define function via C++ pointer: model_cpp <- RcppXPtrUtils::cppXPtr(cpp_code) mcmc <- sampling_nonlinear( k = 0, options = c(2, 2), inside = model_cpp ) head(mcmc) plot(c(mcmc[, 1]), c(mcmc[, 2]), xlim = 0:1, ylim = 0:1)
Provides the necessary linear equality constraints to test stochastic dominance
of continuous distributions, that is, whether the cumulative density functions
satisfy the constraint
for all
.
stochdom_Ab(bins, conditions = 2, order = "<")
stochdom_Ab(bins, conditions = 2, order = "<")
bins |
number of bins of histogram |
conditions |
number of conditions |
order |
order constraint on the random variables across conditions.
The default |
Heathcote, A., Brown, S., Wagenmakers, E. J., & Eidels, A. (2010). Distribution-free tests of stochastic dominance for small samples. Journal of Mathematical Psychology, 54(5), 454-463. doi:10.1016/j.jmp.2010.06.005
stochdom_bf
to obtain a Bayes factor directly.
stochdom_Ab(4, 2) stochdom_Ab(4, 3)
stochdom_Ab(4, 2) stochdom_Ab(4, 3)
Uses discrete bins (as in a histogram) to compute the Bayes factor in favor of stochastic dominance of continuous distributions.
stochdom_bf(x1, x2, breaks = "Sturges", order = "<", ...)
stochdom_bf(x1, x2, breaks = "Sturges", order = "<", ...)
x1 |
a vector with samples from the first random variable/experimental condition. |
x2 |
a vector with samples from the second random variable/experimental condition. |
breaks |
number of bins of histogram. See |
order |
order constraint on the random variables across conditions.
The default |
... |
further arguments passed to |
Heathcote, A., Brown, S., Wagenmakers, E. J., & Eidels, A. (2010). Distribution-free tests of stochastic dominance for small samples. Journal of Mathematical Psychology, 54(5), 454-463. doi:10.1016/j.jmp.2010.06.005
x1 <- rnorm(300, 0, 1) x2 <- rnorm(300, .5, 1) # dominates x1 x3 <- rnorm(300, 0, 1.2) # intersects x1 plot(ecdf(x1)) lines(ecdf(x2), col = "red") lines(ecdf(x3), col = "blue") b12 <- stochdom_bf(x1, x2, order = "<", M = 5e4) b13 <- stochdom_bf(x1, x3, order = "<", M = 5e4) b12$bf b13$bf
x1 <- rnorm(300, 0, 1) x2 <- rnorm(300, .5, 1) # dominates x1 x3 <- rnorm(300, 0, 1.2) # intersects x1 plot(ecdf(x1)) lines(ecdf(x2), col = "red") lines(ecdf(x3), col = "blue") b12 <- stochdom_bf(x1, x2, order = "<", M = 5e4) b13 <- stochdom_bf(x1, x3, order = "<", M = 5e4) b12$bf b13$bf
Computes the logarithm of the marginal likelihood, defined as the integral over the likelihood function weighted by the prior distribution of the error probabilities.
strategy_marginal(k, n, strategy)
strategy_marginal(k, n, strategy)
k |
observed frequencies of Option B. Either a vector or a matrix/data frame (one person per row). |
n |
vector with the number of choices per item type. |
strategy |
a list that defines the predictions of a strategy, see |
k <- c(1, 11, 18) n <- c(20, 20, 20) # pattern: A, A, B with constant error e<.50 strat <- list( pattern = c(-1, -1, 1), c = .5, ordered = FALSE, prior = c(1, 1) ) m1 <- strategy_marginal(k, n, strat) m1 # pattern: A, B, B with ordered error e1<e3<e2<.50 strat2 <- list( pattern = c(-1, 3, 2), c = .5, ordered = TRUE, prior = c(1, 1) ) m2 <- strategy_marginal(k, n, strat2) m2 # Bayes factor: Model 2 vs. Model 1 exp(m2 - m1)
k <- c(1, 11, 18) n <- c(20, 20, 20) # pattern: A, A, B with constant error e<.50 strat <- list( pattern = c(-1, -1, 1), c = .5, ordered = FALSE, prior = c(1, 1) ) m1 <- strategy_marginal(k, n, strat) m1 # pattern: A, B, B with ordered error e1<e3<e2<.50 strat2 <- list( pattern = c(-1, 3, 2), c = .5, ordered = TRUE, prior = c(1, 1) ) m2 <- strategy_marginal(k, n, strat2) m2 # Bayes factor: Model 2 vs. Model 1 exp(m2 - m1)
Returns a list defining the predictions of different choice strategies (e.g., TTB, WADD)
strategy_multiattribute(cueA, cueB, v, strategy, c = 0.5, prior = c(1, 1))
strategy_multiattribute(cueA, cueB, v, strategy, c = 0.5, prior = c(1, 1))
cueA |
cue values of Option A (-1/+1 = negative/positive; 0 = missing). If a matrix is provided, each row defines one item type. |
cueB |
cue values of Option B (see |
v |
cue validities: probabilities that cues lead to correct decision. Must be of the same length as the number of cues. |
strategy |
strategy label, e.g., |
c |
defines the upper boundary for the error probabilities |
prior |
defines the prior distribution for the error probabilities
(i.e., truncated independent beta distributions |
a strategy
object (a list) with the entries:
pattern
: a numeric vector encoding the predicted choice pattern by the sign
(negative = Option A, positive = Option B, 0 = guessing).
Identical error probabilities are encoded by using the same absolute number
(e.g., c(-1,1,1)
defines one error probability with A,B,B predictions).
c
: upper boundary of error probabilities
ordered
: whether error probabilities are linearly ordered by their absolute value in pattern
(largest error: smallest absolute number)
prior
: a numeric vector with two positive values specifying the shape parameters of the beta prior distribution (truncated to the interval [0,c]
label
: strategy label
# single item type v <- c(.9, .8, .7, .6) ca <- c(1, -1, -1, 1) cb <- c(-1, 1, -1, -1) strategy_multiattribute(ca, cb, v, "TTB") strategy_multiattribute(ca, cb, v, "WADDprob") # multiple item types data(heck2017_raw) strategy_multiattribute( heck2017_raw[1:10, c("a1", "a2", "a3", "a4")], heck2017_raw[1:10, c("b1", "b2", "b3", "b4")], v, "WADDprob" )
# single item type v <- c(.9, .8, .7, .6) ca <- c(1, -1, -1, 1) cb <- c(-1, 1, -1, -1) strategy_multiattribute(ca, cb, v, "TTB") strategy_multiattribute(ca, cb, v, "WADDprob") # multiple item types data(heck2017_raw) strategy_multiattribute( heck2017_raw[1:10, c("a1", "a2", "a3", "a4")], heck2017_raw[1:10, c("b1", "b2", "b3", "b4")], v, "WADDprob" )
Posterior model probabilities for multiple strategies (with equal prior model probabilities).
strategy_postprob(k, n, strategies, cpu = 1)
strategy_postprob(k, n, strategies, cpu = 1)
k |
observed frequencies of Option B. Either a vector or a matrix/data frame (one person per row). |
n |
vector with the number of choices per item type. |
strategies |
list of strategies. See strategy_multiattribute |
cpu |
number of processing units for parallel computation. |
strategy_marginal
and model_weights
# pattern 1: A, A, B with constant error e<.50 strat1 <- list( pattern = c(-1, -1, 1), c = .5, ordered = FALSE, prior = c(1, 1) ) # pattern 2: A, B, B with ordered error e1<e3<e2<.50 strat2 <- list( pattern = c(-1, 3, 2), c = .5, ordered = TRUE, prior = c(1, 1) ) baseline <- list( pattern = 1:3, c = 1, ordered = FALSE, prior = c(1, 1) ) # data k <- c(3, 4, 12) # frequencies Option B n <- c(20, 20, 20) # number of choices strategy_postprob(k, n, list(strat1, strat2, baseline))
# pattern 1: A, A, B with constant error e<.50 strat1 <- list( pattern = c(-1, -1, 1), c = .5, ordered = FALSE, prior = c(1, 1) ) # pattern 2: A, B, B with ordered error e1<e3<e2<.50 strat2 <- list( pattern = c(-1, 3, 2), c = .5, ordered = TRUE, prior = c(1, 1) ) baseline <- list( pattern = 1:3, c = 1, ordered = FALSE, prior = c(1, 1) ) # data k <- c(3, 4, 12) # frequencies Option B n <- c(20, 20, 20) # number of choices strategy_postprob(k, n, list(strat1, strat2, baseline))
Transforms ordered item-type predictions to polytope definition.
This allows to use Monte-Carlo methods to compute the Bayes factor
if the number of item types is large (bf_binom
).
strategy_to_Ab(strategy)
strategy_to_Ab(strategy)
strategy |
a decision strategy returned by |
Note: Only works for models without guessing predictions and without equality constraints (i.e., requires separate error probabilities per item type)
a list containing the matrix A
and the vector b
that define a polytope via A*x <= b
.
# strategy: A,B,B,A e2<e3<e4<e1<.50 strat <- list( pattern = c(-1, 4, 3, -2), c = .5, ordered = TRUE, prior = c(1, 1) ) pt <- strategy_to_Ab(strat) pt # compare results to encompassing BF method: b <- list( pattern = 1:4, c = 1, ordered = FALSE, prior = c(1, 1) ) k <- c(2, 20, 18, 0) n <- rep(20, 4) m1 <- strategy_postprob(k, n, list(strat, b)) log(m1[1] / m1[2]) bf_binom(k, n, pt$A, pt$b, log = TRUE)
# strategy: A,B,B,A e2<e3<e4<e1<.50 strat <- list( pattern = c(-1, 4, 3, -2), c = .5, ordered = TRUE, prior = c(1, 1) ) pt <- strategy_to_Ab(strat) pt # compare results to encompassing BF method: b <- list( pattern = 1:4, c = 1, ordered = FALSE, prior = c(1, 1) ) k <- c(2, 20, 18, 0) n <- rep(20, 4) m1 <- strategy_postprob(k, n, list(strat, b)) log(m1[1] / m1[2]) bf_binom(k, n, pt$A, pt$b, log = TRUE)
Find unique item types, which are defined as patterns of cue values that lead to identical strategy predictions.
strategy_unique(strategies, add_baseline = TRUE, reversed = FALSE)
strategy_unique(strategies, add_baseline = TRUE, reversed = FALSE)
strategies |
a list of strategy predictions with the same length of
the vector |
add_baseline |
whether to add a baseline model which assumes one probability in [0,1] for each item type. |
reversed |
whether reversed patterns are treated separately
(default: automatically switch Option A and B if |
a list including:
unique
: a matrix with the unique strategy patterns
item_type
: a vector that maps the original predictions to item types (negative: reversed items)
strategies
: a list with strategy predictions with pattern
adapted to the unique item types
data(heck2017_raw) ca <- heck2017_raw[1:100, c("a1", "a2", "a3", "a4")] cb <- heck2017_raw[1:100, c("b1", "b2", "b3", "b4")] v <- c(.9, .8, .7, .6) strats <- strategy_multiattribute( ca, cb, v, c("WADDprob", "WADD", "TTB") ) strategy_unique(strats)
data(heck2017_raw) ca <- heck2017_raw[1:100, c("a1", "a2", "a3", "a4")] cb <- heck2017_raw[1:100, c("b1", "b2", "b3", "b4")] v <- c(.9, .8, .7, .6) strats <- strategy_multiattribute( ca, cb, v, c("WADDprob", "WADD", "TTB") ) strategy_unique(strats)
Facet-defining inequalities of the strict weak order mixture model for all 10 paired comparisons of 5 choice elements {a,b,c,d,e} in a 3-alternative forced-choice task (Regenwetter & Davis-Stober, 2012).
swop5
swop5
A list with 3 elements:
A
: Matrix with inequality constraints that define a polytope via A*x <= b
.
b
: vector with upper bounds for the inequalities.
start
: A point in the polytope.
options
: A vector with the number of options (=3) per item type.
Regenwetter, M., & Davis-Stober, C. P. (2012). Behavioral variability of choices versus structural inconsistency of preferences. Psychological Review, 119(2), 408-416. doi:10.1037/a0027372
The corresponding data set regenwetter2012
.
data(swop5) tail(swop5$A) # A*x <= b tail(swop5$b) swop5$start # inside SWOP polytope swop5$options # 3 choice options per item # check whether point is in polytope: inside(swop5$start, swop5$A, swop5$b) # get prior samples: p <- sampling_multinom(0, swop5$options, swop5$A, swop5$b, M = 100, start = swop5$start ) colMeans(p) apply(p[, 1:5], 2, plot, type = "l")
data(swop5) tail(swop5$A) # A*x <= b tail(swop5$b) swop5$start # inside SWOP polytope swop5$options # 3 choice options per item # check whether point is in polytope: inside(swop5$start, swop5$A, swop5$b) # get prior samples: p <- sampling_multinom(0, swop5$options, swop5$A, swop5$b, M = 100, start = swop5$start ) colMeans(p) apply(p[, 1:5], 2, plot, type = "l")
For convex polytopes: Requires rPorta
(https://github.com/TasCL/rPorta)
to transform the vertex representation to/from the inequality representation.
Since rPorta
cannot be compiled with R versions >=4.0.0 anymore,
the function is currently deprecated.
V_to_Ab(V) Ab_to_V(A, b, options = 2)
V_to_Ab(V) Ab_to_V(A, b, options = 2)
V |
a matrix with one vertex of a polytope per row (e.g., the admissible preference orders of a random utility model or any other theory). Since the values have to sum up to one within each multinomial condition, the last value of each multinomial is omitted (e.g., the prediction 1-0-0/0-1 for a tri and binomial becomes 1-0/0). |
A |
a matrix defining the convex polytope via |
b |
a vector of the same length as the number of rows of |
options |
number of choice options per item type.
Can be a vector |
Choice models can be represented as polytopes if they assume a latent mixture over a finite number preference patterns (random preference model). For the general approach and theory underlying binary and ternary choice models, see Regenwetter et al. (2012, 2014, 2017).
The function is currently deprecated since the package rPorta
cannot be compiled with R>=4.0.0!
For binary choices (options=2
), additional constraints are added to A
and b
to ensure that all dimensions of the polytope satisfy: 0 <= p_i <= 1.
For ternary choices (options=3
), constraints are added to ensure that 0 <= p_1+p_2 <=1
for pairwise columns (1+2, 3+4, 5+6, ...). See Ab_multinom
.
Regenwetter, M., & Davis-Stober, C. P. (2012). Behavioral variability of choices versus structural inconsistency of preferences. Psychological Review, 119(2), 408-416. doi:10.1037/a0027372
Regenwetter, M., Davis-Stober, C. P., Lim, S. H., Guo, Y., Popova, A., Zwilling, C., … Messner, W. (2014). QTest: Quantitative testing of theories of binary choice. Decision, 1(1), 2-34. doi:10.1037/dec0000007
Regenwetter, M., & Robinson, M. M. (2017). The construct–behavior gap in behavioral decision research: A challenge beyond replicability. Psychological Review, 124(5), 533-550. https://doi.org/10.1037/rev0000067