Abstract
Latent change score models (LCSMs) are used across disciplines in behavioural sciences to study how constructs change over time. LCSMs can be used to estimate the trajectory of one construct (univariate) and allow the investigation of how changes between two constructs (bivariate) are associated with each other over time. This paper introduces the R package lcsm, a tool that aims to help users understand, analyse, and visualise different latent change score models. The lcsm package provides functions to generate model syntax for basic univariate and bivariate latent change score models with different model specifications. It is also possible to visualise different model specifications in simplified path diagrams. An interactive application illustrates the main functions of the package and demonstrates how the model syntax and path diagrams change based on different model specifications. This R package aims to increase the transparency of reporting analyses and to provide an additional resource to learn latent change score modelling.
Keywords: latent change score modelling, structural equation modelling, longitudinal data analysis, lavaan, R
Introduction
Many psychological theories make predictions about changes over time and testing these predictions using appropriate statistical models is important to evaluate the evidence of these theories. Different statistical methods have been used to investigate changes in psychological constructs over time [for reviews see 1, 2]. Longitudinal structural equation modelling has been particularly popular to examine longitudinal processes because of its flexibility to build statistical models that match a particular psychological theory.
Latent change score models (LCSMs) are used across disciplines in the behavioural sciences to study how constructs change over time [e.g., 3– 6]. This framework can be extended to specifically examine how changes in one construct are associated with changes in another construct 7 , and can be expanded to estimate more complex non-linear trajectories compared to other statistical techniques (e.g., autoregressive cross-lagged models). Such ‘change-to-change’ questions may be of interest across a range of research disciplines, given they can be used to examine whether changes on a predictor variable are related to changes on an outcome variable at a subsequent time point. In research on psychological therapies for example, a common question is whether changes in a given therapy process (e.g., negative appraisals) are related to subsequent changes on a therapy outcome measure (e.g., post-traumatic stress disorder (PTSD) symptoms). Latent change score modelling may be particularly suitable to study such questions. However, the most appropriate statistical model for evaluating change depends on the underlying theoretical model of change [see 2, 8, 9, for discussion].
This paper introduces the R package lcsm, a tool that aims to help users understand, analyse, and visualise different LCSMs. Below we start by providing a brief overview of LCSM methodology. For those seeking further introductory resources on structural equation modelling and the use of latent variables, we recommend Grimm et al. 10 , Little 11 , or Kline 12 .
Methodological overview
Latent change score modelling builds on concepts from classical test theory, which assumes that the observed score ( X) of an individual ( i) at a particular time ( t) can be expressed as the individual’s ‘true score’ ( lx) and the individual’s ‘unique score / residual’ ( u) at that time, see Equation 1. By dividing the observed scores in this way, models are able to test theories about unobserved (latent) constructs while reducing the effect of measurement residuals.
The specification in LCSMs is such that the model can estimate a latent variable that captures the change in latent ‘true scores’ between two time points. By combining two longitudinal structural equation modelling methods, namely ‘latent growth curve models’ and ‘autoregressive cross-lag models’, LCSMs can provide a detailed examination of within-person changes in one (i.e., univariate) or more constructs (e.g., bivariate) over time 10, 13 . A common modelling approach is to first understand the individual trajectories of each construct in a univariate LCSM, before combining both models to examine their relationships in a bivariate LCSM. The notation of the parameters in this paper mainly follow existing tutorials [e.g., 7, 10].
Univariate LCSM
A univariate LCSM aims to describe the changes of individuals ( i) in one construct ( X) over time ( t). The LCSM framework offers different options to describe this change: a constant change parameter ( α x × s xi ), a proportional change parameter ( β x × x [ t−1] i ), and an autoregressive effect of the change scores ( ϕ x × ∆ x [ t−1] i ). The choice of which change components to include depends on the theoretical framework and model fit. Equation 2 shows how the change in one construct ( X) at a specific time point ( t) is specified when using these three parameters. The constant change parameter alone is similar to linear change because it has the same effect on all change scores (see the identical paths leading from g2 to each change score dx2 to dx5 in Figure 1). Proportional change describes whether the ‘change score’ at time ( t) is determined by the ‘true score’ of the same construct at the previous time point ( t − 1), see the paths labelled beta_x in Figure 1. Autoregressions of the change scores describe whether any given change score is determined by the previous change score (see the paths labelled phi_x in Figure 1). Note that in this example all parameters are constrained to be equal over time.
Bivariate LCSM
The univariate LCSM can be extended to a bivariate LCSM to examine associations between two constructs over time. Depending on the research question there are different ‘coupling’ options to model the associations between two constructs [for a review see 10]. The following overview focuses on the extension that allows the examination of how changes in one construct are associated with changes in another construct 7 . This particular bivariate LCSM can address research questions like: ‘Do changes in negative appraisals precede subsequent changes in PTSD symptoms during therapy?’.
A simplified path diagram of a bivariate LCSM with five repeated measurements and these parameters is shown in Figure 2. Equation 3 shows how changes of a bivariate LCSM with lagged coupling parameters are constructed. The first line of each equation represents the parameters that describe the within construct changes, while the second line of each equation represents parameters that describe the between construct coupling parameters. In this case, change in construct X is specified the same as in the univariate model, see Equation 3a. Change in construct Y is also specified using the ‘constant change’, ‘proportional change’, and ‘autoregressions of the change scores’ components but includes an additional element: the change in the other construct ( X) at the previous time point ( ξ lag yx × ∆ x [ t−1] i ), see Equation 3b. The parameter ξ lag yx × ∆ x [ t−1] i estimates whether changes in construct Y at one time point ( t) are determined by changes in construct X at the previous time point ( t-1).
It is also important to consider whether to examine concurrent or lagged relationships between the two constructs. In some cases it may be desirable to examine concurrent relationships, for example when the underlying theory predicts that both constructs change simultaneously. For a more detailed discussion on this topic see Wang et al. 14 and Goldsmith et al. 15 . Coefficients are usually constrained to be equal over all time points, but this can be changed by allowing variation between specific (or all) time points. For example, for an intervention with two distinct phases, the associations between two constructs might theoretically be thought to differ between phases, so coefficients could be constrained to be equal within each phase, but permitted to vary between phases. The lcsm package refers to this as a ‘piecewise’ approach.
Why is a package needed?
Multiple script-based software packages support structural equation modelling and can be used for analysing LCSMs, for example lavaan 16 , OpenMx 17 , or Mplus 18 . Other software packages like JASP 19 or Ωnyx 20 also offer a graphical user interface for building and analysing structural equation models. The R package RAMpath 21 offers a framework for analysing longitudinal structural equation models and it can also estimate basic univariate and bivariate LCSMs. Although there exist many tutorials on how to implement latent change score models in different software packages [e.g., 4, 10, 22– 24], most require the user to generate their own syntax from scratch, or manually adapt existing examples to match their data and model specifications. To our knowledge, there is currently no tool that allows the user to input different model specifications and automatically generate the corresponding LCSM syntax.
Specifying LCSMs in current software packages can be complex and cumbersome, especially with larger numbers of repeated measures and when testing sequential models of increasing complexity. Syntax for complex models can be hard to program, is lengthy, and thus prone to errors. For example, lavaan syntax for a bivariate LCSM with 10 repeated measures can consist of between 200 to 300 lines of code. Klopack and Wickrama 24 also highlighted this drawback in a recent tutorial on latent change score modelling in Mplus, ‘Models can be cumbersome to program in available software packages.’ (p. 100). A tool that generates syntax for different model specifications may not only help to streamline the analytic steps involved in latent change score modelling, but also help researchers to reduce errors in code and facilitate a transparent and reproducible way of reporting analyses.
Methods
Implementation
The lcsm package combines the strengths of existing R packages for SEM by providing a framework that makes these packages work together efficiently. The current version of the package (Version 0.1.6) 25 provides a set of functions that help with visualising longitudinal data, generating lavaan syntax for different univariate and bivariate LCSMs, fitting univariate and bivariate LCSMs, and extracting parameter estimates as well as fit statistics.
Further functions allow plotting of simplified path diagrams and data simulation to explore the effects of different model parameters. An overview of the main functions and a short description is presented in Table 1.
Table 1. Main functions of the lcsm R package and their dependencies.
Function | Description | Main dependency ‡ |
---|---|---|
Specify lavaan syntax | ||
specify_uni_lcsm() | Specify lavaan syntax for univariate LCSM | base |
specify_bi_lcsm() | Specify lavaan syntax for bivariate LCSM | base |
Fit models | ||
fit_uni_lcsm() | Fit univariate LCSM | lavaan |
fit_bi_lcsm() | Fit bivariate LCSM | lavaan |
Extract results | ||
extract_fit() | Extract fit statistics from lavaan objects | broom |
extract_param() | Extract parameter estimates from lavaan objects | broom |
Simulate data | ||
sim_uni_lcsm() | Simulate data from univariate LCSM parameters | lavaan |
sim_bi_lcsm() | Simulate data from bivariate LCSM parameters | lavaan |
Visualisation functions | ||
plot_trajectories() | Plot individual trajectories of cases | ggplot2 |
plot_lcsm() | Plot simplified LCSM path diagram | semPlot |
Note. More details about each function can be found in the package documentation or using the help() function in R. ‡ This column lists additional R packages that are required by the functions of the lcsm package.
Operation
The lcsm package can be used with R version 3.5.0 or later on Linux, Mac and Windows. It can be installed from within R using install.packages("lcsm"). The interactive application shinychange supplements this package and illustrates how the lavaan syntax and path diagrams change depending on different model specifications. The next section gives an overview of the workflow of the lcsm package.
Use cases
To demonstrate the implementation of these functions, we will consider the example of 500 participants undertaking a five session longitudinal intervention, where a hypothesised process variable (X), and a hypothesised outcome variable (Y), are measured at each session. Rather than simply looking at whether the process variable predicts outcomes at the end of the intervention, the LCSM approach allows the more detailed analysis of changes in each variable from one session to the next. In this example, our principal question is: Does the amount of change on the process variable X from one session to the next predict the amount of subsequent change in the outcome variable Y?
Simulate data
Simulating data can be very helpful in order to learn new analytic approaches and refine study methodology as required 26 . The functions sim_uni_lcsm() and sim_bi_lcsm() can be used to simulate data based on specific model parameter values specified by the user. Both of these functions return a dataframe in ’wide’ format 1 including a unique identifier ( id) for each individual. Note that LCSMs generally contain multiple parameters which are interdependent. It may not therefore be possible to specify the exact arrangement of parameters desired when simulating data.
In this example, we start by simulating a 500-participant dataset ( df_sim) for variables X and Y for the five session intervention, where both variables are expected to decrease over time and include some missing data. We are also specifying there should be a coupling relationship where change in X predicts subsequent change in Y using the coupling argument. The strength of this coupling relationship and other covariances describing associations between variables X and Y are specified in a list() using the coupling_param argument. All model parameters (e.g., model_x) are described in Table 2 and details about the parameter estimates (e.g., model_x_param) are presented in Table 3.
# Simulate data for worked example df_sim <- sim_bi_lcsm(timepoints = 5, sample.nobs = 500, # Specify percentage (pct) of missing data na_x_pct = .15, na_y_pct = .1, # Define parameters in model X model_x = list(alpha_constant = TRUE, beta = TRUE, phi = TRUE), # Specify parameter estimates in model X model_x_param = list(gamma_lx1 = 29, sigma2_lx1 = .5, sigma2_ux = .2, alpha_g2 = -.3, sigma2_g2 = .6, sigma_g2lx1 = .2, beta_x = -.1, phi_x = .1), # Define parameters in model Y model_y = list(alpha_constant = TRUE, beta = TRUE, phi = TRUE), # Specify parameter estimates in model Y model_y_param = list(gamma_ly1 = 15, sigma2_ly1 = .2, sigma2_uy = .2, alpha_j2 = -.4, sigma2_j2 = .1, sigma_j2ly1 = .02, beta_y = -.2, phi_y = .1), # Define coupling parameters coupling = list(xi_lag_yx = TRUE), # Specify coupling parameter estimates coupling_param = list(sigma_su = .01, sigma_ly1lx1 = .2, sigma_g2ly1 = .1, sigma_j2lx1 = .1, sigma_j2g2 = .01, xi_lag_yx = .5), # Set seed parameter seed = 1234)
Table 2. Available specifications for univariate LCSMs and bivariate coupling options.
Option | Description |
---|---|
Univariate model options | |
alpha_constant | Constant change factor |
alpha_piecewise | Piecewise constant change factor |
alpha_piecewise_num | Change point of piecewise constant change factor |
alpha_linear | Linear change factor |
beta | Proportional change factor: change score x (t)
determined by true score x (t-1) |
phi | Autoregression of change scores: change score x (t)
determined by change score x (t-1) |
Coupling options | |
coupling_piecewise | Piecewise coupling parameters |
coupling_piecewise_num | Change point of piecewise coupling parameters |
delta_con_xy | Change score x (t) determined by true score y (t) |
delta_con_yx | Change score y (t) determined by true score x (t) |
delta_lag_xy | Change score x (t) determined by true score y (t-1) |
delta_lag_yx | Change score y (t) determined by true score x (t-1) |
xi_con_xy | Change score x (t) determined by change score y (t) |
xi_con_yx | Change score y (t) determined by change score x (t) |
xi_lag_xy | Change score x (t) determined by change score y (t-1) |
xi_lag_yx | Change score y (t) determined by change score x (t-1) |
Note. Covar =Covariance. More details about each model option as well as further customisations can be found in the package documentation using help(specify_uni_lcsm) or help(specify_bi_lcsm). Bivariate model options allow for concurrent ( con) and lagged ( lag) coupling between two constructs.
Table 3. Complete list of parameters available in the lcsm package.
Parameter | Symbol | Description |
---|---|---|
Construct X | ||
gamma_lx1 | γ lx 1 | Mean of latent true scores x (Intercept) |
sigma2_lx1 | Variance of latent true scores x | |
sigma2_ux | Variance of observed scores x | |
alpha_g2 | α g 2 | Mean of change factor (g2) |
alpha_g3 | α g 3 | Mean of change factor (g3) |
sigma2_g2 | Variance of change factor (g2) | |
sigma2_g3 | Variance of change factor (g3) | |
sigma_g2lx1 | σ g2 lx1 | Covar: Change factor (g2) with initial true score x (lx1) |
sigma_g3lx1 | σ g3 lx1 | Covar: Change factor (g3) with initial true score x (lx1) |
sigma_g2g3 | σ g2 g3 | Covar: Change factors within construct x |
beta_x | β x | Proportional change factor of construct x |
phi_x | ϕ x | Autoregression of change scores x |
Construct Y | ||
gamma_ly1 | γ ly1 | Mean of latent true scores y (Intercept) |
sigma2_ly1 | Variance of latent true scores y | |
sigma2_uy | Variance of observed scores y | |
alpha_j2 | α j2 | Mean of change factor (j2) |
alpha_j3 | α j3 | Mean of change factor (j3) |
sigma2_j2 | Variance of change factor (j2) | |
sigma2_j3 | Variance of change factor (j3) | |
sigma_j2ly1 | σ j2 ly1 | Covar: Change factor (j2) with initial true score y (ly1) |
sigma_j3ly1 | σ j3 ly1 | Covar: Change factor (j3) with initial true score y (ly1) |
sigma_j2j3 | σ j2 j3 | Covar: Change factors within construct y |
beta_y | β y | Proportional change factor of construct y |
phi_y | ϕ y | Autoregression of change scores y |
Coupling X & Y | ||
sigma_su | σ su | Covar: Residuals x with y |
sigma_ly1lx1 | σ ly1 lx1 | Covar: Intercepts x with y |
sigma_g2ly1 | σ g2 ly1 | Covar: Change factor x (g2) with initial true score y (ly1) |
sigma_g3ly1 | σ g3 ly1 | Covar: Change factor x (g3) with initial true score y (ly1) |
sigma_j2lx1 | σ j2 lx1 | Covar: Change factor y (j2) with initial true score x (lx1) |
sigma_j3lx1 | σ j3 lx1 | Covar: Change factor y (j3) with initial true score x (lx1) |
sigma_j2g2 | σ j2 g2 | Covar: Change factors y (j2) with x (g2) |
sigma_j2g3 | σ j2 g3 | Covar: Change factors y (j2) with x (g3) |
sigma_j3g2 | σ j3 g2 | Covar: Change factors y (j3) with x (g2) |
delta_con_xy | δ con xy | Change score x (t) determined by true score y (t) |
delta_con_yx | δ con yx | Change score y (t) determined by true score x (t) |
delta_lag_xy | δ lag xy | Change score x (t) determined by true score y (t-1) |
delta_lag_yx | δ lag yx | Change score y (t) determined by true score x (t-1) |
xi_con_xy | ξ con xy | Change score x (t) determined by change score y (t) |
xi_con_yx | ξ con yx | Change score y (t) determined by change score x (t) |
xi_lag_xy | ξ lag xy | Change score x (t) determined by change score y (t-1) |
xi_lag_yx | ξ lag yx | Change score y (t) determined by change score x (t-1) |
Note. Covar = Covariance. More details for each parameter can be found in the package documentation using help(sim_uni_lcsm) or help(sim_bi_lcsm).
Visualise longitudinal data
Simulated or real datasets can then be visualised to help with exploring and understanding how the model parameters are associated with different trajectories of change over time. Visualising individual trajectories of repeated measurements may also be helpful for understanding data and informing modelling decisions. A more detailed overview of the rationale for visualising longitudinal data is described in Ghisletta and McArdle 23 and Grimm et al. 10 .
The function plot_trajectories() offers an easy way to visualise longitudinal data. Figure 3 was created using this function to visualise a random 20% sample of individual participants’ trajectories on variables X and Y in our example dataset ( df_sim). This function is built using the R package ggplot2 27 and additional ggplot2 functions can be added to extend the plot.
Fit univariate and bivariate models
Having visualised our example data, we now aim to implement univariate models for variables X and Y separately, before combining these together in a bivariate model. The functions fit_uni_lcsm() and fit_bi_lcsm() can be used to do this, using the lavaan package 16 . By default, full information maximum likelihood (FIML) is used to estimate each model. This method makes the assumption that data is missing completely at random (MCAR) or missing at random (MAR), and permits the inclusion of individuals with incomplete data 28 . Other model estimators and methods to treat missing data that are part of the lavaan package can be specified using the two arguments estimator and missing (for more details see help(lavOptions)).
The example below shows a univariate model for the process variable X. The user specifies the dataset in wide format using the 'data' argument. A list of variables representing the repeated measures of X are specified in the 'var' argument. The LCSM parameters are specified as a list() using the 'model' argument. For example, the code below includes a constant change factor ( alpha_constant), a proportional change factor ( beta), and the autoregression of change scores ( phi). Figure 1 shows a simplified path diagram of this model.
# Fit univariate latent change score model and # save the returned object as 'model1' model1 <- fit_uni_lcsm(data = df_sim, var = c("x1", "x2", "x3", "x4", "x5"), model = list(alpha_constant = TRUE, beta = TRUE, phi = TRUE))
Once we have specified univariate models for both variable X and variable Y, and have evaluated the extent to which these models fit the data using fit statistics (described below), we can combine the best-fitting univariate models into a bivariate LCSM using the function fit_bi_lcsm(). The below example shows this model. The two sets of repeated measures are specified using the arguments 'var_x' and 'var_y', followed by the specifications of the best-fitting univariate models ( 'model_x' and 'model_y'). Note that in this example the specifications of these two models use identical parameters ( alpha_constant, beta, and phi). However, nonidentical specifications for 'model_x' and 'model_y' can be made if this is indicated by the model fit of the individual univariate models.
For bivariate LCSMs, ‘coupling’ parameters, which model the interactions between variables X and Y, can be specified using the 'coupling' argument. The argument shown below, 'coupling = list(xi_lag_yx = TRUE)', addresses the main question of our worked example, by adding a parameter that estimates whether changes in variable Y at time point ( t) are determined by changes in variable X at the previous time point ( t − 1). Figure 2 shows a simplified path diagram of this model.
# Fit bivariate latent change score model and # save the returned object as 'model2' model2 <- fit_bi_lcsm(data = df_sim, var_x = c("x1", "x2", "x3", "x4", "x5"), var_y = c("y1", "y2", "y3", "y4", "y5"), model_x = list(alpha_constant = TRUE, beta = TRUE, phi = TRUE), model_y = list(alpha_constant = TRUE, beta = TRUE, phi = TRUE), coupling = list(xi_lag_yx = TRUE))
If the time lag element ( lag) is not desired, a concurrent ( con) version of each coupling parameter is available (e.g., 'coupling = list(xi_con_yx = TRUE)'). Table 2 shows the full list of available univariate and bivariate model specifications that are implemented in the current version of the lcsm package. These specifications can be included in the LCSM by adding them to the list of parameters and setting them to TRUE.
For users who wish only to generate the lavaan syntax of a model, the functions specify_uni_lcsm() and specify_bi_lcsm() are available. This may be useful to those who wish to make further manual adaptations to the model syntax (e.g., freeing parameters that are fixed over time by default). The lcsm package adds comments to the lavaan syntax to provide more information about each section and to facilitate such adaptations. The interactive application shinychange allows users to explore how the number of repeated measures and different parameters affect the lavaan syntax (see Figure 4).
Extract fit statistics and parameter estimates
To evaluate how well a univariate or bivariate model fits the underlying data, one option is to compare the fit statistics of differently specified models [for further discussion of approaches to evaluating model fit see 10]. This is usually performed in a ‘nested’ way, comparing similar models of increasing complexity. Imagine we wish to compare two versions of a univariate model for the outcome variable Y. We want to evaluate whether the addition of the ‘autoregression of change scores’ parameter ( phi) in the model provides a better description of the data. To do this, we would estimate two nested models; model_y_01, which does not include phi, and model_y_02, which includes phi. The models are otherwise identical. The function extract_fit(model_y_01, model_y_02) can be used to extract commonly used fit statistics for each model. These can be inspected visually or the two models can be compared using the anova() function from lavaan to perform a likelihood ratio test. Below is an example output, using the univariate model model1 we created earlier.
# Extract fit statistics from 'model1' created earlier # More fit statistics can be displayed changing the details argument to TRUE extract_fit(model1, details = FALSE) # # # A tibble: 1 × 8 # # model chisq npar aic bic cfi rmsea srmr # # <chr> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> # # 1 1 11.0 8 5471. 5504. 1 0 0.0814
Parameter estimates of any LCSM fitted with the lcsm package can be extracted using the extract_param() function, which builds on the R package broom 29 . This function returns a dataframe listing each parameter included within the model, together with the corresponding estimate, standard error, and p value. These data can then be interpreted in relation to the study hypotheses. Names and descriptions of all parameters are presented in Table 3.
# Extract parameter estimates from 'model1' created earlier # To simplify the output we change the formatting of p values # and only select the first 5 variables extract_param(model1, printp = TRUE) %>% select(1:5) # # # A tibble: 8 × 5 # # label estimate std.error statistic p.value # # <chr> <dbl> <dbl> <dbl> <chr> # # 1 gamma_lx1 28.9 0.0396 730. < .001 # # 2 sigma2_lx1 0.528 0.0461 11.4 < .001 # # 3 sigma2_ux 0.194 0.00783 24.8 < .001 # # 4 alpha_g2 0.109 0.192 0.567 .571 # # 5 sigma2_g2 0.657 0.0443 14.8 < .001 # # 6 sigma_g2lx1 0.236 0.0332 7.11 < .001 # # 7 beta_x -0.111 0.00603 -18.5 < .001 # # 8 phi_x 0.142 0.0184 7.68 < .001
Plot simplified path diagrams
Visualising models using a simplified path diagram can be a helpful method to understand and check the models being specified, by giving a clear visual representation of the parameters chosen. The plot_lcsm() function of this package can be used to generate such diagrams, and is built on the semPlot package 30 . Figure 1 and Figure 2 were both created using this function.
Discussion
Analysing the longitudinal relationships between changes in two constructs may help to better understand how they unfold over time. LCSMs are a specific form of longitudinal structural equation models that allow researchers to examine these relationships. In psychotherapy research this can be used to examine how changes in specific therapy processes (e.g., negative appraisals) are associated with subsequent changes on a treatment outcome measure (e.g., PTSD symptoms).
This paper addresses a small subset of the specifications available using a latent change score modelling approach. Further adaptations may be required to address specific research questions. Grimm et al. 10 provide a more detailed overview of the methodological background to these models and discuss some possible adaptations and extensions. It is also important to mention that the interpretation of results from LCSMs needs to be considered carefully, especially when multiple parameters (e.g., constant change and proportional change) are used to examine change over time [see 31, 32]. It is hoped that the lcsm package and this tutorial will provide a helpful resource for understanding and implementing LCSMs, and aid in the clear and transparent reporting of these analyses.
Data availability
All code, materials, and data can be found at https://github.com/milanwiedemann/lcsm.
Software availability
Source code available from: https://github.com/milanwiedemann/lcsm.
Archived source code at time of publication: https://zenodo.org/record/6451333#.YlfDZy8Rr0o 25 .
License: MIT
Instructions for installing the package, further technical details, and examples can be found at https://milanwiedemann.github.io/lcsm.
Acknowledgements
An earlier version of this article can be found on PsyArXiv https://doi.org/10.31234/osf.io/atjpu
Funding Statement
This project was supported by a Mental Health Research UK studentship (MW), Wellcome [102176 (GRT); 069777 and 200796 (AE)], the Oxford Health NIHR Biomedical Research Centre (MW, GRT, AE), and the NIHR Oxford Biomedical Research Centre (GRT). The views expressed are those of the authors and not necessarily those of the NHS, the NIHR or the Department of Health. The funders had no role in study design, data collection and analysis, decision to publish, or preparation of the manuscript.
The funders had no role in study design, data collection and analysis, decision to publish, or preparation of the manuscript.
[version 1; peer review: 2 approved]
Footnotes
1One row per individual and one column for each time point of each variable.
References
- 1. Kristopher J: Preacher Advances in mediation analysis: A survey and synthesis of new developments. Annu Rev Psychol. 2015;66:825–852. 10.1146/annurev-psych-010814-015258 [DOI] [PubMed] [Google Scholar]
- 2. Usami S, Murayama K, Hamaker EL: A unified framework of longitudinal models to examine reciprocal relations. Psychol Methods. 2019;24(5):637–657. 10.1037/met0000210 [DOI] [PubMed] [Google Scholar]
- 3. Hawley LL, Padesky CA, Hollon SD, et al. : Cognitive-Behavioral Therapy for Depression Using Mind Over Mood: CBT Skill Use and Differential Symptom Alleviation. Behav Ther. 2017;48(1):29–44. 10.1016/j.beth.2016.09.003 [DOI] [PubMed] [Google Scholar]
- 4. Kievit RA, Brandmaier AM, Ziegler G, et al. : Developmental cognitive neuroscience using latent change score models: A tutorial and applications. Dev Cogn Neurosci. 2018;33:99–117. 10.1016/j.dcn.2017.11.007 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 5. King DW, King LA, McArdle JJ, et al. : Sequential Temporal Dependencies in Associations Between Symptoms of Depression and Posttraumatic Stress Disorder: An Application of Bivariate Latent Difference Score Structural Equation Modeling. Multivariate Behav Res. 2009;44(4):437–464. 10.1080/00273170903103308 [DOI] [PubMed] [Google Scholar]
- 6. King KM, Littlefield AK, McCabe CJ, et al. : Longitudinal modeling in developmental neuroimaging research: Common challenges, and solutions from developmental psychology. Dev Cogn Neurosci. 2018;33:54–72. 10.1016/j.dcn.2017.11.009 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 7. Grimm KJ, An Y, McArdle JJ, et al. : Recent changes leading to subsequent changes: Extensions of multivariate latent difference score models. Struct Equ Modeling. 2012;19(2):268–292. 10.1080/10705511.2012.659627 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 8. McArdle JJ: Latent variable modeling of differences and changes with longitudinal data. Annu Rev Psychol. 2009;60:577–605. 10.1146/annurev.psych.60.110707.163612 [DOI] [PubMed] [Google Scholar]
- 9. Zyphur MJ, Voelkle MC, Tay L, et al. : From Data to Causes II: Comparing Approaches to Panel Data Analysis. Organ Res Methods. 2020;23(4):688–716. 10.1177/1094428119847280 [DOI] [Google Scholar]
- 10. Grimm KJ, Ram N, Estabrook R: Growth Modeling -Structural Equation and Multilevel Modeling Approaches. The Guilford Press. [Google Scholar]
- 11. Little TD: Longitudinal Structural Equation Modeling. Guilford Press.2013. Reference Source [Google Scholar]
- 12. Kline RB: Principles and Practice of Structural Equation Modeling. The Guilford Press, 4 edition.2015. Reference Source [Google Scholar]
- 13. McArdle JJ, Hamagami F: Latent difference score structural models for linear dynamic analyses with incomplete longitudinal data. In: Linda M. Collins and Aline G. Sayer, editors, Decade of Behavior. New Methods for the Analysis of Change. American Psychological Association,2001;139–175. 10.1037/10409-005 [DOI] [Google Scholar]
- 14. Wang L, Zhang Z, Estabrook R: Longitudinal mediation analysis of training intervention effects. In Sy-Miin Chow, Emilio Ferrer, and Fushing Hsieh, editors, Statistical Methods for Modeling Human Dynamics: An Interdisciplinary Dialogue. Notre Dame Series on Quantitative Methodology. Taylor & Francis, 1 edition.2009;32. Reference Source [Google Scholar]
- 15. Goldsmith KA, MacKinnon DP, Chalder T, et al. : Tutorial: The practical application of longitudinal structural equation mediation models in clinical trials. Psychol Methods. 2018;23(2):191–207. 10.1037/met0000154 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 16. Rosseel Y: lavaan: An R Package for Structural Equation Modeling.2012;48(2). 10.18637/jss.v048.i02 [DOI] [Google Scholar]
- 17. Neale MC, Hunter MD, Pritikin JN, et al. : OpenMx 2.0: Extended Structural Equation and Statistical Modeling. Psychometrika. 2016;81(2):535–549. 10.1007/s11336-014-9435-8 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 18. Muthén LK, Muthén BO: Mplus User’s Guide.Muthén & Muthén, 8 edition. Reference Source [Google Scholar]
- 19. JASP Team: JASP. Reference Source [Google Scholar]
- 20. von Oertzen T, Brandmaier AM, Tsang S: Structural Equation Modeling With Onyx. Struct Equ Modeling. 2014;22(1):148–161. 10.1080/10705511.2014.935842 [DOI] [Google Scholar]
- 21. Zhang Z, Hamagami F, Grimm KJ, et al. : Using R Package RAMpath for Tracing SEM Path Diagrams and Conducting Complex Longitudinal Data Analysis. Struct Equ Modeling. 2014;22(1):132–147. 10.1080/10705511.2014.935257 [DOI] [Google Scholar]
- 22. Cáncer PF, Estrada E, Ollero MJF, et al. : Dynamical Properties and Conceptual Interpretation of Latent Change Score Models. Front Psychol. 2021;12:696419. 10.3389/fpsyg.2021.696419 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 23. Ghisletta P, McArdle JJ: Teacher's Corner: Latent Curve Models and Latent Change Score Models Estimated in R. Struct Equ Modeling. 2012;19(4):651–682. 10.1080/10705511.2012.713275 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 24. Klopack ET, Wickrama KKAS: Modeling Latent Change Score Analysis and Extensions in Mplus: A Practical Guide for Researchers. Struct Equ Modeling. 2020;27(1):97–110. 10.1080/10705511.2018.1562929 [DOI] [PMC free article] [PubMed] [Google Scholar]
- 25. Wiedemann M: milanwiedemann/lcsm: (0.1.6). Zenodo. 2022. 10.5281/zenodo.6451333 [DOI] [Google Scholar]
- 26. DeBruine LM, Barr DJ: Understanding mixed-effects models through data simulation. Adv Methods Pract Psychol Sci. 2021;4(1):2515245920965119. 10.1177/2515245920965119 [DOI] [Google Scholar]
- 27. Wickham H: ggplot2: Elegant Graphics for Data Analysis.Springer-Verlag New York. Reference Source [Google Scholar]
- 28. Baraldi AN, Enders CK: An introduction to modern missing data analyses. J Sch Psychol. 2010;48(1):5–37. 10.1016/j.jsp.2009.10.001 [DOI] [PubMed] [Google Scholar]
- 29. Robinson D, Hayes A, Couch S: broom: Convert statistical objects into tidy tibbles. Reference Source [Google Scholar]
- 30. Epskamp S: semPlot: Path Diagrams and Visual Analysis of Various SEM Packages’ Output. Reference Source [Google Scholar]
- 31. Clark DA, Nuttall AK, Bowles RP: Misspecification in latent change score models: Consequences for parameter estimation, model evaluation, and predicting change. Multivariate Behav Res. 2018;53(2):172–189. 10.1080/00273171.2017.1409612 [DOI] [PubMed] [Google Scholar]
- 32. Jacobucci R, Serang S, Grimm KJ: A Short Note on Interpretation in the Dual Change Score Model. Struct Equ Modeling. 2019;26(6):924–930. 10.1080/10705511.2019.1619457 [DOI] [Google Scholar]