The Bass-Ackward factoring algorithm discussed by Goldberg
The Bass-Ackward factoring algorithm discussed by Goldberg
Goldberg (2006) described a hierarchical factor structure organization from the ``top down". The original idea was to do successive factor analyses from 1 to nf factors organized by factor score correlations from one level to the next. Waller (2007) discussed a simple way of doing this for components without finding the scores. Using the factor correlations (from Gorsuch) to organize factors hierarchically results may be organized at many different levels. The algorithm may be applied to principal components (pca) or to true factor analysis.
r: A correlation matrix or a data matrix suitable for factoring
nfactors: Factors from 1 to nfactors will be extracted. If nfactors is a a vector, then just the number of factors specified in the vector will be extracted. (See examples).
fm: Factor method. The default is 'minres' factoring. Although to be consistent with the original Goldberg article, we can also do principal components (fm ="pca").
rotate: What type of rotation to apply. The default for factors is oblimin. Unlike the normal call to pca where the default is varimax, in bassAckward the default for pca is oblimin.
scores: What factor scoring algorithm should be used. The default is "tenBerge", other possibilities include "regression", or "bartlett"
adjust: If using any other scoring proceure that "tenBerge" should we adjust the correlations for the lack of factor score fit?
plot: By default draw a bassAckward diagram
use: How to treat missing data. Use='pairwise" finds pairwise complete correlations.
cor: What kind of correlation to find. The default is Pearson.
weight: Should cases be weighted? Default, no.
correct: If finding tetrachoric or polychoric correlations, what correction should be applied to empty cells (defaults to .5)
x: The object returned by bassAckward
digits: Number of digits to display on each path
cut: Values greater than the abs(cut) will be displayed in a path diagram.
labels: Labels may be taken from the output of the bassAckward function or can be specified as a list.
marg: Margins are set to be slightly bigger than normal to allow for a cleaner diagram
main: The main title for the figure
items: if TRUE, show the items associated with the factors
sort: if TRUE, sort the items by factor loadings
lr: Should the graphic be drawn left to right or top to bottom
curves: Should we show the correlations between factors at the same level
organize: Rename and sort the factors at two lowest levels for a more pleasing figure
values: If TRUE, then show the percent variance accounted for by this factor.
...: Other graphic parameters (e.g., cex)
Details
This is essentially a wrapper to the fa and pca combined with the faCor functions. They are called repeatedly and then the weights from the resulting solutions are used to find the factor/component correlations.
Although the default is do all factor solutions from 1 to the nfactors, this can be simplified by specifying just some of the factor solutions. Thus, for the 135 items of the spi, it is more reasonable to ask for 3,5, and 27 item solutions.
The function bassAckward.diagram may be called using the diagram function or may be called directly.
The output from bassAckward.diagram is the sorted factor structure suitable for using fa.lookup.
Although not particularly pretty, it is possible to do Schmid-Leiman rotations at each level. Specify the rotation as rotate="schmid".
Returns
Call: Echo the call
fm: Echos the factor method used
fa: A list of the factor loadings at each level
bass.ack: A list of the factor correlations at each level
summary: The factors at each level
sumnames: Summary of the factor names
labels: Factor labels including items for each level
r: The correlation matrix analyzed
Phi: The factor correlations at each level
fa: The factor analysis loadings at each level, now includes Phi values
fa.vac: The variance accounted for by each factor at each level
References
Goldberg, L.R. (2006) Doing it all Bass-Ackwards: The development of hierarchical factor structures from the top down. Journal of Research in Personality, 40, 4, 347-358.
Gorsuch, Richard, (1983) Factor Analysis. Lawrence Erlebaum Associates.
Revelle, William. (in prep) An introduction to psychometric theory with applications in R. Springer. Working draft available at https://personality-project.org/r/book/
Waller, N. (2007), A general method for computing hierarchical component structures by Goldberg's Bass-Ackwards method, Journal of Research in Personality, 41, 4, 745-752, DOI: 10.1016/j.jrp.2006.08.005
Author(s)
William Revelle
Note
Goldberg calculated factor/component scores and then correlated these. Waller suggests just looking at the unrotated components and then examining the correlations when rotating different numbers of components. I do not follow the Waller procedure, but rather find successive factors and then find factor/component correlations following Gorsuch.
It is important to note that the BassAckward solution is not a hierarchical solution in the standard meaning. The factors are not factors of factors as is found in a hierarchical model (e.g. sim.hierarchical or omega, but is merely way of organising solutions with a different number of factors. In each case, unlike omega the factors are of the original variables, not the lower level factors. Thus, detailed statistics for any level of the hierarchy may be found by doing a factoring with that particular number of factors.
To find basic statistics for the multiple factorings, examine the fa object. For more detail just do the factoring at that level.
To see the items associated with the lowest level factors, use fa.lookup. For the items associated with other levels, use fa.lookup specifying the level. (See examples.)
See Also
fa, pca, omega and iclust for alternative hierarchical solutions. link{fa.lookup} to show the items in the lowest level of the solution.
Examples
bassAckward(Thurstone,4,main="Thurstone data set")f.labels <- list(level1=cs(Approach,Avoid),level2=cs(PosAffect,NegAffect,Constraint),level3 = cs(Extraversion,Agreeableness,Neuroticism,Conscientiousness,Openness))ba <- bassAckward(bfi[1:25],c(2,3,5),labels=f.labels, main="bfi data set from psychTools", values=TRUE)print(ba,short=FALSE)#show the items associated with the 5 level solutionfa.lookup(ba,dictionary=bfi.dictionary)#now show the items associated with the 3 level solutionfa.lookup(ba$fa[[2]],dictionary=bfi.dictionary)# compare the 3 factor solution to what get by extracting 3 factors directlyf3 <- fa(bfi[1:25],3)f3$loadings - ba$fa[[2]]$loadings # these are the same#do pca instead of factors just summarize, don't plotsummary(bassAckward(bfi[1:25],c(1,3,5,7),fm="pca", main="Components",plot=FALSE))##not run, but useful examplef.labels <- list(level1 = cs(Neg,Pos,Constrain),level2 = cs(Extra,Neuro,Cons,Open,Agree),level3 = cs(attnseeking,sociability,impulsivity, charisma,sensationseek,emotexpr,humor,anxiety, emotstab,irritability,wellbeing,industry,order,author,honesty,perfect,easygoing, selfcontrol,conservatism,creativity,introspect,art, intellect,conform,adaptability,compassion,trust))if(require("psychTools")){sp5 <- bassAckward(psychTools::spi[11:145], c(3,5,27),labels=f.labels, main="spi data set from psychTools")}