Message/Author 

Jiyoung posted on Saturday, June 20, 2009  9:34 am



I want to run a structural equation model. The variables in my model were chosen based on theories that previous studies found. Along with the variables based on theories, I also want to include demographic variables (e.g., gender, race) to control the effect of demographic variables on endogenous variables. I wonder if it is correct that those demographic variables are just added like other exogenous variables based on theories. For instance, let's say that I want to predict intention to use the Internet (INTENTION). My exogenous variables based on theories are 1) perceived ease of use (PEU) and 2) relative advantage (RA). Those are latent variables with multiple indicators. I also want to control the effect of gender, race, income, etc. First, I will run a CFA to examine the validity of PEU and RA. I will also use the following command: genderL by gender; raceAAL by raceAA; race AsianL by raceAsian; raceWhiteL by raceWhite; After I make sure the model fit of the CFA model is good, I will move onto the SEM model. I will also use the following command. Intention on peu ra genderL raceAAL raceAsianL raceWhiteL; I wonder if I am on the right track. If you could clarify my question, I would appreciate it. Thank you. 


You should simply regress intention on the observed covariates. You should not put a factor behind each covariate. 

Jiyoung posted on Monday, June 22, 2009  9:46 am



Thank you so much for clearing that up. Let me make sure if I understand what you said. 1) Do you mean I don't need to create factors for the demographic observed variables? I don't need the following command? genderL by gender; raceAAL by raceAA; race AsianL by raceAsian; raceWhiteL by raceWhite; 2) And also do you mean that I can run SEM with the following command without creating factors for the demographic variables? Intention on peu ra gender raceAA raceAsian raceWhite; 3) In terms of the interpretation of the dummy variables, I wonder if the interpretation of the results is the same as regression. If you could clarify my question, it will be very helpful. Thank you. 


1. You do not need the BY statements. 2. Yes. 3. Yes. 


I want to include SES as a latent variable in a SEM model. The indicators are: education (educ)  7 level ordinal indicator income (inc)  6 level ordinal indicator race/ethnicity (race)  nominal indicator with 5 categories (Black, White, Hispanic, Asian, and other) marital status (mar)  nominal indicator with 5 categories (married, living with partner, divorced, widowed, single never married) nativity (bornUS)  born in US=1 not born US=0 1. I know I need to create dummy variables for the two nominal indicators  marital status and race/ethnicity. What I cannot figure out is how to code the dummy variables and then how to include them in the BY statement for the SES factor. 2. When SES is a latent factor, is it appropriate to have the measured indicators "cause" the latent factor? If so, how is the command for this written? Thank you. 


Nominal factor indicators are allowed in Mplus. See Slide 246 of the Topic 1 course handout for an example how to specify a formative factor. 


Linda, Thank you for the example of how to specify SES as a formative factor. That helps. I am using WLSMV because most of my indicators are categorical (5 point Likert scales) and when I identify marital status and race/ethnicity as nominal I can no longer use this estimator. Given that all of my primary data is nonnormally distributed ordinal data, isn't it better to use dummy variables for my two nominal variables so that I can use WLSMV? If so, would you help me write the commands for a dummy for a 5category race variable (1=Black, 2=White, 3=Hispanic, 4=Asian, 5=other)? Thank you, Susan 


I'm not sure if you are aware of the fact that maximum likelihood is appropriate for categorical outcomes using either logistic or probit regression. If you want to stick with weighted least squares estimation, you can use the DEFINE command to create the dummy variables. See the user's guide for more details. 


I tried ML and defining raceth and marital as nominal variables but get an error message that I do not have enough memory. WLSMV seems to work best with my model (except for my lack of understanding of how to write the command for dummies for my two nominal variables). On pp 449450 in my users manual (version 5, Nov 2007) is a description of how to refer the the levels of a nominal dependent variables in the MODEL command but no description of how to create dummy variables in the DEFINE command. I tried this in the DEFINE command: white=raceth==1; black=raceth==2; hispanic=raceth==3; It seems to work. Is this correct? If not, please help me  I am just a dumb graduate student ready to pull my hair out... Thanks. 


Following is one way to do this: DEFINE; white = 0; if (raceth eq 1) then white = 1; black = 0; if (raceth eq 2) then black = 1; etc. You need k1 dummies where k is the number of categories of the nominal variable. Whenever you create a variable in DEFINE, you should check to see that you get the results intended by saving the old and new variables and spot checking. 

Lucy Morgan posted on Tuesday, February 03, 2015  5:56 am



Hi I need to control for the effects of two observed demographic variables in an otherwise fully latent SEM model using MLM (due to nonnormal data). One is ordinal (education level) and the other is nominal (ethnicity) and both have a significant effect on the dependent variables. I have read through all the posts but I am still not clear what would be the correct approach. I need to run both measurement models and path models including these variables. 1) Can I include both the ordinal and the nominal variables as continuous variables as I do not need to interpret their effects, only control for them? (I will use SPSS to analyse for specific effects) 2) If no, my understanding is that I would need to create dummy variables  so would I state CATEGORICAL = ethnic educa; and then create dummy variables using DEFINE: white = 0; if (raceth eq 1) then white = 1; black = 0; if (raceth eq 2) then black = 1; etc. as outlined in the post above? If yes, do I use the newly created variables black, white, etc in WITH and ON statements or can I simply use ethnic and educ variables in the WITH and ON statements??? Many thanks for your help with this, I am very confused! Lucy 


1. The scale of observed exogenous variables is not specified. The scale is specified only for endogenous variables. 2. You do not need to create dummy variables for an ordinal variable unless you prefer to. You must create dummy variables for a nominal variable. Your code looks correct. For a nominal variable, you should use the dummy variables not the nominal variable in the analysis. 

Back to top 