Why is fitlm affected by variable scale?

조회 수: 3 (최근 30일)
Harold Matthews
Harold Matthews . 2021년 12월 1일
답변: Jeff Miller . 2021년 12월 1일
Dear all,
My statistics is pretty solid and my understanding is that if you fit a linear regression the scale of the X and Y variables should not affect the resulting p-values. I am running fitlm on some data (see demo and data attached) and changing the scale of the variables by transfiorming them to z-scores has a profound effect on the resulting p values. In the attached (Demo.m) code I fit two models with the same model design on the same data (in the attached 'Data.mat' file). The only difference is that for model 1 the X and Y variables are normalised to z scores and in model 2 they are not. I then scatter the p-values. You can see in the upper left corner that two p values that were not significant for model 1 become signfiocant for model 2.
Sorry I cannot get the demo code embedded in this question, so I have attached it. If anyone has any insights into this that would be great :)

채택된 답변

Ive J
Ive J 2021년 12월 1일
Well, the real question would be why not?
You have introduced interaction terms to the model. Two models test different hypotheses (except for the interaction terms). You can find a good explanation here. Clearly, when you remove the interaction terms, all t-stats would be the same for both models.

추가 답변 (1개)

Jeff Miller
Jeff Miller 2021년 12월 1일
Your understanding is correct for linear regression but your model is nonlinear because of the interaction terms. Consider:
zX = zscore(X);
ans =
ans =


Help CenterFile Exchange에서 Linear and Nonlinear Regression에 대해 자세히 알아보기




Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by