From 082d2e98bb97b40f3ae8bbb1965728fe58747df1 Mon Sep 17 00:00:00 2001 From: Jaysukh Makvana <111515433+Jaysukh-409@users.noreply.github.com> Date: Sun, 7 Jul 2024 00:59:34 +0530 Subject: [PATCH] feat: add boolean dtype support to `strided/base/binary-addon-dispatch` PR-URL: https://github.com/stdlib-js/stdlib/pull/2526 Ref: https://github.com/stdlib-js/stdlib/issues/2500 Reviewed-by: Athan Reines --- .../base/binary-addon-dispatch/lib/main.js | 10 ++++- .../base/binary-addon-dispatch/lib/ndarray.js | 10 ++++- .../binary-addon-dispatch/test/test.main.js | 42 ++++++++++++++++++- .../test/test.ndarray.js | 42 ++++++++++++++++++- 4 files changed, 100 insertions(+), 4 deletions(-) diff --git a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/main.js b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/main.js index 11d94df26a64..d6295abdcf85 100644 --- a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/main.js +++ b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/main.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2021 The Stdlib Authors. +* Copyright (c) 2024 The Stdlib Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -27,6 +27,7 @@ var isTypedArrayLike = require( '@stdlib/assert/is-typed-array-like' ); var resolve = require( '@stdlib/strided/base/dtype-resolve-enum' ); var reinterpretComplex64 = require( '@stdlib/strided/base/reinterpret-complex64' ); var reinterpretComplex128 = require( '@stdlib/strided/base/reinterpret-complex128' ); +var reinterpretBoolean = require( '@stdlib/strided/base/reinterpret-boolean' ); var format = require( '@stdlib/string/format' ); @@ -34,6 +35,7 @@ var format = require( '@stdlib/string/format' ); var COMPLEX64 = resolve( 'complex64' ); var COMPLEX128 = resolve( 'complex128' ); +var BOOLEAN = resolve( 'bool' ); // MAIN // @@ -173,6 +175,8 @@ function dispatch( addon, fallback ) { viewX = reinterpretComplex64( x, 0 ); } else if ( dtypeX === COMPLEX128 ) { viewX = reinterpretComplex128( x, 0 ); + } else if ( dtypeX === BOOLEAN ) { + viewX = reinterpretBoolean( x, 0 ); } else { viewX = x; } @@ -180,6 +184,8 @@ function dispatch( addon, fallback ) { viewY = reinterpretComplex64( y, 0 ); } else if ( dtypeY === COMPLEX128 ) { viewY = reinterpretComplex128( y, 0 ); + } else if ( dtypeY === BOOLEAN ) { + viewY = reinterpretBoolean( y, 0 ); } else { viewY = y; } @@ -187,6 +193,8 @@ function dispatch( addon, fallback ) { viewZ = reinterpretComplex64( z, 0 ); } else if ( dtypeZ === COMPLEX128 ) { viewZ = reinterpretComplex128( z, 0 ); + } else if ( dtypeZ === BOOLEAN ) { + viewZ = reinterpretBoolean( z, 0 ); } else { viewZ = z; } diff --git a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/ndarray.js b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/ndarray.js index 998562af3dc7..7c6449e22587 100644 --- a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/ndarray.js +++ b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/lib/ndarray.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2021 The Stdlib Authors. +* Copyright (c) 2024 The Stdlib Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,6 +28,7 @@ var isNonNegativeInteger = require( '@stdlib/assert/is-nonnegative-integer' ).is var resolve = require( '@stdlib/strided/base/dtype-resolve-enum' ); var reinterpretComplex64 = require( '@stdlib/strided/base/reinterpret-complex64' ); var reinterpretComplex128 = require( '@stdlib/strided/base/reinterpret-complex128' ); +var reinterpretBoolean = require( '@stdlib/strided/base/reinterpret-boolean' ); var offsetView = require( '@stdlib/strided/base/offset-view' ); var minViewBufferIndex = require( '@stdlib/strided/base/min-view-buffer-index' ); var format = require( '@stdlib/string/format' ); @@ -37,6 +38,7 @@ var format = require( '@stdlib/string/format' ); var COMPLEX64 = resolve( 'complex64' ); var COMPLEX128 = resolve( 'complex128' ); +var BOOLEAN = resolve( 'bool' ); // MAIN // @@ -200,6 +202,8 @@ function dispatch( addon, fallback ) { viewX = reinterpretComplex64( x, offsetX ); } else if ( dtypeX === COMPLEX128 ) { viewX = reinterpretComplex128( x, offsetX ); + } else if ( dtypeX === BOOLEAN ) { + viewX = reinterpretBoolean( x, offsetX ); } else { viewX = offsetView( x, offsetX ); } @@ -207,6 +211,8 @@ function dispatch( addon, fallback ) { viewY = reinterpretComplex64( y, offsetY ); } else if ( dtypeY === COMPLEX128 ) { viewY = reinterpretComplex128( y, offsetY ); + } else if ( dtypeY === BOOLEAN ) { + viewY = reinterpretBoolean( y, offsetY ); } else { viewY = offsetView( y, offsetY ); } @@ -214,6 +220,8 @@ function dispatch( addon, fallback ) { viewZ = reinterpretComplex64( z, offsetZ ); } else if ( dtypeZ === COMPLEX128 ) { viewZ = reinterpretComplex128( z, offsetZ ); + } else if ( dtypeZ === BOOLEAN ) { + viewZ = reinterpretBoolean( z, offsetZ ); } else { viewZ = offsetView( z, offsetZ ); } diff --git a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.main.js b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.main.js index 55b939302564..e1980891e7c9 100644 --- a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.main.js +++ b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.main.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2021 The Stdlib Authors. +* Copyright (c) 2024 The Stdlib Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -25,8 +25,10 @@ var noop = require( '@stdlib/utils/noop' ); var Float64Array = require( '@stdlib/array/float64' ); var Complex64Array = require( '@stdlib/array/complex64' ); var Complex128Array = require( '@stdlib/array/complex128' ); +var BooleanArray = require( '@stdlib/array/bool' ); var isFloat32Array = require( '@stdlib/assert/is-float32array' ); var isFloat64Array = require( '@stdlib/assert/is-float64array' ); +var isUint8Array = require( '@stdlib/assert/is-uint8array' ); var resolve = require( '@stdlib/strided/base/dtype-resolve-enum' ); var dispatch = require( './../lib' ); @@ -134,6 +136,44 @@ tape( 'the function returns a function which dispatches to an addon function whe } }); +tape( 'the function returns a function which dispatches to an addon function when provided typed arrays (bool)', function test( t ) { + var f; + var x; + var y; + var z; + + f = dispatch( addon, fallback ); + + x = new BooleanArray( 2 ); + y = new BooleanArray( x.length ); + z = new BooleanArray( x.length ); + + f( x.length, 'bool', x, 1, 'bool', y, 1, 'bool', z, 1 ); + + t.end(); + + function addon( N, dx, ax, sx, dy, ay, sy, dz, az, sz ) { + t.ok( true, 'called addon' ); + t.strictEqual( N, x.length, 'returns expected value' ); + t.strictEqual( dx, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( ax ), true, 'returns expected value' ); + t.strictEqual( ax.buffer, x.buffer, 'returns expected value' ); + t.strictEqual( sx, 1, 'returns expected value' ); + t.strictEqual( dy, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( ay ), true, 'returns expected value' ); + t.strictEqual( ay.buffer, y.buffer, 'returns expected value' ); + t.strictEqual( sy, 1, 'returns expected value' ); + t.strictEqual( dz, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( az ), true, 'returns expected value' ); + t.strictEqual( az.buffer, z.buffer, 'returns expected value' ); + t.strictEqual( sz, 1, 'returns expected value' ); + } + + function fallback() { + t.ok( false, 'called fallback' ); + } +}); + tape( 'the function returns a function which dispatches to an addon function when provided typed arrays (complex64)', function test( t ) { var f; var x; diff --git a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.ndarray.js b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.ndarray.js index 62187fd6ad76..cdf9880d43e3 100644 --- a/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.ndarray.js +++ b/lib/node_modules/@stdlib/strided/base/binary-addon-dispatch/test/test.ndarray.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2021 The Stdlib Authors. +* Copyright (c) 2024 The Stdlib Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -27,8 +27,10 @@ var noop = require( '@stdlib/utils/noop' ); var Float64Array = require( '@stdlib/array/float64' ); var Complex64Array = require( '@stdlib/array/complex64' ); var Complex128Array = require( '@stdlib/array/complex128' ); +var BooleanArray = require( '@stdlib/array/bool' ); var isFloat32Array = require( '@stdlib/assert/is-float32array' ); var isFloat64Array = require( '@stdlib/assert/is-float64array' ); +var isUint8Array = require( '@stdlib/assert/is-uint8array' ); var resolve = require( '@stdlib/strided/base/dtype-resolve-enum' ); var dispatch = require( './../lib/ndarray.js' ); @@ -256,6 +258,44 @@ tape( 'the function returns a function which dispatches to an addon function whe } }); +tape( 'the function returns a function which dispatches to an addon function when provided typed arrays (bool)', function test( t ) { + var f; + var x; + var y; + var z; + + f = dispatch( addon, fallback ); + + x = new BooleanArray( 2 ); + y = new BooleanArray( x.length ); + z = new BooleanArray( x.length ); + + f( x.length, 'bool', x, 1, 0, 'bool', y, 1, 0, 'bool', z, 1, 0 ); + + t.end(); + + function addon( N, dx, ax, sx, dy, ay, sy, dz, az, sz ) { + t.ok( true, 'called addon' ); + t.strictEqual( N, x.length, 'returns expected value' ); + t.strictEqual( dx, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( ax ), true, 'returns expected value' ); + t.strictEqual( ax.buffer, x.buffer, 'returns expected value' ); + t.strictEqual( sx, 1, 'returns expected value' ); + t.strictEqual( dy, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( ay ), true, 'returns expected value' ); + t.strictEqual( ay.buffer, y.buffer, 'returns expected value' ); + t.strictEqual( sy, 1, 'returns expected value' ); + t.strictEqual( dz, resolve( 'bool' ), 'returns expected value' ); + t.strictEqual( isUint8Array( az ), true, 'returns expected value' ); + t.strictEqual( az.buffer, z.buffer, 'returns expected value' ); + t.strictEqual( sz, 1, 'returns expected value' ); + } + + function fallback() { + t.ok( false, 'called fallback' ); + } +}); + tape( 'the function returns a function which dispatches to an addon function when provided typed arrays (complex64)', function test( t ) { var f; var x;