public class Kurtosis extends AbstractStorelessUnivariateStatistic implements Serializable
We use the following (unbiased) formula to define kurtosis:
kurtosis = { [n(n+1) / (n -1)(n - 2)(n-3)] sum[(x_i - mean)^4] / std^4 } - [3(n-1)^2 / (n-2)(n-3)]
where n is the number of values, mean is the Mean
and std is the
StandardDeviation
.
Note that this statistic is undefined for n < 4. Double.Nan
is returned when there is not sufficient data to compute the statistic.
Note that Double.NaN may also be returned if the input includes NaN
and / or infinite values.
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.
Modifier and Type | Field and Description |
---|---|
protected boolean |
incMoment
Determines whether or not this statistic can be incremented or cleared.
|
protected org.hipparchus.stat.descriptive.moment.FourthMoment |
moment
Fourth Moment on which this statistic is based
|
Constructor and Description |
---|
Kurtosis()
Construct a Kurtosis.
|
Kurtosis(org.hipparchus.stat.descriptive.moment.FourthMoment m4)
Construct a Kurtosis from an external moment.
|
Kurtosis(Kurtosis original)
Copy constructor, creates a new
Kurtosis identical
to the original . |
Modifier and Type | Method and Description |
---|---|
void |
clear()
Clears the internal state of the Statistic
|
Kurtosis |
copy()
Returns a copy of the statistic with the same internal state.
|
double |
evaluate(double[] values,
int begin,
int length)
Returns the kurtosis of the entries in the specified portion of the
input array.
|
long |
getN()
Returns the number of values that have been added.
|
double |
getResult()
Returns the current value of the Statistic.
|
void |
increment(double d)
Updates the internal state of the statistic to reflect the addition of the new value.
|
equals, hashCode, toString
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
accept, incrementAll, incrementAll
evaluate
andThen
protected final org.hipparchus.stat.descriptive.moment.FourthMoment moment
protected final boolean incMoment
Statistics based on (constructed from) external moments cannot be incremented or cleared.
public Kurtosis()
public Kurtosis(org.hipparchus.stat.descriptive.moment.FourthMoment m4)
m4
- external Momentpublic Kurtosis(Kurtosis original) throws NullArgumentException
Kurtosis
identical
to the original
.original
- the Kurtosis
instance to copyNullArgumentException
- if original is nullpublic void increment(double d)
Note that when Kurtosis(FourthMoment)
is used to
create a Variance, this method does nothing. In that case, the
FourthMoment should be incremented directly.
increment
in interface StorelessUnivariateStatistic
increment
in class AbstractStorelessUnivariateStatistic
d
- the new value.public double getResult()
getResult
in interface StorelessUnivariateStatistic
getResult
in class AbstractStorelessUnivariateStatistic
Double.NaN
if it
has been cleared or just instantiated.public void clear()
clear
in interface StorelessUnivariateStatistic
clear
in class AbstractStorelessUnivariateStatistic
public long getN()
getN
in interface StorelessUnivariateStatistic
public double evaluate(double[] values, int begin, int length) throws MathIllegalArgumentException
See Kurtosis
for details on the computing algorithm.
Throws IllegalArgumentException
if the array is null.
evaluate
in interface StorelessUnivariateStatistic
evaluate
in interface UnivariateStatistic
evaluate
in interface MathArrays.Function
values
- the input arraybegin
- index of the first array element to includelength
- the number of elements to includeMathIllegalArgumentException
- if the input array is null or the array
index parameters are not validUnivariateStatistic.evaluate(double[], int, int)
public Kurtosis copy()
copy
in interface StorelessUnivariateStatistic
copy
in interface UnivariateStatistic
copy
in class AbstractStorelessUnivariateStatistic
Copyright © 2016-2021 CS GROUP. All rights reserved.