take
Syntax
take(X, n)
Arguments
X is a scalar/vector/tuple/matrix/table.
n is an integer or a vector of integers.
Details
-
If X is a scalar (n must also be a scalar): Generates a vector containing n identical values of X.
-
If X is a vector or a tuple:
-
if n is a scalar: takes n elements from X sequentially. It can be left to right (if n > 0) or right to left (if n < 0). The result is a vector.
-
if n is a vector (must be of the same length as X): takes n[i] copies of X[i]. If n[i] <= 0, it skips X[i]. The result is a vector.
-
-
If X is a matrix or table:
-
if n is a scalar: It takes n rows of X sequentially, either from top to bottom (if n > 0) or bottom to top (if n < 0). The result is a matrix or table.
-
if n is a vector (must be of the same length as the number of rows in X): takes n[i] copies of the element at the i-th row of X. If n[i] <= 0, it skips the i-th row and takes no elements. The result is a matrix or table.
-
Examples
take(10,5);
// output: [10,10,10,10,10]
x=`IBM`C`AAPL`BABA;
take(x,10);
// output: ["IBM","C","AAPL","BABA","IBM","C","AAPL","BABA","IBM","C"]
// sequentially and iteratively take 10 elements from vector x
x=3 5 4 6 9;
take(x,3);
// output: [3,5,4]
x=1..3;
x.take(10);
// output: [1,2,3,1,2,3,1,2,3,1]
take(1 2 3, 10);
// output: [1,2,3,1,2,3,1,2,3,1]
take(1,10);
// output: [1,1,1,1,1,1,1,1,1,1]
// an efficient way to generate a vector with default values.
x=take(1,0);
// return an empty INT VECTOR
x;
// output: []
typestr x;
// output: FAST INT VECTOR
x=1..12$3:4;
take(x,2);
// output: [1,2]
take(x,-2);
// output: [11,12]
take(1..3,2 0 2)
// output: [1,1,3,3]
m=matrix(1 2 3, 4 5 6)
take(m,5)
/* output:
col1 col2
1 4
2 5
3 6
1 4
2 5
*/
take(m, 0 2 1)
/* output:
col1 col2
2 5
2 5
3 6
*/
t=table(1 2 3 as a, 4 5 6 as b)
take(t,-4)
/* output:
a b
3 6
1 4
2 5
3 6
*/
take(t, -2 2 1)
/* output:
a b
2 5
2 5
3 6
*/