User Manual: Inquisit Partner Attraction GNAT


___________________________________________________________________________________________________________________	

									ATTRACTION pGNAT
___________________________________________________________________________________________________________________	

Script Author: Marisa Okano
last updated:  10-07-2024 by K. Borchert (katjab@millisecond.com) for Millisecond Software, LLC

Millisecond Software thanks Marisa Okano for sharing her script!

___________________________________________________________________________________________________________________
BACKGROUND INFO 	
___________________________________________________________________________________________________________________

This “Attraction pGNAT” is a modified version of the Go/No-go Association Task (GNAT), 
which was originally designed to measure automatic associations regarding a single target 
construct (Nosek & Banaji, 2001). Specifically, the same basic procedure of the GNAT is 
used to assess the strength of participants' positive versus negative associations 
regarding a single target category (e.g. physical attractiveness); however, the GNAT 
will be modified to reflect the personalized version utilized in the study of explicit and 
implicit preferences of physical attractiveness by Eastwick, Eagly, Finkel, & Johnson (2011).

In general, the GNAT uses uses the Go-Nogo framework of responding to signal and noise stimuli 
to investigate implicit bias. In contrast to reaction time based tests of implicit bias 
(e.g. Implicit Association Test),  the GNAT framework mainly focuses on accuracy data and specifically 
d prime measures (measures of sensitivity to distinguish signals from noise in signal detection theory) 
to infer implicit bias. 

For example, a positive association of 'physical attractiveness' (the target signal) is suggested if the dprime measure 
in the condition 'Physical Attractiveness-I like' (both of these categories are signals) is greater than the
dprime measure in the condition 'Physical Attractiveness-I don't like' (both of these categories are signals).

This script investigates the following three categories:
	PA = physical appearance
	SS = social status 
	PE = personality
by pairing them with the attribute categories 'I like' vs. 'I don't like'

The implemented procedure of the “Attraction pGNAT” is based on:

Eastwick, P. W., Eagly, A. H., Finkel, E. J., & Johnson, S. E. (2011). 
Implicit and explicit preferences for physical attractiveness in a romantic partner: 
A double dissociation in predictive validity. Journal of Personality and Social Psychology, 101, 993-1011.

Adjustments to z-scores as described by:
Gregg, A. & Sedikides, C. (2010). Narcissistic Fragility:
Rethinking Its Links to Explicit and Implicit Self-esteem, Self and Identity, 9:2, 142-161 (p.148)

___________________________________________________________________________________________________________________
TASK DESCRIPTION	
___________________________________________________________________________________________________________________	
Participants are asked to categorize items (e.g words  "attractive", "wealthy" etc) into predetermined 
categories via keystroke presses. The basic task is to press the Spacebar if an items (e.g. "attractive")
belongs to the category currently being tested (e.g. Physical Appearance) and to do nothing if it doesn't.
For practice, participants sort items into categories "Physical Appearance", "Social Status", "Personality" 
as well as evaluative preference categories "I like" and "I don't like".
For the test, participants are asked to sort categories into the paired/combined categories (e.g. 
"Physical Appearance OR I don't like"). When an item belongs to either one of these two categories, 
participants should press the Spacebar.

___________________________________________________________________________________________________________________	
DURATION 
___________________________________________________________________________________________________________________	
the default set-up of the script takes appr. 20 minutes to complete

___________________________________________________________________________________________________________________	
DATA OUTPUT DICTIONARY
___________________________________________________________________________________________________________________
The fields in the data files are:

(1) Raw data file: 'attraction_pgnat_raw*.iqdat' (a separate file for each participant)

build:								The specific Inquisit version used (the 'build') that was run
computer.platform:					the platform the script was run on (win/mac/ios/android)
date, time: 						date and time script was run 
subject, group: 					with the current subject/groupnumber
session:							with the current session id

blockCode, blockNum:				the name and number of the current block (built-in Inquisit variable)
trialCode, trialNum: 				the name and number of the currently recorded trial (built-in Inquisit variable)
										Note: trialNum is a built-in Inquisit variable; it counts all trials run; even those
										that do not store data to the data file. 
										
targetCategory:						1 = PA 1000 trial; 2 = SS 1000 trial; 3 = PE 1000 trial; 0 = other
testTrial:							0 = practice/training; 1 = testtrial (trialCount >= 20 in each testblock)
stimulusItem:						the presented stimuli in order of trial presentation
response:							the participant's response (57 = spacebar; 0 = noResponse)
correct:							the correctness of the response (1 = correct; 0 = incorrect)
latency: 							the response latency (in ms); measured from onset of stims

(2) Summary data file: 'attraction_pgnat_summary*.iqdat' (a separate file for each participant)

inquisit.version: 						Inquisit version run
computer.platform:					the platform the script was run on (win/mac/ios/android)
startDate:							date script was run
startTime:							time script was started
subjectId:							assigned subject id number
groupId:							assigned group id number
sessionId:							assigned session id number
elapsedTime:						time it took to run script (in ms); measured from onset to offset of script
completed:							0 = script was not completed (prematurely aborted); 
									1 = script was completed (all conditions run)
									
									
/////////////////////////////////////////////////////////////////////
TARGET 'PA' Conditions
signals = Physical Appearance (PA)
/////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////
PALike Condition:
signals = Physical Appearance (PA) OR like
noise = anything else (objects OR dislike)
////////////////////////////////////////////////////

rHitPALike:				hit rate for pairing PA-like across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Physical Appearance (PA) OR like) in PALike condition
						
rMissPALike:			miss rate for pairing PA-like across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Physical Appearance (PA) OR like) in PALike condition
						
rFaPALike:				false alarm (FA) rate for pairing PA-like across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR dislike) in PALike condition

rCrPALike:				correct rejection (CR) for pairing PA-like across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR dislike) in PALike condition

zHitPALike:				z-score of hit rate for pairings PA-like (here: Physical Appearance (PA)-like)
zFaPALike:				z-score of FA rate for pairings PA-like (here: Physical Appearance (PA)-like)
										
Note: *Adjustments to z-scores as recommended by:
Gregg, A. & Sedikides, C. (2010). Narcissistic Fragility:
Rethinking Its Links to Explicit and Implicit Self-esteem, Self and Identity, 9:2, 142-161 (p.148)										
=> Adjustments are made if the  FArate (hitRate) = 0 (increased to 0.005) or 1 (decreased to 0.995)*

dPrimePALike:	Computes d' (parametric measure of discriminability btw. signals and noise) for 'Physical Appearance (PA)-like' Pairings
			=> Range (in this script): 
			-5.1516586840152740479 <= dprime <= 5.1516586840152740479 (=perfect performance)
			=> The higher the value, the better signals (go stims) were  distinguished from noise (nogo stims)
			(d' = 0: chance performance; negative d-primes: participant treated nontargets as targets and targets as nontargets)
													
cPALike: 	c-criterion in signal detection:The absolute value of c provides an indication of the strength of
			the response bias/response style
			negative: participant more likely to report that signal (go stims) is present (liberal response style);
			may favor faster responding in speed-accuracy trade-off response paradigms
			positive: favoring caution (conservative response style)
			
////////////////////////////////////////////////////
PADislike Condition:
signals = Physical Appearance (PA) OR dislike 
noise = anything else (objects OR like)
////////////////////////////////////////////////////

rHitPADislike:			hit rate for pairing PA-dislike across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Physical Appearance (PA) OR dislike) in PADislike condition
						
rMissPADislike:			miss rate for pairing PA-dislike across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Physical Appearance (PA) OR dislike) in PADislike condition
						
rFaPADislike:			false alarm (FA) rate for pairing PA-dislike across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR like) in PADislike condition

rCrPADislike:			correct rejection (CR) for pairing PA-dislike across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR like) in PADislike condition

zHitPADislike:			z-score of hit rate for pairings PA-dislike (here: Physical Appearance (PA)-dislike)
zFaPADislike:			z-score of FA rate for pairings PA-dislike (here: Physical Appearance (PA)-dislike)
										
dPrimePADislike:		Computes d' (parametric measure of discriminability btw. signals and noise) for 'Physical Appearance (PA)-dislike' Pairings													
cPADislike: 			c-criterion in PADislike condition			
			
					
dPrimeDiffTargetPA:		the difference in dprime btw. PALike and PADislike (PALike-PADislike)
						=> if d prime for Physical Appearance (PA)-like is larger than for Physical Appearance (PA)-dislike (positive difference):
						participant more closely associated PA with like than with dislike attributes
						=> if d prime for Physical Appearance (PA)-like is smaller than for Physical Appearance (PA)-dislike (negative difference):
						participant more closely associated PA with dislike than with like attributes


/////////////////////////////////////////////////////////////////////
TARGET 'SS' Conditions
signals = Social Status (SS)
/////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////
SSLike Condition:
signals = Social Status (SS) OR like
noise = anything else (objects OR dislike)
////////////////////////////////////////////////////

rHitSSLike:				hit rate for pairing SS-like across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Social Status (SS) OR like) in SSLike condition
						
rMissSSLike:			miss rate for pairing SS-like across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Social Status (SS) OR like) in SSLike condition
						
rFaSSLike:				false alarm (FA) rate for pairing SS-like across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR dislike) in SSLike condition

rCrSSLike:				correct rejection (CR) for pairing SS-like across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR dislike) in SSLike condition

zHitSSLike:				z-score of hit rate for pairings SS-like (here: Social Status (SS)-like)
zFaSSLike:				z-score of FA rate for pairings SS-like (here: Social Status (SS)-like)

dPrimeSSLike:			Computes d' (parametric measure of discriminability btw. signals and noise) for 'Social Status (SS)-like' Pairings													
cSSLike: 				c-criterion in signal detection in SSLike condition
			
////////////////////////////////////////////////////
SSDislike Condition:
signals = Social Status (SS) OR dislike 
noise = anything else (objects OR like)
////////////////////////////////////////////////////

rHitSSDislike:			hit rate for pairing SS-dislike across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Social Status (SS) OR dislike) in SSDislike condition
						
rMissSSDislike:			miss rate for pairing SS-dislike across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Social Status (SS) OR dislike) in SSDislike condition
						
rFaSSDislike:			false alarm (FA) rate for pairing SS-dislike across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR like) in SSDislike condition

rCrSSDislike:			correct rejection (CR) for pairing SS-dislike across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR like) in SSDislike condition

zHitSSDislike:			z-score of hit rate for pairings SS-dislike (here: Social Status (SS)-dislike)
zFaSSDislike:			z-score of FA rate for pairings SS-dislike (here: Social Status (SS)-dislike)
										
dPrimeSSDislike:		Computes d' (parametric measure of discriminability btw. signals and noise) for 'Social Status (SS)-dislike' Pairings													
cSSDislike: 			c-criterion in SSDislike condition			
			
					
dPrimeDiffTargetSS:		the difference in dprime btw. SSLike and SSDislike (SSLike-SSDislike)
						=> if d prime for Social Status (SS)-like is larger than for Social Status (SS)-dislike (positive difference):
						participant more closely associated 'SS' with like than with dislike attributes
						=> if d prime for Social Status (SS)-like is smaller than for Social Status (SS)-dislike (negative difference):
						participant more closely associated 'SS' with dislike than with like attributes								
						
/////////////////////////////////////////////////////////////////////
TARGET 'PE' Conditions
signals = Personality (PE)
/////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////
PELike Condition:
signals = Personality (PE) OR like
noise = anything else (objects OR dislike)
////////////////////////////////////////////////////

rHitPELike:				hit rate for pairing PE-like across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Personality (PE) OR like) in PELike condition
						
rMissPELike:			miss rate for pairing PE-like across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Personality (PE) OR like) in PELike condition
						
rFaPELike:				false alarm (FA) rate for pairing PE-like across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR dislike) in PELike condition

rCrPELike:				correct rejection (CR) for pairing PE-like across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR dislike) in PELike condition

zHitPELike:				z-score of hit rate for pairings PE-like (here: Personality (PE)-like)
zFaPELike:				z-score of FA rate for pairings PE-like (here: Personality (PE)-like)
										
dPrimePELike:			Computes d' (parametric measure of discriminability btw. signals and noise) for 'Personality (PE)-like' Pairings													
cPELike: 				c-criterion in signal detection in PELike condition
			
////////////////////////////////////////////////////
PEDislike Condition:
signals = Personality (PE) OR dislike 
noise = anything else (objects OR like)
////////////////////////////////////////////////////

rHitPEDislike:			hit rate for pairing PE-dislike across all responsetimeouts; test trials only
							hit: pressing spacebar for signals (Personality (PE) OR dislike) in PEDislike condition
						
rMissPEDislike:			miss rate for pairing PE-dislike across all responsetimeouts; test trials only
							miss: not pressing spacebar for signals (Personality (PE) OR dislike) in PEDislike condition
						
rFaPEDislike:			false alarm (FA) rate for pairing PE-dislike across all responsetimeouts; test trials only
							false alarm: pressing spacebar for noise stims (objects OR like) in PEDislike condition

rCrPEDislike:			correct rejection (CR) for pairing PE-dislike across all responsetimeouts; test trials only
							cr: not pressing spacebar for noise stims (objects OR like) in PEDislike condition

zHitPEDislike:			z-score of hit rate for pairings PE-dislike (here: Personality (PE)-dislike)
zFaPEDislike:			z-score of FA rate for pairings PE-dislike (here: Personality (PE)-dislike)
										
dPrimePEDislike:		Computes d' (parametric measure of discriminability btw. signals and noise) for 'Personality (PE)-dislike' Pairings													
cPEDislike: 			c-criterion in PEDislike condition			
			
					
dPrimeDiffTargetPE:		the difference in dprime btw. PELike and PEDislike (PELike-PEDislike)
						=> if d prime for Personality (PE)-like is larger than for Personality (PE)-dislike (positive difference):
						participant more closely associated 'PE' with like than with dislike attributes
						=> if d prime for Personality (PE)-like is smaller than for Personality (PE)-dislike (negative difference):
						participant more closely associated 'PE' with dislike than with like attributes								

___________________________________________________________________________________________________________________	
EXPERIMENTAL SET-UP 
___________________________________________________________________________________________________________________

3 target categories (Physical Appearance (PA), Social Status (SS), and Personality (PE)) x 2 preference categories (like vs. dislike)

* 3 practice blocks of categorizing items into 3 target categories Physical Appearance (PA), Social Status (SS), and Personality (PE) 
	=> target categories are tested in blocked format, order of blocks is random
	=> 25 trials each
* 2 practice blocks of categorizing items into 2 preference categories (Like/Dislike)
	=> preference categories are tested in blocked format, order is random
	=> 20 trials each
* 6 test blocks: combination of 3 target categories (PA, SS, PE) x 2 like categories (like, dislike)
	categorization of items into paired/combined categories (e.g. sort items into "Physical Appearance" OR "I like")
	=> combined categories are tested in blocked format, order of the test blocks is random
	=> 15 practice trials followed by 60 test trials

* responsewindow:
	practice: 750ms
	test: 1000ms
	
___________________________________________________________________________________________________________________	
STIMULI
___________________________________________________________________________________________________________________
under section Editable Stimuli

___________________________________________________________________________________________________________________	
INSTRUCTIONS 
___________________________________________________________________________________________________________________
under section Editable Instructions as well as section Instructions

___________________________________________________________________________________________________________________	
EDITABLE CODE 
___________________________________________________________________________________________________________________
check below for (relatively) easily editable parameters, stimuli, instructions etc. 
Keep in mind that you can use this script as a template and therefore always "mess" with the entire code to 
further customize your experiment.