From 39e46190e1c559e29125e44c8a135c76ef0573dc Mon Sep 17 00:00:00 2001 From: GUNJ JOSHI Date: Sat, 20 Jul 2024 10:27:01 +0530 Subject: [PATCH 1/2] feat: add C implementation for math/base/special/ceilsd --- .../math/base/special/ceilsd/README.md | 106 ++++++++++- .../ceilsd/benchmark/benchmark.native.js | 60 ++++++ .../ceilsd/benchmark/c/native/Makefile | 146 +++++++++++++++ .../ceilsd/benchmark/c/native/benchmark.c | 136 ++++++++++++++ .../math/base/special/ceilsd/binding.gyp | 170 +++++++++++++++++ .../math/base/special/ceilsd/docs/repl.txt | 10 +- .../base/special/ceilsd/docs/types/index.d.ts | 10 +- .../base/special/ceilsd/docs/types/test.ts | 1 - .../base/special/ceilsd/examples/c/Makefile | 146 +++++++++++++++ .../base/special/ceilsd/examples/c/example.c | 34 ++++ .../base/special/ceilsd/examples/index.js | 2 +- .../math/base/special/ceilsd/include.gypi | 53 ++++++ .../include/stdlib/math/base/special/ceilsd.h | 40 ++++ .../math/base/special/ceilsd/lib/index.js | 6 +- .../math/base/special/ceilsd/lib/main.js | 34 ++-- .../math/base/special/ceilsd/lib/native.js | 60 ++++++ .../math/base/special/ceilsd/manifest.json | 96 ++++++++++ .../math/base/special/ceilsd/src/Makefile | 70 +++++++ .../math/base/special/ceilsd/src/addon.c | 23 +++ .../math/base/special/ceilsd/src/main.c | 81 +++++++++ .../math/base/special/ceilsd/test/test.js | 43 ++--- .../base/special/ceilsd/test/test.native.js | 171 ++++++++++++++++++ 22 files changed, 1421 insertions(+), 77 deletions(-) create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/benchmark/benchmark.native.js create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/benchmark/c/native/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/benchmark/c/native/benchmark.c create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/binding.gyp create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/examples/c/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/examples/c/example.c create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/include.gypi create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/include/stdlib/math/base/special/ceilsd.h create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/lib/native.js create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/manifest.json create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/src/Makefile create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/src/addon.c create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/src/main.c create mode 100644 lib/node_modules/@stdlib/math/base/special/ceilsd/test/test.native.js diff --git a/lib/node_modules/@stdlib/math/base/special/ceilsd/README.md b/lib/node_modules/@stdlib/math/base/special/ceilsd/README.md index 853afbdf0404..be8888692368 100644 --- a/lib/node_modules/@stdlib/math/base/special/ceilsd/README.md +++ b/lib/node_modules/@stdlib/math/base/special/ceilsd/README.md @@ -30,25 +30,21 @@ limitations under the License. var ceilsd = require( '@stdlib/math/base/special/ceilsd' ); ``` -#### ceilsd( x, n\[, b] ) +#### ceilsd( x, n, b ) Rounds a `numeric` value to the nearest `number` toward positive infinity with `n` significant figures. ```javascript -var v = ceilsd( 3.141592653589793, 5 ); +var v = ceilsd( 3.141592653589793, 5, 10 ); // returns 3.1416 -v = ceilsd( 3.141592653589793, 1 ); +v = ceilsd( 3.141592653589793, 1, 10 ); // returns 4.0 -v = ceilsd( 12368.0, 2 ); +v = ceilsd( 12368.0, 2, 10 ); // returns 13000.0 -``` - -The default base is `10` (decimal). To round using a different base, provide a third argument. -```javascript -var v = ceilsd( 0.0313, 2, 2 ); +v = ceilsd( 0.0313, 2, 2 ); // returns 0.046875 ``` @@ -78,7 +74,7 @@ var i; for ( i = 0; i < 100; i++ ) { x = (randu()*10000.0) - 5000.0; - y = ceilsd( x, 5 ); + y = ceilsd( x, 5, 10 ); console.log( 'x: %d. Rounded: %d.', x, y ); } ``` @@ -87,6 +83,96 @@ for ( i = 0; i < 100; i++ ) { + + +* * * + +
+ +## C APIs + + + +
+ +
+ + + + + +
+ +### Usage + +```c +#include "stdlib/math/base/special/ceilsd.h" +``` + +#### stdlib_base_ceilsd( x, n, b ) + +Rounds a `numeric` value to the nearest `number` toward negative infinity with `n` significant figures. + +```c +double out = stdlib_base_ceilsd( 0.0313, 2, 2 ); +// returns 0.03125 +``` + +The function accepts the following arguments: + +- **x**: `[in] double` input value. +- **n**: `[in] int32_t` number of significant figures. +- **b**: `[in] int32_t` base. + +```c +double stdlib_base_ceilsd( const double x, const int32_t n, const int32_t b ); +``` + +
+ + + + + +
+ +
+ + + + + +
+ +### Examples + +```c +#include "stdlib/math/base/special/ceilsd.h" +#include +#include + +int main( void ) { + const double x[] = { -5.0, -3.89, -2.78, -1.67, -0.56, 0.56, 1.67, 2.78, 3.89, 5.0 }; + const int32_t n[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; + const int32_t b[] = { 20, 19, 18, 17, 16, 15, 14, 13, 12, 11 }; + + double v; + int i; + for ( i = 0; i < 10; i++ ) { + v = stdlib_base_ceilsd( x[ i ], n[ i ], b[ i ] ); + printf( "ceilsd(%lf, %d, %d) = %lf\n", x[ i ], n[ i ], b[ i ], v ); + } +} +``` + +
+ + + +
+ + +