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 );
+ }
+}
+```
+
+
+
+
+
+
+
+
+