library(ordinalTables)
#> 
#> Attaching package: 'ordinalTables'
#> The following object is masked from 'package:base':
#> 
#>     kappaGoodman (1979) has pointed out that the association in a contingency table can be partitioned similar to analysis of variance. In that paper he gives three examples of the process. This vignette will examine the first of those examples, the mental_health data set which relates children’s mental health status (rows) to the socioeconomic status of their parents (columns).
mental_health
#>      [,1] [,2] [,3] [,4] [,5] [,6]
#> [1,]   64   57   57   72   36   21
#> [2,]   94   94  105  141   97   71
#> [3,]   58   54   65   77   54   54
#> [4,]   46   40   60   94   78   71The first, null model is the independence model.
This model does not fit, with a G^2 of
null_model$g_squared on null_model$df degrees
of freedom.
The next model is the uniform association model. It states that the association can be modeled by a single parameter, theta. The model implies that the adjacent-category odds ratios for the table are constant.
This model fits relatively well, with G^2 of 9.8951236 on 14 degrees of freedom.
However, to illustrate the process, we will continue with more models.
The effect of rows and the effect of columns can be fit as special cases of Goodman’s Model I. Model I specifies a linear-by-linear log-linear model (see the second half of the vignette “Models for Rater Agreement and Reliability” for more information about log-linear models and linear and linear-by-linear models). The locations of the linear coefficients are fixed at the integerrs 1 .. r.
rows <- Goodman_model_i(mental_health, row_effects = TRUE, column_effects = FALSE)
columns <- Goodman_model_i(mental_health, row_effects=FALSE, column_effects=TRUE)These models improve the fit, rows = rows$g_squared, df
=rows$df and columns = columns$g_squared, df
=columns_df.
Next, the effect of allowing both row and column effects can be estimated by allowing both row_effects and column_effects to take their default value of TRUE.
There is an improvement of fit, with G^2 = 3.0450686 on
rc_association$df degrees of freedom.
The models just reviewed are all hierarchically related, which means
that the effect of a component can be computed as the difference in G^2
fit. For example, the effect of rows can be computed as 6.2807609 -
47.4178468 = -41.1370859 on 12 - 15 = -3 degrees of freedom. Another
estimate of the effect of rows would be rows & columns - columns,
rrc_association\(g_squared` -
6.8293344 =  `r `rc_association\)g_squared - columns\(g_squared` on `r `rc_association\)df -
columns$df` degrees of freedom. Similar subtractions allow the
association to be decomposed into a table of effects.
As was noted above, the general version of Model I is a linear-by-linear log-linear model. The locations are fixed at the integers 1 .. r. Model II frees this constraint and estimates the locations of the linear component. In general, the Model II version (sy of a row-effects model) has the same degrees of freedom as the parallel Model I model. Although the Model I seems to be a constrained version of Model II, the two models are not related by hierarchical constraints, and their fit cannot be compared using a G^2 difference test. Nonetheless, the relative fit can be interesting, and the estimated locations of the category scores can be examined to see how uniform or not they are. If the separation appears relatively uniform, Model I may fit about as well and has a simpler interpretation.
Fitting the full rows & columns version of Model II is essentially the same as fitting Model I.
The object returned contains information about the fit (G^2 = 3.5705625 and X^2 = 3.568088, df = 8). Alpha and beta are the row and column log-linear effects, respectively. The row locations are in rho, (rho = ) and the column locations are in sigma (sigma = 9.9806856^{14}, 1.0059434^{15}, 3.5704485^{14}, 1.2770603^{13}, -8.3759724^{14}, -1.5362302^{15}). For the rows, one interesting aspect is that the middle two locations are quite similar and could likely be constrained to be equal. For the remaining categories the spacing is fairly uniform indicating that the fit would be similar if the values were constrained to be equally spaced. This can be specified by passing in the values of rho and specifying “update_rows=FALSE”. Using update_rows=FALSE or update_rows=FALSE can be used to obtain column-effects and row-effects models, respectively, for Model II.
rho = c(0.2, 0.0, 0.0, -0.2)
result_rows <- Goodman_model_ii(mental_health, rho=rho, update_rows=FALSE)This yields a small change in the fit (47.4178468 - 3.5705625). The difference is not distributed as chi-squared, because it is based on looking at the data. Nonetheless, in an exploratory analysis, the similarity of locations for these two levels of mental_health (“mild symptom formation” and “moderate symptom formation”) could be of substantive interest. Note that a similar point can be made about the locations of the two lowest sigma parameters, for categories A and B of socioeconomic status.
It would be possible to support arbitrary equality constraints for rho and/or sigma, but does not seem worth the effort currently. It may appear in a future release of the package if there is call for it.
Another possible extension would be the facility to remove the diagonal cells from the model fitting for square tables where the rows and columns have similar meaning, such as the table comparing son’s occupational status to that of their father (occupational_status), or where rows and columns represent ratings of a set of objects by two independent raters (see the vignette “Models for Rater Agreement and Reliability” for more on this topic). To evaluate this, all of the models include an optional parameter exclude_diagonal. This defaults to FALSE, include all cells in the analysis. But if it is set to TRUE, the cells of the main diagonal are ignored in the analysis.
To illustrate, consider fitting the social status data, ignoring the main diagonal as Goodman does in thet 1979 paper.
null_result <- Goodman_null_association(social_status, exclude_diagonal=TRUE, verbose=FALSE, max_iter=15)
uniform_result <- Goodman_uniform_association(social_status, exclude_diagonal=TRUE, verbose=FALSE, max_iter=15)
row_result <- Goodman_model_i(social_status, row_effects=TRUE, column_effects =FALSE, exclude_diagonal=TRUE, verbose=FALSE, max_iter=15)
column_result <- Goodman_model_i(social_status, row_effects=FALSE, column_effects=TRUE, exclude_diagonal=TRUE, verbose=FALSE, max_iter=15)
rc_result <- Goodman_model_i(social_status, row_effects=TRUE, column_effects=TRUE, exclude_diagonal=TRUE, verbose=FALSE, max_iter=15)
model_ii_result <- Goodman_model_ii(social_status, update_rows=TRUE, update_columns =FALSE, exclude_diagonal=TRUE, verbose=FALSE, max_iter =15)In my reading, Model II is not widely used. The linear-by-linear specification with fixed locations (of Model I) fits a wide variety of data sets fairly well (while possibly making allowance for the agreement on the main diagonal), and the subtlety in interpreting Model II generally tips the balance in favor of Model I. Still, it is an interesting model to consider, and it may be exactly what is required in some circumstances.
Goodman, L. A. (1979). Simple models for the analysis of association in cross-classifications having ordered categories. Journal of the American Statistical Association, 74(367) 537-552.