Class SynchronizedSummaryStatistics
- java.lang.Object
- 
- org.apache.commons.math4.legacy.stat.descriptive.SummaryStatistics
- 
- org.apache.commons.math4.legacy.stat.descriptive.SynchronizedSummaryStatistics
 
 
- 
- All Implemented Interfaces:
- StatisticalSummary
 
 public class SynchronizedSummaryStatistics extends SummaryStatistics Implementation ofSummaryStatisticsthat 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 SynchronizedSummaryStatistics()Construct a SynchronizedSummaryStatistics instance.SynchronizedSummaryStatistics(SynchronizedSummaryStatistics original)A copy constructor.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddValue(double value)Add a value to the data.voidclear()Resets all statistics and storage.SynchronizedSummaryStatisticscopy()Returns a copy of this SynchronizedSummaryStatistics instance with the same internal state.static voidcopy(SynchronizedSummaryStatistics source, SynchronizedSummaryStatistics dest)Copies source to dest.booleanequals(Object object)Returns true iffobjectis aSummaryStatisticsinstance and all statistics have the same values as this.StorelessUnivariateStatisticgetGeoMeanImpl()Returns the currently configured geometric mean implementation.doublegetGeometricMean()Returns the geometric mean of the values that have been added.doublegetMax()Returns the maximum of the values that have been added.StorelessUnivariateStatisticgetMaxImpl()Returns the currently configured maximum implementation.doublegetMean()Returns the mean of the values that have been added.StorelessUnivariateStatisticgetMeanImpl()Returns the currently configured mean implementation.doublegetMin()Returns the minimum of the values that have been added.StorelessUnivariateStatisticgetMinImpl()Returns the currently configured minimum implementation.longgetN()Returns the number of available values.doublegetPopulationVariance()Returns the population variance of the values that have been added.doublegetQuadraticMean()Returns the quadratic mean, a.k.a.doublegetStandardDeviation()Returns the standard deviation of the values that have been added.doublegetSum()Returns the sum of the values that have been added.StorelessUnivariateStatisticgetSumImpl()Returns the currently configured Sum implementation.StorelessUnivariateStatisticgetSumLogImpl()Returns the currently configured sum of logs implementation.StatisticalSummarygetSummary()Return aStatisticalSummaryValuesinstance reporting current statistics.doublegetSumsq()Returns the sum of the squares of the values that have been added.StorelessUnivariateStatisticgetSumsqImpl()Returns the currently configured sum of squares implementation.doublegetVariance()Returns the (sample) variance of the available values.StorelessUnivariateStatisticgetVarianceImpl()Returns the currently configured variance 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.voidsetVarianceImpl(StorelessUnivariateStatistic varianceImpl)Sets the implementation for the variance.StringtoString()Generates a text report displaying summary statistics from values that have been added.- 
Methods inherited from class org.apache.commons.math4.legacy.stat.descriptive.SummaryStatisticscopy, getSecondMoment, getSumOfLogs
 
- 
 
- 
- 
- 
Constructor Detail- 
SynchronizedSummaryStatisticspublic SynchronizedSummaryStatistics() Construct a SynchronizedSummaryStatistics instance.
 - 
SynchronizedSummaryStatisticspublic SynchronizedSummaryStatistics(SynchronizedSummaryStatistics original) throws NullArgumentException A copy constructor. Creates a deep-copy of theoriginal.- Parameters:
- original- the- SynchronizedSummaryStatisticsinstance to copy
- Throws:
- NullArgumentException- if original is null
 
 
- 
 - 
Method Detail- 
getSummarypublic StatisticalSummary getSummary() Return aStatisticalSummaryValuesinstance reporting current statistics.- Overrides:
- getSummaryin class- SummaryStatistics
- Returns:
- Current values of statistics
 
 - 
addValuepublic void addValue(double value) Add a value to the data.- Overrides:
- addValuein class- SummaryStatistics
- Parameters:
- value- the value to add
 
 - 
getNpublic long getN() Returns the number of available values.- Specified by:
- getNin interface- StatisticalSummary
- Overrides:
- getNin class- SummaryStatistics
- Returns:
- The number of available values
 
 - 
getSumpublic double getSum() Returns the sum of the values that have been added.- Specified by:
- getSumin interface- StatisticalSummary
- Overrides:
- getSumin class- SummaryStatistics
- Returns:
- The sum or Double.NaNif no values have been added
 
 - 
getSumsqpublic double getSumsq() Returns the sum of the squares of the values that have been added.Double.NaN is returned if no values have been added. - Overrides:
- getSumsqin class- SummaryStatistics
- Returns:
- The sum of squares
 
 - 
getMeanpublic double getMean() Returns the mean of the values that have been added.Double.NaN is returned if no values have been added. - Specified by:
- getMeanin interface- StatisticalSummary
- Overrides:
- getMeanin class- SummaryStatistics
- Returns:
- the mean
 
 - 
getStandardDeviationpublic double getStandardDeviation() Returns the standard deviation of the values that have been added.Double.NaN is returned if no values have been added. - Specified by:
- getStandardDeviationin interface- StatisticalSummary
- Overrides:
- getStandardDeviationin class- SummaryStatistics
- Returns:
- the standard deviation
 
 - 
getQuadraticMeanpublic double getQuadraticMean() Returns the quadratic mean, a.k.a. root-mean-square of the available values- Overrides:
- getQuadraticMeanin class- SummaryStatistics
- Returns:
- The quadratic mean or Double.NaNif no values have been added.
 
 - 
getVariancepublic double getVariance() Returns the (sample) variance of the available values.This method returns the bias-corrected sample variance (using n - 1in the denominator). UseSummaryStatistics.getPopulationVariance()for the non-bias-corrected population variance.Double.NaN is returned if no values have been added. - Specified by:
- getVariancein interface- StatisticalSummary
- Overrides:
- getVariancein class- SummaryStatistics
- Returns:
- the variance
 
 - 
getPopulationVariancepublic double getPopulationVariance() Returns the population variance of the values that have been added.Double.NaN is returned if no values have been added. - Overrides:
- getPopulationVariancein class- SummaryStatistics
- Returns:
- the population variance
 
 - 
getMaxpublic double getMax() Returns the maximum of the values that have been added.Double.NaN is returned if no values have been added. - Specified by:
- getMaxin interface- StatisticalSummary
- Overrides:
- getMaxin class- SummaryStatistics
- Returns:
- the maximum
 
 - 
getMinpublic double getMin() Returns the minimum of the values that have been added.Double.NaN is returned if no values have been added. - Specified by:
- getMinin interface- StatisticalSummary
- Overrides:
- getMinin class- SummaryStatistics
- Returns:
- the minimum
 
 - 
getGeometricMeanpublic double getGeometricMean() Returns the geometric mean of the values that have been added.Double.NaN is returned if no values have been added. - Overrides:
- getGeometricMeanin class- SummaryStatistics
- Returns:
- the geometric mean
 
 - 
toStringpublic String toString() Generates a text report displaying summary statistics from values that have been added.- Overrides:
- toStringin class- SummaryStatistics
- Returns:
- String with line feeds displaying statistics
 
 - 
clearpublic void clear() Resets all statistics and storage.- Overrides:
- clearin class- SummaryStatistics
 
 - 
equalspublic boolean equals(Object object) Returns true iffobjectis aSummaryStatisticsinstance and all statistics have the same values as this.- Overrides:
- equalsin class- SummaryStatistics
- 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- SummaryStatistics
- Returns:
- hash code
 
 - 
getSumImplpublic StorelessUnivariateStatistic getSumImpl() Returns the currently configured Sum implementation.- Overrides:
- getSumImplin class- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the sum
 
 - 
setSumImplpublic void setSumImpl(StorelessUnivariateStatistic sumImpl) throws MathIllegalStateException Sets the implementation for the Sum. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setSumImplin class- SummaryStatistics
- Parameters:
- sumImpl- the StorelessUnivariateStatistic instance to use for computing the Sum
- Throws:
- 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- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the sum of squares
 
 - 
setSumsqImplpublic void setSumsqImpl(StorelessUnivariateStatistic sumsqImpl) throws MathIllegalStateException Sets the implementation for the sum of squares. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setSumsqImplin class- SummaryStatistics
- Parameters:
- sumsqImpl- the StorelessUnivariateStatistic instance to use for computing the sum of squares
- Throws:
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMinImplpublic StorelessUnivariateStatistic getMinImpl() Returns the currently configured minimum implementation.- Overrides:
- getMinImplin class- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the minimum
 
 - 
setMinImplpublic void setMinImpl(StorelessUnivariateStatistic minImpl) throws MathIllegalStateException Sets the implementation for the minimum. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setMinImplin class- SummaryStatistics
- Parameters:
- minImpl- the StorelessUnivariateStatistic instance to use for computing the minimum
- Throws:
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMaxImplpublic StorelessUnivariateStatistic getMaxImpl() Returns the currently configured maximum implementation.- Overrides:
- getMaxImplin class- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the maximum
 
 - 
setMaxImplpublic void setMaxImpl(StorelessUnivariateStatistic maxImpl) throws MathIllegalStateException Sets the implementation for the maximum. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setMaxImplin class- SummaryStatistics
- Parameters:
- maxImpl- the StorelessUnivariateStatistic instance to use for computing the maximum
- Throws:
- 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- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the log sum
 
 - 
setSumLogImplpublic void setSumLogImpl(StorelessUnivariateStatistic sumLogImpl) throws MathIllegalStateException Sets the implementation for the sum of logs. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setSumLogImplin class- SummaryStatistics
- Parameters:
- sumLogImpl- the StorelessUnivariateStatistic instance to use for computing the log sum
- Throws:
- 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- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the geometric mean
 
 - 
setGeoMeanImplpublic void setGeoMeanImpl(StorelessUnivariateStatistic geoMeanImpl) throws MathIllegalStateException Sets the implementation for the geometric mean. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setGeoMeanImplin class- SummaryStatistics
- Parameters:
- geoMeanImpl- the StorelessUnivariateStatistic instance to use for computing the geometric mean
- Throws:
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getMeanImplpublic StorelessUnivariateStatistic getMeanImpl() Returns the currently configured mean implementation.- Overrides:
- getMeanImplin class- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the mean
 
 - 
setMeanImplpublic void setMeanImpl(StorelessUnivariateStatistic meanImpl) throws MathIllegalStateException Sets the implementation for the mean. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setMeanImplin class- SummaryStatistics
- Parameters:
- meanImpl- the StorelessUnivariateStatistic instance to use for computing the mean
- Throws:
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
getVarianceImplpublic StorelessUnivariateStatistic getVarianceImpl() Returns the currently configured variance implementation.- Overrides:
- getVarianceImplin class- SummaryStatistics
- Returns:
- the StorelessUnivariateStatistic implementing the variance
 
 - 
setVarianceImplpublic void setVarianceImpl(StorelessUnivariateStatistic varianceImpl) throws MathIllegalStateException Sets the implementation for the variance. This method cannot be activated after data has been added - i.e., after addValuehas been used to add data. If it is activated after data has been added, an IllegalStateException will be thrown.- Overrides:
- setVarianceImplin class- SummaryStatistics
- Parameters:
- varianceImpl- the StorelessUnivariateStatistic instance to use for computing the variance
- Throws:
- MathIllegalStateException- if data has already been added (i.e if n > 0)
 
 - 
copypublic SynchronizedSummaryStatistics copy() Returns a copy of this SynchronizedSummaryStatistics instance with the same internal state.- Overrides:
- copyin class- SummaryStatistics
- Returns:
- a copy of this
 
 - 
copypublic static void copy(SynchronizedSummaryStatistics source, SynchronizedSummaryStatistics dest) throws NullArgumentException Copies source to dest.Neither source nor dest can be null. Acquires synchronization lock on source, then dest before copying. - Parameters:
- source- SynchronizedSummaryStatistics to copy
- dest- SynchronizedSummaryStatistics to copy to
- Throws:
- NullArgumentException- if either source or dest is null
 
 
- 
 
-