diff --git a/lib/node_modules/@stdlib/utils/copy-within/README.md b/lib/node_modules/@stdlib/utils/copy-within/README.md
new file mode 100644
index 000000000000..fe85ff4e5392
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/README.md
@@ -0,0 +1,131 @@
+
+
+# copyWithin
+
+> Copy a part of a collection to another location in the same collection.
+
+
+
+
+
+
+
+
+
+
+
+## Usage
+
+```javascript
+var copyWithin = require( '@stdlib/utils/copy-within' );
+```
+
+#### copyWithin( collection, target\[, start\[, end\]\] )
+
+Copies a part of a `collection` to another location in the same `collection`. A `collection` may be either an [`Array`][mdn-array], [`Typed Array`][mdn-typed-array], or an array-like [`Object`][mdn-object] (i.e., an [`Object`][mdn-object] having a valid writable `length` property).
+
+```javascript
+var arr = [ 1, 2, 3, 4, 5 ];
+
+var out = copyWithin( arr, 0, 2, 4 );
+// returns [ 3, 4, 3, 4, 5 ]
+
+var bool = ( out === arr );
+// returns true
+```
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+## Examples
+
+
+
+```javascript
+var Float64Array= require( '@stdlib/array/float64' );
+var copyWithin = require( '@stdlib/utils/copy-within' );
+
+var bool;
+var arr;
+var out;
+
+arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+out = copyWithin( arr, 0, 2, 4 );
+// returns [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+
+bool = ( out === arr );
+// returns true
+
+arr = [ 1, 2, 3, 4, 5 ];
+out = copyWithin( arr, 0, 3, 4 );
+// returns [ 4, 2, 3, 4, 5 ]
+
+bool = ( out === arr );
+// returns true
+
+out = copyWithin( arr, 1, 3 );
+// returns [ 4, 4, 5, 4, 5 ]
+
+bool = ( out === arr );
+// returns true
+```
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+[mdn-array]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array
+
+[mdn-typed-array]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Typed_arrays
+
+[mdn-object]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object
+
+
+
+
diff --git a/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.js b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.js
new file mode 100644
index 000000000000..86362afad8d5
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.js
@@ -0,0 +1,53 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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 isCollection = require( '@stdlib/assert/is-collection' );
+var pkg = require( './../package.json' ).name;
+var copyWithin = require( './../lib' );
+
+
+// MAIN //
+
+bench( pkg+'::array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
diff --git a/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.length.js b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.length.js
new file mode 100644
index 000000000000..49397b37659c
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.length.js
@@ -0,0 +1,128 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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 pow = require( '@stdlib/math/base/special/pow' );
+var isCollection = require( '@stdlib/assert/is-collection' );
+var typedarray = require( '@stdlib/array/typed' );
+var pkg = require( './../package.json' ).name;
+var copyWithin = require( './../lib' );
+
+
+// FUNCTIONS //
+
+/**
+* Creates a benchmark function.
+*
+* @private
+* @param {PositiveInteger} len - array length
+* @param {string} dtype - data type
+* @returns {Function} benchmark function
+*/
+function createBenchmark( len, dtype ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < len; i++ ) {
+ arr[ i ] = i;
+ }
+ arr = typedarray( arr, dtype );
+ return benchmark;
+
+ /**
+ * Benchmark function.
+ *
+ * @private
+ * @param {Benchmark} b - benchmark instance
+ */
+ function benchmark( b ) {
+ var out;
+ var i;
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ out = copyWithin( arr, i%len );
+ if ( !isCollection( out ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( out ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+ }
+}
+
+
+// MAIN //
+
+/**
+* Main execution sequence.
+*
+* @private
+*/
+function main() {
+ var len;
+ var min;
+ var max;
+ var f;
+ var i;
+
+ min = 1; // 10^min
+ max = 6; // 10^max
+
+ for ( i = min; i <= max; i++ ) {
+ len = pow( 10, i );
+
+ f = createBenchmark( len, 'float64' );
+ bench( pkg+':len='+len+',dtype=float64', f );
+
+ f = createBenchmark( len, 'float32' );
+ bench( pkg+':len='+len+',dtype=float32', f );
+
+ f = createBenchmark( len, 'int32' );
+ bench( pkg+':len='+len+',dtype=int32', f );
+
+ f = createBenchmark( len, 'int16' );
+ bench( pkg+':len='+len+',dtype=int16', f );
+
+ f = createBenchmark( len, 'int8' );
+ bench( pkg+':len='+len+',dtype=int8', f );
+
+ f = createBenchmark( len, 'uint32' );
+ bench( pkg+':len='+len+',dtype=uint32', f );
+
+ f = createBenchmark( len, 'uint16' );
+ bench( pkg+':len='+len+',dtype=uint16', f );
+
+ f = createBenchmark( len, 'uint8' );
+ bench( pkg+':len='+len+',dtype=uint8', f );
+
+ f = createBenchmark( len, 'uint8c' );
+ bench( pkg+':len='+len+',dtype=uint8c', f );
+ }
+}
+
+main();
diff --git a/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.object.js b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.object.js
new file mode 100644
index 000000000000..5a4538a2144f
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.object.js
@@ -0,0 +1,62 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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 isCollection = require( '@stdlib/assert/is-collection' );
+var pkg = require( './../package.json' ).name;
+var copyWithin = require( './../lib' );
+
+
+// MAIN //
+
+bench( pkg+'::object', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = {
+ 'length': 10,
+ '0': 0,
+ '1': 1,
+ '2': 2,
+ '3': 3,
+ '4': 4,
+ '5': 5,
+ '6': 6,
+ '7': 7,
+ '8': 8,
+ '9': 9
+ };
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
diff --git a/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.typed_array.js b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.typed_array.js
new file mode 100644
index 000000000000..23bff2f983ca
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/benchmark/benchmark.typed_array.js
@@ -0,0 +1,272 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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 isCollection = require( '@stdlib/assert/is-collection' );
+var Float32Array = require( '@stdlib/array/float32' );
+var Float64Array = require( '@stdlib/array/float64' );
+var Int8Array = require( '@stdlib/array/int8' );
+var Int16Array = require( '@stdlib/array/int16' );
+var Int32Array = require( '@stdlib/array/int32' );
+var Uint8Array = require( '@stdlib/array/uint8' );
+var Uint8ClampedArray = require( '@stdlib/array/uint8c' );
+var Uint16Array = require( '@stdlib/array/uint16' );
+var Uint32Array = require( '@stdlib/array/uint32' );
+var pkg = require( './../package.json' ).name;
+var copyWithin = require( './../lib' );
+
+
+// MAIN //
+
+bench( pkg+'::float64array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Float64Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::float32array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Float32Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::int32array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Int32Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::uint32array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Uint32Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::int16array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Int16Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::uint16array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Uint16Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::int8array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Int8Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::uint8array', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Uint8Array( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
+
+bench( pkg+'::uint8clampedarray', function benchmark( b ) {
+ var arr;
+ var i;
+
+ arr = [];
+ for ( i = 0; i < 10; i++ ) {
+ arr.push( i );
+ }
+
+ arr = new Uint8ClampedArray( arr );
+
+ b.tic();
+ for ( i = 0; i < b.iterations; i++ ) {
+ arr = copyWithin( arr, i % 10 );
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ }
+ b.toc();
+ if ( !isCollection( arr ) ) {
+ b.fail( 'should return an array-like object' );
+ }
+ b.pass( 'benchmark finished' );
+ b.end();
+});
diff --git a/lib/node_modules/@stdlib/utils/copy-within/docs/repl.txt b/lib/node_modules/@stdlib/utils/copy-within/docs/repl.txt
new file mode 100644
index 000000000000..2ad92ad92849
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/docs/repl.txt
@@ -0,0 +1,45 @@
+
+{{alias}}( collection, target[, start[, end]] )
+ Copies a part of a collection to another location in the same collection.
+
+ Parameters
+ ----------
+ collection: Array|TypedArray|Object
+ A collection. If the collection is an `Object`, the collection should
+ be array-like.
+
+ target: integer
+ Zero-based index at which to copy the sequence to.
+
+ start: integer (optional)
+ Zero-based index at which to start copying elements from. Default: 0.
+
+ end: integer (optional)
+ Zero-based index at which to end copying elements from.
+ Default: collection.length.
+
+ Returns
+ -------
+ out: Array|TypedArray|Object
+ Updated collection.
+
+ Examples
+ --------
+ // Arrays:
+ > var arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+ > arr = {{alias}}( arr, 0, 2, 4 )
+ [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+
+ // Typed arrays:
+ > arr = new {{alias:@stdlib/array/float64}}( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+ > arr = {{alias}}( arr, 1 )
+ [ 1.0, 1.0, 2.0, 3.0, 4.0 ]
+
+ // Array-like object:
+ > arr = { 'length': 5, '0': 1.0, '1': 2.0, '2': 3.0, '3': 4.0, '4': 5.0 };
+ > arr = {{alias}}( arr, 0, 1, 4 )
+ { 'length': 5, '0': 2.0, '1': 3.0, '2': 4.0, '3': 4.0, '4': 5.0 }
+
+ See Also
+ --------
+
diff --git a/lib/node_modules/@stdlib/utils/copy-within/docs/types/index.d.ts b/lib/node_modules/@stdlib/utils/copy-within/docs/types/index.d.ts
new file mode 100644
index 000000000000..6e308a17cda9
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/docs/types/index.d.ts
@@ -0,0 +1,58 @@
+/*
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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.
+*/
+
+// TypeScript Version: 2.0
+
+///
+
+import { Collection } from '@stdlib/types/object';
+
+/**
+* Copies a part of a collection to another location in the same collection.
+*
+* @param collection - collection
+* @param target - target index
+* @param start - source start index (default: 0)
+* @param end - source end index (default: collection.length)
+* @throws first argument must be a collection
+* @throws second argument must be an integer
+* @throws third argument must be an integer
+* @throws fourth argument must be an integer
+* @returns updated collection
+*
+* @example
+* var arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+*
+* arr = copyWithin( arr, 0, 2, 4 );
+* // returns [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+*
+* @example
+* var Float64Array = require( `@stdlib/array/float64` );
+*
+* var arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+* // returns [ 1.0, 2.0, 3.0, 4.0, 5.0 ]
+*
+* arr = copyWithin( arr, 1 );
+* // returns [ 1.0, 1.0, 2.0, 3.0, 4.0 ]
+*/
+declare function copyWithin( collection: Collection, target: number, start?: number, end?: number ): Collection; // tslint-disable-line max-line-length
+
+
+// EXPORTS //
+
+export = copyWithin;
diff --git a/lib/node_modules/@stdlib/utils/copy-within/docs/types/test.ts b/lib/node_modules/@stdlib/utils/copy-within/docs/types/test.ts
new file mode 100644
index 000000000000..7a03240847bd
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/docs/types/test.ts
@@ -0,0 +1,42 @@
+/*
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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.
+*/
+
+import copyWithin = require( './index' );
+
+
+// TESTS //
+
+// The function returns the updated input collection ...
+{
+ copyWithin( [ 2, 3 ], 1 ); // $ExpectType Collection
+ copyWithin( [ 'a', 'b', 'c' ], 0, 1 ); // $ExpectType Collection
+ copyWithin( [ true, false ], 1 ); // $ExpectType Collection
+ copyWithin( [ true, true, 1, 2, 3 ], 1, 2, 4 ); // $ExpectType Collection
+}
+
+// The compiler throws an error if the function is provided a first argument which is not a collection...
+{
+ copyWithin( true ); // $ExpectError
+ copyWithin( false ); // $ExpectError
+ copyWithin( 5 ); // $ExpectError
+}
+
+// The compiler throws an error if the function is not provided at least one argument...
+{
+ copyWithin(); // $ExpectError
+}
diff --git a/lib/node_modules/@stdlib/utils/copy-within/examples/index.js b/lib/node_modules/@stdlib/utils/copy-within/examples/index.js
new file mode 100644
index 000000000000..84ef4c7975b6
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/examples/index.js
@@ -0,0 +1,41 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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';
+
+var Float64Array = require( '@stdlib/array/float64' );
+var copyWithin = require( './../lib' );
+
+var arr;
+var out;
+
+arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+out = copyWithin( arr, 1 );
+console.log( out );
+// => [ 1.0, 1.0, 2.0, 3.0, 4.0 ]
+
+console.log( out === arr );
+// => true
+
+arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+out = copyWithin( arr, 0, 2, 4 );
+console.log( out );
+// => [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+
+console.log( out === arr );
+// => true
diff --git a/lib/node_modules/@stdlib/utils/copy-within/lib/index.js b/lib/node_modules/@stdlib/utils/copy-within/lib/index.js
new file mode 100644
index 000000000000..a87a8a1ce34f
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/lib/index.js
@@ -0,0 +1,49 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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';
+
+/**
+* Copy a part of a collection to another location in the same collection.
+*
+* @module @stdlib/utils/copy-within
+*
+* @example
+* var copyWithin = require( '@stdlib/utils/copy-within' );
+* var Float64Array = require( '@stdlib/array/float64' );
+*
+* var arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+*
+* arr = copyWithin( arr, 0, 2, 4 );
+* // returns [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+*
+* arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+* // returns [ 1.0, 2.0, 3.0, 4.0, 5.0 ]
+*
+* arr = copyWithin( arr, 1 );
+* // returns [ 1.0, 1.0, 2.0, 3.0, 4.0 ]
+*/
+
+// MODULES //
+
+var copyWithin = require( './main.js' );
+
+
+// EXPORTS //
+
+module.exports = copyWithin;
diff --git a/lib/node_modules/@stdlib/utils/copy-within/lib/main.js b/lib/node_modules/@stdlib/utils/copy-within/lib/main.js
new file mode 100644
index 000000000000..89c0685914a4
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/lib/main.js
@@ -0,0 +1,132 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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 isCollection = require( '@stdlib/assert/is-collection' );
+var isInteger = require( '@stdlib/assert/is-integer' );
+var max = require( '@stdlib/math/base/special/max' );
+var min = require( '@stdlib/math/base/special/min' );
+
+
+// MAIN //
+
+/**
+* Copies a part of a collection to another location in the same collection.
+*
+* @param {Collection} collection - input collection
+* @param {integer} target - target index
+* @param {integer} [start=0] - source start index
+* @param {integer} [end=collection.length] - source end index
+* @throws {TypeError} first argument must be a collection
+* @throws {TypeError} second argument must be an integer
+* @throws {TypeError} third argument must be an integer
+* @throws {TypeError} fourth argument must be an integer
+* @returns {Collection} modified input collection
+*
+* @example
+* var arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+*
+* arr = copyWithin( arr, 0, 2, 4 );
+* // returns [ 3.0, 4.0, 3.0, 4.0, 5.0 ]
+*
+* @example
+* var Float64Array = require( '@stdlib/array/float64' );
+*
+* var arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+* // returns [ 1.0, 2.0, 3.0, 4.0, 5.0 ]
+*
+* arr = copyWithin( arr, 0, 3, 4 );
+* // returns [ 4.0, 2.0, 3.0, 4.0, 5.0 ]
+*/
+function copyWithin( collection, target, start, end ) {
+ var direction;
+ var count;
+ var final;
+ var from;
+ var len;
+ var to;
+ if ( !isCollection( collection ) ) {
+ throw new TypeError( 'invalid argument. First argument must be a collection. Value: `'+collection+'`.' );
+ }
+ if ( !isInteger( target ) ) {
+ throw new TypeError( 'invalid argument. Second argument must be an integer. Value: `'+target+'`.' );
+ }
+
+ len = collection.length;
+ from = 0;
+ final = len;
+ if ( arguments.length > 2 ) {
+ if ( !isInteger( start ) ) {
+ throw new TypeError( 'invalid argument. Third argument must be an integer. Value: `'+start+'`.' );
+ }
+ from = start;
+
+ if ( arguments.length === 4 ) {
+ if ( !isInteger( end ) ) {
+ throw new TypeError( 'invalid argument. Fourth argument must be an integer. Value: `'+end+'`.' );
+ }
+ final = end;
+ }
+ }
+
+ to = target;
+ if ( to < 0 ) {
+ to = max( 0, to + len );
+ } else {
+ to = min( to, len );
+ }
+ if ( from < 0 ) {
+ from = max( 0, from + len );
+ } else {
+ from = min( from, len );
+ }
+ if ( final < 0 ) {
+ final = max( 0, final + len );
+ } else {
+ final = min( final, len );
+ }
+
+ count = min( final-from, len-to );
+ direction = 1;
+ if ( from < to && to < ( from+count ) ) {
+ direction = -1;
+ from += count - 1;
+ to += count - 1;
+ }
+
+ while ( count > 0 ) {
+ if ( from in collection ) {
+ collection[ to ] = collection[ from ];
+ } else {
+ delete collection[ to ];
+ }
+ from += direction;
+ to += direction;
+ count -= 1;
+ }
+
+ return collection;
+}
+
+
+// EXPORTS //
+
+module.exports = copyWithin;
diff --git a/lib/node_modules/@stdlib/utils/copy-within/package.json b/lib/node_modules/@stdlib/utils/copy-within/package.json
new file mode 100644
index 000000000000..a32a6b4e3f2c
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/package.json
@@ -0,0 +1,78 @@
+{
+ "name": "@stdlib/utils/copy-within",
+ "version": "0.0.0",
+ "description": "Copy a part of a collection to another location in the same collection.",
+ "license": "Apache-2.0",
+ "author": {
+ "name": "The Stdlib Authors",
+ "url": "https://github.com/stdlib-js/stdlib/graphs/contributors"
+ },
+ "contributors": [
+ {
+ "name": "The Stdlib Authors",
+ "url": "https://github.com/stdlib-js/stdlib/graphs/contributors"
+ }
+ ],
+ "main": "./lib",
+ "directories": {
+ "benchmark": "./benchmark",
+ "doc": "./docs",
+ "example": "./examples",
+ "lib": "./lib",
+ "test": "./test"
+ },
+ "types": "./docs/types",
+ "scripts": {},
+ "homepage": "https://github.com/stdlib-js/stdlib",
+ "repository": {
+ "type": "git",
+ "url": "git://github.com/stdlib-js/stdlib.git"
+ },
+ "bugs": {
+ "url": "https://github.com/stdlib-js/stdlib/issues"
+ },
+ "dependencies": {},
+ "devDependencies": {},
+ "engines": {
+ "node": ">=0.10.0",
+ "npm": ">2.7.0"
+ },
+ "os": [
+ "aix",
+ "darwin",
+ "freebsd",
+ "linux",
+ "macos",
+ "openbsd",
+ "sunos",
+ "win32",
+ "windows"
+ ],
+ "keywords": [
+ "stdlib",
+ "stdutils",
+ "stdutil",
+ "utilities",
+ "utility",
+ "utils",
+ "util",
+ "array",
+ "typed array",
+ "typed-array",
+ "float64array",
+ "float32array",
+ "int32array",
+ "uint32array",
+ "int16array",
+ "uint16array",
+ "int8array",
+ "uint8array",
+ "uint8clampedarray",
+ "array-like",
+ "object",
+ "obj",
+ "copywithin",
+ "copy within",
+ "memmove"
+ ]
+}
diff --git a/lib/node_modules/@stdlib/utils/copy-within/test/test.js b/lib/node_modules/@stdlib/utils/copy-within/test/test.js
new file mode 100644
index 000000000000..a3f97e1fcb6b
--- /dev/null
+++ b/lib/node_modules/@stdlib/utils/copy-within/test/test.js
@@ -0,0 +1,152 @@
+/**
+* @license Apache-2.0
+*
+* Copyright (c) 2020 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.
+*/
+
+/* eslint-disable object-curly-newline */
+
+'use strict';
+
+// MODULES //
+
+var tape = require( 'tape' );
+var Float64Array = require( '@stdlib/array/float64' );
+var copyWithin = require( './../lib' );
+
+
+// TESTS //
+
+tape( 'main export is a function', function test( t ) {
+ t.ok( true, __filename );
+ t.strictEqual( typeof copyWithin, 'function', 'main export is a function' );
+ t.end();
+});
+
+tape( 'the function throws an error if not provided either an array, typed array, or an array-like object', function test( t ) {
+ var values;
+ var i;
+
+ values = [
+ '5',
+ 5,
+ NaN,
+ true,
+ false,
+ null,
+ undefined,
+ function noop() {},
+ new Date(),
+ {},
+ { 'length': null },
+ { 'length': -1 },
+ { 'length': 3.14 }
+ ];
+
+ for ( i = 0; i < values.length; i++ ) {
+ t.throws( badValue( values[ i ] ), TypeError, 'throws a type error when provided '+values[i] );
+ }
+ t.end();
+
+ function badValue( value ) {
+ return function badValue() {
+ copyWithin( value, 0 );
+ };
+ }
+});
+
+tape( 'the function copies a part of an array to another location in the same array', function test( t ) {
+ var expected;
+ var arr;
+ var out;
+
+ arr = [ 1.0, 2.0, 3.0, 4.0, 5.0 ];
+ out = copyWithin( arr, 0, 2, 4 );
+
+ t.strictEqual( out, arr, 'returns expected value' );
+
+ expected = [ 3.0, 4.0, 3.0, 4.0, 5.0 ];
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ out = copyWithin( arr, 2, 1, 5 ); // target is after start
+
+ expected = [ 3.0, 4.0, 4.0, 3.0, 4.0 ];
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ t.end();
+});
+
+tape( 'the function copies a part of an array-like object to another location in the same array-like object', function test( t ) {
+ var expected;
+ var arr;
+ var out;
+
+ arr = {
+ 'length': 5,
+ '0': 1.0,
+ '1': 2.0,
+ '2': 3.0,
+ '3': 4.0,
+ '4': 5.0
+ };
+ out = copyWithin( arr, 0, 2, 4 );
+
+ t.strictEqual( out, arr, 'returns expected value' );
+
+ expected = {
+ 'length': 5,
+ '0': 3.0,
+ '1': 4.0,
+ '2': 3.0,
+ '3': 4.0,
+ '4': 5.0
+ };
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ out = copyWithin( arr, 2, 1, 5 ); // target is after start
+
+ expected = {
+ 'length': 5,
+ '0': 3.0,
+ '1': 4.0,
+ '2': 4.0,
+ '3': 3.0,
+ '4': 4.0
+ };
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ t.end();
+});
+
+tape( 'the function copies a part of a typed array to another location in the same typed array', function test( t ) {
+ var expected;
+ var arr;
+ var out;
+
+ arr = new Float64Array( [ 1.0, 2.0, 3.0, 4.0, 5.0 ] );
+ out = copyWithin( arr, 0, 2, 4 );
+
+ t.strictEqual( out, arr, 'returns expected value' );
+
+ expected = new Float64Array( [ 3.0, 4.0, 3.0, 4.0, 5.0 ] );
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ out = copyWithin( arr, 2, 1, 5 ); // target is after start
+
+ expected = new Float64Array( [ 3.0, 4.0, 4.0, 3.0, 4.0 ] );
+ t.deepEqual( arr, expected, 'returns expected value' );
+
+ t.end();
+});