inst/models/passing/OnDemandAlgebra.R

library(OpenMx)

t1 <- mxModel(
  "test",
  mxMatrix("Full", 2,2,values=1:4, free=TRUE, name="z"),
  mxAlgebra(z, name="zCopy", recompute='onDemand', initial=matrix(1., 2,2))
  )

t1 <- omxCheckWarning(mxRun(t1), "Algebra 'zCopy' is set for onDemand recompute yet is still at initial values")
omxCheckEquals(t1$zCopy$result, matrix(1., 2,2))

t2 <- mxModel(t1, mxComputeOnce("zCopy", 'fit'))

t2 <- mxRun(t2)
omxCheckEquals(t2$zCopy$result, t2$z$values)

# ---

e1 <- mxModel(
  "test",
  mxMatrix("Full", 2,2,values=1:4, free=TRUE, name="z"),
  mxAlgebra(z, name="zCopy", recompute='onDemand'))

omxCheckError(mxRun(e1), "Missing value found in initial result of algebra 'test.zCopy'")

e2 <- mxModel(
  "test",
  mxMatrix("Full", 2,2,values=1:4, free=TRUE, name="z"),
  mxAlgebra(z, name="zCopy", initial=matrix(pi,1,1)))

omxCheckError(mxRun(e2), "In algebra 'test.zCopy' initial result will be immediately discarded")

# ---

t3 <- mxModel(
  "test",
  mxMatrix("Full", 2,2,values=1:4, free=TRUE, name="z"),
  mxAlgebraFromString("z", name="zCopy", recompute='onDemand', initial=matrix(1., 2,2)),
  mxComputeOnce("zCopy", 'fit'))

t3 <- mxRun(t3)
omxCheckEquals(t3$zCopy$result, t3$z$values)

Try the OpenMx package in your browser

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

OpenMx documentation built on Nov. 8, 2023, 1:08 a.m.