map2d

Apply a function to each nested element in an array of arrays and assign the result to a nested element in a new array of arrays.

Usage

var map2d = require( '@stdlib/utils/map2d' );

map2d( arr, fcn[, thisArg] )

Applies a function to each nested element in an array of arrays and assigns the result to a nested element in a new array of arrays.

var naryFunction = require( '@stdlib/utils/nary-function' );
var abs = require( '@stdlib/math/base/special/abs' );

var arr = [
    [ -1, -2, -3 ],
    [ -4, -5, -6 ]
];

var out = map2d( arr, naryFunction( abs, 1 ) );
// returns [ [ 1, 2, 3 ], [ 4, 5, 6 ] ]

The applied function is provided the following arguments:

  • value: array element.
  • i: index of the first dimension.
  • j: index of the second dimension.
  • arr: input array.

To set the this context when invoking the input function, provide a thisArg.

var abs = require( '@stdlib/math/base/special/abs' );

function fcn( v ) {
    this.count += 1;
    return abs( v );
}

var arr = [
    [ -1, -2, -3 ],
    [ -4, -5, -6 ]
];

var ctx = {
    'count': 0
};

var out = map2d( arr, fcn, ctx );
// returns [ [ 1, 2, 3 ], [ 4, 5, 6 ] ]

var cnt = ctx.count;
// returns 6

Examples

var filledarrayBy = require( '@stdlib/array/filled-by' );
var discreteUniform = require( '@stdlib/random/base/discrete-uniform' ).factory;
var naryFunction = require( '@stdlib/utils/nary-function' );
var abs2 = require( '@stdlib/math/base/special/abs2' );
var map2d = require( '@stdlib/utils/map2d' );

function fill( i ) {
    var rand = discreteUniform( -10*(i+1), 10*(i+1) );
    return filledarrayBy( 10, 'float64', rand );
}

// Create a nested array of arrays:
var x = filledarrayBy( 10, 'generic', fill );

// Create an explicit unary function:
var f = naryFunction( abs2, 1 );

// Compute the element-wise squared absolute value...
var y = map2d( x, f );

console.log( 'x:' );
console.log( x );

console.log( 'y:' );
console.log( y );
Did you find this page helpful?