Given an arbitrary finite floating point number, is there a way to determine what the next representable floating point number? For example, given 1.0f, by definition the next largest representable number is 1.0f + std::numeric_limits<float>::epsilon(). Is there a way to synthesize an epsilon for any value – not just 1.0f – without resorting to bit twiddling and/or explicit knowledge of how the machine represents floating point values?
Given an arbitrary finite floating point number, is there a way to determine what
Share
In C++11, you use
std::nextafter(). Lacking that, on a C99 system, you usenextafterf,nextafter, ornextafterlfrom the C math library (for typesfloat,double, andlong double, respectively).