limitedDiversity {QCApro} | R Documentation |
Analyze QCA Solution Behaviour under Limited Empirical Diversity
Description
This evaluation function computes all solutions and unique models that result when all n-tuples of minterms are systematically eliminated from a truth table. It has initially been programmed for Baumgartner and Thiem (2017) to test the correctness of QCA's three search strategies (conservative/complex, intermediate, parsimonious).
Usage
limitedDiversity(truth.tab, outcome = "", exo.facs = c(""), sol.type = "ps",
dir.exp = c(), n.drop = 1, c.minterms = FALSE)
Arguments
truth.tab |
A truth table (either in plain format or a truth table object
of class "tt" generated by the |
outcome |
A character vector with the name of the outcome. |
exo.facs |
A character vector with the names of the exogenous factors. |
sol.type |
A character scalar specifying the QCA solution type that should be applied; either "ps" (parsimonious solution), "ps+" (parsimonious solution including both positive and contradiction minterms), "cs" ( conservative solution) or "cs+" (conservative solution including both positive and contradiction minterms). |
dir.exp |
A vector of directional expectations for deriving intermediate
solutions; can only be used in conjunction with |
n.drop |
The number of minterms to be dropped from the truth table. |
c.minterms |
Logical, should contradictions be treated as positive minterms. |
Details
This function computes all solutions and unique models that result when all
n-tuples of observed minterms are systematically dropped from a truth table.
It has been programmed for Baumgartner and Thiem (2017) to test the correctness of QCA's three search strategies (conservative/complex, intermediate, parsimonious) in conjunction with the submodels
function.
The argument truth.tab
specifies the truth table from which minterms are
to be dropped. The truth table can either be in plain format or be a truth table
object of class "tt" generated by the truthTable
function. If it
is a truth table object, the arguments outcome
and exo.facs
need
not be specified. The main difference between a truth table in plain format (as
also used by Coincidence Analysis, for example (Baumgartner 2009)), is that each minterm includes only cases that have identical values on the exogenous factors and the endogenous factor. A QCA truth table object, in contrast, consists of minterms that include both cases with the outcome being analyzed as well as cases with the negation of this outcome. The ratio between these cases is used as the basis for the output function value. Thus, dropping minterms from plain truth tables will drop all cases that are identical with respect to all factors in the factor frame, whereas dropping minterms from QCA truth table objects will drop all cases that are identical with respect to all exogenous factors in the factor frame.
The argument n.drop
specifies the size of the tuples of minterms to be
dropped for generating limited empirical diversity. For example, if the truth
table has 16 observed minterms, n.drop = 2
creates 120 2-tuples,
n.drop = 3
creates 560 3-tuples, and so on.
The argument c.minterms
specifies whether contradictions should be
treated as positive minterms (TRUE
) or negative minterms (FALSE
).
Value
A list with the following three components:
model.shares |
All unique models for all n-tuples of dropped minterms and their occurrence shares. |
solutions |
The solutions for all n-tuples of eliminated minterms. |
tt |
The truth table. |
Contributors
Dusa, Adrian | : programming |
Thiem, Alrik | : development, documentation, programming, testing |
Author(s)
Alrik Thiem (Personal Website; ResearchGate Website)
References
Baumgartner, Michael. 2009. “Inferring Causal Complexity.” Sociological Methods & Research 38 (1):71-101. DOI: 10.1177/0049124109339369.
Baumgartner, Michael, and Alrik Thiem. 2017. “Often Trusted but Never (Properly) Tested: Evaluating Qualitative Comparative Analysis.” Sociological Methods & Research. Advance online publication. DOI: 10.1177/0049124117701487.
See Also
Examples
## Not run:
# number (n) of minterms (mt) and levels (lv) for each factor (exogenous
# and endogenous)
n.mt <- 2^5
n.lv <- rep(2, 5)
# expand to unevaluated truth table and assign case/factor labels
tt.unev <- data.frame(mintermMatrix(n.lv))
dimnames(tt.unev) <- list(1:n.mt, c(LETTERS[1:4], "Z"))
# cull rows from tt.unev that are compatible with aB + Bc + D <=> Z
# to produce evaluated truth table tt.ev
tt.ev <- tt.unev[pmax(tt.unev$D, pmin(1 - tt.unev$A, tt.unev$B),
pmin(tt.unev$B, 1 - tt.unev$C)) == tt.unev$Z, ]
# conservative solutions for all 1-tuples (16)
limitedDiversity(tt.ev, outcome = "Z", sol.type = "cs")$model.shares
# using a truth table object of class 'tt' created by eQMC function
#------------------------------------------------------------------
data(d.represent)
tt <- truthTable(d.represent, outcome = "WNP")
# with objects of class 'tt', exogenous factors and the outcome need not be
# specified again
limitedDiversity(tt)
# proof that the conservative/complex solution type of QCA is incorrect,
# (see Baumgartner and Thiem (2017) for more details)
#-----------------------------------------------------------------------
# 1. build truth table on the basis of reference model aB + Bc + D
tt <- data.frame(mintermMatrix(rep(2, 5)))
dimnames(tt) <- list(as.character(1:32), c(LETTERS[1:4], "OUT"))
tt <- tt[pmax(pmin(1 - tt$A, tt$B), pmin(tt$B, 1 - tt$C), tt$D) == tt$OUT, ]
# 2. generate all conservative/complex solutions for all 16 + 120 scenarios
# of one/two dropped minterm/s
sollist.cs <- vector("list", 2)
sollist.cs <- lapply(1:2, function (x) {
limitedDiversity(tt, outcome = "OUT", sol.type = "cs", n.drop = x)
}
)
# 3. compute in how many scenarios a correctness-preserving submodel of
# the reference model was part of the solution (43.75% for one dropped
# minterm and 16.67% for two dropped minterms)
cs.correct <- numeric(2)
cs.correct <- sapply(1:2, function (x) {round((sum(unlist(lapply(
sollist.cs[[x]][[2]], function (y) {any(
submodels("aB + Bc + D")$submodels %in% y)}
))) / choose(16, x))*100, 2)}
)
cs.correct
## End(Not run)