| lcMethod-class {latrend} | R Documentation | 
lcMethod class
Description
lcMethod objects represent the specification of a method for longitudinal clustering.
Furthermore, the object class contains the logic for estimating the respective method.
You can specify a longitudinal cluster method through one of the method-specific constructor functions,
e.g., lcMethodKML(), lcMethodLcmmGBTM(), or lcMethodDtwclust().
Alternatively, you can instantiate methods through methods::new(), e.g., by calling new("lcMethodKML", response = "Value").
In both cases, default values are specified for omitted arguments.
Details
Because the lcMethod arguments may be unevaluated, argument retrieval functions such as [[ accept an envir argument.
A default environment can be assigned or obtained from a lcMethod object using the environment() function.
Slots
- arguments
- A - listrepresenting the arguments of the- lcMethodobject. Arguments are not evaluated upon creation of the method object. Instead, arguments are stored similar to a- callobject, and are only evaluated when a method is fitted. Do not modify or access.
- sourceCalls
- A list of calls for tracking the original call after substitution. Used for printing objects which require too many characters (e.g. ,function definitions, matrices). Do not modify or access. 
Method arguments
An lcMethod objects represent the specification of a method with a set of configurable parameters (referred to as arguments).
Arguments can be of any type.
It is up to the lcMethod implementation of validate() to ensure that the required arguments are present and are of the expected type.
Arguments can have almost any name. Exceptions include the names "data", "envir", and "verbose".
Furthermore, argument names may not start with a period (".").
Arguments cannot be directly modified, i.e., lcMethod objects are immutable.
Modifying an argument involves creating an altered copy through the update.lcMethod method.
Implementation
The base class lcMethod provides the logic for storing, evaluating, and printing the method parameters.
Subclasses of lcMethod differ only in the fitting procedure logic.
To implement your own lcMethod subclass, you'll want to implement at least the following functions:
-  fit(): The main function for estimating your method.
-  getName(): The name of your method.
-  getShortName(): The abbreviated name of your method.
-  getArgumentDefaults(): Sensible default argument values to your method.
For more complex methods, the additional functions as part of the fitting procedure will be of use.
See Also
Other lcMethod implementations: 
getArgumentDefaults(),
getArgumentExclusions(),
lcMethodAkmedoids,
lcMethodCrimCV,
lcMethodDtwclust,
lcMethodFeature,
lcMethodFunFEM,
lcMethodFunction,
lcMethodGCKM,
lcMethodKML,
lcMethodLMKM,
lcMethodLcmmGBTM,
lcMethodLcmmGMM,
lcMethodMclustLLPA,
lcMethodMixAK_GLMM,
lcMethodMixtoolsGMM,
lcMethodMixtoolsNPRM,
lcMethodRandom,
lcMethodStratify
Other lcMethod functions: 
[[,lcMethod-method,
as.data.frame.lcMethod(),
as.data.frame.lcMethods(),
as.lcMethods(),
as.list.lcMethod(),
evaluate.lcMethod(),
formula.lcMethod(),
names,lcMethod-method,
update.lcMethod()
Examples
method <- lcMethodLMKM(Y ~ Time, id = "Id", time = "Time", nClusters = 2)
method
method <- new("lcMethodLMKM", formula = Y ~ Time, id = "Id", time = "Time", nClusters = 2)
# get argument names
names(method)
# evaluate argument
method$nClusters
# create a copy with updated nClusters argument
method3 <- update(method, nClusters = 3)