diff --git a/assert/is-same-complex64array/coverage.ndjson b/assert/is-same-complex64array/coverage.ndjson index 5245f6dd1f..de65bbc26c 100644 --- a/assert/is-same-complex64array/coverage.ndjson +++ b/assert/is-same-complex64array/coverage.ndjson @@ -1 +1,2 @@ [118,118,100,6,6,100,1,1,100,118,118,100,"c09655109f78750aa2ae9cd6f4c4f0521dc11a08","2024-01-17 13:29:51 -0800"] +[118,118,100,6,6,100,1,1,100,118,118,100,"afa953bde057e396e614ea35b7a32fd5b77479ea","2024-01-24 19:03:35 -0800"] diff --git a/assert/is-same-complex64array/index.html b/assert/is-same-complex64array/index.html index d975d9265c..f9740ee60b 100644 --- a/assert/is-same-complex64array/index.html +++ b/assert/is-same-complex64array/index.html @@ -116,7 +116,7 @@

All files assert/is-same-complex64array/li + + + + + + \ No newline at end of file diff --git a/random/base/cosine/coverage.ndjson b/random/base/cosine/coverage.ndjson new file mode 100644 index 0000000000..68f46bd4a3 --- /dev/null +++ b/random/base/cosine/coverage.ndjson @@ -0,0 +1 @@ +[490,490,100,55,55,100,12,12,100,490,490,100,"afa953bde057e396e614ea35b7a32fd5b77479ea","2024-01-24 19:03:35 -0800"] diff --git a/random/base/cosine/factory.js.html b/random/base/cosine/factory.js.html new file mode 100644 index 0000000000..c3ad33455d --- /dev/null +++ b/random/base/cosine/factory.js.html @@ -0,0 +1,904 @@ + + + + + + Code coverage report for random/base/cosine/lib/factory.js + + + + + + + + + +
+
+

All files / random/base/cosine/lib factory.js

+
+ +
+ 100% + Statements + 273/273 +
+ + +
+ 100% + Branches + 44/44 +
+ + +
+ 100% + Functions + 10/10 +
+ + +
+ 100% + Lines + 273/273 +
+ + +
+

+ 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 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104 +105 +106 +107 +108 +109 +110 +111 +112 +113 +114 +115 +116 +117 +118 +119 +120 +121 +122 +123 +124 +125 +126 +127 +128 +129 +130 +131 +132 +133 +134 +135 +136 +137 +138 +139 +140 +141 +142 +143 +144 +145 +146 +147 +148 +149 +150 +151 +152 +153 +154 +155 +156 +157 +158 +159 +160 +161 +162 +163 +164 +165 +166 +167 +168 +169 +170 +171 +172 +173 +174 +175 +176 +177 +178 +179 +180 +181 +182 +183 +184 +185 +186 +187 +188 +189 +190 +191 +192 +193 +194 +195 +196 +197 +198 +199 +200 +201 +202 +203 +204 +205 +206 +207 +208 +209 +210 +211 +212 +213 +214 +215 +216 +217 +218 +219 +220 +221 +222 +223 +224 +225 +226 +227 +228 +229 +230 +231 +232 +233 +234 +235 +236 +237 +238 +239 +240 +241 +242 +243 +244 +245 +246 +247 +248 +249 +250 +251 +252 +253 +254 +255 +256 +257 +258 +259 +260 +261 +262 +263 +264 +265 +266 +267 +268 +269 +270 +271 +272 +273 +2742x +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 +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +2x +132x +132x +132x +132x +132x +132x +132x +132x +13x +132x +66x +66x +9x +9x +66x +19x +9x +9x +10x +66x +38x +38x +119x +53x +53x +53x +53x +20x +20x +53x +28x +28x +9x +9x +28x +12x +9x +9x +3x +28x +7x +7x +53x +5x +5x +53x +132x +25x +132x +15x +15x +40x +40x +40x +132x +13x +13x +13x +13x +13x +13x +13x +132x +27x +27x +27x +27x +27x +27x +27x +27x +27x +40x +40x +40x +40x +40x +40x +40x +40x +40x +4x +4x +40x +40x +40x +40x +40x +40x +40x +40x +2x +2x +40x +40x +40x +40x +40x +40x +40x +40x +2x +2x +40x +40x +40x +40x +40x +40x +40x +40x +2x +2x +40x +40x +40x +40x +40x +40x +40x +40x +7x +7x +40x +40x +40x +40x +40x +40x +40x +40x +40x +3x +3x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +2x +2x +2x +2x +2x +1x +1x +1x +1x +2x +2x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +1800x +1800x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +40x +805x +805x +805x +802x +805x +5x +5x +800x +805x +132x +2x +2x +2x +2x +2x + 
/**
+* @license Apache-2.0
+*
+* Copyright (c) 2018 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 setReadOnlyAccessor = require( '@stdlib/utils/define-nonenumerable-read-only-accessor' );
+var setReadWriteAccessor = require( '@stdlib/utils/define-nonenumerable-read-write-accessor' );
+var isObject = require( '@stdlib/assert/is-plain-object' );
+var isFunction = require( '@stdlib/assert/is-function' );
+var hasOwnProp = require( '@stdlib/assert/has-own-property' );
+var constantFunction = require( '@stdlib/utils/constant-function' );
+var noop = require( '@stdlib/utils/noop' );
+var randu = require( '@stdlib/random/base/mt19937' ).factory;
+var isnan = require( '@stdlib/math/base/assert/is-nan' );
+var typedarray2json = require( '@stdlib/array/to-json' );
+var format = require( '@stdlib/string/format' );
+var validate = require( './validate.js' );
+var cosine0 = require( './cosine.js' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Returns a pseudorandom number generator for generating random numbers from a raised cosine distribution.
+*
+* @param {number} [mu] - mean parameter
+* @param {PositiveNumber} [s] - scale parameter
+* @param {Options} [options] - function options
+* @param {PRNG} [options.prng] - pseudorandom number generator which generates uniformly distributed pseudorandom numbers
+* @param {PRNGSeedMT19937} [options.seed] - pseudorandom number generator seed
+* @param {PRNGStateMT19937} [options.state] - pseudorandom number generator state
+* @param {boolean} [options.copy=true] - boolean indicating whether to copy a provided pseudorandom number generator state
+* @throws {TypeError} `mu` must be a number
+* @throws {TypeError} `s` must be a positive number
+* @throws {TypeError} options argument must be an object
+* @throws {TypeError} must provide valid options
+* @throws {Error} must provide a valid state
+* @returns {PRNG} pseudorandom number generator
+*
+* @example
+* var cosine = factory( 0.0, 1.0 );
+* var v = cosine();
+* // returns <number>
+*
+* @example
+* var cosine = factory( -3.0, 0.5, {
+*     'seed': 297
+* });
+* var v = cosine();
+* // returns <number>
+*/
+function factory() {
+	var opts;
+	var rand;
+	var prng;
+	var err;
+	var mu;
+	var s;
+	if ( arguments.length === 0 ) {
+		rand = randu();
+	} else if ( arguments.length === 1 ) {
+		opts = arguments[ 0 ];
+		if ( !isObject( opts ) ) {
+			throw new TypeError( format( 'invalid argument. Options argument must be an object. Value: `%s`.', opts ) );
+		}
+		if ( hasOwnProp( opts, 'prng' ) ) {
+			if ( !isFunction( opts.prng ) ) {
+				throw new TypeError( format( 'invalid option. `%s` option must be a pseudorandom number generator function. Option: `%s`.', 'prng', opts.prng ) );
+			}
+			rand = opts.prng;
+		} else {
+			rand = randu( opts );
+		}
+	} else {
+		mu = arguments[ 0 ];
+		s = arguments[ 1 ];
+		err = validate( mu, s );
+		if ( err ) {
+			throw err;
+		}
+		if ( arguments.length > 2 ) {
+			opts = arguments[ 2 ];
+			if ( !isObject( opts ) ) {
+				throw new TypeError( format( 'invalid argument. Options argument must be an object. Value: `%s`.', opts ) );
+			}
+			if ( hasOwnProp( opts, 'prng' ) ) {
+				if ( !isFunction( opts.prng ) ) {
+					throw new TypeError( format( 'invalid option. `%s` option must be a pseudorandom number generator function. Option: `%s`.', 'prng', opts.prng ) );
+				}
+				rand = opts.prng;
+			} else {
+				rand = randu( opts );
+			}
+		} else {
+			rand = randu();
+		}
+	}
+	if ( mu === void 0 ) {
+		prng = cosine2;
+	} else {
+		prng = cosine1;
+	}
+	setReadOnly( prng, 'NAME', 'cosine' );
+ 
+	// If we are provided an "external" PRNG, we don't support getting or setting PRNG state, as we'd need to check for compatible state value types, etc, entailing considerable complexity.
+	if ( opts && opts.prng ) {
+		setReadOnly( prng, 'seed', null );
+		setReadOnly( prng, 'seedLength', null );
+		setReadWriteAccessor( prng, 'state', constantFunction( null ), noop );
+		setReadOnly( prng, 'stateLength', null );
+		setReadOnly( prng, 'byteLength', null );
+		setReadOnly( prng, 'toJSON', constantFunction( null ) );
+		setReadOnly( prng, 'PRNG', rand );
+	} else {
+		setReadOnlyAccessor( prng, 'seed', getSeed );
+		setReadOnlyAccessor( prng, 'seedLength', getSeedLength );
+		setReadWriteAccessor( prng, 'state', getState, setState );
+		setReadOnlyAccessor( prng, 'stateLength', getStateLength );
+		setReadOnlyAccessor( prng, 'byteLength', getStateSize );
+		setReadOnly( prng, 'toJSON', toJSON );
+		setReadOnly( prng, 'PRNG', rand );
+		rand = rand.normalized;
+	}
+	return prng;
+ 
+	/**
+	* Returns the PRNG seed.
+	*
+	* @private
+	* @returns {PRNGSeedMT19937} seed
+	*/
+	function getSeed() {
+		return rand.seed;
+	}
+ 
+	/**
+	* Returns the PRNG seed length.
+	*
+	* @private
+	* @returns {PositiveInteger} seed length
+	*/
+	function getSeedLength() {
+		return rand.seedLength;
+	}
+ 
+	/**
+	* Returns the PRNG state length.
+	*
+	* @private
+	* @returns {PositiveInteger} state length
+	*/
+	function getStateLength() {
+		return rand.stateLength;
+	}
+ 
+	/**
+	* Returns the PRNG state size (in bytes).
+	*
+	* @private
+	* @returns {PositiveInteger} state size (in bytes)
+	*/
+	function getStateSize() {
+		return rand.byteLength;
+	}
+ 
+	/**
+	* Returns the current pseudorandom number generator state.
+	*
+	* @private
+	* @returns {PRNGStateMT19937} current state
+	*/
+	function getState() {
+		return rand.state;
+	}
+ 
+	/**
+	* Sets the pseudorandom number generator state.
+	*
+	* @private
+	* @param {PRNGStateMT19937} s - generator state
+	* @throws {Error} must provide a valid state
+	*/
+	function setState( s ) {
+		rand.state = s;
+	}
+ 
+	/**
+	* Serializes the pseudorandom number generator as a JSON object.
+	*
+	* ## Notes
+	*
+	* -   `JSON.stringify()` implicitly calls this method when stringifying a PRNG.
+	*
+	* @private
+	* @returns {Object} JSON representation
+	*/
+	function toJSON() {
+		var out = {};
+		out.type = 'PRNG';
+		out.name = prng.NAME;
+		out.state = typedarray2json( rand.state );
+		if ( mu === void 0 ) {
+			out.params = [];
+		} else {
+			out.params = [ mu, s ];
+		}
+		return out;
+	}
+ 
+	/**
+	* Returns a pseudorandom number drawn from a raised cosine distribution with bound parameters.
+	*
+	* @private
+	* @returns {number} pseudorandom number
+	*
+	* @example
+	* var v = cosine1();
+	* // returns <number>
+	*/
+	function cosine1() {
+		return cosine0( rand, mu, s );
+	}
+ 
+	/**
+	* Returns a pseudorandom number drawn from a raised cosine distribution.
+	*
+	* @private
+	* @param {number} mu - mean
+	* @param {PositiveNumber} s - scale parameter
+	* @returns {number} pseudorandom number
+	*
+	* @example
+	* var v = cosine2( 0.0, 2.0 );
+	* // returns <number>
+	*
+	* @example
+	* var v = cosine2( 0.0, -1.0 );
+	* // returns NaN
+	*/
+	function cosine2( mu, s ) {
+		if (
+			isnan( mu ) ||
+			isnan( s ) ||
+			s <= 0.0
+		) {
+			return NaN;
+		}
+		return cosine0( rand, mu, s );
+	}
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = factory;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/random/base/cosine/index.html b/random/base/cosine/index.html new file mode 100644 index 0000000000..de668b3c90 --- /dev/null +++ b/random/base/cosine/index.html @@ -0,0 +1,176 @@ + + + + + + Code coverage report for random/base/cosine/lib + + + + + + + + + +
+
+

All files random/base/cosine/lib

+
+ +
+ 100% + Statements + 490/490 +
+ + +
+ 100% + Branches + 55/55 +
+ + +
+ 100% + Functions + 12/12 +
+ + +
+ 100% + Lines + 490/490 +
+ + +
+

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

+ +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
FileStatementsBranchesFunctionsLines
cosine.js +
+
100%44/44100%2/2100%1/1100%44/44
factory.js +
+
100%273/273100%44/44100%10/10100%273/273
index.js +
+
100%65/65100%1/1100%0/0100%65/65
main.js +
+
100%50/50100%1/1100%0/0100%50/50
validate.js +
+
100%58/58100%7/7100%1/1100%58/58
+
+
+
+ + + + + + + + \ No newline at end of file diff --git a/random/base/cosine/index.js.html b/random/base/cosine/index.js.html new file mode 100644 index 0000000000..fe5df1637d --- /dev/null +++ b/random/base/cosine/index.js.html @@ -0,0 +1,280 @@ + + + + + + Code coverage report for random/base/cosine/lib/index.js + + + + + + + + + +
+
+

All files / random/base/cosine/lib index.js

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

+ 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 +661x +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 +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) 2018 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';
+ 
+/**
+* Raised cosine distributed pseudorandom numbers.
+*
+* @module @stdlib/random/base/cosine
+*
+* @example
+* var cosine = require( '@stdlib/random/base/cosine' );
+*
+* var v = cosine( 0.5, 1.0 );
+* // returns <number>
+*
+* @example
+* var factory = require( '@stdlib/random/base/cosine' ).factory;
+* var cosine = factory( 3.0, 2.0, {
+*     'seed': 297
+* });
+*
+* var v = cosine();
+* // returns <number>
+*
+* @example
+* var factory = require( '@stdlib/random/base/cosine' ).factory;
+* var cosine = factory({
+*     'seed': 297
+* });
+*
+* var v = cosine( 3.0, 2.0 );
+* // returns <number>
+*/
+ 
+// MODULES //
+ 
+var setReadOnly = require( '@stdlib/utils/define-nonenumerable-read-only-property' );
+var main = require( './main.js' );
+var factory = require( './factory.js' );
+ 
+ 
+// MAIN //
+ 
+setReadOnly( main, 'factory', factory );
+ 
+ 
+// EXPORTS //
+ 
+module.exports = main;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/random/base/cosine/main.js.html b/random/base/cosine/main.js.html new file mode 100644 index 0000000000..bf80fca0cc --- /dev/null +++ b/random/base/cosine/main.js.html @@ -0,0 +1,235 @@ + + + + + + Code coverage report for random/base/cosine/lib/main.js + + + + + + + + + +
+
+

All files / random/base/cosine/lib main.js

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

+ 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 +511x +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 +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x +1x + 
/**
+* @license Apache-2.0
+*
+* Copyright (c) 2018 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 factory = require( './factory.js' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Returns pseudorandom number drawn from a raised cosine distribution.
+*
+* @name cosine
+* @type {PRNG}
+* @param {number} mu - mean
+* @param {PositiveNumber} s - scale parameter
+* @returns {number} pseudorandom number
+*
+* @example
+* var v = cosine( 0.0, 2.0 );
+* // returns <number>
+*
+* @example
+* var v = cosine( 0.0, -1.0 );
+* // returns NaN
+*/
+var cosine = factory();
+ 
+ 
+// EXPORTS //
+ 
+module.exports = cosine;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/random/base/cosine/validate.js.html b/random/base/cosine/validate.js.html new file mode 100644 index 0000000000..7ee521ee1b --- /dev/null +++ b/random/base/cosine/validate.js.html @@ -0,0 +1,259 @@ + + + + + + Code coverage report for random/base/cosine/lib/validate.js + + + + + + + + + +
+
+

All files / random/base/cosine/lib validate.js

+
+ +
+ 100% + Statements + 58/58 +
+ + +
+ 100% + Branches + 7/7 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 58/58 +
+ + +
+

+ 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 +592x +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 +53x +53x +9x +9x +53x +11x +11x +33x +53x +2x +2x +2x +2x +2x + 
/**
+* @license Apache-2.0
+*
+* Copyright (c) 2018 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 isNumber = require( '@stdlib/assert/is-number' ).isPrimitive;
+var isPositive = require( '@stdlib/assert/is-positive-number' ).isPrimitive;
+var format = require( '@stdlib/string/format' );
+var isnan = require( '@stdlib/assert/is-nan' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Validates parameters.
+*
+* @private
+* @param {number} mu - location parameter
+* @param {PositiveNumber} s - scale parameter
+* @returns {(Error|null)} error or null
+*
+* @example
+* var err = validate( 1.0, 2.0 );
+* if ( err ) {
+*     throw err;
+* }
+*/
+function validate( mu, s ) {
+	if ( !isNumber( mu ) || isnan( mu ) ) {
+		return new TypeError( format( 'invalid argument. First argument must be a number and not NaN. Value: `%s`.', mu ) );
+	}
+	if ( !isPositive( s ) ) {
+		return new TypeError( format( 'invalid argument. Second argument must be a positive number. Value: `%s`.', s ) );
+	}
+	return null;
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = validate;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/random/base/frechet/coverage.ndjson b/random/base/frechet/coverage.ndjson index a840c012fd..03fe2b1c5b 100644 --- a/random/base/frechet/coverage.ndjson +++ b/random/base/frechet/coverage.ndjson @@ -1 +1,2 @@ [507,507,100,61,61,100,12,12,100,507,507,100,"292f38dd36220ad0e6aa869e72a79ff6d3715b88","2024-01-12 02:09:16 -0800"] +[507,507,100,61,61,100,12,12,100,507,507,100,"afa953bde057e396e614ea35b7a32fd5b77479ea","2024-01-24 19:03:35 -0800"] diff --git a/random/base/frechet/factory.js.html b/random/base/frechet/factory.js.html index 7f63a5506e..1bf85579df 100644 --- a/random/base/frechet/factory.js.html +++ b/random/base/frechet/factory.js.html @@ -925,7 +925,7 @@

All files / random + + + + + + \ No newline at end of file diff --git a/string/headercase/index.js.html b/string/headercase/index.js.html new file mode 100644 index 0000000000..052fb5953e --- /dev/null +++ b/string/headercase/index.js.html @@ -0,0 +1,223 @@ + + + + + + Code coverage report for string/headercase/lib/index.js + + + + + + + + + +
+
+

All files / string/headercase/lib index.js

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

+ 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 +4710x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x + 
/**
+* @license Apache-2.0
+*
+* Copyright (c) 2023 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';
+ 
+/**
+* Convert a string to HTTP header case.
+*
+* @module @stdlib/string/headercase
+*
+* @example
+* var headercase = require( '@stdlib/string/headercase' );
+*
+* var str = headercase( 'foo bar' );
+* // returns 'Foo-Bar'
+*
+* str = headercase( '--foo-bar--' );
+* // returns 'Foo-Bar'
+*
+* str = headercase( 'Hello World!' );
+* // returns 'Hello-World'
+*/
+ 
+// MODULES //
+ 
+var main = require( './main.js' );
+ 
+ 
+// EXPORTS //
+ 
+module.exports = main;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/string/headercase/main.js.html b/string/headercase/main.js.html new file mode 100644 index 0000000000..2d0e115086 --- /dev/null +++ b/string/headercase/main.js.html @@ -0,0 +1,274 @@ + + + + + + Code coverage report for string/headercase/lib/main.js + + + + + + + + + +
+
+

All files / string/headercase/lib main.js

+
+ +
+ 100% + Statements + 63/63 +
+ + +
+ 100% + Branches + 4/4 +
+ + +
+ 100% + Functions + 1/1 +
+ + +
+ 100% + Lines + 63/63 +
+ + +
+

+ 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 +6410x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +10x +45x +45x +9x +9x +36x +45x +10x +10x +10x +10x +10x + 
/**
+* @license Apache-2.0
+*
+* Copyright (c) 2023 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 isString = require( '@stdlib/assert/is-string' ).isPrimitive;
+var format = require( '@stdlib/string/format' );
+var base = require( '@stdlib/string/base/headercase' );
+ 
+ 
+// MAIN //
+ 
+/**
+* Converts a string to HTTP header case.
+*
+* @param {string} str - string to convert
+* @throws {TypeError} must provide a string
+* @returns {string} HTTP header-cased string
+*
+* @example
+* var out = headercase( 'foo bar' );
+* // returns 'Foo-Bar'
+*
+* @example
+* var out = headercase( 'IS_MOBILE' );
+* // returns 'Is-Mobile'
+*
+* @example
+* var out = headercase( 'Hello World!' );
+* // returns 'Hello-World'
+*
+* @example
+* var out = headercase( '--foo-bar--' );
+* // returns 'Foo-Bar'
+*/
+function headercase( str ) {
+	if ( !isString( str ) ) {
+		throw new TypeError( format( 'invalid argument. First argument must be a string. Value: `%s`.', str ) );
+	}
+	return base( str );
+}
+ 
+ 
+// EXPORTS //
+ 
+module.exports = headercase;
+ 
+ +
+
+ + + + + + + + \ No newline at end of file diff --git a/string/remove-first/coverage.ndjson b/string/remove-first/coverage.ndjson index a2b2cec03c..e4b2b7879d 100644 --- a/string/remove-first/coverage.ndjson +++ b/string/remove-first/coverage.ndjson @@ -1 +1,2 @@ [177,177,100,20,20,100,1,1,100,177,177,100,"982de7581326be5be20dda30103779ac5ae5767f","2023-09-21 14:40:45 -0700"] +[177,177,100,20,20,100,1,1,100,177,177,100,"afa953bde057e396e614ea35b7a32fd5b77479ea","2024-01-24 19:03:35 -0800"] diff --git a/string/remove-first/index.html b/string/remove-first/index.html index 749c6640b2..3f38f9d90c 100644 --- a/string/remove-first/index.html +++ b/string/remove-first/index.html @@ -116,7 +116,7 @@

All files string/remove-first/lib