From 8b94125d69de1698c5b40f2039b9234a2c979288 Mon Sep 17 00:00:00 2001
From: Manvith <148960168+manvith2003@users.noreply.github.com>
Date: Sat, 14 Dec 2024 21:41:11 +0530
Subject: [PATCH 1/3] feat: add C implementation for
@stdlib/stats/base/dists/normal/cdf
---
.../stats/base/dists/normal/cdf/README.md | 98 +++++++++
.../dists/normal/cdf/benchmark/benchmark.js | 22 +-
.../normal/cdf/benchmark/benchmark.native.js | 74 +++++++
.../dists/normal/cdf/benchmark/c/Makefile | 146 +++++++++++++
.../dists/normal/cdf/benchmark/c/benchmark.c | 143 +++++++++++++
.../stats/base/dists/normal/cdf/binding.gyp | 170 +++++++++++++++
.../base/dists/normal/cdf/examples/c/Makefile | 146 +++++++++++++
.../dists/normal/cdf/examples/c/example.c | 43 ++++
.../stats/base/dists/normal/cdf/include.gypi | 53 +++++
.../stdlib/stats/base/dists/normal/cdf.h | 38 ++++
.../stats/base/dists/normal/cdf/lib/native.js | 73 +++++++
.../stats/base/dists/normal/cdf/manifest.json | 82 ++++++++
.../stats/base/dists/normal/cdf/package.json | 3 +
.../stats/base/dists/normal/cdf/src/Makefile | 70 +++++++
.../stats/base/dists/normal/cdf/src/addon.c | 23 ++
.../stats/base/dists/normal/cdf/src/main.c | 58 ++++++
.../base/dists/normal/cdf/test/test.native.js | 196 ++++++++++++++++++
17 files changed, 1432 insertions(+), 6 deletions(-)
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/benchmark/benchmark.native.js
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/benchmark/c/Makefile
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/benchmark/c/benchmark.c
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/binding.gyp
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/examples/c/Makefile
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/examples/c/example.c
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/include.gypi
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/include/stdlib/stats/base/dists/normal/cdf.h
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/lib/native.js
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/manifest.json
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/src/Makefile
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/src/addon.c
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/src/main.c
create mode 100644 lib/node_modules/@stdlib/stats/base/dists/normal/cdf/test/test.native.js
diff --git a/lib/node_modules/@stdlib/stats/base/dists/normal/cdf/README.md b/lib/node_modules/@stdlib/stats/base/dists/normal/cdf/README.md
index 1da8c09549cd..eceb34b15252 100644
--- a/lib/node_modules/@stdlib/stats/base/dists/normal/cdf/README.md
+++ b/lib/node_modules/@stdlib/stats/base/dists/normal/cdf/README.md
@@ -148,6 +148,104 @@ for ( i = 0; i < 10; i++ ) {
+
+
+* * *
+
+
+
+## C APIs
+
+
+
+
+
+
+
+
+
+
+
+### Usage
+
+```c
+#include "stdlib/stats/base/dists/normal/cdf.h"
+```
+
+#### stdlib_base_dists_normal_cdf( x, a, b )
+
+Evaluates the cumulative distribution function (CDF) for an normal distribution.
+
+```c
+double out = stdlib_base_dists_normal_cdf( 2.0, 0.0, 1.0 );
+// returns ~0.977
+```
+
+The function accepts the following arguments:
+
+- **x**: `[in] double` input value.
+- **mu**: `[in] double` mean.
+- **sigma**: `[in] double` standard deviation.
+
+```c
+double stdlib_base_dists_normal_cdf( cconst double x, const double mu, const double sigma );
+```
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+### Examples
+
+```c
+#include "stdlib/stats/base/dists/normal/cdf.h"
+#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 x;
+ double mu;
+ double sigma;
+ double y;
+ int i;
+
+ for ( i = 0; i < 10; i++ ) {
+ x = random_uniform( 0.0, 10.0 );
+ mu = random_uniform( -5.0, 5.0 );
+ sigma = random_uniform( 0.1, 20.0 );
+ y = stdlib_base_dists_normal_cdf( x, mu, sigma );
+ printf( "x: %lf, µ: %lf, σ: %lf, F(x;µ,σ): %lf\n", x, mu, sigma, y );
+ }
+}
+```
+
+
+
+
+
+
+
+
+