Michael Thomas Flanagan's Java Scientific Library

PCA Class:     Principal component analysis

     

Last update: 22 August 2012
Library main page

This class contains the methods necessary for a basic Principal Component Analysis with a varimax rotation. Options are available for an analysis using either the covariance or the correlation martix. A parallel analysis, using Monte Carlo simulations, is performed. Extraction criteria based on eigenvalues greater than unity, greater than a Monte Carlo eigenvalue percentile or greater than the Monte Carlo eigenvalue means are available.

The data may be entered from a text file or as a 2D array (String, double, float, int, char, boolean or Matrix)
Responses may be entered as:
'No response' handling options: deletion, replacement (mean of the item, mean of the persons responses, total mean, zero, user supplied value) are available.
In this documentation responses or measurements will be referred to as responses or scores, questions or environmental changes as items and the responding agencies as persons irrespective of whether the data is scientific, sociological, psychometric, educational etc. and whether the responding agency is human or inanimate.

Spelling note: All methods in this class containing 'standardized' or 'Standardized' in their name may be spelt with an s replacing the z, i.e. as 'standardised' or 'Standardised', e.g. the method standardizedAlpha() may also be spelt standardisedAlpha() and, similarly, Curtosis and Curtoses may replace Kurtosis and Kurtoses respectively.
Statistics notes: The terms mean, standard deviation, variance and covariance used in this page and in the method names refer to the sample means, sample standard deviations, sample variances and sample covariances.
The denominator of the varaiances, covariances, standard deviations, skewnesses and kurtoses may be set as n or as n−1. See Set denominator.

PCA is closely related to Factor Analysis but they are not identical. See Brian Ripley's Principal Component Analysis and Factor Analysis [Oxford] for an explanation of the differences. Not all of the methods descibed in this page form part of a conventional PCA but as the latter methods dominate the class title PCA has been retained for convenience and compatibility with earlier versions.

PCA is a subclass of the superclass Scores.

See Stat class for the general statistical methods and functions, RankAnalysis for matrix rank analysis and Cronbach for Cronbach's alpha analysis.

import directive: import flanagan.analysis.PCA;

SUMMARY OF METHODS

Constructor   public PCA()
Enter the data Read title, item names
and responses from text file
Enter responses
as rows per person
public void readScoresAsRowPerPersonA()
public void readScoresAsRowPerPersonA(String filename)
public void readScoresAsRowPerPersonB()
public void readScoresAsRowPerPersonB(String filename)
public void readScoresAsRowPerPersonC()
public void readScoresAsRowPerPersonC(String filename)
public void readScoresAsRowPerPersonD()
public void readScoresAsRowPerPersonD(String filename)
Enter responses
as rows per item
public void readScoresAsRowPerItemA()
public void readScoresAsRowPerItemA(Stringfilename)
public void readScoresAsRowPerItemB()
public void readScoresAsRowPerItemB(Stringfilename)
public void readScoresAsRowPerItemC()
public void readScoresAsRowPerItemC(Stringfilename)
public void readScoresAsRowPerItemD()
public void readScoresAsRowPerItemD(Stringfilename)
Enter data via program
arrays and Strings
Enter responses
as rows per person
public void enterScoresAsRowPerPerson(String[][] responses)
public void enterScoresAsRowPerPerson(double[][] responses)
public void enterScoresAsRowPerPerson(float[][] responses)
public void enterScoresAsRowPerPerson(int[][] responses)
public void enterScoresAsRowPerPerson(char[][] responses)
public void enterScoresAsRowPerPerson(boolean[][] responses)
public void enterScoresAsRowPerPerson(Matrix responses)
Enter responses
as rows per item
public void enterScoresAsRowPerItem(String[][] responses)
public void enterScoresAsRowPerItem(double[][] responses)
public void enterScoresAsRowPerItem(float[][] responses)
public void enterScoresAsRowPerItem(int[][] responses)
public void enterScoresAsRowPerItem(char[][] responses)
public void enterScoresAsRowPerItem(boolean[][] responses)
public void enterScoresAsRowPerItem(Matrix responses)
Enter title public void enterTitle(String title)
Enter item names public void enterItemNames(String[] itemNames)
Additional data entry options Suspend reading letters as numerals public void suspendLetterToNumeral()
public void letterToNumeral()
Dichotomous data pairs Reset numerical representation public void resetDichotomousYesTrue(double newYesTrue)
public void resetDichotomousNoFalse(double newNoFalse)
Get numerical representation public double getDichotomousYesTrue()
public double getDichotomousNoFalse()
Additional dichotomous data pairs public void additionalDichotomousPairs(String falseSign, String trueSign)
Missing response
('no response') handling
Deletions Persons public void setPersonDeletionPercentage(double percentage)
Items public void setItemDeletionPercentage(double percentage)
Replacements public void setMissingDataOption(int option)
Set the denominator
(variance, standard deviation etc.)
Set to n public void setDenominatortoN()
Set to n-1 public void setDenominatortoNminusOne()
Choice of matrix Covariance matrix public void useCovarianceMatrix()
Correlation matrix public void useCorrelationMatrix()
Parallel analysis options Random deviates public void useUniformDeviates()
public void useGaussianDeviates()
Number of simulations public void setNumberOfSimulations(int nSimul)
public int getNumberOfSimulations()
Percentile value public void setParallelAnalysisPercentileValue(double perCent)
public double getParallelAnalysisPercentileValue()
Full analysis Perform and output a full analysis public void analysis()
public void analysis(String filename)
Set output file type public void setOutputFileType(int option)
Set incremented numbering of the output file public void setFileNumbering()
Remove incremented numbering of the output file public void removeFileNumbering()
Set output precision public void numberOfDecimalPlaces(int trunc)
public void numberOfDecimalPlacesAll(int trunc)
Scree Plots Data and parallel analysis public void screePlot()
Data alone public void screePlotDataAlone()
Eigenvalues Data as calculated public double[] eigenValues()
ordered public double[] orderedEigenValues()
indices public int[] eigenValueIndices()
proportions (%) public double[] proportionPercentage()
cumulative % public double[] cumulativePercentage()
Parallel analysis all simulations public double[][] monteCarloEigenValues()
means public double[] monteCarloEigenMeans()
standard deviations public double[] monteCarloEigenStandardDeviations()
percentiles public double[] monteCarloEigenPercentiles()
Number of significant components Eigenvalues greater than or equal to unity public int nOneOrGreater()
Eigenvalues greater than the Monte Carlo means public int nMeanCrossover()
Eigenvalues greater than the Monte Carlo percentiles public int nPercentileCrossover()
Eigenvectors Data as calculated public double[][] eigenVectorsAsRows()
public double[][] eigenVectorsAsColumns()
ordered public double[][] orderedEigenVectorsAsRows()
public double[][] orderedEigenVectorsAsColumns()
Loading factors as rows public double[][] loadingFactorsAsRows()
as columns public double[][] loadingFactorsAsColumns()
Communalities   public double[] communalities()
Communality Weights   public double[] communalityWeights()
Covariance matrix   public Matrix covarianceMatrix()
Correlation matrix   public Matrix correlationMatrix()
Partial correlation matrix   public Matrix partialCorrelationMatrix()
KMO [Kaiser-Meyer-Olkin] Statistic   public double overallKMO()
  public double[] itemKMOs()
Bartlett Test of Sphericity Chi-Square public double chiSquareBartlett()
Probability public double probabilityBartlett()
Degrees of freedom public int dofBartlett()
X matrix   public Matrix xMatrix()
Transpose of the X matrix   public Matrix xMatrixTranspose()
Original data   public Matrix originalMatrix()
Varimax rotation Varimax settings convergence tolerance public void setVarimaxTolerance(double tolerance)
set maximum iterations public void setVarimaxMaximumIterations(int maximumIterations)
return iterations taken public int getVarimaxIterations()
Varimax option normal varimax public void useNormalVarimax()
raw varimax public void useRawVarimax()
return option used public String getVarimaxOption()
Perform rotation: instance methods default varimax public void varimaxRotation(int nExtracted)
normal varimax public void normalVarimaxRotation(int nExtracted)
raw varimax public void rawVarimaxRotation(int nExtracted)
Perform rotation: static methods normal varimax public static double[][] normalVarimaxRotation(double[][] loadinFactors, double[] communalityWeights)
public static double[][] normalVarimaxRotation(double[][] loadinFactors, double[] communalityWeights, double tolerance, int[] maximumIterations)
raw varimax public static double[][] rawVarimaxRotation(double[][] loadinFactors)
public static double[][] rawVarimaxRotation(double[][] loadinFactors, double tolerance, int[] maximumIterations)
transpose a matrix public static double[][] transposeMatrix(double[][] matrix)
Rotated eigenvalues ordered values public double[] rotatedEigenValues()
propotion (%) public double[] rotatedProportionPercentage()
cumulative % public double[] rotatedCumulativePercentage()
Rotated loading factors as rows public double[] rotatedLoadingFactorsAsRows()
as columns public double[] rotatedLoadingFactorsAsColumns()
Scatter plots Plot of item - item responses raw data public void rawItemItemPlot(String itemName1, String itemName2)
public void rawItemItemPlot(int itemIndex1, int itemIndex2)
standardized data public void standardizedItemItemPlot(String itemName1, String itemName2)
public void standardizedItemItemPlot(int itemIndex1, int itemIndex2)
Plot of item - mean of items responses raw data public void rawItemMeansPlot(String itemName)
public void rawItemMeansPlot(int itemIndex)
standardized data public void standardizedItemMeansPlot(String itemName)
public void standardizedItemMeansPlot(int itemIndex)
Delete an item delete by name public double[][] deleteItem(String itemName)
delete by index public double[][] deleteItem(int itemIndex)
Correlation coefficients Between all items Correlation coefficient matrix/td> public double[][] rawCorrelationCoefficients()
public double[][] standardizedCorrelationCoefficients()
Average correlation coefficient public double rawAverageCorrelationCoefficients()
public double standardizedAverageCorrelationCoefficients()
Average correlation coefficient
including item totals
public double rawAverageCorrelationCoefficientsWithTotals()
public double standardizedAverageCorrelationCoefficientsWithTotals()
Standard deviation of the correlation coefficients public double rawStandardDeviationCorrelationCoefficients()
public double standardizedStandardDeviationCorrelationCoefficients()
Standard deviation of the correlation coefficient
including item totals
public double rawStandardDeviationCorrelationCoefficientsWithTotals()
public double standardizedStandardDeviationCorrelationCoefficientsWithTotals()
Between pairs Item-item pair public double rawCorrelationCoefficient(String itemName1, String itemName2)
public double rawCorrelationCoefficient(int itemIndex1, int itemIndex2)
public double standardizedCorrelationCoefficient(String itemName1, String itemName2)
public double standardizedCorrelationCoefficient(int itemIndex1, int itemIndex2)
Item-(totals of the items) pair public double rawCorrelationCoefficient(String itemName)
public double rawCorrelationCoefficient(int itemIndex)
public double standardizedCorrelationCoefficient(String itemName)
public double standardizedCorrelationCoefficient(int itemIndex)
Covariances Between all items Covariance matrix/td> public double[][] rawCovariances()
public double[][] standardizedCovariances()
Between pairs Item-item pair public double rawCovariance(String itemName1, String itemName2)
public double rawCovariance(int itemIndex1, int itemIndex2)
public double standardizedCovariance(String itemName1, String itemName2)
public double standardizedCovariance(int itemIndex1, int itemIndex2)
Item-(totals of the items) pair public double rawCovariance(String itemName)
public double rawCovariance(int itemIndex)
public double standardizedCovariance(String itemName)
public double standardizedCovariance(int itemIndex)
Item means Mean values of all items Raw data public double[] rawItemMeans()
Standardized data public double[] standardizedItemMeans()
Mean value of an individual item Raw data public double rawItemMean(int index)
public double rawItemMean(String name)
Standardized data public double standardizedItemMean(int index)
public double standardizedItemMean(String name)
Mean value of all item means Raw data public double rawMeanOfItemMeans()
Standardized data public double standardizedMeanOfItemMeans()
Standard deviation of all item means Raw data public double rawStandardDeviationOfItemMeans()
Standardized data public double standardizedStandardDeviationOfItemMeans()
Variance of all item means Raw data public double rawVarianceOfItemMeans()
Standardized data public double standardizedVarianceOfItemMeans()
Maximum of all item means Raw data public double rawMaximumOfItemMeans()
Standardized data public double standardizedMaximumOfItemMeans()
Minimum of all item means Raw data public double rawMinimumOfItemMeans()
Standardized data public double standardizedMinimumOfItemMeans()
Range of all item means Raw data public double rawRangeOfItemMeans()
Standardized data public double standardizedRangeOfItemMeans()
Item standard deviations Standard deviations of all items Raw data public double[] rawItemStandardDeviations()
Standardized data public double[] standardizedItemStandardDeviations()
Standard deviation value of an individual item Raw data public double rawItemStandardDeviation(int index)
public double rawItemStandardDeviation(String name)
Standardized data public double standardizedItemStandardDeviation(int index)
public double standardizedItemStandardDeviation(String name)
Mean value of all item standard deviations Raw data public double rawMeanOfItemStandardDeviations()
Standardized data public double standardizedMeanOfItemStandardDeviations()
Standard deviation of all item standard deviations Raw data public double rawStandardDeviationOfItemStandardDeviations()
Standardized data public double standardizedStandardDeviationOfItemStandardDeviations()
Variance of all item standard deviations Raw data public double rawVarianceOfItemStandardDeviations()
Standardized data public double standardizedVarianceOfItemStandardDeviations()
Maximum of all item standard deviations Raw data public double rawMaximumOfItemStandardDeviations()
Standardized data public double standardizedMaximumOfItemStandardDeviations()
Minimum of all item standard deviations Raw data public double rawMinimumOfItemStandardDeviations()
Standardized data public double standardizedMinimumOfItemStandardDeviations()
Range of all item standard deviations Raw data public double rawRangeOfItemStandardDeviations()
Standardized data public double standardizedRangeOfItemStandardDeviations()
Item variances Variances of all items Raw data public double[] rawItemVariances()
Standardized data public double[] standardizedItemVariances()
Variance of an individual item Raw data public double rawItemVariance(int index)
public double rawItemVariance(String name)
Standardized data public double standardizedItemVariance(int index)
public double standardizedItemVariance(String name)
Mean value of all item variances Raw data public double rawMeanOfItemVariances()
Standardized data public double standardizedMeanOfItemVariances()
Standard deviation of all item variances Raw data public double rawVarianceOfItemVariances()
Standardized data public double standardizedVarianceOfItemVariances()
Variance of all item variances Raw data public double rawVarianceOfItemVariances()
Standardized data public double standardizedVarianceOfItemVariances()
Maximum of all item variances Raw data public double rawMaximumOfItemVariances()
Standardized data public double standardizedMaximumOfItemVariances()
Minimum of all item variances Raw data public double rawMinimumOfItemVariances()
Standardized data public double standardizedMinimumOfItemVariances()
Range of all item variances Raw data public double rawRangeOfItemVariances()
Standardized data public double standardizedRangeOfItemVariances()
Item maxima Maxima of all items Raw data public double[] rawItemMaxima()
Standardized data public double[] standardizedItemMaxima()
Maximum of an individual item Raw data public double rawItemMaximum(int index)
public double rawItemMaximum(String name)
Standardized data public double standardizedItemMaximum(int index)
public double standardizedItemMaximum(String name)
Mean value of all item maxima Raw data public double rawMeanOfItemMaxima()
Standardized data public double standardizedMeanOfItemMaxima()
Standard deviation of all item maxima Raw data public double rawVarianceOfItemMaxima()
Standardized data public double standardizedVarianceOfItemMaxima()
Variance of all item maxima Raw data public double rawVarianceOfItemMaxima()
Standardized data public double standardizedVarianceOfItemMaxima()
Maximum of all item maxima Raw data public double rawMaximumOfItemMaxima()
Standardized data public double standardizedMaximumOfItemMaxima()
Minimum of all item maxima Raw data public double rawMinimumOfItemMaxima()
Standardized data public double standardizedMinimumOfItemMaxima()
Range of all item maxima Raw data public double rawRangeOfItemMaxima()
Standardized data public double standardizedRangeOfItemMaxima()
Item minima Minima of all items Raw data public double[] rawItemMinima()
Standardized data public double[] standardizedItemMinima()
Minimum of an individual item Raw data public double rawItemMinimum(int index)
public double rawItemMinimum(String name)
Standardized data public double standardizedItemMinimum(int index)
public double standardizedItemMinimum(String name)
Mean value of all item minima Raw data public double rawMeanOfItemMinima()
Standardized data public double standardizedMeanOfItemMinima()
Standard deviation of all item minima Raw data public double rawVarianceOfItemMinima()
Standardized data public double standardizedVarianceOfItemMinima()
Variance of all item minima Raw data public double rawVarianceOfItemMinima()
Standardized data public double standardizedVarianceOfItemMinima()
Minimum of all item minima Raw data public double rawMinimumOfItemMinima()
Standardized data public double standardizedMinimumOfItemMinima()
Minimum of all item minima Raw data public double rawMinimumOfItemMinima()
Standardized data public double standardizedMinimumOfItemMinima()
Range of all item minima Raw data public double rawRangeOfItemMinima()
Standardized data public double standardizedRangeOfItemMinima()
Item ranges Ranges of all items Raw data public double[] rawItemRanges()
Standardized data public double[] standardizedItemRanges()
Range of an individual item Raw data public double rawItemRange(int index)
public double rawItemRange(String name)
Standardized data public double standardizedItemRange(int index)
public double standardizedItemRange(String name)
Mean value of all item ranges Raw data public double rawMeanOfItemRanges()
Standardized data public double standardizedMeanOfItemRanges()
Standard deviation of all item ranges Raw data public double rawVarianceOfItemRanges()
Standardized data public double standardizedVarianceOfItemRanges()
Variance of all item ranges Raw data public double rawVarianceOfItemRanges()
Standardized data public double standardizedVarianceOfItemRanges()
Minimum of all item ranges Raw data public double rawMinimumOfItemRanges()
Standardized data public double standardizedMinimumOfItemRanges()
Minimum of all item ranges Raw data public double rawMinimumOfItemRanges()
Standardized data public double standardizedMinimumOfItemRanges()
Range of all item ranges Raw data public double rawRangeOfItemRanges()
Standardized data public double standardizedRangeOfItemRanges()
Item medians Medians of all items Raw data public double[] rawItemMedians()
Standardized data public double[] standardizedItemMedians()
Median of an individual item Raw data public double rawItemMedian(int index)
public double rawItemMedian(String name)
Standardized data public double standardizedItemMedian(int index)
public double standardizedItemMedian(String name)
Mean value of all item medians Raw data public double rawMeanOfItemMedians()
Standardized data public double standardizedMeanOfItemMedians()
Standard deviation of all item medians Raw data public double rawVarianceOfItemMedians()
Standardized data public double standardizedVarianceOfItemMedians()
Variance of all item medians Raw data public double rawVarianceOfItemMedians()
Standardized data public double standardizedVarianceOfItemMedians()
Minimum of all item medians Raw data public double rawMinimumOfItemMedians()
Standardized data public double standardizedMinimumOfItemMedians()
Minimum of all item medians Raw data public double rawMinimumOfItemMedians()
Standardized data public double standardizedMinimumOfItemMedians()
Range of all item medians Raw data public double rawRangeOfItemMedians()
Standardized data public double standardizedRangeOfItemMedians()
Item totals Totals of all items Raw data public double[] rawItemTotals()
Standardized data public double[] standardizedItemTotals()
Total of an individual item Raw data public double rawItemTotal(int index)
public double rawItemTotal(String name)
Standardized data public double standardizedItemTotal(int index)
public double standardizedItemTotal(String name)
Mean value of all item totals Raw data public double rawMeanOfItemTotals()
Standardized data public double standardizedMeanOfItemTotals()
Standard deviation of all item totals Raw data public double rawVarianceOfItemTotals()
Standardized data public double standardizedVarianceOfItemTotals()
Variance of all item totals Raw data public double rawVarianceOfItemTotals()
Standardized data public double standardizedVarianceOfItemTotals()
Minimum of all item totals Raw data public double rawMinimumOfItemTotals()
Standardized data public double standardizedMinimumOfItemTotals()
Minimum of all item totals Raw data public double rawMinimumOfItemTotals()
Standardized data public double standardizedMinimumOfItemTotals()
Range of all item totals Raw data public double rawRangeOfItemTotals()
Standardized data public double standardizedRangeOfItemTotals()
Item Moment Skewness Moment skewness of all items Raw data public double[] rawItemMomentSkewnessess()
Standardized data public double[] standardizedItemMomentSkewnessess()
Moment skewness of an individual item Raw data public double rawItemMomentSkewness(int index)
public double rawItemMomentSkewness(String name)
Standardized data public double standardizedItemMomentSkewness(int index)
public double standardizedItemMomentSkewness(String name)
Item Median Skewness Median skewness of all items Raw data public double[] rawItemMedianSkewnessess()
Standardized data public double[] standardizedItemMedianSkewnessess()
Median skewness of an individual item Raw data public double rawItemMedianSkewness(int index)
public double rawItemMedianSkewness(String name)
Standardized data public double standardizedItemMedianSkewness(int index)
public double standardizedItemMedianSkewness(String name)
Item Quartile Skewness Quartile skewness of all items Raw data public double[] rawItemQuartileSkewnessess()
Standardized data public double[] standardizedItemQuartileSkewnessess()
Quartile skewness of an individual item Raw data public double rawItemQuartileSkewness(int index)
public double rawItemQuartileSkewness(String name)
Standardized data public double standardizedItemQuartileSkewness(int index)
public double standardizedItemQuartileSkewness(String name)
Item Excess Kurtosis Excess kurtoses of all items Raw data public double[] rawItemExcesskurtoses()
Standardized data public double[] standardizedItemExcesskurtoses()
Excess kurtosis of an individual item Raw data public double rawItemExcessKurtosis(int index)
public double rawItemExcessKurtosis(String name)
Standardized data public double standardizedItemExcessKurtosis(int index)
public double standardizedItemExcessKurtosis(String name)
Item Names and Indices   Names of the used items public String[] itemNames()
Item names as entered public String[] originalItemNames()
Deleted item names public String[] deletedItemNames()
Index of an item public int itemIndex(String name)
Name of an item public String itemName(int index)
Number of Items   Number of items used public int usedNumbeOfItems()
Number of items entered public int originalNumbeOfItems()
Number of items deleted public int numbeOfDeletedItems()
Person Means Mean values of all persons Raw data public double[] rawPersonMeans()
Standardized data public double[] standardizedPersonMeans()
Mean of an individual person Raw data public double rawPersonMean(int index)
Standardized data public double standardizedPersonMean(int index)
Person Standard Deviations Standard deviations of all persons Raw data public double[] rawPersonStandardDeviations()
Standardized data public double[] standardizedPersonStandardDeviations()
Standard deviation of an individual person Raw data public double rawPersonStandardDeviation(int index)
Standardized data public double standardizedPersonStandardDeviation(int index)
Person Variances Variances of all persons Raw data public double[] rawPersonVariances()
Standardized data public double[] standardizedPersonVariances()
Variance of an individual person Raw data public double rawPersonVariance(int index)
Standardized data public double standardizedPersonVariance(int index)
Person Maxima Maxima of all persons Raw data public double[] rawPersonMaxima()
Standardized data public double[] standardizedPersonMaxima()
Maximum of an individual person Raw data public double rawPersonMaximum(int index)
Standardized data public double standardizedPersonMaximum(int index)
Person Minima Minima of all persons Raw data public double[] rawPersonMinima()
Standardized data public double[] standardizedPersonMinima()
Minimum of an individual person Raw data public double rawPersonMinimum(int index)
Standardized data public double standardizedPersonMinimum(int index)
Person Ranges Ranges of all persons Raw data public double[] rawPersonRanges()
Standardized data public double[] standardizedPersonRanges()
Range of an individual person Raw data public double rawPersonRange(int index)
Standardized data public double standardizedPersonRange(int index)
Person Totals Totals of all persons Raw data public double[] rawPersonTotals()
Standardized data public double[] standardizedPersonTotals()
Total of an individual person Raw data public double rawPersonTotal(int index)
Standardized data public double standardizedPersonTotal(int index)
Person Indices   Indices of the used persons public String[] personIndices()
Deleted person indices public String[] deletedPersonsIndices()
Number of Persons   Number of Persons used public int usedNumberOfPersons()
Number of persons entered public int originalNumberOfPersons()
Number of persons deleted public int numbeOfDeletedPersons()
All responses Mean Raw data public double rawAllResponsesMean()
Standardized data public double standardizedAllResponsesMean()
Standard Deviation Raw data public double rawAllResponsesStandardDeviation()
Standardized data public double standardizedAllResponsesStandardDeviation()
Variance Raw data public double rawAllResponsesVariance()
Standardized data public double standardizedAllResponsesVariance()
Minimum Raw data public double rawAllResponsesMinimum()
Standardized data public double standardizedAllResponsesMinimum()
Maximum Raw data public double rawAllResponsesMaximum()
Standardized data public double standardizedAllResponsesMaximum()
Range Raw data public double rawAllResponsesRange()
Standardized data public double standardizedAllResponsesRange()
Total Raw data public double rawAllResponsesTotal()
Standardized data public double standardizedAllResponsesTotal()
Responses Original responses as entered public Object originalScores()
as row per item public double[][] originalScoresAsRowPerItem()
as row per person public double[][] originalScoresAsRowPerPerson()
Used responses (Raw data) as row per item public double[][] usedScoresAsRowPerItem()
as row per person public double[][] usedScoresAsRowPerPerson()
Used responses (Standardized data) as row per item public double[][] standardizedScoresAsRowPerItem()
as row per person public double[][] standardizedScoresAsRowPerPerson()
Replaced responses item name and person index of replacements public String[] indicesOfReplacedScores()
Number of responses original number public int originalTotalNumberOfScores()
number used public int usedTotalNumberOfScores()
number deleted public int numberOfDeletedScores()
number of missing responses replaced public int numberOfReplacedScores()




CONSTRUCTOR

public PCA()
Usage:                      PCA pca = new PCA();
Creates an instance of PCA.

ENTER DATA

The data may be read from a text file or entered via data arrays and Strings created within your program. The responses may be enetered as rows of responses per person or as rows of responses per item.

READ THE DATA FROM A TEXT FILE
The responses may be enetered as rows of responses per person or as rows of responses per item.

Read responses as rows per person

The responses may be read from a file of one of four formats:

Format A
readScoresAsRowPerPersonA

Title
Number of items
Number of persons
Row of item names
Matrix of scores arranged as rows
 starting with the person name
 then scores for that person
 with separators, e.g. space, comma.

details
Format B
readScoresAsRowPerPersonB

Title
Number of items
Number of persons
Row of item names
Row of person names
Matrix of scores arranged as
 row per person
 with separators, e.g. space, comma.

details
Format C
readScoresAsRowPerPersonC
Scores only

Matrix of scores arranged as
 row per person
 with separators, e.g. space, comma.

details
Format D
readScoresAsRowPerPersonD
Scores only

Matrix of single character scores arranged as
 row per person
 WITHOUT separators, e.g. 1101011

details
Replaced methods
readScoresAsRowPerPerson

Format A
public void readScoresAsRowPerPersonA()
public void readScoresAsRowPerPersonA(String filename)
Usage:                      pca.readScoresAsRowPerPersonA();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerPersonA(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataOne.txt".

The text file must be of the following format:

     data title
     number of items
     number of persons
     item names (one word each), as either a row or a column, e.g.    item1      item2  . . .   itemn
     name of person 1      response of person 1 to item 1      response of person 1 to item 2  . . .   response of person 1 to the nth item (all on one line)
     name of person 2      response of person 2 to item 1      response of person 2 to item 2  . . .   response of person 2 to the nth item (all on one line)
     . . .
     name of person m      response of person m to item 1      response of person m to item 2  . . .   response of person m to the nth item (all on one line)

where there are n items and m persons.
The item and person names must be single words. Each response may be a floating point number, an integer number, a single word or a single letter. The item names and responses may be separated from any preceding and/or any following number or word by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for a person must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataOneA.txt, using spaces as separators.
Example data file, ScoresDataTwoA.txt using spaces as separators with missing responses.
Example data file, ScoresDataThreeA.txt using commas as separators and spaces for missing responses.

Format B
public void readScoresAsRowPerPersonB()
public void readScoresAsRowPerPersonB(String filename)
Usage:                      pca.readScoresAsRowPerPersonB();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerPersonB(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataOne.txt".

The text file must be of the following format:

     data title
     number of items
     number of persons
     item names (one word each), as either a row or a column, e.g.    item1      item2  . . .   itemn
     person names (one word each), as either a row or a column, e.g.    person1      person2  . . .   personm
     response of person 1 to item 1      response of person 1 to item 2  . . .   response of person 1 to the nth item (all on one line)
     response of person 2 to item 1      response of person 2 to item 2  . . .   response of person 2 to the nth item (all on one line)
     . . .
     response of person m to item 1      response of person m to item 2  . . .   response of person m to the nth item (all on one line)

where there are n items and m persons.
The item and person names must be single words. Each response may be a floating point number, an integer number, a single word or a single letter. The item names and responses may be separated from any preceding and/or any following number or word by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for a person must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataOneB.txt, using spaces as separators.
Example data file, ScoresDataTwoB.txt using spaces as separators with missing responses.
Example data file, ScoresDataThreeB.txt using commas as separators and spaces for missing responses.

Format C
public void readScoresAsRowPerPersonC()
public void readScoresAsRowPerPersonC(String filename)
Usage:                      pca.readScoresAsRowPerPersonC();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerPersonC(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataOne.txt".

The text file must be of the following format:

     response of person 1 to item 1      response of person 1 to item 2  . . .   response of person 1 to the nth item (all on one line)
     response of person 2 to item 1      response of person 2 to item 2  . . .   response of person 2 to the nth item (all on one line)
     . . .
     response of person m to item 1      response of person m to item 2  . . .   response of person m to the nth item (all on one line)

where there are n items and m persons.
Each response may be a floating point number, an integer number, a single word or a single letter. The responses may be separated from any preceding and/or any following number by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for a person must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataOneC.txt, using spaces as separators.
Example data file, ScoresDataTwoC.txt using spaces as separators with missing responses.
Example data file, ScoresDataThreeC.txt using commas as separators and spaces for missing responses.

Format D
public void readScoresAsRowPerPersonD()
public void readScoresAsRowPerPersonD(String filename)
Usage:                      pca.readScoresAsRowPerPersonD();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerPersonD(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataOne.txt".

The text file must be of the following format:

     response of person 1 to item 1      response of person 1 to item 2  . . .   response of person 1 to the nth item (all on one line)
     response of person 2 to item 1      response of person 2 to item 2  . . .   response of person 2 to the nth item (all on one line)
     . . .
     response of person m to item 1      response of person m to item 2  . . .   response of person m to the nth item (all on one line)

where there are n items and m persons.
Each response may be a single character, i.e. a single digit number or a single alphabetic character. The responses should NOT be separated from the preceding and/or following response by a searotor. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any letter not listed above as a valid response.
Example data file, ScoresDataOneD.txt.

Replaced methods
public void readScoresAsRowPerPerson()
public void readScoresAsRowPerPerson(String filename)
The above format A to format D methods replace the original read from file methods, readScoresAsRowPerPerson() and readScoresAsRowPerPerson(filename). The older methods have been retained for compatibility purposes and their documentation may be accessed by clicking Scores - replaced methods.

Read responses as rows per item

The responses may be read from a file of one of four formats:

Format A
readScoresAsRowPerItemA

Title
Number of items
Number of persons
Row of item names
Matrix of scores arranged as rows
 starting with the item name
 then scores for that item
 with separators, e.g. space, comma.

details
Format B
readScoresAsRowPerItemB

Title
Number of items
Number of persons
Row of item names
Row of person names
Matrix of scores arranged as
 row per item
 with separators, e.g. space, comma.

details
Format C
readScoresAsRowPerItemC
Scores only

Matrix of scores arranged as
 row per item
 with separators, e.g. space, comma.

details
Format D
readScoresAsRowPerItemD
Scores only

Matrix of single character scores arranged as
 row per item
 WITHOUT separators, e.g. 1101011

details
Replaced methods
readScoresAsRowPerItem

Format A
public void readScoresAsRowPerItemA()
public void readScoresAsRowPerItemA(String filename)
Usage:                      pca.readScoresAsRowPerItemA();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerItemA(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataTwo.txt".

The text file must be of the following format:

     data title
     number of items
     number of persons
     person names (one word each), as either a row or a column, e.g.    person1      person2  . . .   personm
     name of item 1      response to item 1 by person 1      response to item 1 by person 2  . . .   response to item 1 by the mth person (all on one line)
     name of item 2      response to item 2 by person 1      response to item 2 by person 2  . . .   response to item 2 by the mth person(all on one line)
     . . . .
     name of item n      response to item n by person 1      response to item n by person 2  . . .   response to item n by the mth person (all on one line)

where there are n items and m persons.
The item and person names must be single words. Each response may be a floating point number, an integer, a single word or a single letter. The item names and responses may be separated from any preceding and/or any following number or word by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for an item must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataFourA.txt, using spaces as separators.
Example data file, ScoresDataFiveA.txt using spaces as separators with missing responses.
Example data file, ScoresDataSixA.txt using commas as separators and spaces for missing responses.

Format B
public void readScoresAsRowPerItemB()
public void readScoresAsRowPerItemB(String filename)
Usage:                      pca.readScoresAsRowPerItemB();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerItemB(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataTwo.txt".

The text file must be of the following format:

     data title
     number of items
     number of persons
     item names (one word each), as either a row or a column, e.g.    item1      item2  . . .   itemn
     person names (one word each), as either a row or a column, e.g.    person1      person2  . . .   personm
     response to item 1 by person 1      response to item 1 by person 2  . . .   response to item 1 by the mth person (all on one line)
     response to item 2 by person 1      response to item 2 by person 2  . . .   response to item 2 by the mth person(all on one line)
     . . . .
     response to item n by person 1      response to item n by person 2  . . .   response to item n by the mth person (all on one line)

where there are n items and m persons.
The item names must be single words. Each response may be a floating point number, an integer, a single word or a single letter. The item names and responses may be separated from any preceding and/or any following number or word by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for an item must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataFourB.txt, using spaces as separators.
Example data file, ScoresDataFiveB.txt using spaces as separators with missing responses.
Example data file, ScoresDataSixB.txt using commas as separators and spaces for missing responses.

Format C
public void readScoresAsRowPerItemC()
public void readScoresAsRowPerItemC(String filename)
Usage:                      pca.readScoresAsRowPerItemC();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerItemC(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataTwo.txt".

The text file must be of the following format:

     response to item 1 by person 1      response to item 1 by person 2  . . .   response to item 1 by the mth person (all on one line)
     response to item 2 by person 1      response to item 2 by person 2  . . .   response to item 2 by the mth person(all on one line)
     . . . .
     response to item n by person 1      response to item n by person 2  . . .   response to item n by the mth person (all on one line)

where there are n items and m persons.
The item names must be single words. Each response may be a floating point number, an integer, a single word or a single letter. The item names and responses may be separated from any preceding and/or any following number or word by a single space or several spaces, a comma, a tab, a semicolon, colon or end of line. All responses for an item must be on the same line. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any word or letter, prefereably a word, e.g. abs or missing, not listed above as a valid response. If it is represented by a space that space MUST be preceded and followed by a comma, a tab, a semicolon, colon or end of line.
Example data file, ScoresDataOneC.txt, using spaces as separators.
Example data file, ScoresDataTwoC.txt using spaces as separators with missing responses.
Example data file, ScoresDataThreeC.txt using commas as separators and spaces for missing responses.

Format D
public void readScoresAsRowPerItemD()
public void readScoresAsRowPerItemD(String filename)
Usage:                      pca.readScoresAsRowPerItemD();
The data is read from a text (.txt) file selected via a dialogue window that will display all directories, and their files, on the user's computer and which opens, displaying the current directory, when this method is called.

Usage:                      pca.readScoresAsRowPerItemD(filename);
The data is read from the text (.txt) file filename. The file name must include its extension, e.g. .txt. It must either be in the working directory or the file name filename must also include the path to the appropriate directory, e.g. "C:\\AnalysisPrograms\\ScoresAnalyses\\ScoresDataTwo.txt".

The text file must be of the following format:

     response to item 1 by person 1      response to item 1 by person 2  . . .   response to item 1 by the mth person (all on one line)
     response to item 2 by person 1      response to item 2 by person 2  . . .   response to item 2 by the mth person(all on one line)
     . . . .
     response to item n by person 1      response to item n by person 2  . . .   response to item n by the mth person (all on one line)

where there are n items and m persons.
Each response may be a single character, i.e. a single digit number or a single alphabetic character. The responses should NOT be separated from the preceding and/or following response by a searotor. The following list shows how the recognized non-numerical responses will be converted to a numeric format.
* See
Resetting dichotomous pair representation for methods that reset the half-pair values of dichotomous pairs, e.g. for converting YES and NO to 1 and 0.
See additionalDichotomousPairs() for setting the option of reading dichotomous data with a non-numerical dichotomous pair not listed above.
A missing response may be represented by any letter not listed above as a valid response.
Example data file, ScoresDataOneD.txt.

Replaced methods
public void readScoresAsRowPerItem()
public void readScoresAsRowPerItem(String filename)
The above format A to format D methods replace the original read from file methods, readScoresAsRowPerItem() and readScoresAsRowPerItem(filename). The older methods have been retained for compatibility purposes and their documentation may be accessed by clicking Scores - replaced methods.




ENTER DATA VIA PROGRAM ARRAYS AND STRINGS
The responses may be enetered as rows of responses per person or as rows of responses per item.

Enter responses as rows per person
public void enterScoresAsRowPerPerson(String[][] responses)
public void enterScoresAsRowPerPerson(double[][] responses)
public void enterScoresAsRowPerPerson(float[][] responses)
public void enterScoresAsRowPerPerson(int[][] responses)
public void enterScoresAsRowPerPerson(char[][] responses)
public void enterScoresAsRowPerPerson(boolean[][] responses)
public void enterScoresAsRowPerPerson(Matrix responses)
Usage:                      pca.enterScoresAsRowPerPerson(responses);
The responses are entered via the two-dimension al array, responses. The array must be ordered in the following manner:

     responses[0][0] - response of person 1 to item 1      responses[0][1] - response of person 1 to item 2  . . .   responses[0][n-1] - response of person 1 to the nth item
     responses[1][0] - response of person 2 to item 1      responses[1][1] - response of person 1 to item 2  . . .   responses[1][n-1] - response of person 2 to the nth item
     . . . .
     responses[m-1][0] - response of person m to item 1      responses[m-1][1] - response of person m to item 2  . . .   responses[m-1][n-1] - response of person m to the nth item
where there are n items and m persons.
The allowed formats of the responses depends on the type of the array:

Enter responses as rows per item
public void enterScoresAsRowPerItem(String[][] responses)
public void enterScoresAsRowPerItem(double[][] responses)
public void enterScoresAsRowPerItem(float[][] responses)
public void enterScoresAsRowPerItem(int[][] responses)
public void enterScoresAsRowPerItem(char[][] responses)
public void enterScoresAsRowPerItem(boolean[][] responses)
public void enterScoresAsRowPerItem(Matrix responses)
Usage:                      pca.enterScoresAsRowPerItem(responses);
The responses are entered via the two-dimension al array, responses. The array must be ordered in the following manner:

     responses[0][0] - response to item 1 of person 1      responses[0][1] - response to item 1 of person 2  . . .   responses[0][m-1] - response to item 1 of the mth person
     responses[1][0] - response to item 2 of person 1      responses[1][1] - response to item 2 of person 2  . . .   responses[1][m-1] - response to item 2 of the mth person
     . . . .
     responses[n-1][0] - response to item n of person 1      responses[n-1][1] - response to item n of person 2  . . .   responses[n-1][m-1] - response to item n of the mth person
where there are n items and m persons.
The allowed formats of the responses depends on the type of the array:



ENTER TITLE
public void enterTitle(String title)
Usage:                      pca.enterTitle(title)
This is an optional method, for use if the responses have been entered via an array within your program. The data title is entered via the String argument title. A second line,
  Program execution initiated at the time on the date
will be automatically added to the entered title. This title is used as a header to the analysis output files.
If this method is not called, and the responses have been entered via an array within your program, a default title,
  Untitled PCA Analysis
  Program execution initiated at the time on the date
will be created.



ITEM NAMES
Enter the item names
public void enterItemNames(String[] names)
Usage:                      pca.enterItemNames(names)
This is an optional method, for use if the responses have been entered via an array within your program. The item names are entered via the String[] argument names. It is suggested that you use short single word descriptors as these names are used as column headers in the analysis output files.
If this method is not called, and the responses have been entered via an array within your program, an array of default names,
  item1,  item2,  item3,  item4 . . .
will be created.

Get all the entered item names
public String[] originalItemNames()
Usage:                      itemNames = pca.originalItemNames()
This method returns the item names of all the items entered, i.e. before any item deletions have been made.

Get all the item names used
public String[] itemNames()
Usage:                      itemNames = pca.itemNames()
This method returns the item names of the items used, i.e. after any item deletions have been made.

Get an person used item name
public String itemNames(int index)
Usage:                      itemName = pca.itemNames(index)
This method returns the item name of the item with the index index. NOTE!! the indices of the items starts at 1 NOT at 0.

Get the index of an item
public int itemIndex(String itemName)
Usage:                      index = pca.itemIndex(itemName)
This method returns the index of the item named itemName. NOTE!! the indices of the items starts at 1 NOT at 0.



ADDITIONAL DATA ENTRY OPTIONS

SUSPEND READING LETTERS AS NUMERALS
Suspeding the alphabetic to numerical conversion
public void suspendLetterToNumeral()
Usage:                      pca.suspendLetterToNumeral()
The default option of this class (since 18 November 2010) is that alphabetic responses are converted to numerical responses (See read and enter methods above for conversion details). Calling this method suspends these conversions.

Restoring the alphabetic to numerical conversion
public void letterToNumeral()
Usage:                      pca.letterToNumeral()
The method restores the conversion of alphabetic responses to numerical responses (See read and enter methods above for conversion details). It need only be called if such conversions have been suspended (see method immediately above) and need restoring.



DICHOTOMOUS DATA PAIRS

Reset Dichotomous Data Pair Numerical Representation
public void resetDichotomousYesTrue(double newYesTrue)
Usage:                      pca.resetDichotomousYesTrue(newYesTrue)
This method resets the numerical representation of the dichotomous half-pair responses, e.g. true, True, TRUE, yes, Yes, YES, y and Y, to the value passed as the argument newYesTrue. The default value is 1.

public void resetDichotomousNoFalse(double newNoFalse)
Usage:                      pca.resetDichotomousNoFalse(NoFalse)
This method resets the numerical representation of the dichotomous half-pair responses, e.g. false, false, FALSE, no, No, NO, n and N, to the value passed as the argument newNoFalse. The default value is -1.

Get the Dichotomous Data Pair Numerical Representations
public double getDichotomousYesTrue()
Usage:                      yvalue = pca.getDichotomousYesTrue()
This method returns the numerical value used to represent the dichotomous half-pair Yes, yes, Yes, Y, y, True, TRUE, True or any added equivalent.

public double getDichotomousNoFalse()
Usage:                      nvalue = pca.getDichotomousNoFalse()
This method returns the numerical value used to represent the dichotomous half-pair no, No, NO, n , N, false, false, FALSE or any added equivalent.

Additional Dichotomous Data Pairs
public void additionalDichotomousPairs(String falseSign, String trueSign)
Usage:                      pca.additionalDichotomousPairs(falseSign, trueSign)
This method should be called if you wish any of the above appropriate response entry methods to read dichotomous data in which the dichotomous pair is not one of the pairs already recognized by this class. The recognized pairs are (true, True or TRUE)/(false, false or FALSE), (yes, Yes, YES, y or Y)/(no, No, NO, n or N) or any numerical pair. If your pair is not one of the recognized pair enter the pair via the arguments falseSign and trueSign. Responses equal to the argument falseSign, on data processing, will be converted to -1 [default value] and those equal to trueSign will be converted to 1 [default value]. See immediately above for methods that can be called to alter the true/yes and false/no default values. This additionalDichotomousPairs method may be called if the data has been or will be read in from a text file or has been or will be entered via a String[][] array or a char[][] array.

The method public void otherDichotomousData(String falseSign, String trueSign) performs the same function as public void additionalDichotomousPairs(String falseSign, String trueSign).



MISSING RESPONSES

Missing responses ('no responses'), i.e. the failure of an person to respond to an item, may be dealt with by replacement (replacement options below), deletion of the person or deletion of an item.

DELETIONS
Persons
public void setPersonDeletionPercentage(double percentage)
Usage:                      pca.setPersonDeletionPercentage(percentage)
This method allows the setting of the percentage of 'no responses' associated with a person at which all the responses of that person will be deleted. The required percentage is entered via the argument percentage. A value of 0.0 will ensure that an person is deleted if that person misses just 1 response. A value of 100.0 ensures that no person will be deleted. The default value, i.e. the value used if this method is not called, is 0.0. Missing responses that are not deleted will be replaced (see setMissingDataOption for replacement options).

Items
public void setItemDeletionPercentage(double percentage)
Usage:                      pca.setItemDeletionPercentage(percentage)
This method allows the setting of the percentage of 'no responses' associated with an item at which all the responses of that item will be deleted. The required percentage is entered via the argument percentage. A value of 0.0 will ensure that an item is deleted if it contains only 1 missing response. A value of 100.0 ensures that no item will be deleted. The default value, i.e. the value used if this method is not called, is 100.0. Missing responses that are not deleted will be replaced (see setMissingDataOption for replacement options).

REPLACEMENTS
public void setMissingDataOption(int option)
Usage:                      pca.setMissingData(Optionoption)
This method allows a choice of the replacement procedure for missing responses that have not been deleted. The option choice is entered as the integer argument option. There are 5 options:
The default option, i.e. the option used if this method is not called, is option 3. See deletions for deletion options.



SETTING THE DENOMINATOR

public void setDenominatorToN()
Usage:                      pca.setDenominatorToN();
Sets the denominator of the calculated variances, covariances, standard deviations, moment skewnesses, median skewnesses or kurtoses to the number of data points, n, e.g. a standard deviation will be calculated as

The default value of the denominator is (n − 1),

public void setDenominatorToNminusOne()
Usage:                      pca.setDenominatorToNminusOne();
Sets the denominator of the calculated variances, covariances, standard deviations, moment skewnesses, median skewnesses or kurtoses to the number of data points minus one, (n−1), e.g. a standard deviation will be calculated as

The is the default value and this method need only be called in the above method (set to n) as already been called and a reset to (n − 1) is required





CHOICE OF MATRIX

Covariance matrix
public void useCovarianceMatrix()
Usage:                      pca.useCovarianceMatrix();
Calling this method sets the covariance matrix as the matrix whose eigenvalues and eigenvectors are found by the principal component analysis.

Correlation matrix
public void useCorrelationMatrix()
Usage:                      pca.useCorrelationMatrix();
Calling this method sets the correlation matrix as the matrix whose eigenvalues and eigenvectors are found by the principal component analysis. This is the default option of this class.



PARALLEL ANALYSIS OPTIONS

Random deviates
The Monte Carlo parallel analysis performs
a large number of of simulations of the principal component analysis each time replacing the real data with random numbers. These numbers may be uniform random deviates or Gaussian random deviates.
public void useUniformDeviates()
public void useGaussianDeviates()
Usage:                      pca.useUniformDeviates();
This method sets the random number generator to one generating uniform random deviates. This is the default option.

Usage:                      pca.useGaussianDeviates();
This method sets the random number generator to one generating Gaussian random deviates (normal random deviates).

Number of simulations
public void setNumberOfSimulations(int nSimul)
public int getNumberOfSimulations()
Usage:                      pca.setNumberOfSimulations(nSimul);
This method resets the number of simulations used in the Monte Carlo parallel analysis to the argument nSimul. The default value is 200.

Usage:                      nSimul = pca.getNumberOfSimulations();
This method returns the number of simulations used in the Monte Carlo parallel analysis.

Percentiles
public void setParallelAnalysisPercentileValue(double perCent)
public double getParallelAnalysisPercentileValue()
Usage:                      pca.setParallelAnalysisPercentileValue(percent);
This method resets the the percentile value, used in choosing the number of components to be extracted by comparing the data eigenvalues and the Monte Carlo parallel analysis eigenvalue percentiles, to the argument percent. The default value is 95 percent.

Usage:                      percent = pca.getParallelAnalysisPercentileValue();
This method returns the the percentile value used in choosing the number of components to be extracted by comparing the data eigenvalues and the Monte Carlo parallel analysis eigenvalue percentiles.



FULL ANALYSIS WITH OUTPUT TO A FILE

Perform analysis and output the results to a file
public void analysis(String filename)
public void analysis()
Usage:                      pca.analysis(filename)
This method performs a full analysis with scree plot display (details below) and writes the results to a text file named filename.
If you add the ".txt" extension to the name in the the String filename the results will be written to a text file that displays the results in an easily readable format.
If you add the ".xls" extension, the results are written in a format to facilitate display by Microsoft Excel. On opening, with Microsoft Excel, a ".xls" file created by this method Microsoft Excel may ask you to verify that file is Excel readable. Click the "yes" button in the query box.
The output file will be created in the directory in which you are working unless you add a path to filename, e.g. "C:\\AnalysisPrograms\\PCAAnalyses\\PCAOutputOne.txt".
See setFileNumbering() for option of adding an incremented number to the filename to prevent overwriting of files.

Usage:                      pca.analysis()
This method performs a full analysis with scree plot display (details below) and writes the results to a text file named PCAOutput. The default option of this method is to write to a text file that displays the results in an easily readable format. Calling the method setOutputFileType(option) allows this option to be changed to one in which the results are written in a format to facilitate display by Microsoft Excel. On opening, with Microsoft Excel, a ".xls" file created by this method Microsoft Excel may ask you to verify that file is Excel readable. Click the "yes" button in the query box.

A scree plot is displayed, in both methods, showing:
It is accompanied by a dialogue box requesting the number of factors to be extracted

The output file will be created in the directory in which you are working.
See setFileNumbering() for option of adding an incremented number to the filename to prevent overwriting of files.

The output file will contain the following:

Set output file type
public void setOutputFileType(int option)
Usage:                      pca.setOutputFileType(option)
This method allows the setting of the type of the output file. There are two options set by the argument option:

Set incremental numbering of output filename to prevent overwriting
public void setFileNumbering()
Usage:                      pca.setFileNumbering()
If this optional method is called a integer number will be added to the output file name. On the first creation of a file of the given file name the number will be 1. On further creations of a file of the same given file name the number will be incremented by 1 thus prevention overwriting of the file.

Remove incremental numbering of output filename
public void removeFileNumbering()
Usage:                      pca.removeFileNumbering()
If this method is called the incremental numbering of the output file, described in setFileNumbering() above, is removed.

Set the precision with which floating point numbers are written
public void numberOfDecimalPlaces(int trunc)
Usage:                      pca.numberOfDecimalPlaces(trunc)
This optional method sets the number of places displayed after the decimal point when floating point numbers are written to an output file. The number of places required is entered via the argument trunc. The default value is 6. The displayed number is the rounded equivalent of the stored number. If the precision of the entered data is greater than the value trunc the output method overides the trunc value and uses the maximum precision of the entered data. See immediately below (numberOfDecimalPlacesAll) for a method that sets the output precision irrespective of the input precision.

public void numberOfDecimalPlacesAll(int trunc)
Usage:                      pca.numberOfDecimalPlacesAll(trunc)
This optional method sets the number of places displayed after the decimal point when floating point numbers are written to an output file. The number of places required is entered via the argument trunc. The default value is 6. The displayed number is the rounded equivalent of the stored number. The precision set by this method is used in the output irrespective of the precision of the input data. See immediately above (numberOfDecimalPlaces) for a method that sets takes the precision of the entered data into account.



SCREE PLOTS

Data and parallel analysis scree Plot
public void screePlot()
Usage:                      pca.screePlot()
This method displays the following scree plots on one graph:
Data alone scree plot
public void screePlotDataAlone()
Usage:                      pca.screePlotDataAlone()
This method displays the scree plot of the data eigenvalues only.



EIGENVALUES

DATA EIGENVALUES
Data eigenvalues as calculated
public double[] eigenValues()
Usage:                      eigenvalues = pca.eigenValues()
This method returns all the eigenvalues as calculated. See below for ordered eigenvalues.

Ordered data eigenvalues
public double[] orderedEigenValues()
Usage:                      eigenvalues = pca.orderedEigenValues()
This method returns all the eigenvalues sorted into a descending order.

Eigenvalue indices
public int[] eigenValueIndices()
Usage:                      indices = pca.eigenValueIndices()
This method returns the indices of the eigenvalues before they were sorted into a descending order.

Eigenvalue proportions as a percentage
public double[] proportionPercentage()
Usage:                      prop = pca.proportionPercentage()
This method returns the eigenvalues sorted into a descending order and expressed as a percentage of the total of all the eigenvalues.

Eigenvalue proportions as a cumulative percentage
public double[] cumulativePercentage()
Usage:                      cumul = pca.cumulativePercentage()
This method returns the eigenvalues sorted into a descending order and expressed as a cumulative percentage of the total of all the eigenvalues.

PARALLEL ANALYSIS EIGENVALUES
Eigenvalues from all simulations
public double[][] monteCarloEigenValues()
Usage:                      simuleigenvalues = pca.monteCarloEigenValues()
This method returns all the eigenvalues for all the simulations. Each row contains the eigenvalues, in descending order, for an individual simulation.

Means of the ordered eigenvalues from all simulations
public double[] monteCarloEigenMeans()
Usage:                      simulmeans = pca.monteCarloEigenMeans()
This method returns the means of the ordered eigenvalues for all the simulations.

Standard deviations of the ordered eigenvalues from all simulations
public double[] monteCarloEigenStandardDeviations()
Usage:                      simulsds = pca.monteCarloEigenStandardDeviations()
This method returns the standard deviations of the ordered eigenvalues for all the simulations.

Percentiles of the ordered eigenvalues from all simulations
public double[] monteCarloEigenPercentiles()
Usage:                      simulpc = pca.monteCarloEigenPercentiles()
This method returns the percentiless of the ordered eigenvalues for all the simulations. The default value percenyile is a 95% percentile. See
percentile value for restting the percentile value.



NUMBER OF SIGNIFICANT COMPONENTS

public int nOneOrGreater()
public int nMeanCrossover()
public int nPercentileCrossover()
Usage:                      nSignificant = pca.nOneOrGreater()
This method returns the number of unrotated eigenvalues with values greater than or equal to unity.

Usage:                      nSignificant = pca.nMeanCrossover()
This method returns the number of unrotated eigenvalues with values greater than the corresponding means of the eigenvalues obtained from the Monte Carlo simulations using random data sets.

Usage:                      nSignificant = pca.nPercentileCrossover()
This method returns the number of unrotated eigenvalues with values greater than the corresponding percentiles of the eigenvalues obtained from the Monte Carlo simulations using random data sets. The default percentile is a 95% percentile. See set percentile for a method that resets the percentile to a user supplied value.



EIGENVECTORS

DATA EIGENVECTORS
Data eigenvectors as calculated
public double[][] eigenVectorsAsRows()
public double[][] eigenVectorsAsColumns()
Usage:                      eigenvectors = pca.eigenVectorsAsRows()
This method returns all the eigenvectors as calculated with each eigenvector corresponding to an eigenvalue returned as a row. See below for ordered eigenvectors.

Usage:                      eigenvectors = pca.eigenVectorsAsColumns()
This method returns all the eigenvectors as calculated with each eigenvector corresponding to an eigenvalue returned as a column. See below for ordered eigenvectors.

Ordered data eigenvectors
public double[][] orderedEigenVectorAsRows()
public double[][] orderedEigenVectorAsColumns()
Usage:                      eigenvectors = pca.orderedEigenVectorsAsRows()
This method returns all the eigenvectors sorted to match a descending order of the corresponding eigenvalues. Each eigenvector corresponding to an eigenvalue returned as a row.

Usage:                      eigenvectors = pca.orderedEigenVectorsAsColumnss()
This method returns all the eigenvectors sorted to match a descending order of the corresponding eigenvalues. Each eigenvector corresponding to an eigenvalue returned as a column.



LOADING FACTORS

public double[][] loadingFactorsAsRows()
public double[][] loadingFactorsAsColumns()
Usage:                      loadingFactors = pca.loadingFactorsAsRows()
This method returns all the loading factors with loading factors corresponding to an eigenvalue returned as a row. Loading factors are calculated by multiplying the corresponding eigenvector by the square root of the relevant eigenvalue.

Usage:                      eigenvectors = pca.loadingFactorsAsColumns()
This method returns all the loading factors with loading factors corresponding to an eigenvalue returned as a column. Loading factors are calculated by multiplying the corresponding eigenvector by the square root of the relevant eigenvalue.



COMMUNALITIES

public double[] communalities()
Usage:                      communalities = pca.communalities()
This method returns all the communalities, hi2, where

bi,j are the loading factors (as rows) and n is the number of items. The communality, h12, is returned as the array element communalities[0], h22, as communalities[1] etc.



COMMUNALITY WEIGHTS

public double[] communalityWeights()
Usage:                      weights = pca.communalityWeights()
This method returns all the communality weights, hi, where

bi,j are the loading factors (as rows) and n is the number of items. The communality weight, h1, is returned as the array element weight[0], h2, as weight[1] etc.
If a raw varimax rotation is used the communality weights used will all be set to unity.



VARIMAX ROTATION

VARIMAX SETTINGS
public void setVarimaxTolerance(double tolerance)
public void setVarimaxMaximumIterations(int maximumIterations)
public int getVarimaxIterations()

Usage:                      pca.setVarimaxTolerance(tolerance)
This method sets the tolerance used to determine whether the maximization iteration in the varimax rotation has converged, i.e. whether two successve complete sets of pairwise rotations give values of the varimax criterion (see
V below) that differ by less than the tolerance. The default value of the tolerance is 0.0001.

Usage:                      pca.setVarimaxMaximumIterations(maximumIterations)
This method sets the maximum number of iterations allowed by the maximization iteration in the varimax rotation. The default value is 1000. If this value is reached the current estimates of the rotated factors are returned.

Usage:                      iterations = pca.getVarimaxIterations()
This method returns the number of iterations used in the maximization iteration in the varimax rotation..

VARIMAX OPTIONS
public void useNormalVarimax()
public void useRawVarimax()
public String getVarimaxOption()
Usage:                      pca.useNormalVarimax()
This method sets the varimax option to that of the normal varimax criterion, i.e. the varimax criterion including weighting by the square roots of the relevant commmunalities; a rotation that maximizes

where bjp are the rotated loading factors for the m extracted factors and the n items and hj2 is the communality of the jth item taken over the m extracted factors.

Usage:                      pca.useRawVarimax()
This method sets the varimax option to that of the raw varimax criterion, i.e. the varimax criterion with NO weighting by the square roots of the relevant commmunalities; a rotation that maximizes

where bjp are the rotated loading factors for the m extracted factors and the n items.

Usage:                     option = pca.getNormalVarimax()
Returns the varimax option that is set as the default option, i.e. either "normal varimax option" or "raw varimax option".

PERFORM ROTATION
Instance methods
public void varimaxRotation(int nExtracted)
public void normalVarimaxRotation(int nExtracted)
public void rawVarimaxRotation(int nExtracted)
Usage:                      pca.varimaxRotation(nExtracted)
This method performs a varimax rotation on the nExtracted factors. The nExtracted factors are chosen as those with the nExtracted highest corrseponding unrotated eigenvalues. The varimax criterion option used is the default value, a normal varimax rotation if not reset, or the option reset by one of the methods described
above.

Usage:                      pca.normalVarimaxRotation(nExtracted)
This method performs a varimax rotation on the nExtracted factors. The nExtracted factors are chosen as those with the nExtracted highest corrseponding unrotated eigenvalues. The varimax criterion option used is the normal varimax rotation irrespective of the instance's default option.

Usage:                      pca.rawVarimaxRotation(nExtracted)
This method performs a varimax rotation on the nExtracted factors. The nExtracted factors are chosen as those with the nExtracted highest corrseponding unrotated eigenvalues. The varimax criterion option used is the raw varimax rotation irrespective of the instance's default option.

Static methods
Static methods for performing a varimax rotation on a user supplied matrix are also provided.
public static double[][] normalVarimaxRotation(double[][] loadinFactors, double[] communalityWeights)
public static double[][] normalVarimaxRotation(double[][] loadinFactors, double[] communalityWeights, double tolerance, int[] maximumIterations)
public static double[][] rawVarimaxRotation(double[][] loadinFactors)
public static double[][] rawVarimaxRotation(double[][] loadinFactors, double tolerance, int[] maximumIterations)
public static double[][] transposeMatrix(double[][] matrix)
Usage:                      rotatedFactors = PCA.normalVarimaxRotation(loadingFactors, communalityWeights)
This method performs a
normal varimax rotation on the matrix loadingFactors factors. The communality weights, communalityWeights should be the sum of the squares of the relevant loading factors. The rotated factors are returned as rotatedFactors. The loading factors must be entered as a loadings for a given factor as a row of the matrix. See transpose a matrix if your data has the factors arranged as columns. Default values of 0.0001 and 1000 are used for the tolerance and maximum number of iterations in the varimax iteration.

Usage:                      rotatedFactors = PCA.normalVarimaxRotation(loadingFactors, communalityWeights, tolerance, maximumIterations)
This method performs a normal varimax rotation on the matrix loadingFactors factors. The communality weights, communalityWeights should be the sum of the squares of the relevant loading factors. The rotated factors are returned as rotatedFactors. The loading factors must be entered as a loadings for a given factor as a row of the matrix. See transpose a matrix if your data has the factors arranged as columns. The tolerance and maximum number of iterations in the varimax iteration are supplied as the arguments tolerance and maximumIterations.

Usage:                      rotatedFactors = PCA.rawVarimaxRotation(loadingFactors)
This method performs a raw varimax rotation on the matrix loadingFactors factors. The rotated factors are returned as rotatedFactors. The loading factors must be entered as a loadings for a given factor as a row of the matrix. See transpose a matrix if your data has the factors arranged as columns. Default values of 0.0001 and 1000 are used for the tolerance and maximum number of iterations in the varimax iteration.

Usage:                      rotatedFactors = PCA.rawVarimaxRotation(loadingFactors, tolerance, maximumIterations)
This method performs a raw varimax rotation on the matrix loadingFactors factors. The rotated factors are returned as rotatedFactors. The loading factors must be entered as a loadings for a given factor as a row of the matrix. See transpose a matrix if your data has the factors arranged as columns. The tolerance and maximum number of iterations in the varimax iteration are supplied as the arguments tolerance and maximumIterations.

Usage:                      transpose = PCA.transposeMatrix(matrix)
This method returns the transpose of the matrix matrix. This methd is included for easy conversion of data stored as loading factors per item as matrix columns to a matrix with loading factors per item stored as rows. See
Matrix class for full class of matrix manipulations.

ROTATED EIGENVALUES
public double[] rotatedEigenValues()
public double[] rotatedProportionPercentage()
public double[] rotatedCumulativePercentage()
Usage:                      eigenvalues = pca.rotatedEigenValues()
This method returns the rotated eigenvalues. These values are scaled so that the total variance associated with the extracted fators does not change on rotation.

Usage:                      proportions = pca.rotatedProportionPercentage()
This method returns the rotated eigenvalues expressed as a percentage of the total variance calculated using all unrotated eigenvalues. The returned values have been scaled so that the total variance associated with the extracted fators does not change on rotation.

Usage:                      cumulatives = pca.rotatedCumulativePercentage()
This method returns the rotated eigenvalues expressed as a cumulative percentage of the total variance calculated using all unrotated eigenvalues. The returned values have been scaled so that the total variance associated with the extracted fators does not change on rotation.


ROTATED LOADING FACTORS
public double[] rotatedLoadingFactorsAsRows()
public double[] rotatedLoadingFactorsAsColumns()
Usage:                      loadf = pca.rotatedLoadingFactorsAsRows()
This method returns the rotated loading factors corresponding to an eigenvalue returned as a row. These values are scaled so that the total variance associated with the extracted fators does not change on rotation.

Usage:                      loadf = pca.rotatedLoadingFactorsAsColumns()
This method returns the rotated loading factors corresponding to an eigenvalue returned as a column. These values are scaled so that the total variance associated with the extracted fators does not change on rotation.




KAISER-MEYER-OLKIN (KMO) STATISTIC [Measure of Sampling Adequacy (MSA)]

public double overallKMO()
public double[] itemKMOs()
Usage:                      kmostatistic = pca.overallKMO()
This method returns the KMO [Kaiser-Meyer-Olkin] statistic:

where rij are the elements of the correlation matrix, aij are the elements of the partial correlation matrix calculated as

where Ckl are the cofactors of the correlation matrix and n is the number of items.

Usage:                      kmos = pca.itemKMOs()
This method returns the array of individual item KMO [Kaiser-Meyer-Olkin] statistics:

where rij are the elements of the correlation matrix, aij are the elements of the partial correlation matrix calculated as

where Ckl are the cofactors of the correlation matrix and n is the number of items.

BARTLETT TEST OF SPHERICITY

public double chiSquareBartlett()
Usage:                      chiSquare = pca.chiSquareBartlett()
This method returns the value of the Bartlett Test for Sphericity Chi-Square:

where N is the sample size. e.g. the number of persons, n is the number of items and |R| is the determinant of the correlation matrix.

public double probabilityBartlett()
Usage:                      significance = pca.probabilityBartlett()
This method returns the value of the Bartlett Test for Sphericity Chi-Square probability.

public int dofBartlett()
Usage:                      dof = pca.dofBartlett()
This method returns the value of the Bartlett Test for Sphericity Chi-Square degrees of freedom, n(n-1)/2, where n is the number of items.




X MATRIX

public Matrix xMatrix()
Usage:                      xMatrix = pca.xMatrix()
This method returns the X matrix as an instance of Matrix. The X matrix is the data matrix with each element within a row (an itm) replaced by its value with the mean of the row subtracted and the result divided by the square root of the number of items minus one (or of the number of items - see set the denominator).

COVARIANCE MATRIX

public Matrix covarianceMatrix()
Usage:                      covMatrix = pca.covarianceMatrix()
This method returns the covariance matrix as an instance of Matrix.

CORRELATION MATRIX

public Matrix correlationMatrix()
Usage:                      corrMatrix = pca.correlationMatrix()
This method returns the correlation matrix as an instance of Matrix.

PARTIAL CORRELATION MATRIX

public Matrix partialCorrelationMatrix()
Usage:                      partialCorrMatrix = pca.partialCorrelationMatrix()
This method returns the partial correlation matrix as an instance of Matrix.

TRANSPOSE OF THE X MATRIX

public Matrix xMatrixTranspose()
Usage:                      xMatrixT = pca.xMatrixTranspose()
This method returns the transpose of the X matrix as an instance of Matrix. The X matrix is the data matrix with each element within a row (an itm) replaced by its value with the mean of the row subtracted and the result divided by the square root of the number of items minus one (or of the number of items - see set the denominator).

ORIGINAL DATA MATRIX

public Matrix originalMatrix()()
Usage:                      data = pca.originalMatrix()()
This method returns the original data as an instance of Matrix.



DELETE AN ITEM

public double[][] deleteItem(String itemName)
public double[][] deleteItem(int itemIndex)
Usage:                      newResponseMatrix = pca.deleteItem(itemName)
This method returns a matrix containing the entered data with the item with the name contained in the String itemName deleted. The returned matrix contains any 'no response' replacements in the remaining responses that were made in the original response matrix and will not contain any deletion made to the original data. The format of the returned matrix is responses of each item per column.

Usage:                      newResponseMatrix = pca.deleteItem(itemIndex)
This method returns a matrix containing the entered data with the item of index itemIndex deleted. The indices run from 1 to n. The returned matrix contains any 'no response' replacements in the remaining responses that were made in the original response matrix and will not contain any deletion made to the original data. The format of the returned matrix is responses of each item per column.



SCATTER PLOTS

Plot of item - item responses
public void rawItemItemPlot(String itemName1, String itemName2)
public void rawItemItemPlot(int item1Index1, int itemIndex2)
public void standardizedItemItemPlot(String itemName1, String itemName2)
public void standardizedItemItemPlot(int item1Index1, int itemIndex2)
Usage:                      pca.rawItemItemPlot(itemName1, itemName2)
Calling this method displays, in a new window, a plot of the raw data responses of the item named itemName1 against the raw data responses of the item named itemName2.

Usage:                      pca.rawItemItemPlot(itemIndex1, itemIndex2)
Calling this method displays, in a new window, a plot of the raw data responses of the item with an index itemIndex1 against the raw data responses of the item with an index itemIndex2. NOTE!! the item indices start at 1 not at 0. See Item Names for methods that return an item index or name.

Usage:                      pca.standardizedItemItemPlot(itemName1, itemName2)
Calling this method displays, in a new window, a plot of the standardized data responses of the item named itemName1 against the standardized data responses of the item named itemName2.

Usage:                      pca.standardizedItemItemPlot(itemIndex1, itemIndex2)
Calling this method displays, in a new window, a plot of the standardized data responses of the item with an index itemIndex1 against the standardized data responses of the item with an index itemIndex2. NOTE!! the item indices start at 1 not at 0. See Item Names for methods that return an item index or name.

Plot of item - means of item responses
public void rawItemMeansPlot(String itemName)
public void rawItemMeansPlot(int item1Index)
public void standardizedItemMeansPlot(String itemName)
public void standardizedItemMeansPlot(int item1Index)
Usage:                      pca.rawItemMeansPlot(itemName)
Calling this method displays, in a new window, a plot of the raw data responses of the item named itemName against the means of the raw data responses of all items.

Usage:                      pca.rawItemMeansPlot(itemIndex)
Calling this method displays, in a new window, a plot of the raw data responses of the item with an index itemIndex a against the means of the raw data responses of all items. NOTE!! the item indices start at 1 not at 0. See Item Names for methods that return an item index or name.

Usage:                      pca.standardizedItemMeansPlot(itemName)
Calling this method displays, in a new window, a plot of the standardized data responses of the item named itemName against the means of the standardized data responses of all items.

Usage:                      pca.standardizedItemMeansPlot(itemIndex)
Calling this method displays, in a new window, a plot of the standardized data responses of the item with an index itemIndex against the means of the standardized data responses of all items. NOTE!! the item indices start at 1 not at 0. See Item Names for methods that return an item index or name.





CORRELATION COEFFICIENTS

BETWEEN ALL ITEMS
Correlation Coefficient Matrix
public double[][] rawCorrelationCoefficients()
public double[][] standardizedCorrelationCoefficients()
Usage:                      corrCoeff = pca.rawCorrelationCoefficients()
This method returns an (n+1) times (n+1) matrix where n is the number of items. Rows and columns 0 to n-1 contain the correlation coefficients, for the raw data responses, between all pairs of items, e.g. corrCoeff[0][3] contains the correlation coefficient between the first item and the fourth item. Rows and columns n contain the correlation coefficients between the items and the totals of all the items, e.g. corrCoeff[1][n] contains the correlation coefficient, for the raw data responses, between the second item and the totals of all n items.

Usage:                      corrCoeff = pca.standardizedCorrelationCoefficients()
This method returns an (n+1) times (n+1) matrix where n is the number of items. Rows and columns 0 to n-1 contain the correlation coefficients, for the standardized data responses, between all pairs of items, e.g. corrCoeff[0][3] contains the correlation coefficient between the first item and the fourth item. Rows and columns n contain the correlation coefficients between the items and the totals of all the items, e.g. corrCoeff[1][n] contains the correlation coefficient, for the standardized data responses, between the second item and the totals of all n items.

Average correlation coefficient, excluding totals
public double rawAverageCorrelationCoefficients()
public double standardizedAverageCorrelationCoefficients()
Usage:                      meanCorrCoeff = pca.rawAverageCorrelationCoefficients()
This method returns, for the raw data responses, the average of all the correlation coefficients between items,

where n is the number of items and ri,j is the correlation coefficient between the ith and jth items. This method does not include, in the average, the correlation coefficients with the totals of all the items (see
below).

Usage:                      meanCorrCoeff = pca.standardizedAverageCorrelationCoefficients()
This method returns, for the standardized data responses, the average of all the correlation coefficients between items,

where n is the number of items and ri,j is the correlation coefficient between the ith and jth items. This method does not include, in the average, the correlation coefficients with the totals of all the items (see below).

Average correlation coefficient, including totals
public double rawStandardDeviationCorrelationCoefficientsWithTotals()
public double standardizedStandardDeviationCorrelationCoefficientsWithTotals()
Usage:                      meanCorrCoeff = pca.rawStandardDeviationCorrelationCoefficientsWithTotals()
This method returns, for the raw data responses, the average of all the correlation coefficients between items and the totals of all items,

where n is the number of items and ri,j, for i and j less than or equal to n is the correlation coefficient between the ith and jth items and ri,n+1 is the correlation coefficient between the ith item and the totals of all items. See
above) for exclusion of totals.

Usage:                      meanCorrCoeff = pca.standardizedStandardDeviationCorrelationCoefficientsWithTotals()
This method returns, for the standardized data responses, the average of all the correlation coefficients between items and the totals of all items,

where n is the number of items and ri,j, for i and j less than or equal to n is the correlation coefficient between the ith and jth items and ri,n+1 is the correlation coefficient between the ith item and the totals of all items. See above for exclusion of totals.

Standard deviation of the correlation coefficients, excluding totals
public double rawStandardDeviationCorrelationCoefficients()
public double standardizedStandardDeviationCorrelationCoefficients()
Usage:                      sdCorrCoeff = pca.rawStandardDeviationCorrelationCoefficients()
This method returns, for the raw data responses, the standard deviation of all the correlation coefficients between items. This method does not include, in the average, the correlation coefficients with the totals of all the items (see
below).

Usage:                      sdCorrCoeff = pca.standardizedStandardDeviationCorrelationCoefficients()
This method returns, for the standardized data responses, the standard deviation of all the correlation coefficients between items. This method does not include, in the average, the correlation coefficients with the totals of all the items (see below).

Standard deviation of the correlation coefficients, including totals
public double rawStandardDeviationCorrelationCoefficientsWithTotals()
public double standardizedStandardDeviationCorrelationCoefficientsWithTotals()
Usage:                      sdCorrCoeff = pca.rawStandardDeviationCorrelationCoefficientsWithTotals()
This method returns, for the raw data responses, the standard deviation of all the correlation coefficients between items and the totals of all items. See
above) for exclusion of totals.

Usage:                      sdCorrCoeff = pca.standardizedStandardDeviationCorrelationCoefficientsWithTotals()
This method returns, for the standardized data responses, the standard deviation of all the correlation coefficients between items and the totals of all items. See above for exclusion of totals.

BETWEEN PAIRS
Item-item pair
public double rawCorrelationCoefficient(String itemName1, String itemName2)
public double rawCorrelationCoefficient(int itemIndex1, int itemIndex2)
public double standardizedCorrelationCoefficient(String itemName1, String itemName2)
public double standardizedCorrelationCoefficient(int itemIndex1, int itemIndex2)
Usage:                      corrCoeff = pca.rawCorrelationCoefficient(itemName1, itemName2)
This method returns the correlation coefficient, for the raw data responses, between the item with the name contained in the String itemName1 and the item with the name contained in the String itemName2.

Usage:                      corrCoeff = pca.rawCorrelationCoefficient(itemIndex1, itemIndex2)
This method returns the correlation coefficient, for the raw data responses, between the item of index itemIndex1 and the item of index itemIndex2. The indices run from 1 to n.

Usage:                      corrCoeff = pca.standardizedCorrelationCoefficient(itemName1, itemName2)
This method returns the correlation coefficient, for the standardized data responses, between the item with the name contained in the String itemName1 and the item with the name contained in the String itemName2.

Usage:                      corrCoeff = pca.standardizedCorrelationCoefficient(itemIndex1, itemIndex2)
This method returns the correlation coefficient, for the standardized data responses, between the item of index itemIndex1 and the item of index itemIndex2. The indices run from 1 to n.

Item-(totals of all items) pair
public double rawCorrelationCoefficient(String itemName)
public double rawCorrelationCoefficient(int itemIndex)
public double standardizedCorrelationCoefficient(String itemName)
public double standardizedCorrelationCoefficient(int itemIndex)
Usage:                      corrCoeff = pca.rawCorrelationCoefficient(itemName)
This method returns the correlation coefficient, for the raw data responses, between the item with the name contained in the String itemName and the totals of all items.

Usage:                      corrCoeff = pca.rawCorrelationCoefficient(itemIndex)
This method returns the correlation coefficient, for the raw data responses, between the item of index itemIndex and the totals of all items. The indices run from 1 to n.

Usage:                      corrCoeff = pca.standardizedCorrelationCoefficient(itemName1)
This method returns the correlation coefficient, for the standardized data responses, between the item with the name contained in the String itemName1 and the totals of all items.

Usage:                      corrCoeff = pca.standardizedCorrelationCoefficient(itemIndex)
This method returns the correlation coefficient, for the standardized data responses, between the item of index itemIndex aand the totals of all items. The indices run from 1 to n.





COVARIANCES

BETWEEN ALL ITEMS
Covariance Matrix
public double[][] rawCovariances()
public double[][] standardizedCovariances()
Usage:                      covar = pca.rawCovariances()
This method returns an (n+1) times (n+1) matrix where n is the number of items. Rows and columns 0 to n-1 contain the covariances, for the raw data responses, between all pairs of items, e.g. corrCoeff[0][3] contains the covariance between the first item and the fourth item. Rows and columns n contain the covariances between the items and the totals of all the items, e.g. corrCoeff[1][n] contains the covariance, for the raw data responses, between the second item and the totals of all n items. The diagonal elements contain the variances, e.g. covar[2][2] contins the variance of the third item.
See Setting the denominator for covariance formulae options.

Usage:                      covar = pca.standardizedCovariances()
This method returns an (n+1) times (n+1) matrix where n is the number of items. Rows and columns 0 to n-1 contain the covariances, for the standardized data responses, between all pairs of items, e.g. corrCoeff[0][3] contains the covariance between the first item and the fourth item. Rows and columns n contain the covariances between the items and the totals of all the items, e.g. corrCoeff[1][n] contains the covariance, for the standardized data responses, between the second item and the totals of all n items. The diagonal elements contain the variances, e.g. covar[2][2] contins the variance of the third item.
See Setting the denominator for covariance formulae options.

BETWEEN PAIRS
Item-item pair
public double rawCovariance(String itemName1, String itemName2)
public double rawCovariance(int itemIndex1, int itemIndex2)
public double standardizedCovariance(String itemName1, String itemName2)
public double standardizedCovariance(int itemIndex1, int itemIndex2)
Usage:                      covar = pca.rawCovariance(itemName1, itemName2)
This method returns the covariance, for the raw data responses, between the item with the name contained in the String itemName1 and the item with the name contained in the String itemName2.

Usage:                      covar = pca.rawCovariance(itemIndex1, itemIndex2)
This method returns the covariance, for the raw data responses, between the item of index itemIndex1 and the item of index itemIndex2. The indices run from 1 to n.

Usage:                      covar = pca.standardizedCovariance(itemName1, itemName2)
This method returns the covariance, for the standardized data responses, between the item with the name contained in the String itemName1 and the item with the name contained in the String itemName2.

Usage:                      covar = pca.standardizedCovariance(itemIndex1, itemIndex2)
This method returns the covariance, for the standardized data responses, between the item of index itemIndex1 and the item of index itemIndex2. The indices run from 1 to n.

See Setting the denominator for covariance formulae options.

Item-(totals of all items) pair
public double rawCovariance(String itemName)
public double rawCovariance(int itemIndex)
public double standardizedCovariance(String itemName)
public double standardizedCovariance(int itemIndex)
Usage:                      covar = pca.rawCovariance(itemName)
This method returns the covariance, for the raw data responses, between the item with the name contained in the String itemName and the totals of all items.

Usage:                      covar = pca.rawCovariance(itemIndex)
This method returns the covariance, for the raw data responses, between the item of index itemIndex and the totals of all items. The indices run from 1 to n.

Usage:                      covar = pca.standardizedCovariance(itemName1)
This method returns the covariance, for the standardized data responses, between the item with the name contained in the String itemName1 and the totals of all items.

Usage:                      covar = pca.standardizedCovariance(itemIndex)
This method returns the covariance, for the standardized data responses, between the item of index itemIndex aand the totals of all items. The indices run from 1 to n.

See Setting the denominator for covariance formulae options.



ITEM MEANS

MEAN VALUES OF ALL ITEMS
Raw data
public double[] rawItemMeans()
Usage:                      itemMeans = pca.rawItemMeans()
This method returns the means, calculated using the raw data, of all the items. The order of items is as entered minus any deleted due to missing responses.
Standardized data
public double[] standardizedItemMeans()
Usage:                      itemMeans = pca.standardizedItemMeans()
This method returns the means, calculated using standardized data, of all the items. The order of items is as entered minus any deleted due to missing responses.

MEAN VALUE OF AN INDIVIDUAL ITEM
Raw data
public double rawItemMean(int index)
public double rawItemMean(String name)
Usage:                      itemMean = pca.rawItemMean(item)
This method returns the mean, calculated using the raw data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.
Standardized data
public double standardizedItemMean(int index)
public double standardizedItemMean(String name)
Usage:                      itemMean = pca.standardizedItemMean(item)
This method returns the mean, calculated using standardized data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.

MEAN VALUE OF ALL ITEM MEANS
Raw data
public double rawMeanOfItemMeans()
Usage:                      itemMeanOfMeans = pca.rawMeanOfItemMeans()
This method returns the mean, calculated using the raw data, of the means of all items.
Standardized data
public double standardizedMeanOfItemMeans()
Usage:                      itemMeanOfMeans = pca.standardizedMeanOfItemMeans()
This method returns the mean, calculated using standardized data, of the means of all items.

STANDARD DEVIATION OF ALL ITEM MEANS
Raw data
public double rawStandardDeviationOfItemMeans()
Usage:                      itemSdOfMeans = pca.rawStandardDeviationOfItemMeans()
This method returns the standard deviation, calculated using the raw data, of the means of all items.
Standardized data
public double[] standardizedStandardDeviationOfItemMeans()
Usage:                      itemSdOfMeans = pca.standardizedStandardDeviationOfItemMeans()
This method returns the standard deviation, calculated using standardized data, of the means of all items.

See Setting the denominator for standard deviation formulae options.

VARIANCE OF ALL ITEM MEANS
Raw data
public double rawVarianceOfItemMeans()
Usage:                      itemVarOfMeans = pca.rawVarianceOfItemMeans()
This method returns the variance, calculated using the raw data, of the means of all items.
Standardized data
public double[] standardizedVarianceOfItemMeans()
Usage:                      itemVarOfMeans = pca.standardizedVarianceOfItemMeans()
This method returns the variance, calculated using standardized data, of the means of all items.

See Setting the denominator for variance formulae options.

MAXIMUM OF ALL ITEM MEANS
Raw data
public double rawMaximumOfItemMeans()
Usage:                      itemMaxOfMeans = pca.rawMaximumOfItemMeans()
This method returns the maximum, calculated using the raw data, of the means of all items.
Standardized data
public double[] standardizedMaximumOfItemMeans()
Usage:                      itemMaxOfMeans = pca.standardizedMaximumOfItemMeans()
This method returns the maximum, calculated using standardized data, of the means of all items.

MINIMUM OF ALL ITEM MEANS
Raw data
public double rawMinimumOfItemMeans()
Usage:                      itemMinOfMeans = pca.rawMinimumOfItemMeans()
This method returns the minimum, calculated using the raw data, of the means of all items.
Standardized data
public double[] standardizedMinimumOfItemMeans()
Usage:                      itemMinOfMeans = pca.standardizedMinimumOfItemMeans()
This method returns the minimum, calculated using standardized data, of the means of all items.

RANGE OF ALL ITEM MEANS
Raw data
public double rawRangeOfItemMeans()
Usage:                      itemRangeOfMeans = pca.rawRangeOfItemMeans()
This method returns the range, calculated using the raw data, of the means of all items.
Standardized data
public double[] standardizedRangeOfItemMeans()
Usage:                      itemRangeOfMeans = pca.standardizedRangeOfItemMeans()
This method returns the range, calculated using standardized data, of the means of all items.



ITEM MOMENT SKEWNESS

The moment skewness of an item is defined as

where xi are the responses to the item in question, is the sample mean of the item and s is the sample standard deviation of the item.
The default denominator is (n−1). See Setting the denominator for methods resetting the denominator.

MOMENT SKEWNESS OF ALL ITEMS
Raw data
public double[] rawItemMomentSkewnessess()
Usage:                      skewness = pca.rawItemMomentSkewnessess()
This method returns the moment skewnesses, calculated using the raw data, of all the items. The order of items is as entered minus any deleted due to missing responses.
Standardized data
public double[] standardizedItemMomentSkewnessess() Usage:                      skewness = pca.standardizedItemMomentSkewnessess()
This method returns the moment skewnesses, calculated using standardized data, of all the items. The order of items is as entered minus any deleted due to missing responses.

MOMENT SKEWNESS OF AN INDIVIDUAL ITEM
Raw data
public double rawItemMomentSkewness(int index)
public double rawItemMomentSkewness(String name)
Usage:                      skewness = pca.rawItemMomentSkewness(item)
This method returns the moment skewness, calculated using the raw data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.
Standardized data
public double standardizedItemMomentSkewness(int index)
public double standardizedItemMomentSkewness(String name)
Usage:                      skewness = pca.standardizedItemMomentSkewness(item)
This method returns the moment skewness, calculated using standardized data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.

ITEM MEDIAN SKEWNESS (Pearson's median skewness coefficient)

The median skewness of an item is defined as

See Setting the denominator for standard deviation formulae options.

MEDIAN SKEWNESS OF ALL ITEMS
Raw data
public double[] rawItemMedianSkewnessess()
Usage:                      skewness = pca.rawItemMedianSkewnessess()
This method returns the median skewnesses, calculated using the raw data, of all the items. The order of items is as entered minus any deleted due to missing responses.
Standardized data
public double[] standardizedItemMedianSkewnessess()
Usage:                      skewness = pca.standardizedItemMedianSkewnessess()
This method returns the median skewnesses, calculated using standardized data, of all the items. The order of items is as entered minus any deleted due to missing responses.

MEDIAN SKEWNESS OF AN INDIVIDUAL ITEM
Raw data
public double rawItemMedianSkewness(int index)
public double rawItemMedianSkewness(String name)
Usage:                      skewness = pca.rawItemMedianSkewness(item)
This method returns the median skewness, calculated using the raw data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.
Standardized data
public double standardizedItemMedianSkewness(int index)
public double standardizedItemMedianSkewness(String name)
Usage:                      skewness = pca.standardizedItemMedianSkewness(item)
This method returns the median skewness, calculated using standardized data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.

ITEM QUARTILE SKEWNESS (Bowley skewness coefficient)

The quartile skewness of an item is defined as

where the Qs denote the interquartile ranges of the item.

QUARTILE SKEWNESS OF ALL ITEMS
Raw data
public double[] rawItemMedianSkewnessess()
Usage:                      skewness = pca.rawItemQuartileSkewnessess()
This method returns the quartile skewnesses, calculated using the raw data, of all the items. The order of items is as entered minus any deleted due to missing responses.
Standardized data
public double[] rawItemQuartileSkewnessess()
Usage:                      skewness = pca.standardizedItemQuartileSkewnessess()
This method returns the quartile skewnesses, calculated using standardized data, of all the items. The order of items is as entered minus any deleted due to missing responses.

QUARTILE SKEWNESS OF AN INDIVIDUAL ITEM
Raw data
public double rawItemQuartileSkewness(int index)
public double rawItemQuartileSkewness(String name)
Usage:                      skewness = pca.rawItemMedianSkewness(item)
This method returns the quartile skewness, calculated using the raw data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.
Standardized data
public double standardizedItemQuartileSkewness(int index)
public double standardizedItemQuartileSkewness(String name)
Usage:                      skewness = pca.standardizedItemMedianSkewness(item)
This method returns the quartile skewness, calculated using standardized data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.



ITEM EXCESS KURTOSIS

The excess kurtosis of an item is defined as

where xi are the responses to the item in question, is the sample mean of the item and s is the sample standard deviation opf the item, i.e. returns the kurtosis of the item minus the kurtosis of a Gaussian distribution (3.0).
The default denominator is (n−1). See Setting the denominator for methods resetting the denominator.

EXCESS KURTOSES OF ALL ITEMS
Raw data
public double[] rawItemExcessKurtoses()
Usage:                      kurtoses = pca.rawItemExcessKurtoses()
This method returns the excess kurtoses, calculated using the raw data, of all the items. The order of items is as entered minus any deleted due to missing responses.
Standardized data
public double[] standardizedItemExcesskurtoses()
Usage:                      kurtoses = pca.standardizedItemExcesskurtoses()
This method returns the excess kurtoses, calculated using standardized data, of all the items. The order of items is as entered minus any deleted due to missing responses.

EXCESS KURTOSIS OF AN INDIVIDUAL ITEM
Raw data
public double rawItemExcessKurtosis(int index)
public double rawItemExcessKurtosis(String name)
Usage:                      kurtosis = pca.rawItemExcessKurtosis(item)
This method returns the excess kurtosis, calculated using the raw data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.
Standardized data
public double standardizedItemExcessKurtosis(int index)
public double standardizedItemExcessKurtosis(String name)
Usage:                      kurtosis = pca.standardizedItemExcessKurtosis(item)
This method returns the excess kurtosis, calculated using standardized data, of an individual item. The item may be identified (argument item) by its index or its name. Note that the order of items starts at 1 and NOT 0. The order is as entered minus any deleted due to missing responses.



ITEM NAMES AND INDICES

NAMES OF THE USED ITEMS
public String[] itemNames()
Usage:                      names = pca.itemNames()
This method returns the names of the items used, i.e. after any deletions due to 'missing responses'.

NAMES OF THE ENTERED ITEMS
public String[] originalItemNames()
Usage:                      names = pca.originalItemNames()
This method returns the names of the items originally entered, i.e. before any deletions due to 'missing responses'.

NAMES OF ANY DELETED ITEMS
public String[] deletedItemsNames()
Usage:                      names = pca.deletedItemsNames()
This method returns the names of items originally entered but then deleted as part of the 'missing responses' handling. If no items have been deleted null is returned.

INDEX OF AN ITEM
public int itemIndex(String name)
Usage:                      index = pca.itemIndex(name)
This method returns the index of the item whose name is passed to the method as the argument name. NOTE the indices of names start at 1 and NOT at zero.

NAME OF AN ITEM
public String itemName(int index)
Usage:                      name = pca.itemName(index)
This method returns the name of the item whose index is passed to the method as the argument index. NOTE the indices of names start at 1 and NOT at zero.



NUMBER OF ITEMS

Number of items used
public int usedNumbeOfItems()
Usage:                      num = pca.usedNumbeOfItems()
This method returns the number of items used, i.e. after any deletions due to the 'missing response' handling.

Number of items entered
public int originalNumbeOfItems()
Usage:                      num = pca.originalNumbeOfItems()
This method returns the number of items entered, i.e. before any deletions due to the 'missing response' handling.

Number of items deleted
public int numbeOfDeletedItems()
Usage:                      num = pca.numbeOfDeletedItems()
This method returns the number of items deleted due to the 'missing response' handling.



PERSON INDICES

INDICES OF THE USED PERSONS
public String[] personIndices()
Usage:                      names = pca.personIndices()
This method returns the indices of the persons used, i.e. after any deletions due to 'missing responses'. NOTE the indices of the persons start at 1 and NOT at zero.

INDICES OF ANY DELETED PERSONSS
public String[] deletedPersonsIndices()
Usage:                      names = pca.deletedPersonsIndices()
This method returns the indices of items originally entered but then deleted as part of the 'missing responses' handling. NOTE the indices of the persons start at 1 and NOT at zero.



NUMBER OF PERSONS

Number of persons used
public int usedNumbeOfPersons()
Usage:                      num = pca.usedNumbeOfPersons()
This method returns the number of persons used, i.e. after any deletions due to the 'missing response' handling.

Number of persons entered
public int originalNumbeOfPersons()
Usage:                      num = pca.originalNumbeOfPersons()
This method returns the number of persons entered, i.e. before any deletions due to the 'missing response' handling.

Number of persons deleted
public int numbeOfDeletedPersons()
Usage:                      num = pca.numbeOfDeletedPersons()
This method returns the number of persons deleted due to the 'missing response' handling.



RESPONSES

ORIGINAL RESONSES
Responses as originally entered
public Object originalScores()
Usage:                      originalData = pca.originalScores()
This method returns the responses as originally entered, i.e. before any deletions. They are returned as a Java Object as they may have been entered as String[][], double[][], float[][], int[][], char[][], boolean[][] or Matrix. If they were originally read in from a text file the returned Object is of type String[][].

Original responses as row per item
public double[][] originalScoresAsRowPerItem()
Usage:                      originalData = pca.originalScoresAsRowPerItem()
This method returns the original responses entered rearranged as a two dimensional array of doubles orgainized as a row of responses for each item. Missing responses are returned as Double.NaN.

Original responses as row per person
public double[][] originalScoresAsRowPerPerson()
Usage:                      originalData = pca.originalScoresAsRowPerPerson()
This method returns the original responses entered rearranged as a two dimensional array of doubles orgainized as a row of responses for each person. Missing responses are returned as Double.NaN.

RESPONSES AS USED (RAW DATA)
Responses as used as row per item
public double[][] usedScoresAsRowPerItem()
Usage:                      data = pca.usedScoresAsRowPerItem()
This method returns the raw data responses as used, i.e. minus any deleted items or persons, arranged as a two dimensional array of doubles orgainized as a row of responses for each item. Retained missing responses are returned with the chosen substituted values.

Responses as used as row per person
public double[][] usedScoresAsRowPerItem()
Usage:                      data = pca.usedScoresAsRowPerPerson()
This method returns the raw data responses as used, i.e. minus any deleted items or persons, arranged as a two dimensional array of doubles orgainized as a row of responses for each person. Retained missing responses are returned with the chosen substituted values.

RESPONSES AS USED (STANDARDIZED DATA)
Standardized responses as used as row per item
public double[][] standardizedScoresAsRowPerItem()
Usage:                      data = pca.standardizedScoresAsRowPerItem()
This method returns the standardized data responses as used, i.e. minus any deleted items or persons, arranged as a two dimensional array of doubles orgainized as a row of responses for each item. Retained missing responses are returned with the chosen standardized substituted values.

Standardized responses as used as row per person
public double[][] standardizedScoresAsRowPerItem()
Usage:                      data = pca.standardizedScoresAsRowPerPerson()
This method returns the standardized data responses as used, i.e. minus any deleted items or persons, arranged as a two dimensional array of doubles orgainized as a row of responses for each person. Retained missing responses are returned with the chosen standardized substituted values.

ITEM NAME AND PERSON INDEX OF THE REPLACED RESPONSES
Standardized responses as used as row per item
public String[] indicesOfReplacedScores()
Usage:                      repl = pca.ndicesOfReplacedScores()
This method returns the item name and person index for all 'missing responses' that have been replaced rather than deleted. NOTE that the indices of the persons starts at 1 NOT at 0.

NUMBER OF RESPONSES
Original number of scores
public int originalTotalNumberOfScores()
Usage:                      nScores = pca.originalTotalNumberOfScores()
This method returns the original number of responses entered, i.e. before any deletions.

Number of scores used
public int usedTotalNumberOfScores()
Usage:                      nScores = pca.usedTotalNumberOfScores()
This method returns the number of responses used, i.e. after any deletions.

Number of deleted scores
public int numberOfDeletedScores()
Usage:                      nDeletes = pca.numberOfDeletedScores()
This method returns the number of responses that have been deleted in the handling of any 'missing responses'.

Number of replacement scores
public int numberOfReplacedScores()
Usage:                      nDeletes = pca.numberOfReplacedScores()
This method returns the number of responses that have been replaced in the handling of any 'missing responses'.



SOME OF THE DOCUMENTATION IS STILL UNDER CONSTRUCTION

Some of the item statistic methods, e.g. rawItemStandardDeviation(), person statistic methods, e.g. standardizedPersonVariances(), and allResponses statistic methods, e.g. rawAllResponsesMaximum(), have still to be fully documented. All of these follow the same format as that of the corresponding methods in the
Item Means methods documented above. Their full individual documentation will be added later.



EXAMPLE PROGRAM

An example program, PCA_Analysis, and the associated documentation may be found on PCA Analysis.



BIBLIOGRAPHY

Cohen, L., Manion, L. & Morrison, K, A. (2008), Research Methods in Education, 6th Edition, Routledge, London & New York, Chapter twenty five, Multidimensional measurement and factor analysis, pp 559-585.

Harman, H. H. (1976), Modern Factor Analysis, 3rd Edition Revised, The University of Chigago Press, Chicago & London.



OTHER CLASSES USED BY THIS CLASS

This class uses the following classes in this library:


This page was prepared by Dr Michael Thomas Flanagan