public class SymbolicGeometricMean extends AbstractSymbolicStorelessUnivariateStatistic implements java.io.Serializable
Uses a SumOfLogs
instance to compute sum of logs and returns
exp( 1/n (sum of logs) ).
Therefore,
NaN.
Double.POSITIVE_INFINITY
, but at least one value is 0, the
result is 0.
Double.POSITIVE_INFINITY
and
Double.NEGATIVE_INFINITY
are among the values, the result is
NaN.
Note that this implementation is not synchronized. If
multiple threads access an instance of this class concurrently, and at least
one of the threads invokes the increment()
or
clear()
method, it must be synchronized externally.
Constructor and Description |
---|
SymbolicGeometricMean()
Create a GeometricMean instance
|
SymbolicGeometricMean(SymbolicSumOfLogs sumOfLogs)
Create a GeometricMean instance using the given SumOfLogs instance
|
Modifier and Type | Method and Description |
---|---|
void |
clear()
Clears the internal state of the Statistic
|
IExpr |
evaluate(IAST values,
int begin,
int length)
Returns the geometric mean of the entries in the specified portion of the
input array.
|
long |
getN()
Returns the number of values that have been added.
|
IExpr |
getResult()
Returns the current value of the Statistic.
|
AbstractSymbolicStorelessUnivariateStatistic |
getSumLogImpl()
Returns the currently configured sum of logs implementation
|
void |
increment(IExpr d)
Updates the internal state of the statistic to reflect the addition of the
new value.
|
void |
setSumLogImpl(AbstractSymbolicStorelessUnivariateStatistic sumLogImpl)
Sets the implementation for the sum of logs.
|
evaluate, incrementAll, incrementAll, test, test, test, test
public SymbolicGeometricMean()
public SymbolicGeometricMean(SymbolicSumOfLogs sumOfLogs)
sumOfLogs
- sum of logs instance to use for computationpublic void increment(IExpr d)
increment
in interface StorelessSymbolicUnivariateStatistic
increment
in class AbstractSymbolicStorelessUnivariateStatistic
d
- the new value.public IExpr getResult()
getResult
in interface StorelessSymbolicUnivariateStatistic
getResult
in class AbstractSymbolicStorelessUnivariateStatistic
Double.NaN
if it has been
cleared or just instantiated.public void clear()
clear
in interface StorelessSymbolicUnivariateStatistic
clear
in class AbstractSymbolicStorelessUnivariateStatistic
public IExpr evaluate(IAST values, int begin, int length)
See SymbolicGeometricMean
for details on the computing algorithm.
Throws IllegalArgumentException
if the array is null.
evaluate
in interface SymbolicUnivariateStatistic
evaluate
in class AbstractSymbolicStorelessUnivariateStatistic
values
- input array containing the valuesbegin
- first array element to includelength
- the number of elements to includejava.lang.IllegalArgumentException
- if the input array is null or the array index parameters are not
validUnivariateStatistic.evaluate(double[],
int, int)
public long getN()
getN
in interface StorelessSymbolicUnivariateStatistic
getN
in class AbstractSymbolicStorelessUnivariateStatistic
public void setSumLogImpl(AbstractSymbolicStorelessUnivariateStatistic sumLogImpl)
Sets the implementation for the sum of logs.
This method must be activated before any data has been added - i.e., before
increment
has been used to add data; otherwise
an IllegalStateException will be thrown.
sumLogImpl
- the StorelessUnivariateStatistic instance to use for computing the
log sumjava.lang.IllegalStateException
- if data has already been added (i.e if n > 0)public AbstractSymbolicStorelessUnivariateStatistic getSumLogImpl()