The group by
and group by options
tags can be applied to the enable cheatsweep
widget in order to define different groups and establish different rules for each group. The group by
tag determines the grouping, whereas the group by options
tag is used to set the CheatSweep parameters for each defined group.
group_by
The group by
tag accepts a variable for input, such as QPANEL or QCOUNTRY. When defined, CheatSweep will consider each option of the variable as unique "groups." The variable defined here must be single-select.
group_by_options (from)
The group by options
/group by options from
tag will work with the group by
tag to define parameters for each group. If used, group by
must be defined.
Options for CheatSweep (CS) groups can be define by either rules attached to the tag OR a variable.
- If identifying a variable, use
group by options from
. Rules must be listed alongside the option using decorators. - If identifying through rules on the tag, use
group by options
and define using a heredoc. Each line within the heredoc corresponds to the related option in thegroup by
variable, e.g., rules prefaced with '1' correspond to group 1 in thegroup by
variable.
Note that each option defined for group by options
can include different tags or multiple tags.
Syntax
In the below code block, all capital letters represent integer values.
Defining options with heredoc
enable cheatsweep
group by: QSAMPLE
group by options: <<END
1. remove: N%; threshold: X
2. remove: M%; start sweep: Z
3. threshold: Y; disable rules: A, B
END
Defining options in separate variable
enable cheatsweep group by: QVAR group by options from: QVAR VAR. type: radio invisible: y 1. Group 1 {{remove: N%}} {{startsweep: X}} 2. Group 2 {{remove: M%}} {{threshold: Y}} 3. Group 3 {{threshold: P%}} {{repeatsweep: n}}
Tags
The following tags can be used with group by options
, either as a semicolon-separated list of tags or as element decorators.
Tag | Description | Example |
---|---|---|
threshold |
Sets a minimum CheatSweep probability (csp) score for considering a respondent as possible fraud. Input may be an integer or decimal between 1 and 99, inclusive (e.g., '90' indicates anyone with a 90% or higher chance of being fraudulent should be removed). | threshold: 45 |
remove |
Sets a percentage for which respondents should be removed from the data. An input of 'n%' indicates the highest n% of csp scores should be removed. | remove: 5% |
start_sweep |
Sets a limit to the number of respondents that should be allowed into the survey before CheatSweep starts sweeping the data. By default, CheatSweep will begin analyzing data after 50 respondents. | start_sweep: 100 |
repeat_sweep |
Accepts 'y' (yes) and 'n' (no) inputs; setting repeatsweep to 'n' prevents earlier scored respondents from being reclassified (from F to C, or C to F) due to later results. | repeat_sweep: n |
disable_rules |
Allows users to specify a comma separated list of existing CheatSweep rules that should be disabled, either for all respondents or subsets of respondents. For a list of existing CheatSweep rules, click Custom CheatSweep Rules. |
disable rules: 51, 12 |
seeking_value |
Allows users to include condition logic referencing a specific question (or series of questions) to flag respondents who might be attempting to qualify for a survey when they shouldn't. | seeking_value: countChecked($Q1) |
add_rule |
Allows users to include or modify a rule by adding the following lines. The keys (shown to the left of each => arrow) are 'id', 'test', 'bad', and 'good', and should remain unchanged. Change the "values" (on the right side) of each key as appropriate. |
|
Note that rules may be defined at the enable cheatsweep
widget, with other rules defined at the group-level. Group-level rules override widget-level rules. If no rules are set at either the group or widget level, system CheatSweep defaults will apply.
Examples
Basic
In the example below, CheatSweep will treat each country (defined in QCOUNTRY) as a unique scoring group. By default, CheatSweep starts sweeping when N=50, so whenever a group option reaches N=50, CheatSweep will begin to sweep at a threshold of 80.
enable cheatsweep allow_dup: n group by: QCOUNTRY threshold: 80 COUNTRY. type: radio invisible: y cvalue: url_param('c') 1. uk 2. br 3. fr
Defining group_by rules with enable_cheatsweep
When the rules for groups are defined within the group by options
tag, a heredoc is required. If a particular grouping does not include a CheatSweep tag that is also defined as part of enable cheatsweep
- or is a default setting for CheatSweep - then the default/widget level rules will apply to that group. In the example below, since group 2 does not include a start sweep
tag but enable cheatsweep
does, CheatSweep will begin sweeping group 2's respondent data after the 10th respondent.
enable cheatsweep start sweep: 10 group by: QSAMPLE group by options: <<END 1. remove: 5%; start sweep: 5 2. remove: 8%; repeat sweep: n; disable rules: 51, 12 3. threshold: 85; start sweep: 4 END
Defining group_by rules with separate variable
In the following example, QCOUNTRY is used to define the options and rules. Since each country/option in QCOUNTRY uses option data to define their remove
, threshold
, startsweep
, and other values/rates, instead of using group by options
with enable cheatsweep
, use the group by options from
tag.
enable cheatsweep group by: QCOUNTRY group by options from: QCOUNTRY COUNTRY. type: radio invisible: y cvalue: url_param('c') 1. uk {{remove: 5%}} {{startsweep: 15}} 2. br {{remove: 8%}} {{repeatsweep: n}} {{disablerules: 51, 12}} 3. fr {{threshold: 85}} {{start_sweep: 25}}
Option level vs. widget level
When the same tag is applied both at the widget level and the option level, the option level rules will prevail. In the example below, the startsweep
rates for the options defined by group by options
would take precedent over the more globally defined level of startsweep: 30
. Any tags applied to enable cheatsweep
that are not included with the options will be applied to those options.
Since the 3rd option does not include a startsweep
tag, it will inherit the startsweep
rate defined outside of the heredoc, beginning at N=30. Options 1 and 2 will also inherit threshold: 80
since neither option includes a threshold
tag, and allow_dup: y
will be applied to all options.
enable cheatsweep startsweep: 30 allow_dup: y threshold: 80 group by: QCOUNTRY group by options: <<END 1. remove: 5%; start sweep: 25 2. remove: 15%; start sweep: 100 3. threshold: 70; END
With disable_rules
In this case, with no startsweep
tag included, CheatSweep will default to starting at N=50 for all options defined in QCOUNTRY. Since allow_dup
and disable_rules
are defined outside of group by options
, their definitions will apply to all options included in QCOUNTRY.
enable cheatsweep allow_dup: y group by: QCOUNTRY group by options: <<END 1. remove: 5% 2. remove: 15% 3. threshold: 70 END disable rules: 51,55,61,105
Comments
0 comments
Please sign in to leave a comment.