inst/models/nightly/DefaultOptTolerance.R

#options(error = utils::recover)
library(OpenMx)

set.seed(1)
numDims <- 2

genOrthogonal<-function(dim) { 
  Q<-MOrthogonal(runif(dim))
  return(Q)
}

# Construct an orthogonal matrix whose first few columns are standardized 'M'
# where columns of 'M' are orthogonal.
# Here "standardized 'M'" means each its columns has length 1.
MOrthogonal<-function(M)
{
  # can set the parameter "tol" of "qr" to decide how small value should be 0
  tmp<-qr(M)
  Q<-qr.Q(tmp,complete=TRUE)
  if(is.vector(M)) { if(Q[1]*M[1]<0) Q<- -Q }
  else { if(Q[1,1]*M[1,1]<0) Q<- - Q }
  return(Q)
}

# adapted from clusterGeneration 1.3.1 by Weiliang Qiu, Harry Joe
genPositiveDefMat <- function(dim, low=-1.4, upp=1.4) {
  u<-matrix(0, dim,dim)
  egvalues <- exp(runif(dim,min=low,max=upp))
  diag(u)<-egvalues #the diagonal elements of u are positive
  Sigma<-u
  if(dim>1)
  { Q<-genOrthogonal(dim) # generate an orthogonal matrix 
    Sigma<-Q%*%u%*%t(Q) # the final positive definite matrix
  }
  Sigma
}

trueMean <- rnorm(numDims)
trueCov <- round(genPositiveDefMat(numDims), 6)
names(trueMean) <- paste("f", 1:numDims, sep="")
dimnames(trueCov) <- list(paste("f", 1:numDims, sep=""), paste("f", 1:numDims, sep=""))

t1 <- mxModel("test",
              mxData(observed=trueCov, means=trueMean, numObs=100, type="cov"),
              mxMatrix(name="mean", values=rnorm(numDims), nrow=1, ncol=numDims, free=TRUE,
                       dimnames=list(NULL, paste("f", 1:numDims, sep=""))),
              mxMatrix(type="Symm", name="cov", ncol=numDims, nrow=numDims, free=TRUE,
                       labels=paste("v", 1:(numDims*(numDims+1)/2), sep=""),
                       dimnames=dimnames(trueCov)),
              mxExpectationNormal(means="mean", covariance="cov"),
              mxFitFunctionML(),
              mxComputeGradientDescent())
t1$cov$values <- diag(numDims)
startVal <- omxGetParameters(t1)

trials <- 100
drift <- rep(NA, trials)

for (trial in 1:100) {
  set.seed(trial)
  t1 <- omxSetParameters(t1, values=startVal + runif(5, -.25, .25), labels=names(startVal))
  t1Fit <- mxRun(t1, silent=TRUE, suppressWarnings=TRUE)
  drift[trial] <- t1Fit$output$fit
}

stat <- sd(drift)
print(stat)

omxCheckCloseEnough(stat, 0, 2e-10)
OpenMx/OpenMx documentation built on Feb. 15, 2024, 3:14 p.m.