From 276510dc76d33b2372d574762b24aa9ba870caff Mon Sep 17 00:00:00 2001 From: GUNJ JOSHI Date: Sat, 10 Aug 2024 01:02:26 +0530 Subject: [PATCH 1/4] feat: add C implementation for math/base/special/binomcoefln --- .../math/base/special/binomcoefln/README.md | 90 +++++++++- .../binomcoefln/benchmark/benchmark.native.js | 63 +++++++ .../binomcoefln/benchmark/c/native/Makefile | 146 +++++++++++++++ .../benchmark/c/native/benchmark.c | 135 ++++++++++++++ .../math/base/special/binomcoefln/binding.gyp | 170 ++++++++++++++++++ .../special/binomcoefln/examples/c/Makefile | 146 +++++++++++++++ .../special/binomcoefln/examples/c/example.c | 33 ++++ .../base/special/binomcoefln/include.gypi | 53 ++++++ .../stdlib/math/base/special/binomcoefln.h | 40 +++++ .../base/special/binomcoefln/lib/native.js | 59 ++++++ .../base/special/binomcoefln/manifest.json | 87 +++++++++ .../base/special/binomcoefln/src/Makefile | 70 ++++++++ .../math/base/special/binomcoefln/src/addon.c | 22 +++ .../math/base/special/binomcoefln/src/main.c | 59 ++++++ .../base/special/binomcoefln/test/test.js | 7 +- .../special/binomcoefln/test/test.native.js | 91 ++++++++++ 16 files changed, 1267 insertions(+), 4 deletions(-) create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/benchmark/benchmark.native.js create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/benchmark/c/native/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/benchmark/c/native/benchmark.c create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/binding.gyp create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/examples/c/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/examples/c/example.c create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/include.gypi create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/include/stdlib/math/base/special/binomcoefln.h create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/lib/native.js create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/manifest.json create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/src/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/src/addon.c create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/src/main.c create mode 100644 lib/node_modules/@stdlib/math/base/special/binomcoefln/test/test.native.js diff --git a/lib/node_modules/@stdlib/math/base/special/binomcoefln/README.md b/lib/node_modules/@stdlib/math/base/special/binomcoefln/README.md index bcc823735951..909794b90460 100644 --- a/lib/node_modules/@stdlib/math/base/special/binomcoefln/README.md +++ b/lib/node_modules/@stdlib/math/base/special/binomcoefln/README.md @@ -83,7 +83,7 @@ var binomcoefln = require( '@stdlib/math/base/special/binomcoefln' ); #### binomcoefln( n, k ) -Evaluates the [binomial coefficient][binomial-coefficient] of two integers `n` and `k`. +Evaluates the natural logarithm of the [binomial coefficient][binomial-coefficient] of two integers `n` and `k`. ```javascript var v = binomcoefln( 8, 2 ); @@ -158,6 +158,94 @@ for ( i = 0; i < 100; i++ ) { + + +* * * + +
+ +## C APIs + + + +
+ +
+ + + + + +
+ +### Usage + +```c +#include "stdlib/math/base/special/binomcoefln.h" +``` + +#### stdlib_base_binomcoefln( n, k ) + +Evaluates the natural logarithm of the [binomial coefficient][binomial-coefficient] of two integers `n` and `k`. + +```c +double v = stdlib_base_binomcoefln( 8, 2 ); +// returns ~3.332 +``` + +The function accepts the following arguments: + +- **n**: `[in] int64_t` input value. +- **k**: `[in] int64_t` input value. + +```c +double stdlib_base_binomcoefln( const int64_t n, const int64_t k ); +``` + +
+ + + + + +
+ +
+ + + + + +
+ +### Examples + +```c +#include "stdlib/math/base/special/binomcoefln.h" +#include +#include + +int main( void ) { + const int64_t a[] = { 24, 32, 48, 116, 33 }; + const int64_t b[] = { 12, 6, 15, 52, 22 }; + + double out; + int i; + for ( i = 0; i < 5; i++ ) { + out = stdlib_base_binomcoef( a[ i ], b[ i ] ); + printf( "binomcoef(%ln, %ln) = %lf\n", a[ i ], b[ i ], out ); + } +} +``` + +
+ + + +
+ + +