|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectuk.ac.starlink.ttools.func.Arrays
public class Arrays
Functions which operate on array-valued cells. The array parameters of these functions can only be used on values which are already arrays (usually, numeric arrays). In most cases that means on values in table columns which are declared as array-valued. FITS and VOTable tables can have columns which contain array values, but other formats such as CSV cannot.
If you want to calculate aggregating functions like sum, min, max etc
on multiple values which are not part of an array,
it's easier to use the functions from the Lists
class.
Note that none of these functions will calculate statistical functions over a whole column of a table.
The functions fall into a number of categories:
size
,
count
,
countTrue
,
maximum
,
minimum
,
sum
,
mean
,
median
,
quantile
,
stdev
,
variance
,
join
.
add
,
subtract
,
multiply
,
divide
,
reciprocal
,
condition
.
array
,
which lets you assemble an array value from a list of scalar numbers.
This can be used with the aggregating functions here,
but it's generally easier to use the corresponding functions from
the Lists
class.
Method Summary | |
---|---|
static double[] |
add(Object array,
double constant)
Returns the result of adding a constant value to every element of a numeric array. |
static double[] |
add(Object array1,
Object array2)
Returns the result of adding two numeric arrays element by element. |
static double[] |
array(double... values)
Returns a floating point numeric array built from the given arguments. |
static double[] |
condition(boolean[] flagArray,
double trueValue,
double falseValue)
Maps a boolean array to a numeric array by using supplied numeric values to represent true and false values from the input array. |
static int |
count(Object array)
Returns the number of non-blank elements in the array. |
static int |
countTrue(boolean[] array)
Returns the number of true elements in an array of boolean values. |
static double[] |
divide(Object array1,
Object array2)
Returns the result of dividing two numeric arrays element by element. |
static int[] |
intArray(int... values)
Returns an integer numeric array built from the given arguments. |
static String |
join(Object array,
String joiner)
Returns a string composed of concatenating all the elements of an array, separated by a joiner string. |
static double |
maximum(Object array)
Returns the largest of the non-blank elements in the array. |
static double |
mean(Object array)
Returns the mean of all the non-blank elements in the array. |
static double |
median(Object array)
Returns the median of the non-blank elements in the array. |
static double |
minimum(Object array)
Returns the smallest of the non-blank elements in the array. |
static double[] |
multiply(Object array,
double constant)
Returns the result of multiplying every element of a numeric array by a constant value. |
static double[] |
multiply(Object array1,
Object array2)
Returns the result of multiplying two numeric arrays element by element. |
static double |
quantile(Object array,
double quant)
Returns a quantile value of the non-blank elements in the array. |
static double[] |
reciprocal(Object array)
Returns the result of taking the reciprocal of every element of a numeric array. |
static int |
size(Object array)
Returns the number of elements in the array. |
static double |
stdev(Object array)
Returns the population standard deviation of all the non-blank elements in the array. |
static String[] |
stringArray(String... values)
Returns a String array built from the given arguments. |
static double[] |
subtract(Object array1,
Object array2)
Returns the result of subtracting one numeric array from the other element by element. |
static double |
sum(Object array)
Returns the sum of all the non-blank elements in the array. |
static double |
variance(Object array)
Returns the population variance of all the non-blank elements in the array. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Method Detail |
---|
public static double sum(Object array)
array
is not a numeric array, null
is returned.
array
- array of numbers
array
public static double mean(Object array)
array
is not a numeric array, null
is returned.
array
- array of numbers
array
public static double variance(Object array)
array
is not a numeric array,
null
is returned.
array
- array of numbers
array
public static double stdev(Object array)
array
is not a numeric array,
null
is returned.
array
- array of numbers
array
public static double minimum(Object array)
array
is not a numeric array, null
is returned.
array
- array of numbers
array
public static double maximum(Object array)
array
is not a numeric array, null
is returned.
array
- array of numbers
array
public static double median(Object array)
array
is not a numeric array, null
is returned.
array
- array of numbers
array
public static double quantile(Object array, double quant)
quant
value;
values of 0, 0.5 and 1 give the minimum, median and maximum
respectively. A value of 0.99 would give the 99th percentile.
array
- array of numbersquant
- number in the range 0-1 deterining which quantile
to calculate
quant
public static int size(Object array)
array
is not an array, zero is returned.
array
- array
array
public static int count(Object array)
array
is not an array, zero is returned.
array
- array (may or may not be numeric)
array
public static int countTrue(boolean[] array)
array
- array of true/false values
array
public static String join(Object array, String joiner)
array
is not an array, null is returned.
array
- array of numbers or stringsjoiner
- text string to interpose between adjacent elements
array
elements separated by
joiner
stringsjoin(array(1.5,2.1,-3.9), "; ") = "1.5; 2.1; -3.9"
public static double[] add(Object array1, Object array2)
null
is returned.
The types of the arrays do not need to be the same,
so for example it is permitted to add an integer array
to a floating point array.
array1
- first array of numeric valuesarray2
- second array of numeric values
array1
and array2
,
the same length as the input arraysadd(array(1,2,3), array(0.1,0.2,0.3))
= [1.1, 2.2, 3.3]
public static double[] add(Object array, double constant)
array
argument is not a numeric array,
null
is returned.
array
- array inputconstant
- value to add to each array element
array
parameteradd(array(1,2,3), 10) = [11,12,13]
public static double[] subtract(Object array1, Object array2)
null
is returned.
The types of the arrays do not need to be the same,
so for example it is permitted to subtract an integer array
from a floating point array.
array1
- first array of numeric valuesarray2
- second array of numeric values
array1
and array2
,
the same length as the input arrayssubtract(array(1,2,3), array(0.1,0.2,0.3))
= [0.9, 1.8, 2.7]
public static double[] multiply(Object array1, Object array2)
null
is returned.
The types of the arrays do not need to be the same,
so for example it is permitted to multiply an integer array
by a floating point array.
array1
- first array of numeric valuesarray2
- second array of numeric values
array1
and array2
,
the same length as the input arraysmultiply(array(1,2,3), array(2,4,6)) = [2, 8, 18]
public static double[] multiply(Object array, double constant)
array
argument is not a numeric array,
null
is returned.
array
- array inputconstant
- value by which to multiply each array element
array
parametermultiply(array(1,2,3), 2) = [2, 4, 6]
public static double[] divide(Object array1, Object array2)
null
is returned.
The types of the arrays do not need to be the same,
so for example it is permitted to divide an integer array
by a floating point array.
array1
- array of numerator values (numeric)array2
- array of denominator values (numeric)
array1[i]/array2[i]
the same length as the input arraysdivide(array(0,9,4), array(1,3,8)) = [0, 3, 0.5]
public static double[] reciprocal(Object array)
array
argument is not a numeric array,
null
is returned.
array
- array input
array
parameterreciprocal(array(1,2,0.25) = [1, 0.5, 4]
public static double[] condition(boolean[] flagArray, double trueValue, double falseValue)
This has the same effect as applying the expression
outArray[i] = flagArray[i] ? trueValue : falseValue
.
flagArray
- array of boolean valuestrueValue
- output value corresponding to an input true valuefalseValue
- output value corresponding to an input false value
flagArray
condition([true, false, true], 1, 0) = [1, 0, 1]
public static double[] array(double... values)
values
- one or more array elements
public static int[] intArray(int... values)
values
- one or more array elements
public static String[] stringArray(String... values)
values
- one or more array elements
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |