Skip to content

Commit

Permalink
Auto-generated commit
Browse files Browse the repository at this point in the history
  • Loading branch information
stdlib-bot committed Jul 27, 2024
1 parent e4445c8 commit 21c848b
Show file tree
Hide file tree
Showing 23 changed files with 1,467 additions and 92 deletions.
36 changes: 36 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5161,6 +5161,39 @@ A total of 2 issues were closed in this release:

<!-- /.package -->

<section class="package" id="math-base-special-truncsd-unreleased">

#### [@stdlib/math/base/special/truncsd](https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/math/base/special/truncsd)

<details>

<section class="features">

##### 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)

</section>

<!-- /.features -->

<section class="breaking-changes">

##### 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.

</section>

<!-- /.breaking-changes -->

</details>

</section>

<!-- /.package -->

<section class="package" id="math-base-special-vercos-unreleased">

#### [@stdlib/math/base/special/vercos](https://github.com/stdlib-js/stdlib/tree/develop/lib/node_modules/%40stdlib/math/base/special/vercos)
Expand Down Expand Up @@ -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

Expand Down Expand Up @@ -5626,6 +5661,7 @@ A total of 29 people contributed to this release. Thank you to the following con

<details>

- [`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)_
Expand Down
106 changes: 96 additions & 10 deletions base/special/truncsd/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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
```

Expand Down Expand Up @@ -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 );
}
```
Expand All @@ -87,6 +83,96 @@ for ( i = 0; i < 100; i++ ) {

<!-- /.examples -->

<!-- C interface documentation. -->

* * *

<section class="c">

## C APIs

<!-- Section to include introductory text. Make sure to keep an empty line after the intro `section` element and another before the `/section` close. -->

<section class="intro">

</section>

<!-- /.intro -->

<!-- C usage documentation. -->

<section class="usage">

### 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 );
```
</section>
<!-- /.usage -->
<!-- C API usage notes. Make sure to keep an empty line after the `section` element and another before the `/section` close. -->
<section class="notes">
</section>
<!-- /.notes -->
<!-- C API usage examples. -->
<section class="examples">
### Examples
```c
#include "stdlib/math/base/special/truncsd.h"
#include <stdio.h>
#include <stdint.h>
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 );
}
}
```

</section>

<!-- /.examples -->

</section>

<!-- /.c -->

<!-- Section for related `stdlib` packages. Do not manually edit this section, as it is automatically populated. -->

<section class="related">
Expand Down
60 changes: 60 additions & 0 deletions base/special/truncsd/benchmark/benchmark.native.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
/**
* @license Apache-2.0
*
* Copyright (c) 2024 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

'use strict';

// MODULES //

var resolve = require( 'path' ).resolve;
var bench = require( '@stdlib/bench' );
var randu = require( '@stdlib/random/base/randu' );
var isnan = require( './../../../../base/assert/is-nan' );
var tryRequire = require( '@stdlib/utils/try-require' );
var pkg = require( './../package.json' ).name;


// VARIABLES //

var truncsd = tryRequire( resolve( __dirname, './../lib/native.js' ) );
var opts = {
'skip': ( truncsd instanceof Error )
};


// MAIN //

bench( pkg+'::native', opts, function benchmark( b ) {
var x;
var y;
var i;

b.tic();
for ( i = 0; i < b.iterations; i++ ) {
x = ( randu() * 1.0e7 ) - 5.0e6;
y = truncsd( x, 2, 2 );
if ( isnan( y ) ) {
b.fail( 'should not return NaN' );
}
}
b.toc();
if ( isnan( y ) ) {
b.fail( 'should not return NaN' );
}
b.pass( 'benchmark finished' );
b.end();
});
Loading

0 comments on commit 21c848b

Please sign in to comment.