diff --git a/lib/node_modules/@stdlib/array/fixed-endian-factory/README.md b/lib/node_modules/@stdlib/array/fixed-endian-factory/README.md
index 84beae70a578..40b7970589b3 100644
--- a/lib/node_modules/@stdlib/array/fixed-endian-factory/README.md
+++ b/lib/node_modules/@stdlib/array/fixed-endian-factory/README.md
@@ -306,6 +306,38 @@ var v = arr.get( 0 );
// returns 1.0
```
+
+
+#### TypedArrayFE.prototype.at( i )
+
+Returns an array element located at integer position (index) `i`, with support for both nonnegative and negative integer positions.
+
+```javascript
+var Float64ArrayFE = fixedEndianFactory( 'float64' );
+
+var arr = new Float64ArrayFE( 'little-endian', [ 1.0, 2.0, 3.0 ] );
+
+var out = arr.at( 0 );
+// returns 1.0
+
+out = arr.at( -1 );
+// returns 3.0
+```
+
+If provided an out-of-bounds index, the method returns `undefined`.
+
+```javascript
+var Float64ArrayFE = fixedEndianFactory( 'float64' );
+
+var arr = new Float64ArrayFE( 'little-endian', [ 1.0, 2.0, 3.0 ] );
+
+var v = arr.at( 100 );
+// returns undefined
+
+v = arr.at( -100 );
+// returns undefined
+```
+
#### TypedArrayFE.prototype.forEach( callbackFn\[, thisArg] )
diff --git a/lib/node_modules/@stdlib/array/fixed-endian-factory/benchmark/benchmark.at.js b/lib/node_modules/@stdlib/array/fixed-endian-factory/benchmark/benchmark.at.js
new file mode 100644
index 000000000000..e1971ef5236f
--- /dev/null
+++ b/lib/node_modules/@stdlib/array/fixed-endian-factory/benchmark/benchmark.at.js
@@ -0,0 +1,146 @@
+/**
+* @license Apache-2.0
+*
+* 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.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*/
+
+'use strict';
+
+// MODULES //
+
+var bench = require( '@stdlib/bench' );
+var isNumber = require( '@stdlib/assert/is-number' ).isPrimitive;
+var pkg = require( './../package.json' ).name;
+var factory = require( './../lib' );
+
+
+// VARIABLES //
+
+var Float64ArrayFE = factory( 'float64' );
+
+
+// MAIN //
+
+bench( pkg+'::nonnegative_indices:at:endianness=little-endian', function benchmark( b ) {
+ var arr;
+ var N;
+ var v;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+ arr = new Float64ArrayFE( 'little-endian', arr );
+ N = arr.length;
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ v = arr.at( i % N );
+ if ( typeof v !== 'number' ) {
+ b.fail( 'should return a number' );
+ }
+ }
+ b.toc();
+ if ( !isNumber( v ) ) {
+ b.fail( 'should return a number' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::negative_indices:at:endianness=little-endian', function benchmark( b ) {
+ var arr;
+ var N;
+ var v;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+ arr = new Float64ArrayFE( 'little-endian', arr );
+ N = arr.length;
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ v = arr.at( -( i % N ) - 1 );
+ if ( typeof v !== 'number' ) {
+ b.fail( 'should return a number' );
+ }
+ }
+ b.toc();
+ if ( !isNumber( v ) ) {
+ b.fail( 'should return a number' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::nonnegative_indices:at:endianness=big-endian', function benchmark( b ) {
+ var arr;
+ var N;
+ var v;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 1000; i++ ) {
+ arr.push( i );
+ }
+ arr = new Float64ArrayFE( 'big-endian', arr );
+ N = arr.length;
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ v = arr.at( i % N );
+ if ( typeof v !== 'number' ) {
+ b.fail( 'should return a number' );
+ }
+ }
+ b.toc();
+ if ( !isNumber( v ) ) {
+ b.fail( 'should return a number' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::negative_indices:at:endianness=big-endian', function benchmark( b ) {
+ var arr;
+ var N;
+ var v;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 1000; i++ ) {
+ arr.push( i );
+ }
+ arr = new Float64ArrayFE( 'big-endian', arr );
+ N = arr.length;
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ v = arr.at( -( i % N ) - 1 );
+ if ( typeof v !== 'number' ) {
+ b.fail( 'should return a number' );
+ }
+ }
+ b.toc();
+ if ( !isNumber( v ) ) {
+ b.fail( 'should return a number' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
diff --git a/lib/node_modules/@stdlib/array/fixed-endian-factory/lib/main.js b/lib/node_modules/@stdlib/array/fixed-endian-factory/lib/main.js
index f87d12884fe6..055b436b4ffc 100644
--- a/lib/node_modules/@stdlib/array/fixed-endian-factory/lib/main.js
+++ b/lib/node_modules/@stdlib/array/fixed-endian-factory/lib/main.js
@@ -23,6 +23,7 @@
// MODULES //
var isNonNegativeInteger = require( '@stdlib/assert/is-nonnegative-integer' ).isPrimitive;
+var isInteger = require( '@stdlib/assert/is-integer' ).isPrimitive;
var isCollection = require( '@stdlib/assert/is-collection' );
var isArrayBuffer = require( '@stdlib/assert/is-arraybuffer' );
var isObject = require( '@stdlib/assert/is-object' );
@@ -457,6 +458,36 @@ function factory( dtype ) { // eslint-disable-line max-lines-per-function, stdli
return new this( order, args );
});
+ /**
+ * Returns an array element located at integer position (index) `i`, with support for both nonnegative and negative integer indices.
+ *
+ * @private
+ * @name at
+ * @memberof TypedArray.prototype
+ * @type {Function}
+ * @param {integer} idx - element index
+ * @throws {TypeError} `this` must be a typed array instance
+ * @throws {TypeError} must provide an integer
+ * @returns {(*|void)} array element
+ */
+ setReadOnly( TypedArray.prototype, 'at', function at( idx ) {
+ var len;
+ if ( !isTypedArray( this ) ) {
+ throw new TypeError( format( 'invalid invocation. `this` is not %s %s.', CHAR2ARTICLE[ dtype[0] ], CTOR_NAME ) );
+ }
+ if ( !isInteger( idx ) ) {
+ throw new TypeError( format( 'invalid argument. Must provide an integer. Value: `%s`.', idx ) );
+ }
+ len = this._length;
+ if ( idx < 0 ) {
+ idx += len;
+ }
+ if ( idx < 0 || idx >= len ) {
+ return;
+ }
+ return this._buffer[ GETTER ]( idx * BYTES_PER_ELEMENT, this._isLE );
+ });
+
/**
* Pointer to the underlying data buffer.
*
diff --git a/lib/node_modules/@stdlib/array/fixed-endian-factory/test/test.at.js b/lib/node_modules/@stdlib/array/fixed-endian-factory/test/test.at.js
new file mode 100644
index 000000000000..a46c5f4191cd
--- /dev/null
+++ b/lib/node_modules/@stdlib/array/fixed-endian-factory/test/test.at.js
@@ -0,0 +1,153 @@
+/**
+* @license Apache-2.0
+*
+* 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.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*/
+
+'use strict';
+
+// MODULES //
+
+var tape = require( 'tape' );
+var hasOwnProp = require( '@stdlib/assert/has-own-property' );
+var isFunction = require( '@stdlib/assert/is-function' );
+var factory = require( './../lib' );
+
+
+// TESTS //
+
+tape( 'main export is a function', function test( t ) {
+ t.ok( true, __filename );
+ t.strictEqual( typeof factory, 'function', 'main export is a function' );
+ t.end();
+});
+
+tape( 'the function returns a function', function test( t ) {
+ var ctor = factory( 'float64' );
+ t.strictEqual( isFunction( ctor ), true, 'returns expected value' );
+ t.end();
+});
+
+tape( 'attached to the prototype of the returned function is an `at` method', function test( t ) {
+ var ctor = factory( 'float64' );
+ t.strictEqual( hasOwnProp( ctor.prototype, 'at' ), true, 'returns expected value' );
+ t.strictEqual( isFunction( ctor.prototype.at ), true, 'returns expected value' );
+ t.end();
+});
+
+tape( 'the method throws an error if invoked with a `this` context which is not a typed array instance', function test( t ) {
+ var values;
+ var ctor;
+ var arr;
+ var i;
+
+ ctor = factory( 'float64' );
+ arr = new ctor( 'little-endian', 5 );
+
+ values = [
+ '5',
+ 5,
+ NaN,
+ true,
+ false,
+ null,
+ void 0,
+ {},
+ [],
+ function noop() {}
+ ];
+ for ( i = 0; i < values.length; i++ ) {
+ t.throws( badValue( values[i] ), TypeError, 'throws an error when provided '+values[i] );
+ }
+ t.end();
+
+ function badValue( value ) {
+ return function badValue() {
+ return arr.at.call( value, 0 );
+ };
+ }
+});
+
+tape( 'the method throws an error if provided an index argument which is not an integer', function test( t ) {
+ var values;
+ var ctor;
+ var arr;
+ var i;
+
+ ctor = factory( 'float64' );
+ arr = new ctor( 'little-endian', [ 1.0, 2.0, 3.0, 4.0 ] );
+
+ values = [
+ '5',
+ 3.14,
+ NaN,
+ true,
+ false,
+ null,
+ void 0,
+ {},
+ [],
+ function noop() {}
+ ];
+ for ( i = 0; i < values.length; i++ ) {
+ t.throws( badValue( values[i] ), TypeError, 'throws an error when provided '+values[i] );
+ }
+ t.end();
+
+ function badValue( value ) {
+ return function badValue() {
+ return arr.at( value );
+ };
+ }
+});
+
+tape( 'the method returns `undefined` if provided an index which exceeds array dimensions', function test( t ) {
+ var ctor;
+ var arr;
+ var v;
+ var i;
+
+ ctor = factory( 'float64' );
+ arr = new ctor( 'little-endian', [ 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0 ] );
+
+ for ( i = -arr.length; i < arr.length; i++ ) {
+ if ( i < 0 ) {
+ v = arr.at( i - arr.length );
+ t.strictEqual( v, void 0, 'returns expected value for index '+(i-arr.length) );
+ } else {
+ v = arr.at( arr.length+i );
+ t.strictEqual( v, void 0, 'returns expected value for index '+(arr.length+i) );
+ }
+ }
+ t.end();
+});
+
+tape( 'the method returns an array element', function test( t ) {
+ var expected;
+ var ctor;
+ var arr;
+ var v;
+ var i;
+
+ ctor = factory( 'float64' );
+ arr = new ctor( 'little-endian', [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+ expected = [ 1.0, 2.0, 3.0, 4.0, 5.0, 1.0, 2.0, 3.0, 4.0, 5.0 ];
+
+ for ( i = -arr.length; i < arr.length; i++ ) {
+ v = arr.at( i );
+ t.strictEqual( v, expected[ i + arr.length ], 'returns expected value' );
+ }
+ t.end();
+});