std::nextafter, std::nexttoward
From cppreference.com
| Defined in header
<cmath>
|
||
| float nextafter( float from, float to );
|
(1) | (since C++11) |
| double nextafter( double from, double to );
|
(2) | (since C++11) |
| long double nextafter( long double from, long double to );
|
(3) | (since C++11) |
| Promoted nextafter( Arithmetic from, Arithmetic to );
|
(4) | (since C++11) |
| float nexttoward( float from, long double to );
|
(5) | (since C++11) |
| double nexttoward( double from, long double to );
|
(6) | (since C++11) |
| long double nexttoward( long double from, long double to );
|
(7) | (since C++11) |
| double nexttoward( Integral from, long double to );
|
(8) | (since C++11) |
Returns the next representable value of from in the direction of to. If from equals to to, to is returned.
4) If any argument has integral type, it is cast to double. If any other argument is long double, then the return type is long double, otherwise it is double
[edit] Parameters
| from, to | - | floating point values |
[edit] Return value
the next representable value of from in the direction of to.
[edit] Example
Run this code
#include <cmath> #include <iostream> #include <iomanip> int main() { std::cout << "0.1 lies between the doubles " << std::setprecision(100) << '\n' << 0.1 << '\n' << " and\n" << std::nextafter(0.1, 0) << '\n'; }
Output:
0.1 lies between the doubles 0.1000000000000000055511151231257827021181583404541015625 and 0.09999999999999999167332731531132594682276248931884765625