From 21c848b7209b8d4f3c9e245c36b290c5edd6a943 Mon Sep 17 00:00:00 2001 From: stdlib-bot Date: Sat, 27 Jul 2024 18:38:54 +0000 Subject: [PATCH] Auto-generated commit --- CHANGELOG.md | 36 ++++ base/special/truncsd/README.md | 106 ++++++++++- .../truncsd/benchmark/benchmark.native.js | 60 ++++++ .../truncsd/benchmark/c/native/Makefile | 146 ++++++++++++++ .../truncsd/benchmark/c/native/benchmark.c | 136 +++++++++++++ base/special/truncsd/binding.gyp | 170 +++++++++++++++++ base/special/truncsd/docs/repl.txt | 12 +- base/special/truncsd/docs/types/index.d.ts | 10 +- base/special/truncsd/docs/types/test.ts | 15 -- base/special/truncsd/examples/c/Makefile | 146 ++++++++++++++ base/special/truncsd/examples/c/example.c | 34 ++++ base/special/truncsd/examples/index.js | 2 +- base/special/truncsd/include.gypi | 53 ++++++ .../stdlib/math/base/special/truncsd.h | 40 ++++ base/special/truncsd/lib/index.js | 6 +- base/special/truncsd/lib/main.js | 34 ++-- base/special/truncsd/lib/native.js | 60 ++++++ base/special/truncsd/manifest.json | 96 ++++++++++ base/special/truncsd/src/Makefile | 70 +++++++ base/special/truncsd/src/addon.c | 23 +++ base/special/truncsd/src/main.c | 81 ++++++++ base/special/truncsd/test/test.js | 43 ++--- base/special/truncsd/test/test.native.js | 180 ++++++++++++++++++ 23 files changed, 1467 insertions(+), 92 deletions(-) create mode 100644 base/special/truncsd/benchmark/benchmark.native.js create mode 100644 base/special/truncsd/benchmark/c/native/Makefile create mode 100644 base/special/truncsd/benchmark/c/native/benchmark.c create mode 100644 base/special/truncsd/binding.gyp create mode 100644 base/special/truncsd/examples/c/Makefile create mode 100644 base/special/truncsd/examples/c/example.c create mode 100644 base/special/truncsd/include.gypi create mode 100644 base/special/truncsd/include/stdlib/math/base/special/truncsd.h create mode 100644 base/special/truncsd/lib/native.js create mode 100644 base/special/truncsd/manifest.json create mode 100644 base/special/truncsd/src/Makefile create mode 100644 base/special/truncsd/src/addon.c create mode 100644 base/special/truncsd/src/main.c create mode 100644 base/special/truncsd/test/test.native.js diff --git a/CHANGELOG.md b/CHANGELOG.md index a5809c4d4..6358bfa74 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5161,6 +5161,39 @@ A total of 2 issues were closed in this release: +
+ +#### [@stdlib/math/base/special/truncsd](https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/math/base/special/truncsd) + +
+ +
+ +##### Features + +- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3) - add C implementation for `math/base/special/truncsd` [(#2666)](https://github.com/stdlib-js/stdlib/pull/2666) + +
+ + + +
+ +##### BREAKING CHANGES + +- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3): add C implementation for `math/base/special/truncsd` +- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3): The third argument 'b' in the JavaScript implementation of `truncsd` is now mandatory. To migrate, explicitly supply the old default value of `10` as the third argument. + +
+ + + +
+ +
+ + +
#### [@stdlib/math/base/special/vercos](https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/math/base/special/vercos) @@ -5514,6 +5547,8 @@ This release closes the following issue: ### BREAKING CHANGES +- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3): add C implementation for `math/base/special/truncsd` +- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3): The third argument 'b' in the JavaScript implementation of `truncsd` is now mandatory. To migrate, explicitly supply the old default value of `10` as the third argument. - [`5df976a`](https://github.com/stdlib-js/stdlib/commit/5df976abacaaf3082890fa852e40edfdf1b79f4b): update namespace TypeScript declarations - [`5df976a`](https://github.com/stdlib-js/stdlib/commit/5df976abacaaf3082890fa852e40edfdf1b79f4b): base parameter is no longer optional @@ -5626,6 +5661,7 @@ A total of 29 people contributed to this release. Thank you to the following con
+- [`fce4265`](https://github.com/stdlib-js/stdlib/commit/fce42651903b96cc6a0f26e84afc812fa4ea94b3) - **feat:** add C implementation for `math/base/special/truncsd` [(#2666)](https://github.com/stdlib-js/stdlib/pull/2666) _(by Gunj Joshi)_ - [`4a2534a`](https://github.com/stdlib-js/stdlib/commit/4a2534a22c2ead42a6318bed2fce221286f9f7a8) - **feat:** add C implementation for `math/base/special/fresnelc` [(#2680)](https://github.com/stdlib-js/stdlib/pull/2680) _(by Gunj Joshi)_ - [`c476e32`](https://github.com/stdlib-js/stdlib/commit/c476e32e617de04644d9fbf399a34f80661778ea) - **feat:** add C implementation for `math/base/special/fresnels` [(#2675)](https://github.com/stdlib-js/stdlib/pull/2675) _(by Gunj Joshi)_ - [`7e04d9e`](https://github.com/stdlib-js/stdlib/commit/7e04d9e27fb5008c1cbc6e45e08ea6ad4b8993d2) - **refactor:** use max-safe-nth-factorial package [(#2676)](https://github.com/stdlib-js/stdlib/pull/2676 ) _(by Gunj Joshi)_ diff --git a/base/special/truncsd/README.md b/base/special/truncsd/README.md index ea89af61a..c75dc566c 100644 --- a/base/special/truncsd/README.md +++ b/base/special/truncsd/README.md @@ -30,25 +30,21 @@ limitations under the License. var truncsd = require( '@stdlib/math/base/special/truncsd' ); ``` -#### truncsd( x, n\[, b] ) +#### truncsd( x, n, b ) Rounds a `numeric` value to the nearest `number` toward zero with `n` significant figures. ```javascript -var v = truncsd( 3.141592653589793, 5 ); +var v = truncsd( 3.141592653589793, 5, 10 ); // returns 3.1415 -v = truncsd( 3.141592653589793, 1 ); +v = truncsd( 3.141592653589793, 1, 10 ); // returns 3.0 -v = truncsd( 12368.0, 2 ); +v = truncsd( 12368.0, 2, 10 ); // returns 12000.0 -``` - -The default base is `10` (decimal). To round using a different base, provide a third argument. -```javascript -var v = truncsd( 0.0313, 2, 2 ); +v = truncsd( 0.0313, 2, 2 ); // returns 0.03125 ``` @@ -78,7 +74,7 @@ var i; for ( i = 0; i < 100; i++ ) { x = (randu()*10000.0) - 5000.0; - y = truncsd( x, 5 ); + y = truncsd( 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/truncsd.h" +``` + +#### stdlib_base_truncsd( x, n, b ) + +Rounds a `numeric` value to the nearest `number` toward negative infinity with `n` significant figures. + +```c +double out = stdlib_base_truncsd( 3.141592653589793, 5, 10 ); +// returns 3.1415 +``` + +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_truncsd( const double x, const int32_t n, const int32_t b ); +``` + +
+ + + + + +
+ +
+ + + + + +
+ +### Examples + +```c +#include "stdlib/math/base/special/truncsd.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_truncsd( x[ i ], n[ i ], b[ i ] ); + printf( "truncsd(%lf, %d, %d) = %lf\n", x[ i ], n[ i ], b[ i ], v ); + } +} +``` + +
+ + + +
+ + +