R/runTriadExperiment.R

Defines functions DisplayOneTriad

Documented in DisplayOneTriad

#DefineMyScale <- function(rr = c(seq(0, 0.9, len = 10), 0.98)) {
#			#sqrt(r)  # for equal-spacing in r^2
#			rr
#			}
			
DisplayOneTriad <- function(rr, PntNum = 100, ptSize = 1, xlim = c(-4, 4), ylim = c(-4, 4)) {
	for (ix in 1:3) {
		covm <- matrix(c(1, rep(rr[ix], 2), 1), 2, 2)
		xy <- MASS::mvrnorm(n = PntNum, rep(0, 2), covm, 
				empirical = TRUE)
		plot(xy, axes = FALSE, xlab = "", ylab = "", pty = "s",
			cex = ptSize, pch = 16, col = "black",
			xlim = xlim, ylim = ylim)
	}
			}

runTriadExperiment <- function (DisplayTrial, DefineStimuli, NumTrials = NULL, DisplaySize = 3.5, 
    aspect = 1, ...) 
{
    cat("Three stimuli are presented on each trial \n")
    cat("If you perceive a greater difference between  \n")
    cat("  the middle and the left one, enter a 1. \n")
    cat("If you perceive a greater difference between \n")
    cat("  the middle and the right, enter a 2. \n")
    cat("If you want to quit, enter a 0 \n\n\n")
    stim <- do.call(DefineStimuli, list())
    NumStimuli <- length(stim)
    allTrials <- t(combn(seq(NumStimuli), 3))
    trialOrder <- sample(seq(nrow(allTrials)), replace = FALSE)
    trial <- allTrials[trialOrder, ]
    topbot <- as.logical(rbinom(nrow(trial), 1, 0.5))
    trial[topbot, ] <- trial[topbot, c(3, 2, 1)]
    resp <- rep(NA, nrow(trial))
    DispConf <- if (sum(c(DisplaySize, aspect * DisplaySize) < 
        7.5)) 
        list(width = 3 * DisplaySize, height = aspect * DisplaySize)
    else list(width = 3 * DisplaySize/aspect, height = DisplaySize)
    do.call(dev.new, DispConf)
    NT <- if (missing(NumTrials)) 
        seq(nrow(trial))
    else seq(NumTrials)
    for (tr in NT) {
        par(mfrow = c(1, 3))
        do.call(DisplayTrial, list(stim[trial[tr, ]], ...))
        cat("\n", tr, "\nEnter 1 (Left) or 2 (Right) Pair: ", 
            "\n")
        ii <- 0
        while (!(resp[tr] %in% c("0", "1", "2"))) {
        	  x <- character(0)
            if (ii > 0) 
                print("Enter only 1, 2 or 0 to quit")
            while (length(x) == 0) x <- 
            	scan(what = character(0), n = 1)
            resp[tr] <- x
            ii <- ii + 1
            resp[tr]
        }
        if (resp[tr] == "0") 
            break
    }
    graphics.off()
    resp <- as.integer(resp) - 1
    results <- data.frame(resp = resp, stim = trial)
    results <- as.data.frame(lapply(results, as.integer))
    names(results) <- c("resp", paste("S", 1:3, sep = ""))
    attr(results, "stimulus") <- stim
    attr(results, "invord") <- topbot
    class(results) <- c("mlbs.df", "data.frame")
    results
}

Try the MLDS package in your browser

Any scripts or data that you put into this service are public.

MLDS documentation built on Aug. 20, 2023, 9:06 a.m.