Merging new namespace proposal from branch experimental into the trunk.
[openmx:openmx.git] / man / mxData.Rd
1 \name{mxData}
2 \alias{mxData}
3
4 \title{Function To Create MxData Object}
5
6 \description{
7    This function creates a new \link{MxData} object.
8 }
9
10 \usage{
11 mxData(matrix, type, vector = NA, numObs = NA)
12 }
13
14 \arguments{
15    \item{matrix}{A matrix or data.frame which provides data to the MxData object.}
16    \item{type}{A character string defining the type of data in the 'matrix' argument. Must be one of 'raw', 'cov', 'cor', or 'sscp'.}
17    \item{vector}{An optional vector of means for use when 'type' is 'cov', 'cor' or 'sscp'.}
18    \item{numObs}{The number of observations in the data supplied in the 'matrix' argument. Required unless 'type' equals 'raw'.}
19 }
20
21 \details{
22 The mxData function creates \link{MxData} objects, which can be used as arguments in \link{MxModel} objects. The 'matrix' argument may take either a data frame or a matrix, which is then described with the 'type' argument. Data types describe compatibility and usage with objective functions in MxModel objects. Four different data types are supported:
23 \itemize{
24 \item{raw}{The contents of the 'matrix' argument are treated as raw data. Missing values are permitted and must be designated as the system missing value. The 'vector' and 'numObs' arguments cannot be specified, as the 'vector' argument is not relevant and the 'numObs' argument is automatically populated with the number of rows in the data. Data of this type must use the \link{mxFIMLObjective} function as its objective function in MxModel objects, which deals with covariance estimation under full-information maximum likelihood.}
25
26 \item{cov}{The contents of the 'matrix' argument are treated as a covariance matrix. The 'vector' argument is not required, but may be included for estimations involving means. The 'numObs' argument is required, which should reflect the number of observations or rows in the data described by the covariance matrix. Data of this type may use the \link{mxMLObjective}, or \link{mxRAMObjective} functions, depending on the specified model.}
27
28 \item{cor}{The contents of the 'matrix' argument are treated as a correlation matrix. The 'vector' argument is not required, but may be included for estimations involving means. The 'numObs' argument is required, which should reflect the number of observations or rows in the data described by the covariance matrix. Data of this type may use the \link{mxMLObjective}, or \link{mxRAMObjective} functions, depending on the specified model.}
29
30 \item{sscp}{The contents of the 'matrix' argument are treated as a sums-of-squares and cross-products matrix. The 'vector' argument is not required, but may be included for estimations involving means. The 'numObs' argument is required, which should reflect the number of observations or rows in the data described by the covariance matrix. Data of this type may use the \link{mxMLObjective}, or \link{mxRAMObjective} functions, depending on the specified model.}
31 }
32
33 MxData objects may not be included in \link{MxAlgebra} objects or use the \link{mxAlgebraObjective} function. If these capabilities are desired, data should be appropriately input or transformed using the \link{mxMatrix} and \link{mxAlgebra} functions.
34
35 While column names are stored in the 'matrix' slot of MxData objects, these names are not recognized as variable names in \link{MxPath} objects. Variable names must be specified using the 'manifestVars' argument of the \link{mxModel} function prior to use in MxPath objects.
36
37 The mxData function does not currently place restrictions on the size, shape, or symmetry of matrices input into the 'matrix' argument. While it is possible to specify MxData objects as covariance, correlation or sscp matrices that do not have the properties commonly associated with these matrices, failure to correctly specify these matrices will likely lead to problems in model estimation.
38 }
39
40 \value{
41         Returns a new \link{MxData} object.
42 }
43
44 \references{
45 The Mx manual may be found at http://www.vcu.edu/mx/documentation.html.
46 }
47
48 \seealso{
49 \link{MxData} for the S4 class created by mxData. \link{matrix} and \link{data.frame} for objects which may be entered as arguments in the 'matrix' slot. More information about the OpenMx package may be found \link[=OpenMx]{here}. 
50 }
51
52 \examples{      
53 #Create a covariance matrix
54 covMatrix <- matrix( c(0.77642931, 0.39590663, 
55     0.39590663, 0.49115615), 
56     nrow = 2, ncol = 2, byrow = TRUE)
57
58 #Create an MxData object including that covariance matrix
59 data <- mxData(covMatrix, 'cov', numObs = 100)
60
61 model <- mxModel(data) 
62
63 }