From c4e91516b9dd355aa65cb470132eb284fccb9765 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Fri, 27 Dec 2024 18:14:23 +0530 Subject: [PATCH 01/18] feat: add-erlang-kurtosis --- .../base/dists/erlang/kurtosis/README.md | 109 +++++++++++ .../kurtosis/benchmark/benchmark.native.js | 65 +++++++ .../erlang/kurtosis/benchmark/c/Makefile | 146 +++++++++++++++ .../erlang/kurtosis/benchmark/c/benchmark.c | 137 ++++++++++++++ .../base/dists/erlang/kurtosis/binding.gyp | 170 ++++++++++++++++++ .../dists/erlang/kurtosis/examples/c/Makefile | 146 +++++++++++++++ .../erlang/kurtosis/examples/c/example.c | 37 ++++ .../base/dists/erlang/kurtosis/include.gypi | 53 ++++++ .../stdlib/stats/base/dists/erlang/kurtosis.h | 38 ++++ .../base/dists/erlang/kurtosis/lib/native.js | 74 ++++++++ .../base/dists/erlang/kurtosis/manifest.json | 84 +++++++++ .../base/dists/erlang/kurtosis/package.json | 3 + .../base/dists/erlang/kurtosis/src/Makefile | 70 ++++++++ .../base/dists/erlang/kurtosis/src/addon.c | 23 +++ .../base/dists/erlang/kurtosis/src/main.c | 67 +++++++ .../dists/erlang/kurtosis/test/test.native.js | 139 ++++++++++++++ 16 files changed, 1361 insertions(+) create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c create mode 100644 lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index eba35207fc33..257b40a15746 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -143,6 +143,115 @@ for ( i = 0; i < 10; i++ ) { + + +
+ +## C APIs + + + +
+ +
+ + + + + +
+ +### Usage + +```c +#include "stdlib/stats/base/dists/erlang/kurtosis.h" +``` + +#### stdlib_base_dists_erlang_kurtosis( k, lambda ) + +Evaluates the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda` at a value `x`. + +```c +double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); +// returns ~6.0 + +y = stdlib_base_dists_erlang_kurtosis( 4.0, 12.0 ); +// returns ~1.5 + +y = stdlib_base_dists_erlang_kurtosis( 8.0, 2.0 ); +// returns ~0.75 + +y = stdlib_base_dists_erlang_kurtosis( 1.0, -0.1 ); +// returns NaN + +y = stdlib_base_dists_erlang_kurtosis( -0.1, 1.0 ); +// returns NaN + +y = stdlib_base_dists_erlang_kurtosis( 2.0, NaN ); +// returns NaN + +y = stdlib_base_dists_erlang_kurtosis( NaN, 2.0 ); +// returns NaN +``` + +The function accepts the following arguments: + +- **k**: `[in] double` shape parameter +- **lambda**: `[in] double` rate parameter + +```c +double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ); +``` + +
+ + + + + +
+ +
+ + + + + +
+ +### Examples + +```c +#include "stdlib/stats/base/dists/erlang/kurtosis.h" +#include "stdlib/math/base/special/round.h" +#include "stdlib/constants/float64/eps.h" +#include +#include + +int main( void ) { + double k; + double lambda; + double y; + int i; + + for ( i = 0; i < 10; i++ ) { + k = stdlib_base_round( ( (double)rand() / (double)RAND_MAX )*10.0 ); + lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ); + y = stdlib_base_dists_erlang_kurtosis( k, lambda ); + printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); + } +} +``` + +
+ + + +
+ + +
diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js new file mode 100644 index 000000000000..1e8bae7ba77a --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -0,0 +1,65 @@ +/** +* @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 resolve = require( 'path' ).resolve; +var bench = require( '@stdlib/bench' ); +var randu = require( '@stdlib/random/base/randu' ); +var isnan = require( '@stdlib/math/base/assert/is-nan' ); +var ceil = require( '@stdlib/math/base/special/ceil' ); +var tryRequire = require( '@stdlib/utils/try-require' ); +var EPS = require( '@stdlib/constants/float64/eps' ); +var pkg = require( './../package.json' ).name; +var kurtosis = require( './../lib' ); + + +// VARIABLES // + +var kurtosis = tryRequire( resolve( __dirname, './../lib/native.js' ) ); +var opts = { + 'skip': ( kurtosis instanceof Error ) +}; + + +// MAIN // + +bench( pkg+'::native', opts, function benchmark( b ) { + var lambda; + var k; + var y; + var i; + + b.tic(); + for ( i = 0; i < b.iterations; i++ ) { + k = ceil( randu()*10.0 ); + lambda = ( randu()*10.0 ) + EPS; + y = kurtosis( k, lambda ); + if ( isnan( y ) ) { + b.fail( 'should not return NaN' ); + } + } + b.toc(); + if ( isnan( y ) ) { + b.fail( 'should not return NaN' ); + } + b.pass( 'benchmark finished' ); + b.end(); +}); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile new file mode 100644 index 000000000000..f69e9da2b4d3 --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile @@ -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. +#/ + +# VARIABLES # + +ifndef VERBOSE + QUIET := @ +else + QUIET := +endif + +# Determine the OS ([1][1], [2][2]). +# +# [1]: https://en.wikipedia.org/wiki/Uname#Examples +# [2]: http://stackoverflow.com/a/27776822/2225624 +OS ?= $(shell uname) +ifneq (, $(findstring MINGW,$(OS))) + OS := WINNT +else +ifneq (, $(findstring MSYS,$(OS))) + OS := WINNT +else +ifneq (, $(findstring CYGWIN,$(OS))) + OS := WINNT +else +ifneq (, $(findstring Windows_NT,$(OS))) + OS := WINNT +endif +endif +endif +endif + +# Define the program used for compiling C source files: +ifdef C_COMPILER + CC := $(C_COMPILER) +else + CC := gcc +endif + +# Define the command-line options when compiling C files: +CFLAGS ?= \ + -std=c99 \ + -O3 \ + -Wall \ + -pedantic + +# Determine whether to generate position independent code ([1][1], [2][2]). +# +# [1]: https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#Code-Gen-Options +# [2]: http://stackoverflow.com/questions/5311515/gcc-fpic-option +ifeq ($(OS), WINNT) + fPIC ?= +else + fPIC ?= -fPIC +endif + +# List of includes (e.g., `-I /foo/bar -I /beep/boop/include`): +INCLUDE ?= + +# List of source files: +SOURCE_FILES ?= + +# List of libraries (e.g., `-lopenblas -lpthread`): +LIBRARIES ?= + +# List of library paths (e.g., `-L /foo/bar -L /beep/boop`): +LIBPATH ?= + +# List of C targets: +c_targets := benchmark.out + + +# RULES # + +#/ +# Compiles source files. +# +# @param {string} [C_COMPILER] - C compiler (e.g., `gcc`) +# @param {string} [CFLAGS] - C compiler options +# @param {(string|void)} [fPIC] - compiler flag determining whether to generate position independent code (e.g., `-fPIC`) +# @param {string} [INCLUDE] - list of includes (e.g., `-I /foo/bar -I /beep/boop/include`) +# @param {string} [SOURCE_FILES] - list of source files +# @param {string} [LIBPATH] - list of library paths (e.g., `-L /foo/bar -L /beep/boop`) +# @param {string} [LIBRARIES] - list of libraries (e.g., `-lopenblas -lpthread`) +# +# @example +# make +# +# @example +# make all +#/ +all: $(c_targets) + +.PHONY: all + +#/ +# Compiles C source files. +# +# @private +# @param {string} CC - C compiler (e.g., `gcc`) +# @param {string} CFLAGS - C compiler options +# @param {(string|void)} fPIC - compiler flag determining whether to generate position independent code (e.g., `-fPIC`) +# @param {string} INCLUDE - list of includes (e.g., `-I /foo/bar`) +# @param {string} SOURCE_FILES - list of source files +# @param {string} LIBPATH - list of library paths (e.g., `-L /foo/bar`) +# @param {string} LIBRARIES - list of libraries (e.g., `-lopenblas`) +#/ +$(c_targets): %.out: %.c + $(QUIET) $(CC) $(CFLAGS) $(fPIC) $(INCLUDE) -o $@ $(SOURCE_FILES) $< $(LIBPATH) -lm $(LIBRARIES) + +#/ +# Runs compiled benchmarks. +# +# @example +# make run +#/ +run: $(c_targets) + $(QUIET) ./$< + +.PHONY: run + +#/ +# Removes generated files. +# +# @example +# make clean +#/ +clean: + $(QUIET) -rm -f *.o *.out + +.PHONY: clean diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c new file mode 100644 index 000000000000..0047a3e5cb74 --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -0,0 +1,137 @@ +/** +* @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. +*/ + +#include "stdlib/stats/base/dists/erlang/kurtosis.h" +#include "stdlib/math/base/special/ceil.h" +#include "stdlib/constants/float64/eps.h" +#include +#include +#include +#include +#include + +#define NAME "erlang-kurtosis" +#define ITERATIONS 1000000 +#define REPEATS 3 + +/** +* Prints the TAP version. +*/ +static void print_version( void ) { + printf( "TAP version 13\n" ); +} + +/** +* Prints the TAP summary. +* +* @param total total number of tests +* @param passing total number of passing tests +*/ +static void print_summary( int total, int passing ) { + printf( "#\n" ); + printf( "1..%d\n", total ); // TAP plan + printf( "# total %d\n", total ); + printf( "# pass %d\n", passing ); + printf( "#\n" ); + printf( "# ok\n" ); +} + +/** +* Prints benchmarks results. +* +* @param elapsed elapsed time in seconds +*/ +static void print_results( double elapsed ) { + double rate = (double)ITERATIONS / elapsed; + printf( " ---\n" ); + printf( " iterations: %d\n", ITERATIONS ); + printf( " elapsed: %0.9f\n", elapsed ); + printf( " rate: %0.9f\n", rate ); + printf( " ...\n" ); +} + +/** +* Returns a clock time. +* +* @return clock time +*/ +static double tic( void ) { + struct timeval now; + gettimeofday( &now, NULL ); + return (double)now.tv_sec + (double)now.tv_usec/1.0e6; +} + +/** +* Generates a random number on the interval [0,1). +* +* @return random number +*/ +static double rand_double( void ) { + int r = rand(); + return (double)r / ( (double)RAND_MAX + 1.0 ); +} + +/** +* Runs a benchmark. +* +* @return elapsed time in seconds +*/ +static double benchmark( void ) { + double elapsed; + double k; + double lambda; + double y; + double t; + int i; + + t = tic(); + for ( i = 0; i < ITERATIONS; i++ ) { + k = stdlib_base_ceil( ( (double)rand() / (double)RAND_MAX )*10.0 ); + lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ) + STDLIB_CONSTANT_FLOAT64_EPS; + y = stdlib_base_dists_erlang_kurtosis( k, lambda ); + if ( y != y ) { + printf( "should not return NaN\n" ); + break; + } + } + elapsed = tic() - t; + if ( y != y ) { + printf( "should not return NaN\n" ); + } + return elapsed; +} + +/** +* Main execution sequence. +*/ +int main( void ) { + double elapsed; + int i; + + // Use the current time to seed the random number generator: + srand( time( NULL ) ); + + print_version(); + for ( i = 0; i < REPEATS; i++ ) { + printf( "# c::%s\n", NAME ); + elapsed = benchmark(); + print_results( elapsed ); + printf( "ok %d benchmark finished\n", i+1 ); + } + print_summary( REPEATS, REPEATS ); +} diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp new file mode 100644 index 000000000000..ec3992233442 --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp @@ -0,0 +1,170 @@ +# @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. + +# A `.gyp` file for building a Node.js native add-on. +# +# [1]: https://gyp.gsrc.io/docs/InputFormatReference.md +# [2]: https://gyp.gsrc.io/docs/UserDocumentation.md +{ + # List of files to include in this file: + 'includes': [ + './include.gypi', + ], + + # Define variables to be used throughout the configuration for all targets: + 'variables': { + # Target name should match the add-on export name: + 'addon_target_name%': 'addon', + + # Set variables based on the host OS: + 'conditions': [ + [ + 'OS=="win"', + { + # Define the object file suffix: + 'obj': 'obj', + }, + { + # Define the object file suffix: + 'obj': 'o', + } + ], # end condition (OS=="win") + ], # end conditions + }, # end variables + + # Define compile targets: + 'targets': [ + + # Target to generate an add-on: + { + # The target name should match the add-on export name: + 'target_name': '<(addon_target_name)', + + # Define dependencies: + 'dependencies': [], + + # Define directories which contain relevant include headers: + 'include_dirs': [ + # Local include directory: + '<@(include_dirs)', + ], + + # List of source files: + 'sources': [ + '<@(src_files)', + ], + + # Settings which should be applied when a target's object files are used as linker input: + 'link_settings': { + # Define libraries: + 'libraries': [ + '<@(libraries)', + ], + + # Define library directories: + 'library_dirs': [ + '<@(library_dirs)', + ], + }, + + # C/C++ compiler flags: + 'cflags': [ + # Enable commonly used warning options: + '-Wall', + + # Aggressive optimization: + '-O3', + ], + + # C specific compiler flags: + 'cflags_c': [ + # Specify the C standard to which a program is expected to conform: + '-std=c99', + ], + + # C++ specific compiler flags: + 'cflags_cpp': [ + # Specify the C++ standard to which a program is expected to conform: + '-std=c++11', + ], + + # Linker flags: + 'ldflags': [], + + # Apply conditions based on the host OS: + 'conditions': [ + [ + 'OS=="mac"', + { + # Linker flags: + 'ldflags': [ + '-undefined dynamic_lookup', + '-Wl,-no-pie', + '-Wl,-search_paths_first', + ], + }, + ], # end condition (OS=="mac") + [ + 'OS!="win"', + { + # C/C++ flags: + 'cflags': [ + # Generate platform-independent code: + '-fPIC', + ], + }, + ], # end condition (OS!="win") + ], # end conditions + }, # end target <(addon_target_name) + + # Target to copy a generated add-on to a standard location: + { + 'target_name': 'copy_addon', + + # Declare that the output of this target is not linked: + 'type': 'none', + + # Define dependencies: + 'dependencies': [ + # Require that the add-on be generated before building this target: + '<(addon_target_name)', + ], + + # Define a list of actions: + 'actions': [ + { + 'action_name': 'copy_addon', + 'message': 'Copying addon...', + + # Explicitly list the inputs in the command-line invocation below: + 'inputs': [], + + # Declare the expected outputs: + 'outputs': [ + '<(addon_output_dir)/<(addon_target_name).node', + ], + + # Define the command-line invocation: + 'action': [ + 'cp', + '<(PRODUCT_DIR)/<(addon_target_name).node', + '<(addon_output_dir)/<(addon_target_name).node', + ], + }, + ], # end actions + }, # end target copy_addon + ], # end targets +} diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile new file mode 100644 index 000000000000..6aed70daf167 --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile @@ -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. +#/ + +# VARIABLES # + +ifndef VERBOSE + QUIET := @ +else + QUIET := +endif + +# Determine the OS ([1][1], [2][2]). +# +# [1]: https://en.wikipedia.org/wiki/Uname#Examples +# [2]: http://stackoverflow.com/a/27776822/2225624 +OS ?= $(shell uname) +ifneq (, $(findstring MINGW,$(OS))) + OS := WINNT +else +ifneq (, $(findstring MSYS,$(OS))) + OS := WINNT +else +ifneq (, $(findstring CYGWIN,$(OS))) + OS := WINNT +else +ifneq (, $(findstring Windows_NT,$(OS))) + OS := WINNT +endif +endif +endif +endif + +# Define the program used for compiling C source files: +ifdef C_COMPILER + CC := $(C_COMPILER) +else + CC := gcc +endif + +# Define the command-line options when compiling C files: +CFLAGS ?= \ + -std=c99 \ + -O3 \ + -Wall \ + -pedantic + +# Determine whether to generate position independent code ([1][1], [2][2]). +# +# [1]: https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#Code-Gen-Options +# [2]: http://stackoverflow.com/questions/5311515/gcc-fpic-option +ifeq ($(OS), WINNT) + fPIC ?= +else + fPIC ?= -fPIC +endif + +# List of includes (e.g., `-I /foo/bar -I /beep/boop/include`): +INCLUDE ?= + +# List of source files: +SOURCE_FILES ?= + +# List of libraries (e.g., `-lopenblas -lpthread`): +LIBRARIES ?= + +# List of library paths (e.g., `-L /foo/bar -L /beep/boop`): +LIBPATH ?= + +# List of C targets: +c_targets := example.out + + +# RULES # + +#/ +# Compiles source files. +# +# @param {string} [C_COMPILER] - C compiler (e.g., `gcc`) +# @param {string} [CFLAGS] - C compiler options +# @param {(string|void)} [fPIC] - compiler flag determining whether to generate position independent code (e.g., `-fPIC`) +# @param {string} [INCLUDE] - list of includes (e.g., `-I /foo/bar -I /beep/boop/include`) +# @param {string} [SOURCE_FILES] - list of source files +# @param {string} [LIBPATH] - list of library paths (e.g., `-L /foo/bar -L /beep/boop`) +# @param {string} [LIBRARIES] - list of libraries (e.g., `-lopenblas -lpthread`) +# +# @example +# make +# +# @example +# make all +#/ +all: $(c_targets) + +.PHONY: all + +#/ +# Compiles C source files. +# +# @private +# @param {string} CC - C compiler (e.g., `gcc`) +# @param {string} CFLAGS - C compiler options +# @param {(string|void)} fPIC - compiler flag determining whether to generate position independent code (e.g., `-fPIC`) +# @param {string} INCLUDE - list of includes (e.g., `-I /foo/bar`) +# @param {string} SOURCE_FILES - list of source files +# @param {string} LIBPATH - list of library paths (e.g., `-L /foo/bar`) +# @param {string} LIBRARIES - list of libraries (e.g., `-lopenblas`) +#/ +$(c_targets): %.out: %.c + $(QUIET) $(CC) $(CFLAGS) $(fPIC) $(INCLUDE) -o $@ $(SOURCE_FILES) $< $(LIBPATH) -lm $(LIBRARIES) + +#/ +# Runs compiled examples. +# +# @example +# make run +#/ +run: $(c_targets) + $(QUIET) ./$< + +.PHONY: run + +#/ +# Removes generated files. +# +# @example +# make clean +#/ +clean: + $(QUIET) -rm -f *.o *.out + +.PHONY: clean diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c new file mode 100644 index 000000000000..234fa4753a88 --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -0,0 +1,37 @@ +/** +* @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. +*/ + +#include "stdlib/stats/base/dists/erlang/kurtosis.h" +#include "stdlib/math/base/special/round.h" +#include "stdlib/constants/float64/eps.h" +#include +#include + +int main( void ) { + double k; + double lambda; + double y; + int i; + + for ( i = 0; i < 10; i++ ) { + k = stdlib_base_round( ( (double)rand() / (double)RAND_MAX )*10.0 ); + lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ); + y = stdlib_base_dists_erlang_kurtosis( k, lambda ); + printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); + } +} diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi new file mode 100644 index 000000000000..575cb043c0bf --- /dev/null +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi @@ -0,0 +1,53 @@ +# @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. + +# A GYP include file for building a Node.js native add-on. +# +# Main documentation: +# +# [1]: https://gyp.gsrc.io/docs/InputFormatReference.md +# [2]: https://gyp.gsrc.io/docs/UserDocumentation.md +{ + # Define variables to be used throughout the configuration for all targets: + 'variables': { + # Source directory: + 'src_dir': './src', + + # Include directories: + 'include_dirs': [ + ' Date: Fri, 27 Dec 2024 18:25:56 +0530 Subject: [PATCH 02/18] fix: CI error --- .../stats/base/dists/erlang/kurtosis/manifest.json | 4 +--- .../base/dists/erlang/kurtosis/test/test.native.js | 11 +++++------ 2 files changed, 6 insertions(+), 9 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json index bf75e02c65da..6318812d7aa6 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json @@ -57,9 +57,7 @@ "libpath": [], "dependencies": [ "@stdlib/constants/float64/eps", - "@stdlib/math/base/assert/is-positive-integer", - "@stdlib/math/base/assert/is-nan", - "@stdlib/math/base/special/round" + "@stdlib/math/base/special/ceil" ] }, { diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js index fd7fe344ad5f..ca66937b90c6 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js @@ -28,7 +28,6 @@ var tryRequire = require( '@stdlib/utils/try-require' ); var PINF = require( '@stdlib/constants/float64/pinf' ); var NINF = require( '@stdlib/constants/float64/ninf' ); var EPS = require( '@stdlib/constants/float64/eps' ); -var kurtosis = require( './../lib' ); // FIXTURES // @@ -46,13 +45,13 @@ var opts = { // TESTS // -tape( 'main export is a function', function test( t ) { +tape( 'main export is a function', opts, function test( t ) { t.ok( true, __filename ); t.strictEqual( typeof kurtosis, 'function', 'main export is a function' ); t.end(); }); -tape( 'if provided `NaN` for any parameter, the function returns `NaN`', function test( t ) { +tape( 'if provided `NaN` for any parameter, the function returns `NaN`', opts, function test( t ) { var v = kurtosis( NaN, 0.5 ); t.equal( isnan( v ), true, 'returns NaN' ); @@ -62,7 +61,7 @@ tape( 'if provided `NaN` for any parameter, the function returns `NaN`', functio t.end(); }); -tape( 'if provided a `k` that is not a positive integer, the function returns `NaN`', function test( t ) { +tape( 'if provided a `k` that is not a positive integer, the function returns `NaN`', opts, function test( t ) { var y; y = kurtosis( 1.5, 2.0 ); @@ -92,7 +91,7 @@ tape( 'if provided a `k` that is not a positive integer, the function returns `N t.end(); }); -tape( 'if provided `lambda <= 0`, the function returns `NaN`', function test( t ) { +tape( 'if provided `lambda <= 0`, the function returns `NaN`', opts, function test( t ) { var y; y = kurtosis( 2, -1.0 ); @@ -113,7 +112,7 @@ tape( 'if provided `lambda <= 0`, the function returns `NaN`', function test( t t.end(); }); -tape( 'the function returns the excess kurtosis of an Erlang distribution', function test( t ) { +tape( 'the function returns the excess kurtosis of an Erlang distribution', opts, function test( t ) { var expected; var lambda; var delta; From a8ab999c30eab92c2705de1397c355bf2dd6dbbc Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Fri, 27 Dec 2024 18:32:05 +0530 Subject: [PATCH 03/18] fix: CI error --- .../base/dists/erlang/kurtosis/benchmark/benchmark.native.js | 1 - .../@stdlib/stats/base/dists/erlang/kurtosis/manifest.json | 4 +++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index 1e8bae7ba77a..28f2c5c3305b 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -28,7 +28,6 @@ var ceil = require( '@stdlib/math/base/special/ceil' ); var tryRequire = require( '@stdlib/utils/try-require' ); var EPS = require( '@stdlib/constants/float64/eps' ); var pkg = require( './../package.json' ).name; -var kurtosis = require( './../lib' ); // VARIABLES // diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json index 6318812d7aa6..61e0f2a7583c 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json @@ -57,7 +57,9 @@ "libpath": [], "dependencies": [ "@stdlib/constants/float64/eps", - "@stdlib/math/base/special/ceil" + "@stdlib/math/base/special/ceil", + "@stdlib/math/base/assert/is-positive-integer", + "@stdlib/math/base/assert/is-nan" ] }, { From d3ca5b57bea558493d8449b74ae4e36bd1ecffe0 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sat, 18 Jan 2025 00:54:50 +0530 Subject: [PATCH 04/18] chore: clean up --- .../base/dists/erlang/kurtosis/README.md | 29 +++++-------------- .../erlang/kurtosis/benchmark/benchmark.js | 18 +++++++++--- .../kurtosis/benchmark/benchmark.native.js | 18 +++++++++--- .../erlang/kurtosis/benchmark/c/benchmark.c | 15 ++++++---- .../erlang/kurtosis/examples/c/example.c | 17 +++++++---- .../stdlib/stats/base/dists/erlang/kurtosis.h | 2 +- .../base/dists/erlang/kurtosis/src/main.c | 4 +-- 7 files changed, 60 insertions(+), 43 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index 257b40a15746..5b4e6a600e85 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -169,29 +169,11 @@ for ( i = 0; i < 10; i++ ) { #### stdlib_base_dists_erlang_kurtosis( k, lambda ) -Evaluates the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda` at a value `x`. +Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. ```c double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); // returns ~6.0 - -y = stdlib_base_dists_erlang_kurtosis( 4.0, 12.0 ); -// returns ~1.5 - -y = stdlib_base_dists_erlang_kurtosis( 8.0, 2.0 ); -// returns ~0.75 - -y = stdlib_base_dists_erlang_kurtosis( 1.0, -0.1 ); -// returns NaN - -y = stdlib_base_dists_erlang_kurtosis( -0.1, 1.0 ); -// returns NaN - -y = stdlib_base_dists_erlang_kurtosis( 2.0, NaN ); -// returns NaN - -y = stdlib_base_dists_erlang_kurtosis( NaN, 2.0 ); -// returns NaN ``` The function accepts the following arguments: @@ -229,6 +211,11 @@ element and another before the `/section` close. --> #include #include +static double random_uniform( const double min, const double max ) { + double v = (double)rand() / ( (double)RAND_MAX + 1.0 ); + return min + ( v*(max-min) ); +} + int main( void ) { double k; double lambda; @@ -236,8 +223,8 @@ int main( void ) { int i; for ( i = 0; i < 10; i++ ) { - k = stdlib_base_round( ( (double)rand() / (double)RAND_MAX )*10.0 ); - lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ); + k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); + lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js index ab18f262d1b1..c0718216ac26 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js @@ -21,7 +21,8 @@ // MODULES // var bench = require( '@stdlib/bench' ); -var randu = require( '@stdlib/random/base/randu' ); +var uniform = require( '@stdlib/random/base/uniform' ); +var Float64Array = require( '@stdlib/array/float64' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); var ceil = require( '@stdlib/math/base/special/ceil' ); var EPS = require( '@stdlib/constants/float64/eps' ); @@ -33,15 +34,24 @@ var kurtosis = require( './../lib' ); bench( pkg, function benchmark( b ) { var lambda; + var len; var k; var y; var i; + len = 100; + k = new Float64Array( len ); + for ( i = 0; i < len; i++ ) { + k[ i ] = ceil( uniform( 0.0, 10.0 ) ); + } + lambda = new Float64Array( len ); + for ( i = 0; i < len; i++ ) { + lambda[ i ] = uniform( EPS, 10.0 ); + } + b.tic(); for ( i = 0; i < b.iterations; i++ ) { - k = ceil( randu()*10.0 ); - lambda = ( randu()*10.0 ) + EPS; - y = kurtosis( k, lambda ); + y = kurtosis( k[ i%100 ], lambda[ i%100 ] ); if ( isnan( y ) ) { b.fail( 'should not return NaN' ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index 28f2c5c3305b..81dd41a14c6d 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -22,7 +22,8 @@ var resolve = require( 'path' ).resolve; var bench = require( '@stdlib/bench' ); -var randu = require( '@stdlib/random/base/randu' ); +var uniform = require( '@stdlib/random/base/uniform' ); +var Float64Array = require( '@stdlib/array/float64' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); var ceil = require( '@stdlib/math/base/special/ceil' ); var tryRequire = require( '@stdlib/utils/try-require' ); @@ -42,15 +43,24 @@ var opts = { bench( pkg+'::native', opts, function benchmark( b ) { var lambda; + var len; var k; var y; var i; + len = 100; + k = new Float64Array( len ); + for ( i = 0; i < len; i++ ) { + k[ i ] = ceil( uniform( 0.0, 10.0 ) ); + } + lambda = new Float64Array( len ); + for ( i = 0; i < len; i++ ) { + lambda[ i ] = uniform( EPS, 10.0 ); + } + b.tic(); for ( i = 0; i < b.iterations; i++ ) { - k = ceil( randu()*10.0 ); - lambda = ( randu()*10.0 ) + EPS; - y = kurtosis( k, lambda ); + y = kurtosis( k[ i%100 ], lambda[ i%100 ] ); if ( isnan( y ) ) { b.fail( 'should not return NaN' ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index 0047a3e5cb74..4b617d5d5137 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -93,17 +93,22 @@ static double rand_double( void ) { */ static double benchmark( void ) { double elapsed; - double k; - double lambda; + double k[ 100 ]; + double lambda[ 100 ]; double y; double t; int i; + for ( i = 0; i < 100; i++ ) { + k[ i ] = stdlib_base_ceil( random_uniform( 0.0, 10.0 ) ); + } + for ( i = 0; i < 100; i++ ) { + lambda[ i ] = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); + } + t = tic(); for ( i = 0; i < ITERATIONS; i++ ) { - k = stdlib_base_ceil( ( (double)rand() / (double)RAND_MAX )*10.0 ); - lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ) + STDLIB_CONSTANT_FLOAT64_EPS; - y = stdlib_base_dists_erlang_kurtosis( k, lambda ); + y = stdlib_base_dists_erlang_kurtosis( k[ i%100 ], lambda[ i%100 ] ); if ( y != y ) { printf( "should not return NaN\n" ); break; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index 234fa4753a88..6a2168cc6d9d 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -22,16 +22,21 @@ #include #include +static double random_uniform( const double min, const double max ) { + double v = (double)rand() / ( (double)RAND_MAX + 1.0 ); + return min + ( v*(max-min) ); +} + int main( void ) { - double k; - double lambda; + double k; + double lambda; double y; int i; for ( i = 0; i < 10; i++ ) { - k = stdlib_base_round( ( (double)rand() / (double)RAND_MAX )*10.0 ); - lambda = ( ( (double)rand() / (double)RAND_MAX )*10.0 ); - y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); + k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); + lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); + y = stdlib_base_dists_erlang_kurtosis( k, lambda ); + printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); } } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h index 49cc0e5770f3..5996fed4c299 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h @@ -27,7 +27,7 @@ extern "C" { #endif /** -* Evaluates the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda` at a value `x`. +* Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. */ double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index 541913ccf234..f08751917090 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -21,7 +21,7 @@ #include "stdlib/math/base/assert/is_nan.h" /** -* Evaluates the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda` at a value `x`. +* Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. * * @param k shape parameter * @param lambda rate parameter @@ -56,7 +56,7 @@ * // returns NaN */ double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ) { - if ( + if ( !stdlib_base_is_positive_integer( k ) || stdlib_base_is_nan( lambda ) || lambda <= 0.0 From a9b8497e6fec731af857b11aae285a063ff2305c Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sat, 18 Jan 2025 00:58:00 +0530 Subject: [PATCH 05/18] chore: update bench --- .../dists/erlang/kurtosis/benchmark/c/benchmark.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index 4b617d5d5137..5ced6e03baf8 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -77,13 +77,15 @@ static double tic( void ) { } /** -* Generates a random number on the interval [0,1). +* Generates a random number on the interval [min,max). * -* @return random number +* @param min minimum value (inclusive) +* @param max maximum value (exclusive) +* @return random number */ -static double rand_double( void ) { - int r = rand(); - return (double)r / ( (double)RAND_MAX + 1.0 ); +static double random_uniform( const double min, const double max ) { + double v = (double)rand() / ( (double)RAND_MAX + 1.0 ); + return min + ( v*(max-min) ); } /** From abf079e7e9059b3991750d83e8954d4a00242c7e Mon Sep 17 00:00:00 2001 From: stdlib-bot <82920195+stdlib-bot@users.noreply.github.com> Date: Fri, 17 Jan 2025 19:29:02 +0000 Subject: [PATCH 06/18] chore: update copyright years --- .../base/dists/erlang/kurtosis/benchmark/benchmark.native.js | 2 +- .../stats/base/dists/erlang/kurtosis/benchmark/c/Makefile | 2 +- .../stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp | 2 +- .../stats/base/dists/erlang/kurtosis/examples/c/Makefile | 2 +- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/include.gypi | 2 +- .../kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/main.c | 2 +- .../stats/base/dists/erlang/kurtosis/test/test.native.js | 2 +- 13 files changed, 13 insertions(+), 13 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index 81dd41a14c6d..9612d66f9fb4 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile index f69e9da2b4d3..a4bd7b38fd74 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/Makefile @@ -1,7 +1,7 @@ #/ # @license Apache-2.0 # -# Copyright (c) 2024 The Stdlib Authors. +# Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index 5ced6e03baf8..afd40199090c 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp index ec3992233442..68a1ca11d160 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/binding.gyp @@ -1,6 +1,6 @@ # @license Apache-2.0 # -# Copyright (c) 2024 The Stdlib Authors. +# Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile index 6aed70daf167..25ced822f96a 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/Makefile @@ -1,7 +1,7 @@ #/ # @license Apache-2.0 # -# Copyright (c) 2024 The Stdlib Authors. +# Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index 6a2168cc6d9d..f93db1fb5209 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi index 575cb043c0bf..ecfaf82a3279 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include.gypi @@ -1,6 +1,6 @@ # @license Apache-2.0 # -# Copyright (c) 2024 The Stdlib Authors. +# Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h index 5996fed4c299..f9c8d0e89b68 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js index af65d78f0444..3e1166fb6799 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile index bcf18aa46655..7733b6180cb4 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/Makefile @@ -1,7 +1,7 @@ #/ # @license Apache-2.0 # -# Copyright (c) 2024 The Stdlib Authors. +# Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c index f250a00c4bd5..ff012c102cfd 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index f08751917090..698229257836 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js index ca66937b90c6..f693ae51f086 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2024 The Stdlib Authors. +* Copyright (c) 2025 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. From cb50b8fa207244a289f8cb358273472b46c4dc92 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Fri, 31 Jan 2025 23:05:00 +0530 Subject: [PATCH 07/18] chore: minor updates --- .../stats/base/dists/erlang/kurtosis/benchmark/benchmark.js | 6 +++--- .../dists/erlang/kurtosis/benchmark/benchmark.native.js | 6 +++--- .../@stdlib/stats/base/dists/erlang/kurtosis/manifest.json | 1 - 3 files changed, 6 insertions(+), 7 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js index c0718216ac26..eece299d86dd 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js @@ -21,10 +21,10 @@ // MODULES // var bench = require( '@stdlib/bench' ); +var discreteUniform = require( '@stdlib/random/base/discrete-uniform' ); var uniform = require( '@stdlib/random/base/uniform' ); var Float64Array = require( '@stdlib/array/float64' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); -var ceil = require( '@stdlib/math/base/special/ceil' ); var EPS = require( '@stdlib/constants/float64/eps' ); var pkg = require( './../package.json' ).name; var kurtosis = require( './../lib' ); @@ -42,7 +42,7 @@ bench( pkg, function benchmark( b ) { len = 100; k = new Float64Array( len ); for ( i = 0; i < len; i++ ) { - k[ i ] = ceil( uniform( 0.0, 10.0 ) ); + k[ i ] = discreteUniform( 0.0, 10.0 ); } lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { @@ -51,7 +51,7 @@ bench( pkg, function benchmark( b ) { b.tic(); for ( i = 0; i < b.iterations; i++ ) { - y = kurtosis( k[ i%100 ], lambda[ i%100 ] ); + y = kurtosis( k[ i % len ], lambda[ i % len ] ); if ( isnan( y ) ) { b.fail( 'should not return NaN' ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index 9612d66f9fb4..2ee171c80fc1 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -22,10 +22,10 @@ var resolve = require( 'path' ).resolve; var bench = require( '@stdlib/bench' ); +var discreteUniform = require( '@stdlib/random/base/discrete-uniform' ); var uniform = require( '@stdlib/random/base/uniform' ); var Float64Array = require( '@stdlib/array/float64' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); -var ceil = require( '@stdlib/math/base/special/ceil' ); var tryRequire = require( '@stdlib/utils/try-require' ); var EPS = require( '@stdlib/constants/float64/eps' ); var pkg = require( './../package.json' ).name; @@ -51,7 +51,7 @@ bench( pkg+'::native', opts, function benchmark( b ) { len = 100; k = new Float64Array( len ); for ( i = 0; i < len; i++ ) { - k[ i ] = ceil( uniform( 0.0, 10.0 ) ); + k[ i ] = discreteUniform( 0.0, 10.0 ); } lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { @@ -60,7 +60,7 @@ bench( pkg+'::native', opts, function benchmark( b ) { b.tic(); for ( i = 0; i < b.iterations; i++ ) { - y = kurtosis( k[ i%100 ], lambda[ i%100 ] ); + y = kurtosis( k[ i % len ], lambda[ i % len ] ); if ( isnan( y ) ) { b.fail( 'should not return NaN' ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json index 61e0f2a7583c..ecc8de00a7a9 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/manifest.json @@ -39,7 +39,6 @@ "libpath": [], "dependencies": [ "@stdlib/math/base/napi/binary", - "@stdlib/constants/float64/eps", "@stdlib/math/base/assert/is-positive-integer", "@stdlib/math/base/assert/is-nan" ] From 3a438bae16b370448f92a44e4edd1c588e3e9fec Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Wed, 5 Feb 2025 21:45:06 +0530 Subject: [PATCH 08/18] chore: changes from code review --- .../base/dists/erlang/kurtosis/README.md | 4 ++-- .../erlang/kurtosis/benchmark/c/benchmark.c | 2 +- .../base/dists/erlang/kurtosis/lib/native.js | 1 + .../base/dists/erlang/kurtosis/src/main.c | 24 ------------------- 4 files changed, 4 insertions(+), 27 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index 5b4e6a600e85..b9ae65bb4b4e 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -178,8 +178,8 @@ double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); The function accepts the following arguments: -- **k**: `[in] double` shape parameter -- **lambda**: `[in] double` rate parameter +- **k**: `[in] double` shape parameter. +- **lambda**: `[in] double` rate parameter. ```c double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index afd40199090c..a2f207043acc 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -110,7 +110,7 @@ static double benchmark( void ) { t = tic(); for ( i = 0; i < ITERATIONS; i++ ) { - y = stdlib_base_dists_erlang_kurtosis( k[ i%100 ], lambda[ i%100 ] ); + y = stdlib_base_dists_erlang_kurtosis( k[ i % 100 ], lambda[ i % 100 ] ); if ( y != y ) { printf( "should not return NaN\n" ); break; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js index 3e1166fb6799..8507abb5f349 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js @@ -28,6 +28,7 @@ var addon = require( './../src/addon.node' ); /** * Returns the excess kurtosis of an Erlang distribution. * +* @private * @param {PositiveInteger} k - shape parameter * @param {PositiveNumber} lambda - rate parameter * @returns {NonNegativeNumber} excess kurtosis diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index 698229257836..e47cb64485e3 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -30,30 +30,6 @@ * @example * double y = stdlib_base_dists_beta_kurtosis( 1.0, 1.0 ); * // returns ~6.0 -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( 4.0, 12.0 ); -* // returns ~1.5 -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( 8.0, 2.0 ); -* // returns ~0.75 -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( 1.0, -0.1 ); -* // returns NaN -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( -0.1, 1.0 ); -* // returns NaN -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( 2.0, NaN ); -* // returns NaN -* -* @example -* double y = stdlib_base_dists_beta_kurtosis( NaN, 2.0 ); -* // returns NaN */ double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ) { if ( From bf82bf5480000a507e0b4eea08f1cf2cd163b0c9 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Thu, 6 Feb 2025 10:44:42 +0530 Subject: [PATCH 09/18] chore: stuff from code review --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 4 ++-- .../stats/base/dists/erlang/kurtosis/benchmark/benchmark.js | 4 +--- .../base/dists/erlang/kurtosis/benchmark/benchmark.native.js | 4 +--- .../stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c | 2 -- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/main.c | 4 ++-- 6 files changed, 7 insertions(+), 13 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index b9ae65bb4b4e..ee9661d3e44c 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -173,7 +173,7 @@ Returns the excess kurtosis for a erlang distribution with shape parameter `k` a ```c double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); -// returns ~6.0 +// returns 6.0 ``` The function accepts the following arguments: @@ -226,7 +226,7 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %1f. λ: %1f. Kurt(X;k,λ): %lf\n", k, lambda, y ); } } ``` diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js index eece299d86dd..75ad507b7ffd 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js @@ -41,11 +41,9 @@ bench( pkg, function benchmark( b ) { len = 100; k = new Float64Array( len ); - for ( i = 0; i < len; i++ ) { - k[ i ] = discreteUniform( 0.0, 10.0 ); - } lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { + k[ i ] = discreteUniform( 0.0, 10.0 ); lambda[ i ] = uniform( EPS, 10.0 ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index 2ee171c80fc1..e29e737aa8c8 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -50,11 +50,9 @@ bench( pkg+'::native', opts, function benchmark( b ) { len = 100; k = new Float64Array( len ); - for ( i = 0; i < len; i++ ) { - k[ i ] = discreteUniform( 0.0, 10.0 ); - } lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { + k[ i ] = discreteUniform( 0.0, 10.0 ); lambda[ i ] = uniform( EPS, 10.0 ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index a2f207043acc..e3d8976e6588 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -103,8 +103,6 @@ static double benchmark( void ) { for ( i = 0; i < 100; i++ ) { k[ i ] = stdlib_base_ceil( random_uniform( 0.0, 10.0 ) ); - } - for ( i = 0; i < 100; i++ ) { lambda[ i ] = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index f93db1fb5209..07aa43b735ba 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -37,6 +37,6 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %1f, λ: %1f, Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %1f. λ: %1f. Kurt(X;k,λ): %lf\n", k, lambda, y ); } } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index e47cb64485e3..acc6c271208d 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -25,11 +25,11 @@ * * @param k shape parameter * @param lambda rate parameter -* @returns excess kurtosis +* @return excess kurtosis * * @example * double y = stdlib_base_dists_beta_kurtosis( 1.0, 1.0 ); -* // returns ~6.0 +* // returns 6.0 */ double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ) { if ( From 32102312459a33a7f89bae561090e345c517d583 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Fri, 7 Feb 2025 10:54:32 +0530 Subject: [PATCH 10/18] chore: minor clean up --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 2 +- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index ee9661d3e44c..20d53f2410c6 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -226,7 +226,7 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %1f. λ: %1f. Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %lf, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); } } ``` diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index 07aa43b735ba..af3e2f7d0663 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -37,6 +37,6 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %1f. λ: %1f. Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %lf, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); } } From 50f4d6a1bf679fb6f10a4509aeed249a46d335b9 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Fri, 7 Feb 2025 20:17:41 +0530 Subject: [PATCH 11/18] chore: update markdown description --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index 20d53f2410c6..79756562b758 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -169,7 +169,7 @@ for ( i = 0; i < 10; i++ ) { #### stdlib_base_dists_erlang_kurtosis( k, lambda ) -Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. +Returns the [excess kurtosis][kurtosis] of an [Erlang][erlang-distribution] distribution with parameters `k` (shape parameter) and `lambda` (rate parameter). ```c double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); From 58ed035ecc8ab905b95ba3e1da5d3561dcbdb308 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sun, 2 Mar 2025 21:01:10 +0530 Subject: [PATCH 12/18] refactor: add int32_t logic around k parameter --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 5 +++-- .../stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c | 3 ++- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 3 ++- .../include/stdlib/stats/base/dists/erlang/kurtosis.h | 4 +++- .../@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/main.c | 4 ++-- 6 files changed, 13 insertions(+), 8 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index 79756562b758..d577d82d23dd 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -178,11 +178,11 @@ double y = stdlib_base_dists_erlang_kurtosis( 1.0, 1.0 ); The function accepts the following arguments: -- **k**: `[in] double` shape parameter. +- **k**: `[in] int32_t` shape parameter. - **lambda**: `[in] double` rate parameter. ```c -double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ); +double stdlib_base_dists_erlang_kurtosis( const isnt32_t k, const double lambda ); ```
@@ -208,6 +208,7 @@ element and another before the `/section` close. --> #include "stdlib/stats/base/dists/erlang/kurtosis.h" #include "stdlib/math/base/special/round.h" #include "stdlib/constants/float64/eps.h" +#include #include #include diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c index e3d8976e6588..991db8af44ea 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/c/benchmark.c @@ -19,6 +19,7 @@ #include "stdlib/stats/base/dists/erlang/kurtosis.h" #include "stdlib/math/base/special/ceil.h" #include "stdlib/constants/float64/eps.h" +#include #include #include #include @@ -95,7 +96,7 @@ static double random_uniform( const double min, const double max ) { */ static double benchmark( void ) { double elapsed; - double k[ 100 ]; + int32_t k[ 100 ]; double lambda[ 100 ]; double y; double t; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index af3e2f7d0663..7b53226fed19 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -19,6 +19,7 @@ #include "stdlib/stats/base/dists/erlang/kurtosis.h" #include "stdlib/math/base/special/round.h" #include "stdlib/constants/float64/eps.h" +#include #include #include @@ -28,7 +29,7 @@ static double random_uniform( const double min, const double max ) { } int main( void ) { - double k; + int32_t k; double lambda; double y; int i; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h index f9c8d0e89b68..86e51ceb7d7d 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h @@ -19,6 +19,8 @@ #ifndef STDLIB_STATS_BASE_DISTS_ERLANG_KURTOSIS_H #define STDLIB_STATS_BASE_DISTS_ERLANG_KURTOSIS_H +#include + /* * If C++, prevent name mangling so that the compiler emits a binary file having undecorated names, thus mirroring the behavior of a C compiler. */ @@ -29,7 +31,7 @@ extern "C" { /** * Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. */ -double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ); +double stdlib_base_dists_erlang_kurtosis( const int32_t k, const double lambda ); #ifdef __cplusplus } diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c index ff012c102cfd..bc40f4eb953a 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/addon.c @@ -20,4 +20,4 @@ #include "stdlib/math/base/napi/binary.h" // cppcheck-suppress shadowFunction -STDLIB_MATH_BASE_NAPI_MODULE_DD_D( stdlib_base_dists_erlang_kurtosis ) +STDLIB_MATH_BASE_NAPI_MODULE_ID_D( stdlib_base_dists_erlang_kurtosis ) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index acc6c271208d..03590d6c12fc 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -19,7 +19,7 @@ #include "stdlib/stats/base/dists/erlang/kurtosis.h" #include "stdlib/math/base/assert/is_positive_integer.h" #include "stdlib/math/base/assert/is_nan.h" - +#include /** * Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. * @@ -31,7 +31,7 @@ * double y = stdlib_base_dists_beta_kurtosis( 1.0, 1.0 ); * // returns 6.0 */ -double stdlib_base_dists_erlang_kurtosis( const double k, const double lambda ) { +double stdlib_base_dists_erlang_kurtosis( const int32_t k, const double lambda ) { if ( !stdlib_base_is_positive_integer( k ) || stdlib_base_is_nan( lambda ) || From 622717d39d52a7725f0b7dcbf77c730c9f81c66a Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sun, 2 Mar 2025 21:31:36 +0530 Subject: [PATCH 13/18] chore: update bench --- .../stats/base/dists/erlang/kurtosis/benchmark/benchmark.js | 3 ++- .../base/dists/erlang/kurtosis/benchmark/benchmark.native.js | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js index 75ad507b7ffd..00c9ce8b38d4 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.js @@ -24,6 +24,7 @@ var bench = require( '@stdlib/bench' ); var discreteUniform = require( '@stdlib/random/base/discrete-uniform' ); var uniform = require( '@stdlib/random/base/uniform' ); var Float64Array = require( '@stdlib/array/float64' ); +var Int32Array = require( '@stdlib/array/int32' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); var EPS = require( '@stdlib/constants/float64/eps' ); var pkg = require( './../package.json' ).name; @@ -40,7 +41,7 @@ bench( pkg, function benchmark( b ) { var i; len = 100; - k = new Float64Array( len ); + k = new Int32Array( len ); lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { k[ i ] = discreteUniform( 0.0, 10.0 ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js index e29e737aa8c8..5b1b91f8a4ca 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/benchmark/benchmark.native.js @@ -25,6 +25,7 @@ var bench = require( '@stdlib/bench' ); var discreteUniform = require( '@stdlib/random/base/discrete-uniform' ); var uniform = require( '@stdlib/random/base/uniform' ); var Float64Array = require( '@stdlib/array/float64' ); +var Int32Array = require( '@stdlib/array/int32' ); var isnan = require( '@stdlib/math/base/assert/is-nan' ); var tryRequire = require( '@stdlib/utils/try-require' ); var EPS = require( '@stdlib/constants/float64/eps' ); @@ -49,7 +50,7 @@ bench( pkg+'::native', opts, function benchmark( b ) { var i; len = 100; - k = new Float64Array( len ); + k = new Int32Array( len ); lambda = new Float64Array( len ); for ( i = 0; i < len; i++ ) { k[ i ] = discreteUniform( 0.0, 10.0 ); From 437ee7944b5f99d02a9f42c620cd61cd1c083ab4 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sun, 2 Mar 2025 22:32:35 +0530 Subject: [PATCH 14/18] fix: CI errors --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 4 ++-- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index d577d82d23dd..ca9ffd5a6004 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -218,7 +218,7 @@ static double random_uniform( const double min, const double max ) { } int main( void ) { - double k; + int32_t k; double lambda; double y; int i; @@ -227,7 +227,7 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %lf, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %d, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); } } ``` diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index 7b53226fed19..694af0aa040c 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -38,6 +38,6 @@ int main( void ) { k = stdlib_base_round( random_uniform( 0.0, 10.0 ) ); lambda = random_uniform( STDLIB_CONSTANT_FLOAT64_EPS, 10.0 ); y = stdlib_base_dists_erlang_kurtosis( k, lambda ); - printf( "k: %lf, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); + printf( "k: %d, λ: %lf, Kurt(X;k,λ): %lf\n", k, lambda, y ); } } From 1e0d364b267e8e539012f0ecd765a95b3bafd3e7 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Wed, 12 Mar 2025 19:53:49 +0530 Subject: [PATCH 15/18] chore: stuff from code review --- .../@stdlib/stats/base/dists/erlang/kurtosis/README.md | 2 +- .../stats/base/dists/erlang/kurtosis/examples/c/example.c | 2 +- .../include/stdlib/stats/base/dists/erlang/kurtosis.h | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/src/main.c | 7 ++++--- 4 files changed, 7 insertions(+), 6 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md index ca9ffd5a6004..dbc52601de27 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/README.md @@ -218,8 +218,8 @@ static double random_uniform( const double min, const double max ) { } int main( void ) { - int32_t k; double lambda; + int32_t k; double y; int i; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c index 694af0aa040c..fd246d0ccd65 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/examples/c/example.c @@ -29,8 +29,8 @@ static double random_uniform( const double min, const double max ) { } int main( void ) { - int32_t k; double lambda; + int32_t k; double y; int i; diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h index 86e51ceb7d7d..2aa44bd7249e 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/include/stdlib/stats/base/dists/erlang/kurtosis.h @@ -29,7 +29,7 @@ extern "C" { #endif /** -* Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. +* Returns the excess kurtosis for an Erlang distribution with shape parameter `k` and rate parameter `lambda`. */ double stdlib_base_dists_erlang_kurtosis( const int32_t k, const double lambda ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index 03590d6c12fc..3b02dde63e66 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -20,20 +20,21 @@ #include "stdlib/math/base/assert/is_positive_integer.h" #include "stdlib/math/base/assert/is_nan.h" #include + /** -* Returns the excess kurtosis for a erlang distribution with shape parameter `k` and rate parameter `lambda`. +* Returns the excess kurtosis for an Erlang distribution with shape parameter `k` and rate parameter `lambda`. * * @param k shape parameter * @param lambda rate parameter * @return excess kurtosis * * @example -* double y = stdlib_base_dists_beta_kurtosis( 1.0, 1.0 ); +* double y = stdlib_base_dists_beta_kurtosis( 1, 1.0 ); * // returns 6.0 */ double stdlib_base_dists_erlang_kurtosis( const int32_t k, const double lambda ) { if ( - !stdlib_base_is_positive_integer( k ) || + k > 0.0 || stdlib_base_is_nan( lambda ) || lambda <= 0.0 ) { From 474e8f3543dfcafde49ecc33f2ca0141a1702c82 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Wed, 12 Mar 2025 19:58:59 +0530 Subject: [PATCH 16/18] chore: testing with diff values of k --- .../@stdlib/stats/base/dists/erlang/kurtosis/src/main.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c index 3b02dde63e66..a65f8c8e2e85 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/src/main.c @@ -34,7 +34,7 @@ */ double stdlib_base_dists_erlang_kurtosis( const int32_t k, const double lambda ) { if ( - k > 0.0 || + k <= 0.0 || stdlib_base_is_nan( lambda ) || lambda <= 0.0 ) { From 94e88bc7bcf05f77e245a6d7b8b16f2f5627f447 Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Wed, 12 Mar 2025 21:33:43 +0530 Subject: [PATCH 17/18] chore: testing with diff values of k --- .../@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js | 2 +- .../@stdlib/stats/base/dists/erlang/kurtosis/test/test.js | 4 ++-- .../stats/base/dists/erlang/kurtosis/test/test.native.js | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js index 8507abb5f349..d04b2d99c5ed 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js @@ -47,7 +47,7 @@ var addon = require( './../src/addon.node' ); * * @example * var v = kurtosis( 1.5, 2.0 ); -* // returns NaN +* // returns 6.0 * * @example * var v = kurtosis( 1, -0.1 ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.js index ed46b4917d5f..abfa8f42cea2 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.js @@ -55,10 +55,10 @@ tape( 'if provided `NaN` for any parameter, the function returns `NaN`', functio tape( 'if provided a `k` that is not a positive integer, the function returns `NaN`', function test( t ) { var y; - y = kurtosis( 1.5, 2.0 ); + y = kurtosis( 1.7, 2.0 ); t.equal( isnan( y ), true, 'returns NaN' ); - y = kurtosis( 3.9, 2.0 ); + y = kurtosis( 3.7, 2.0 ); t.equal( isnan( y ), true, 'returns NaN' ); y = kurtosis( 0.0, 2.0 ); diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js index f693ae51f086..405ac8478860 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js @@ -64,10 +64,10 @@ tape( 'if provided `NaN` for any parameter, the function returns `NaN`', opts, f tape( 'if provided a `k` that is not a positive integer, the function returns `NaN`', opts, function test( t ) { var y; - y = kurtosis( 1.5, 2.0 ); + y = kurtosis( 1.7, 2.0 ); t.equal( isnan( y ), true, 'returns NaN' ); - y = kurtosis( 3.9, 2.0 ); + y = kurtosis( 3.7, 2.0 ); t.equal( isnan( y ), true, 'returns NaN' ); y = kurtosis( 0.0, 2.0 ); From aa533e18835d5314c986b0c8fe569c4c8c6b857a Mon Sep 17 00:00:00 2001 From: Neerajpathak07 Date: Sun, 16 Mar 2025 00:32:26 +0530 Subject: [PATCH 18/18] chore: update tests --- .../@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js | 4 ---- .../stats/base/dists/erlang/kurtosis/test/test.native.js | 6 ------ 2 files changed, 10 deletions(-) diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js index d04b2d99c5ed..422513468ca5 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/lib/native.js @@ -46,10 +46,6 @@ var addon = require( './../src/addon.node' ); * // returns 0.75 * * @example -* var v = kurtosis( 1.5, 2.0 ); -* // returns 6.0 -* -* @example * var v = kurtosis( 1, -0.1 ); * // returns NaN * diff --git a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js index 405ac8478860..6c19553f6055 100644 --- a/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js +++ b/lib/node_modules/@stdlib/stats/base/dists/erlang/kurtosis/test/test.native.js @@ -64,12 +64,6 @@ tape( 'if provided `NaN` for any parameter, the function returns `NaN`', opts, f tape( 'if provided a `k` that is not a positive integer, the function returns `NaN`', opts, function test( t ) { var y; - y = kurtosis( 1.7, 2.0 ); - t.equal( isnan( y ), true, 'returns NaN' ); - - y = kurtosis( 3.7, 2.0 ); - t.equal( isnan( y ), true, 'returns NaN' ); - y = kurtosis( 0.0, 2.0 ); t.equal( isnan( y ), true, 'returns NaN' );