Class SynchronizedMultivariateSummaryStatistics
- java.lang.Object
- 
- org.apache.commons.math4.legacy.stat.descriptive.MultivariateSummaryStatistics
- 
- org.apache.commons.math4.legacy.stat.descriptive.SynchronizedMultivariateSummaryStatistics
 
 
- 
- All Implemented Interfaces:
- StatisticalMultivariateSummary
 
 public class SynchronizedMultivariateSummaryStatistics extends MultivariateSummaryStatistics Implementation ofMultivariateSummaryStatisticsthat is safe to use in a multithreaded environment. Multiple threads can safely operate on a single instance without causing runtime exceptions due to race conditions. In effect, this implementation makes modification and access methods atomic operations for a single instance. That is to say, as one thread is computing a statistic from the instance, no other thread can modify the instance nor compute another statistic.- Since:
- 1.2
 
- 
- 
Constructor SummaryConstructors Constructor Description SynchronizedMultivariateSummaryStatistics(int k, boolean isCovarianceBiasCorrected)Construct a SynchronizedMultivariateSummaryStatistics instance.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddValue(double[] value)Add an n-tuple to the data.voidclear()Resets all statistics and storage.booleanequals(Object object)Returns true iffobjectis aMultivariateSummaryStatisticsinstance and all statistics have the same values as this.RealMatrixgetCovariance()Returns the covariance matrix of the values that have been added.intgetDimension()Returns the dimension of the data.StorelessUnivariateStatistic[]getGeoMeanImpl()Returns the currently configured geometric mean implementation.double[]getGeometricMean()Returns an array whose ith entry is the geometric mean of the.double[]getMax()Returns an array whose ith entry is the maximum of the.StorelessUnivariateStatistic[]getMaxImpl()Returns the currently configured maximum implementation.double[]getMean()Returns an array whose ith entry is the mean of the.StorelessUnivariateStatistic[]getMeanImpl()Returns the currently configured mean implementation.double[]getMin()Returns an array whose ith entry is the minimum of the.StorelessUnivariateStatistic[]getMinImpl()Returns the currently configured minimum implementation.longgetN()Returns the number of available values.double[]getStandardDeviation()Returns an array whose ith entry is the standard deviation of the.double[]getSum()Returns an array whose ith entry is the sum of the.StorelessUnivariateStatistic[]getSumImpl()Returns the currently configured Sum implementation.double[]getSumLog()Returns an array whose ith entry is the sum of logs of the.StorelessUnivariateStatistic[]getSumLogImpl()Returns the currently configured sum of logs implementation.double[]getSumSq()Returns an array whose ith entry is the sum of squares of the.StorelessUnivariateStatistic[]getSumsqImpl()Returns the currently configured sum of squares implementation.inthashCode()Returns hash code based on values of statistics.voidsetGeoMeanImpl(StorelessUnivariateStatistic[] geoMeanImpl)Sets the implementation for the geometric mean.voidsetMaxImpl(StorelessUnivariateStatistic[] maxImpl)Sets the implementation for the maximum.voidsetMeanImpl(StorelessUnivariateStatistic[] meanImpl)Sets the implementation for the mean.voidsetMinImpl(StorelessUnivariateStatistic[] minImpl)Sets the implementation for the minimum.voidsetSumImpl(StorelessUnivariateStatistic[] sumImpl)Sets the implementation for the Sum.voidsetSumLogImpl(StorelessUnivariateStatistic[] sumLogImpl)Sets the implementation for the sum of logs.voidsetSumsqImpl(StorelessUnivariateStatistic[] sumsqImpl)Sets the implementation for the sum of squares.StringtoString()Generates a text report displaying summary statistics from values that have been added.
 
- 
- 
- 
Constructor Detail- 
SynchronizedMultivariateSummaryStatisticspublic SynchronizedMultivariateSummaryStatistics(int k, boolean isCovarianceBiasCorrected) Construct a SynchronizedMultivariateSummaryStatistics instance.- Parameters:
- k- dimension of the data
- isCovarianceBiasCorrected- if true, the unbiased sample covariance is computed, otherwise the biased population covariance is computed
 
 
- 
 - 
Method Detail- 
addValuepublic void addValue(double[] value) throws DimensionMismatchException Add an n-tuple to the data.- Overrides:
- addValuein class- MultivariateSummaryStatistics
- Parameters:
- value- the n-tuple to add
- Throws:
- DimensionMismatchException- if the length of the array does not match the one used at construction
 
 - 
getDimensionpublic int getDimension() Returns the dimension of the data.- Specified by:
- getDimensionin interface- StatisticalMultivariateSummary
- Overrides:
- getDimensionin class- MultivariateSummaryStatistics
- Returns:
- The dimension of the data
 
 - 
getNpublic long getN() Returns the number of available values.- Specified by:
- getNin interface- StatisticalMultivariateSummary
- Overrides:
- getNin class- MultivariateSummaryStatistics
- Returns:
- The number of available values
 
 - 
getSumpublic double[] getSum() Returns an array whose ith entry is the sum of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getSumin interface- StatisticalMultivariateSummary
- Overrides:
- getSumin class- MultivariateSummaryStatistics
- Returns:
- the array of component sums
 
 - 
getSumSqpublic double[] getSumSq() Returns an array whose ith entry is the sum of squares of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getSumSqin interface- StatisticalMultivariateSummary
- Overrides:
- getSumSqin class- MultivariateSummaryStatistics
- Returns:
- the array of component sums of squares
 
 - 
getSumLogpublic double[] getSumLog() Returns an array whose ith entry is the sum of logs of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getSumLogin interface- StatisticalMultivariateSummary
- Overrides:
- getSumLogin class- MultivariateSummaryStatistics
- Returns:
- the array of component log sums
 
 - 
getMeanpublic double[] getMean() Returns an array whose ith entry is the mean of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getMeanin interface- StatisticalMultivariateSummary
- Overrides:
- getMeanin class- MultivariateSummaryStatistics
- Returns:
- the array of component means
 
 - 
getStandardDeviationpublic double[] getStandardDeviation() Returns an array whose ith entry is the standard deviation of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getStandardDeviationin interface- StatisticalMultivariateSummary
- Overrides:
- getStandardDeviationin class- MultivariateSummaryStatistics
- Returns:
- the array of component standard deviations
 
 - 
getCovariancepublic RealMatrix getCovariance() Returns the covariance matrix of the values that have been added.- Specified by:
- getCovariancein interface- StatisticalMultivariateSummary
- Overrides:
- getCovariancein class- MultivariateSummaryStatistics
- Returns:
- the covariance matrix
 
 - 
getMaxpublic double[] getMax() Returns an array whose ith entry is the maximum of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getMaxin interface- StatisticalMultivariateSummary
- Overrides:
- getMaxin class- MultivariateSummaryStatistics
- Returns:
- the array of component maxima
 
 - 
getMinpublic double[] getMin() Returns an array whose ith entry is the minimum of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getMinin interface- StatisticalMultivariateSummary
- Overrides:
- getMinin class- MultivariateSummaryStatistics
- Returns:
- the array of component minima
 
 - 
getGeometricMeanpublic double[] getGeometricMean() Returns an array whose ith entry is the geometric mean of the. ith entries of the arrays that have been added usingMultivariateSummaryStatistics.addValue(double[])- Specified by:
- getGeometricMeanin interface- StatisticalMultivariateSummary
- Overrides:
- getGeometricMeanin class- MultivariateSummaryStatistics
- Returns:
- the array of component geometric means
 
 - 
toStringpublic String toString() Generates a text report displaying summary statistics from values that have been added.- Overrides:
- toStringin class- MultivariateSummaryStatistics
- Returns:
- String with line feeds displaying statistics
 
 - 
clearpublic void clear() Resets all statistics and storage.- Overrides:
- clearin class- MultivariateSummaryStatistics
 
 - 
equalspublic boolean equals(Object object) Returns true iffobjectis aMultivariateSummaryStatisticsinstance and all statistics have the same values as this.- Overrides:
- equalsin class- MultivariateSummaryStatistics
- Parameters:
- object- the object to test equality against.
- Returns:
- true if object equals this
 
 - 
hashCodepublic int hashCode() Returns hash code based on values of statistics.- Overrides:
- hashCodein class- MultivariateSummaryStatistics
- Returns:
- hash code
 
 - 
getSumImplpublic StorelessUnivariateStatistic[] getSumImpl() Returns the currently configured Sum implementation.- Overrides:
- getSumImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the sum
 
 - 
setSumImplpublic void setSumImpl(StorelessUnivariateStatistic[] sumImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the Sum. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setSumImplin class- MultivariateSummaryStatistics
- Parameters:
- sumImpl- the StorelessUnivariateStatistic instance to use for computing the Sum
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getSumsqImplpublic StorelessUnivariateStatistic[] getSumsqImpl() Returns the currently configured sum of squares implementation.- Overrides:
- getSumsqImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the sum of squares
 
 - 
setSumsqImplpublic void setSumsqImpl(StorelessUnivariateStatistic[] sumsqImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the sum of squares. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setSumsqImplin class- MultivariateSummaryStatistics
- Parameters:
- sumsqImpl- the StorelessUnivariateStatistic instance to use for computing the sum of squares
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMinImplpublic StorelessUnivariateStatistic[] getMinImpl() Returns the currently configured minimum implementation.- Overrides:
- getMinImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the minimum
 
 - 
setMinImplpublic void setMinImpl(StorelessUnivariateStatistic[] minImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the minimum. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setMinImplin class- MultivariateSummaryStatistics
- Parameters:
- minImpl- the StorelessUnivariateStatistic instance to use for computing the minimum
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMaxImplpublic StorelessUnivariateStatistic[] getMaxImpl() Returns the currently configured maximum implementation.- Overrides:
- getMaxImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the maximum
 
 - 
setMaxImplpublic void setMaxImpl(StorelessUnivariateStatistic[] maxImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the maximum. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setMaxImplin class- MultivariateSummaryStatistics
- Parameters:
- maxImpl- the StorelessUnivariateStatistic instance to use for computing the maximum
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getSumLogImplpublic StorelessUnivariateStatistic[] getSumLogImpl() Returns the currently configured sum of logs implementation.- Overrides:
- getSumLogImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the log sum
 
 - 
setSumLogImplpublic void setSumLogImpl(StorelessUnivariateStatistic[] sumLogImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the sum of logs. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setSumLogImplin class- MultivariateSummaryStatistics
- Parameters:
- sumLogImpl- the StorelessUnivariateStatistic instance to use for computing the log sum
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getGeoMeanImplpublic StorelessUnivariateStatistic[] getGeoMeanImpl() Returns the currently configured geometric mean implementation.- Overrides:
- getGeoMeanImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the geometric mean
 
 - 
setGeoMeanImplpublic void setGeoMeanImpl(StorelessUnivariateStatistic[] geoMeanImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the geometric mean. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setGeoMeanImplin class- MultivariateSummaryStatistics
- Parameters:
- geoMeanImpl- the StorelessUnivariateStatistic instance to use for computing the geometric mean
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMeanImplpublic StorelessUnivariateStatistic[] getMeanImpl() Returns the currently configured mean implementation.- Overrides:
- getMeanImplin class- MultivariateSummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the mean
 
 - 
setMeanImplpublic void setMeanImpl(StorelessUnivariateStatistic[] meanImpl) throws DimensionMismatchException, MathIllegalStateException Sets the implementation for the mean. This method must be activated before any data has been added - i.e., before addValuehas been used to add data; otherwise an IllegalStateException will be thrown.- Overrides:
- setMeanImplin class- MultivariateSummaryStatistics
- Parameters:
- meanImpl- the StorelessUnivariateStatistic instance to use for computing the mean
- Throws:
- DimensionMismatchException- if the array dimension does not match the one used at construction
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 
- 
 
-