# nextafter, nextafterf, nextafterl, nexttoward, nexttowardf, nexttowardl

< c‎ | numeric‎ | math

Common mathematical functions
Functions
Basic operations
 abslabsllabsimaxabs(C99)(C99) fabs divldivlldivimaxdiv(C99)(C99)
 fmod remainder(C99) remquo(C99) fma(C99) fdim(C99) nannanfnanlnandN(C99)(C99)(C99)(C23)
Maximum/minimum operations
 fmax(C99) fmaximum(C23) fmaximum_mag(C23) fmaximum_num(C23) fmaximum_mag_num(C23)
 fmin(C99) fminimum(C23) fminimum_mag(C23) fminimum_num(C23) fminimum_mag_num(C23)
Exponential functions
 exp exp10(C23) exp2(C99) expm1(C99) exp10m1(C23) exp2m1(C23)
 log log10 log2(C99) log1plogp1(C99)(C23) log10p1(C23) log2p1(C23)
Power functions
 sqrt cbrt(C99) rootn(C23) rsqrt(C23)
 hypot(C99) compound(C23) pow pown(C23) powr(C23)
Trigonometric and hyperbolic functions
 sin cos tan asin acos atan atan2 sinpi(C23) cospi(C23) tanpi(C23)
 asinpi(C23) acospi(C23) atanpi(C23) atan2pi(C23) sinh cosh tanh asinh(C99) acosh(C99) atanh(C99)
Error and gamma functions
 erf(C99) erfc(C99)
 lgamma(C99) tgamma(C99)
Nearest integer floating-point operations
 ceil floor roundlroundllround(C99)(C99)(C99) roundeven(C23) trunc(C99)
 nearbyint(C99) rintlrintllrint(C99)(C99)(C99) fromfpfromfpxufromfpufromfpx(C23)(C23)(C23)(C23)
Floating-point manipulation functions
 ldexp frexp scalbnscalbln(C99)(C99) ilogbllogb(C99)(C23) logb(C99)
 modf nextafternexttoward(C99)(C99) nextupnextdown(C23)(C23) copysign(C99) canonicalize(C23)
Narrowing operations
 fdiv(C23) ffma(C23) fsqrt(C23)
Quantum and quantum exponent functions
 quantizedN(C23) samequantumdN(C23)
 quantumdN(C23) llquantexpdN(C23)
Decimal re-encoding functions
 encodedecdN(C23) decodedecdN(C23)
 encodebindN(C23) decodebindN(C23)
Classification
 fpclassify(C99) iscanonical(C23) isfinite(C99) isinf(C99) isnan(C99) isnormal(C99) signbit(C99) issubnormal(C23) iszero(C23)
 isgreater(C99) isgreaterequal(C99) isless(C99) islessequal(C99) islessgreater(C99) isunordered(C99) issignaling(C23) iseqsig(C23)
Types
 div_tldiv_tlldiv_timaxdiv_t(C99)(C99)
 float_tdouble_t(C99)(C99) _Decimal32_t_Decimal64_t(C23)(C23)
Macro constants
Special floating-point values
 HUGE_VALFHUGE_VALHUGE_VALLHUGE_VALDN(C99)(C99)(C23)
 INFINITYDEC_INFINITY(C99)(C23) NANDEC_NAN(C99)(C23)
Arguments and return values
 FP_ILOGB0FP_ILOGBNAN(C99)(C99) FP_INT_UPWARDFP_INT_DOWNWARDFP_INT_TOWARDZEROFP_INT_TONEARESTFROMZEROFP_INT_TONEAREST(C23)(C23)(C23)(C23)(C23)
 FP_LLOGB0FP_LLOGBNAN(C23)(C23) FP_NORMALFP_SUBNORMALFP_ZEROFP_INFINITEFP_NAN(C99)(C99)(C99)(C99)(C99)
Error handling
Fast operation indicators

 Defined in header  float       nextafterf( float from, float to ); (1) (since C99) double      nextafter( double from, double to ); (2) (since C99) long double nextafterl( long double from, long double to ); (3) (since C99) float       nexttowardf( float from, long double to ); (4) (since C99) double      nexttoward( double from, long double to ); (5) (since C99) long double nexttowardl( long double from, long double to ); (6) (since C99) Defined in header  #define nextafter(from, to) (7) (since C99) #define nexttoward(from, to) (8) (since C99)
1-3) First, converts both arguments to the type of the function, then returns the next representable value of from in the direction of to. If from equals to to, to is returned.
4-6) First, converts the first argument to the type of the function, then returns the next representable value of from in the direction of to. If from equals to to, to is returned, converted from long double to the return type of the function without loss of range or precision.
7) Type-generic macro: If any argument has type long double, nextafterl is called. Otherwise, if any argument has integer type or has type double, nextafter is called. Otherwise, nextafterf is called.
8) Type-generic macro: If the argument from has type long double, nexttowardl is called. Otherwise, if from has integer type or the type double, nexttoward is called. Otherwise, nexttowardf is called.

## Contents

### Parameters

 from, to - floating point values

### Return value

If no errors occur, the next representable value of from in the direction of to. is returned. If from equals to, then to is returned, converted to the type of the function.

If a range error due to overflow occurs, ±HUGE_VAL, ±HUGE_VALF, or ±HUGE_VALL is returned (with the same sign as from).

If a range error occurs due to underflow, the correct result is returned.

### Error handling

Errors are reported as specified in math_errhandling.

If the implementation supports IEEE floating-point arithmetic (IEC 60559),

• if from is finite, but the expected result is an infinity, raises FE_INEXACT and FE_OVERFLOW
• if from does not equal to and the result is subnormal or zero, raises FE_INEXACT and FE_UNDERFLOW
• in any case, the returned value is independent of the current rounding mode
• if either from or to is NaN, NaN is returned