any
Syntax
any(func, args...)
Arguments
func is a function.
args are the required parameters of func. They can be vectors/matrices/tables. They do not need to have the same data form, but they must have the same size. Data size is the number of elements for a vector, the number of columns for a matrix, and the number of rows for a table.
Details
Apply a function on each element of all arguments. The template runs through each element of a vector, each column of a matrix, and each row of a table. It stops execution and returns a true value as soon as one function call returns a true value. It returns a false value if all function calls return false values.
Examples
Template any
on a vector:
x = 1 2 3 11 12 13 NULL 102 103;
y = x cut 3;
y;
// output: ([1,2,3],[11,12,13],[,102,103])
any(hasNull, y);
// output: 1
// check if any of [1,2,3],[11,12,13],[,102,103] has null values;
x=1 25 7 15 11 197 16 18 23;
y=x cut 3;
y;
// output: ([1,25,7],[15,11,197],[16,18,23])
any(in, 7 8 23, y);
// output: 1
// return true since 7 is in [1, 25, 7], although 8 is not in [15,11,197]
any(in, 8 20 19, y);
// output: 0
// 8 is not in [1,25,7], 20 is not in [15,11,197], and 19 is not in [16,18,23]
any(lt, 4 5 6, 1 2 3);
// output: 0
// check if 4<1, 5<2 and 6<3
any(<, 4 5 6, 1 7 3);
// output: 1
// return true as 5<7 is true
Template any
on a matrix. For a matrix, the template runs through
each column.
x=1..6$2:3;
x;
#0 | #1 | #2 |
---|---|---|
1 | 3 | 5 |
2 | 4 | 6 |
any(in, 6 1 4, x);
// output: 0
any(in, 3 4 2, x);
// output: 1
// return true as 4 is in the second column of matrix x
Template any
on a table. For a table, the template runs through each
row. In the following example, we define a function varscompare
to
compare the values of 2 variables in a table.
x=table(1 2 3 as a, 4 5 6 as b);
x;
a | b |
---|---|
1 | 4 |
2 | 5 |
3 | 6 |
def varscompare(t): t.a>t.b;
any(varscompare, x);
// output: 0
y=table(1 7 3 as a, 4 5 6 as b);
y;
a | b |
---|---|
1 | 4 |
7 | 5 |
3 | 6 |
any(varscompare, y);
// output: 1
//return true as 7>5 is true