mxMatrix {OpenMx} | R Documentation |

This functions creates a new MxMatrix object.

mxMatrix(type = "Full", nrow = NA, ncol = NA, free = FALSE, values = NA, labels = NA, lbound = NA, ubound = NA, byrow = getOption('mxByrow'), dimnames = NA, name = NA)

`type` |
a character string indicating the matrix type, where type indicates the range of values and equalities in the matrix. Must be one of: ‘Diag’, ‘Full’, ‘Iden’, ‘Lower’, ‘Sdiag’, ‘Stand’, ‘Symm’, ‘Unit’, or ‘Zero’. |

`nrow` |
the desired number of rows. One or both of ‘nrow’ and ‘ncol’ is required when ‘values’, ‘free’, ‘labels’, ‘lbound’, and ‘ubound’ arguments are not matrices, depending on the matrix type. |

`ncol` |
the desired number of columns. One or both of ‘nrow’ and ‘ncol’ is required when ‘values’, ‘free’, ‘labels’, ‘lbound’, and ‘ubound’ arguments are not matrices, depending on the matrix type. |

`free` |
a vector or matrix of logicals for free parameter specification. A single ‘TRUE’ or ‘FALSE’ will set all allowable variables to free or fixed, respectively. |

`values` |
a vector or matrix of numeric starting values. By default, all values are set to zero. |

`labels` |
a vector or matrix of characters for variable label specification. |

`lbound` |
a vector or matrix of numeric lower bounds. Default bounds are specified with an NA. |

`ubound` |
a vector or matrix of numeric upper bounds. Default bounds are specified with an NA. |

`byrow` |
logical. If ‘FALSE’ (default), the ‘values’, ‘free’, ‘labels’, ‘lbound’, and ‘ubound’ matrices are populated by column rather than by row. |

`dimnames` |
list. The dimnames attribute for the matrix: a list of length 2 giving the row and column names respectively. An empty list is treated as NULL, and a list of length one as row names. The list can be named, and the list names will be used as names for the dimensions. |

`name` |
an optional character string indicating the name of the MxMatrix object created by the mxModel function. |

The mxMatrix function creates MxMatrix objects, which consist of a pair of matrices and a ‘type’ argument. The ‘values’ matrix is made up of numeric elements whose usage and capabilities in other functions are defined by the ‘free’ matrix. If an element is specified as a fixed parameter in the ‘free’ matrix, then the element in the ‘values’ matrix is treated as a constant value and cannot be altered or updated by an objective function when included in an mxRun function. If an element is specified as a free parameter in the ‘free’ matrix, the element in the ‘value’ matrix is considered a starting value and can be changed by an objective function when included in an mxRun function. Free parameters are specified with a character string, non-zero numeric value, or ‘NA’; fixed parameters are specified with a numeric zero.

Objects created by the mxMatrix function are of a specific ‘type’, which specifies the number and location of parameters in the ‘labels’ matrix and the starting values in the ‘values’ matrix. Input ‘values’, ‘free’, and ‘labels’ matrices must be of appropriate shape and have appropriate values for the matrix type requested. Nine types of matrices are supported:

‘Diag’ | matrices must be square, and only elements on the principle diagonal may be specified as free parameters or take non-zero values. All other elements are required to be fixed parameters with a value of 0. |

‘Full’ | matrices may be either rectangular or square, and all elements in the matrix may be freely estimated. This type is the default for the mxMatrix() function. |

‘Iden’ | matrices must be square, and consist of no free parameters. Matrices of this type have a value of 1 for all entries on the principle diagonal and the value 0 in all off-diagonal entries. |

‘Lower’ | matrices must be square, with a value of 0 for all entries in the upper triangle and no free parameters in the upper triangle. |

‘Sdiag’ | matrices must be square, with a value of 0 for all entries in the upper triangle and along the diagonal. No free parameters in the upper triangle or along the diagonal. |

‘Symm’ | matrices must be square, and elements in the principle diagonal and lower triangular portion of the matrix may be free parameters of any value. Elements in the upper triangular portion of the matrix are constrained to be equal to those in the lower triangular portion, such that the value and parameter specificiation of the element in row i and column j is identical to to the value and specification of the element in row j and column i. |

‘Stand’ | matrices are symmetric matrices (see 'Symm') with 1's along the main diagonal. |

‘Unit’ | matrices may be either rectangular or square, and contain no free parameters. All elements in matrices of this type have a value of 1 for all elements. |

‘Zero’ | matrices may be either rectangular or square, and contain no free parameters. All elements in matrices of this type have a value of 0 for all elements. |

When ‘type’ is either ‘Lower’, ‘Sdiag’, ‘Symm’, or ‘Stand’, and the arguments to ‘free’, ‘values’, ‘labels’, ‘lbound’, or ‘ubound’ are vectors with enough elements to populate exactly one half of the matrix, then `mxMatrix()`

populates the lower triangle of the matrix (and transposes the lower triangle if the matrix is symmetric).

Returns a new MxMatrix object, which consists of a ‘values’ matrix of numeric starting values, a ‘free’ matrix describing free parameter specification, a ‘labels’ matrix of labels for the variable names, and ‘lbound’ and ‘ubound’ matrices of the lower and upper parameter bounds. This MxMatrix object can be used as an argument in the mxAlgebra, mxBounds, mxConstraint and mxModel functions.

The OpenMx User's guide can be found at http://openmx.psyc.virginia.edu/documentation.

MxMatrix for the S4 class created by mxMatrix. More information about the OpenMx package may be found here.

# Create a 3 x 3 identity matrix idenMatrix <- mxMatrix(type = "Iden", nrow = 3, ncol = 3, name = "I") # Create a full 4 x 2 matrix from existing # value matrix with all free parameters vals <- matrix(1:8, nrow = 4) fullMatrix <- mxMatrix(type = "Full", values = vals, free = TRUE, name = "foo") # Create a 3 x 3 symmetric matrix with free off- # diagonal parameters and starting values symmMatrix <- mxMatrix(type = "Symm", nrow = 3, ncol = 3, free = c(FALSE, TRUE, TRUE, FALSE, TRUE, FALSE), values = c(1, .8, .8, 1, .8, 1), labels = c(NA, "free1", "free2", NA, "free3", NA), name = "bar")

[Package *OpenMx* version 1.0.0-1448 Index]