public class Sum extends AbstractStorelessUnivariateStatistic implements Serializable
If there are no values in the dataset, then 0 is returned. If any of the values are NaN
, then
NaN
is returned.
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 |
---|
Sum()
Create a Sum instance
|
Sum(Sum original)
Copy constructor, creates a new
Sum identical
to the original |
Modifier and Type | Method and Description |
---|---|
void |
clear()
Clears the internal state of the Statistic
|
Sum |
copy()
Returns a copy of the statistic with the same internal state.
|
static void |
copy(Sum source,
Sum dest)
Copies source to dest.
|
double |
evaluate(double[] values,
double[] weights)
The weighted sum of the entries in the the input array.
|
double |
evaluate(double[] values,
double[] weights,
int begin,
int length)
The weighted sum of the entries in the specified portion of
the input array, or 0 if the designated subarray
is empty.
|
double |
evaluate(double[] values,
int begin,
int length)
The sum of the entries in the specified portion of
the input array, or 0 if the designated subarray
is empty.
|
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, evaluate, hashCode, incrementAll, incrementAll
evaluate, getData, getDataRef, setData, setData, test, test, test, test
public Sum()
public Sum(Sum original)
Sum
identical
to the original
original
- the Sum
instance to copyNullArgumentException
- if original is nullpublic void increment(double d)
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 long getN()
getN
in interface StorelessUnivariateStatistic
public void clear()
clear
in interface StorelessUnivariateStatistic
clear
in class AbstractStorelessUnivariateStatistic
public double evaluate(double[] values, int begin, int length)
Throws MathIllegalArgumentException
if the array is null.
evaluate
in interface UnivariateStatistic
evaluate
in interface MathArrays.Function
evaluate
in class AbstractStorelessUnivariateStatistic
values
- the input arraybegin
- index of the first array element to includelength
- the number of elements to includeMathIllegalArgumentException
- if the array is null or the array index
parameters are not validUnivariateStatistic.evaluate(double[], int, int)
public double evaluate(double[] values, double[] weights, int begin, int length)
Throws MathIllegalArgumentException
if any of the following are true:
Uses the formula,
weighted sum = Σ(values[i] * weights[i])
values
- the input arrayweights
- the weights arraybegin
- index of the first array element to includelength
- the number of elements to includeMathIllegalArgumentException
- if the parameters are not validpublic double evaluate(double[] values, double[] weights)
Throws MathIllegalArgumentException
if any of the following are true:
Uses the formula,
weighted sum = Σ(values[i] * weights[i])
values
- the input arrayweights
- the weights arrayMathIllegalArgumentException
- if the parameters are not validpublic Sum copy()
copy
in interface StorelessUnivariateStatistic
copy
in interface UnivariateStatistic
copy
in class AbstractStorelessUnivariateStatistic
public static void copy(Sum source, Sum dest)
Neither source nor dest can be null.
source
- Sum to copydest
- Sum to copy toNullArgumentException
- if either source or dest is nullCopyright © 2021 CNES. All rights reserved.