Nothing
permtest.smacofR <- function(object, data = NULL, method.dat = "rows", nrep = 100, verbose = TRUE, ...)
{
## val ... stress value
## n... number of objects
## p... number of dimensions
## ... additional arguments to be passed from smacofRect
#if (class(object)[1] != "smacofR") stop("Permutation test is currenlty implemented for objects of class smacofB from smacofSym() only! \n")
method.dat <- match.arg(method.dat, c("full", "rows"))
data <- object$obsdiss
m <- object$nobj ## number of objects (columns)
n <- object$nind ## number of observations (rows)
nm <- n * m
p <- object$ndim ## number of dimensions
val <- object$stress ## metric stress (normalized)
smacall <- object$call
stressvec <- rep (0, nrep) ## vector for stress values
congmat <- matrix(0, nrep, n)
#perms <- shuffleSet(m, nset = nper)
for (irep in 1:nrep) {
if (method.dat == "rows") { ## permutation within rows
permmat <- t(apply(data, 1, function(pp) { ## computes permuted matrix
ind <- sample(1:m, m)
pp[ind]
}))
} else { ## full permutation
ind <- sample(1:nm)
permmat <- matrix(as.vector(data)[ind], ncol = m)
}
smacall$delta <- permmat
resperm <- eval(smacall)
stressvec[irep] <- resperm$stress
congmat[irep, ] <- resperm$congvec
if (verbose) cat("Permutation: ", formatC (irep, digits=3, width=3), "Stress: ", formatC (stressvec[irep], digits=10, width=15, format="f"), "\n")
}
pval <- length(which(stressvec < val))/nrep
result <- list(stressvec = stressvec, stress.obs = val, pval = pval,
congmat = congmat, nobj = n, nrep = nrep, call = match.call())
class(result) <- "smacofPerm"
result
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.