diff --git a/blas/ext/base/dssumors/coverage.ndjson b/blas/ext/base/dssumors/coverage.ndjson new file mode 100644 index 000000000..660628d28 --- /dev/null +++ b/blas/ext/base/dssumors/coverage.ndjson @@ -0,0 +1 @@ +[429,429,100,44,44,100,4,4,100,429,429,100,"a0d8ed6fb23dddd6b674ebde3013026dd5d8ad7d","2024-04-14 23:08:39 -0400"] diff --git a/blas/ext/base/dssumors/dssumors.js.html b/blas/ext/base/dssumors/dssumors.js.html new file mode 100644 index 000000000..5f982bcca --- /dev/null +++ b/blas/ext/base/dssumors/dssumors.js.html @@ -0,0 +1,355 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/dssumors.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib dssumors.js

+
+ +
+ 100% + Statements + 90/90 +
+ + +
+ 100% + Branches + 19/19 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 90/90 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +912x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +13x +13x +13x +13x +13x +13x +13x +13x +2x +2x +13x +2x +2x +9x +13x +6x +6x +6x +6x +5x +15x +15x +5x +6x +3x +3x +6x +168x +168x +3x +3x +13x +1x +13x +2x +2x +13x +12x +12x +12x +3x +13x +2x +2x +2x +2x +2x + 
/**
+* @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';
+ 
+// VARIABLES //
+ 
+var M = 6;
+ 
+ 
+// MAIN //
+ 
+/**
+* Computes the sum of single-precision floating-point strided array elements using ordinary recursive summation with extended accumulation and returning an extended precision result.
+*
+* @param {PositiveInteger} N - number of indexed elements
+* @param {Float32Array} x - input array
+* @param {integer} stride - stride length
+* @returns {number} sum
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+*
+* var x = new Float32Array( [ 1.0, -2.0, 2.0 ] );
+*
+* var v = dssumors( 3, x, 1 );
+* // returns 1.0
+*/
+function dssumors( N, x, stride ) {
+	var sum;
+	var ix;
+	var m;
+	var i;
+ 
+	sum = 0.0;
+	if ( N <= 0 ) {
+		return sum;
+	}
+	if ( N === 1 || stride === 0 ) {
+		return x[ 0 ];
+	}
+	// If the stride is equal to `1`, use unrolled loops...
+	if ( stride === 1 ) {
+		m = N % M;
+ 
+		// If we have a remainder, run a clean-up loop...
+		if ( m > 0 ) {
+			for ( i = 0; i < m; i++ ) {
+				sum += x[ i ];
+			}
+		}
+		if ( N < M ) {
+			return sum;
+		}
+		for ( i = m; i < N; i += M ) {
+			sum += x[i] + x[i+1] + x[i+2] + x[i+3] + x[i+4] + x[i+5];
+		}
+		return sum;
+	}
+	if ( stride < 0 ) {
+		ix = (1-N) * stride;
+	} else {
+		ix = 0;
+	}
+	for ( i = 0; i < N; i++ ) {
+		sum += x[ ix ];
+		ix += stride;
+	}
+	return sum;
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/dssumors.native.js.html b/blas/ext/base/dssumors/dssumors.native.js.html new file mode 100644 index 000000000..3fdd4f40d --- /dev/null +++ b/blas/ext/base/dssumors/dssumors.native.js.html @@ -0,0 +1,238 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/dssumors.native.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib dssumors.native.js

+
+ +
+ 100% + Statements + 51/51 +
+ + +
+ 100% + Branches + 2/2 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 51/51 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +523x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +51x +51x +51x +3x +3x +3x +3x +3x + 
/**
+* @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 addon = require( './../src/addon.node' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Computes the sum of single-precision floating-point strided array elements using ordinary recursive summation with extended accumulation and returning an extended precision result.
+*
+* @param {PositiveInteger} N - number of indexed elements
+* @param {Float32Array} x - input array
+* @param {integer} stride - stride length
+* @returns {number} sum
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+*
+* var x = new Float32Array( [ 1.0, -2.0, 2.0 ] );
+*
+* var v = dssumors( 3, x, 1 );
+* // returns 1.0
+*/
+function dssumors( N, x, stride ) {
+	return addon( N, x, stride );
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/index.html b/blas/ext/base/dssumors/index.html new file mode 100644 index 000000000..882c66c5f --- /dev/null +++ b/blas/ext/base/dssumors/index.html @@ -0,0 +1,206 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib + + + + + + + + + +
+
+

All files blas/ext/base/dssumors/lib

+
+ +
+ 100% + Statements + 429/429 +
+ + +
+ 100% + Branches + 44/44 +
+ + +
+ 100% + Functions + 4/4 +
+ + +
+ 100% + Lines + 429/429 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
FileStatementsBranchesFunctionsLines
dssumors.js +
+
100%90/90100%19/19100%1/1100%90/90
dssumors.native.js +
+
100%51/51100%2/2100%1/1100%51/51
index.js +
+
100%68/68100%3/3100%0/0100%68/68
main.js +
+
100%35/35100%1/1100%0/0100%35/35
native.js +
+
100%35/35100%1/1100%0/0100%35/35
ndarray.js +
+
100%90/90100%16/16100%1/1100%90/90
ndarray.native.js +
+
100%60/60100%2/2100%1/1100%60/60
+
+
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/index.js.html b/blas/ext/base/dssumors/index.js.html new file mode 100644 index 000000000..4d114a570 --- /dev/null +++ b/blas/ext/base/dssumors/index.js.html @@ -0,0 +1,289 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/index.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib index.js

+
+ +
+ 100% + Statements + 68/68 +
+ + +
+ 100% + Branches + 3/3 +
+ + +
+ 100% + Functions + 0/0 +
+ + +
+ 100% + Lines + 68/68 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +693x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +1x +3x +2x +2x +3x +3x +3x +3x +3x +3x +3x + 
/**
+* @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';
+ 
+/**
+* Compute the sum of single-precision floating-point strided array elements using ordinary recursive summation with extended accumulation and returning an extended precision result.
+*
+* @module @stdlib/blas/ext/base/dssumors
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+* var dssumors = require( '@stdlib/blas/ext/base/dssumors' );
+*
+* var x = new Float32Array( [ 1.0, -2.0, 2.0 ] );
+*
+* var v = dssumors( 3, x, 1 );
+* // returns 1.0
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+* var dssumors = require( '@stdlib/blas/ext/base/dssumors' );
+*
+* var x = new Float32Array( [ 2.0, 1.0, 2.0, -2.0, -2.0, 2.0, 3.0, 4.0 ] );
+*
+* var v = dssumors.ndarray( 4, x, 2, 1 );
+* // returns 5.0
+*/
+ 
+// MODULES //
+ 
+var join = require( 'path' ).join;
+var tryRequire = require( '@stdlib/utils/try-require' );
+var isError = require( '@stdlib/assert/is-error' );
+var main = require( './main.js' );
+ 
+ 
+// MAIN //
+ 
+var dssumors;
+var tmp = tryRequire( join( __dirname, './native.js' ) );
+if ( isError( tmp ) ) {
+	dssumors = main;
+} else {
+	dssumors = tmp;
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+// exports: { "ndarray": "dssumors.ndarray" }
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/main.js.html b/blas/ext/base/dssumors/main.js.html new file mode 100644 index 000000000..b8fdc3a89 --- /dev/null +++ b/blas/ext/base/dssumors/main.js.html @@ -0,0 +1,190 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/main.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib main.js

+
+ +
+ 100% + Statements + 35/35 +
+ + +
+ 100% + Branches + 1/1 +
+ + +
+ 100% + Functions + 0/0 +
+ + +
+ 100% + Lines + 35/35 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +361x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x + 
/**
+* @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 setReadOnly = require( '@stdlib/utils/define-nonenumerable-read-only-property' );
+var dssumors = require( './dssumors.js' );
+var ndarray = require( './ndarray.js' );
+ 
+ 
+// MAIN //
+ 
+setReadOnly( dssumors, 'ndarray', ndarray );
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/native.js.html b/blas/ext/base/dssumors/native.js.html new file mode 100644 index 000000000..590459a3a --- /dev/null +++ b/blas/ext/base/dssumors/native.js.html @@ -0,0 +1,190 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/native.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib native.js

+
+ +
+ 100% + Statements + 35/35 +
+ + +
+ 100% + Branches + 1/1 +
+ + +
+ 100% + Functions + 0/0 +
+ + +
+ 100% + Lines + 35/35 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +361x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x + 
/**
+* @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 setReadOnly = require( '@stdlib/utils/define-nonenumerable-read-only-property' );
+var dssumors = require( './dssumors.native.js' );
+var ndarray = require( './ndarray.native.js' );
+ 
+ 
+// MAIN //
+ 
+setReadOnly( dssumors, 'ndarray', ndarray );
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/ndarray.js.html b/blas/ext/base/dssumors/ndarray.js.html new file mode 100644 index 000000000..ca33c11b7 --- /dev/null +++ b/blas/ext/base/dssumors/ndarray.js.html @@ -0,0 +1,355 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/ndarray.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib ndarray.js

+
+ +
+ 100% + Statements + 90/90 +
+ + +
+ 100% + Branches + 16/16 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 90/90 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +912x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +13x +13x +13x +13x +13x +13x +13x +13x +2x +2x +13x +2x +2x +9x +9x +9x +13x +6x +6x +6x +6x +5x +15x +15x +15x +5x +6x +3x +3x +6x +168x +168x +168x +3x +3x +13x +12x +12x +12x +3x +13x +2x +2x +2x +2x +2x + 
/**
+* @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';
+ 
+// VARIABLES //
+ 
+var M = 6;
+ 
+ 
+// MAIN //
+ 
+/**
+* Computes the sum of single-precision floating-point strided array elements using ordinary recursive summation with extended accumulation and returning an extended precision result.
+*
+* @param {PositiveInteger} N - number of indexed elements
+* @param {Float32Array} x - input array
+* @param {integer} stride - stride length
+* @param {NonNegativeInteger} offset - starting index
+* @returns {number} sum
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+*
+* var x = new Float32Array( [ 2.0, 1.0, 2.0, -2.0, -2.0, 2.0, 3.0, 4.0 ] );
+*
+* var v = dssumors( 4, x, 2, 1 );
+* // returns 5.0
+*/
+function dssumors( N, x, stride, offset ) {
+	var sum;
+	var ix;
+	var m;
+	var i;
+ 
+	sum = 0.0;
+	if ( N <= 0 ) {
+		return sum;
+	}
+	if ( N === 1 || stride === 0 ) {
+		return x[ offset ];
+	}
+	ix = offset;
+ 
+	// If the stride is equal to `1`, use unrolled loops...
+	if ( stride === 1 ) {
+		m = N % M;
+ 
+		// If we have a remainder, run a clean-up loop...
+		if ( m > 0 ) {
+			for ( i = 0; i < m; i++ ) {
+				sum += x[ ix ];
+				ix += stride;
+			}
+		}
+		if ( N < M ) {
+			return sum;
+		}
+		for ( i = m; i < N; i += M ) {
+			sum += x[ix] + x[ix+1] + x[ix+2] + x[ix+3] + x[ix+4] + x[ix+5];
+			ix += M;
+		}
+		return sum;
+	}
+	for ( i = 0; i < N; i++ ) {
+		sum += x[ ix ];
+		ix += stride;
+	}
+	return sum;
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/blas/ext/base/dssumors/ndarray.native.js.html b/blas/ext/base/dssumors/ndarray.native.js.html new file mode 100644 index 000000000..11f2e0259 --- /dev/null +++ b/blas/ext/base/dssumors/ndarray.native.js.html @@ -0,0 +1,265 @@ + + + + + + Code coverage report for blas/ext/base/dssumors/lib/ndarray.native.js + + + + + + + + + +
+
+

All files / blas/ext/base/dssumors/lib ndarray.native.js

+
+ +
+ 100% + Statements + 60/60 +
+ + +
+ 100% + Branches + 2/2 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 60/60 +
+ + +
+

+ Press n or j to go to the next uncovered block, b, p or k for the previous block. +

+ +
+
+

+
1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +612x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +13x +13x +13x +13x +13x +13x +13x +13x +13x +2x +2x +2x +2x +2x + 
/**
+* @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 minViewBufferIndex = require( '@stdlib/strided/base/min-view-buffer-index' );
+var offsetView = require( '@stdlib/strided/base/offset-view' );
+var addon = require( './dssumors.native.js' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Computes the sum of single-precision floating-point strided array elements using ordinary recursive summation with extended accumulation and returning an extended precision result.
+*
+* @param {PositiveInteger} N - number of indexed elements
+* @param {Float32Array} x - input array
+* @param {integer} stride - stride length
+* @param {NonNegativeInteger} offset - starting index
+* @returns {number} sum
+*
+* @example
+* var Float32Array = require( '@stdlib/array/float32' );
+*
+* var x = new Float32Array( [ 2.0, 1.0, 2.0, -2.0, -2.0, 2.0, 3.0, 4.0 ] );
+*
+* var v = dssumors( 4, x, 2, 1 );
+* // returns 5.0
+*/
+function dssumors( N, x, stride, offset ) {
+	var view;
+ 
+	offset = minViewBufferIndex( N, stride, offset );
+ 
+	view = offsetView( x, offset );
+ 
+	return addon( N, view, stride );
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = dssumors;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file