diff options
| author | Craig Jennings <c@cjennings.net> | 2024-04-07 13:41:34 -0500 |
|---|---|---|
| committer | Craig Jennings <c@cjennings.net> | 2024-04-07 13:41:34 -0500 |
| commit | 754bbf7a25a8dda49b5d08ef0d0443bbf5af0e36 (patch) | |
| tree | f1190704f78f04a2b0b4c977d20fe96a828377f1 /devdocs/c/numeric%2Fmath%2Fround.html | |
new repository
Diffstat (limited to 'devdocs/c/numeric%2Fmath%2Fround.html')
| -rw-r--r-- | devdocs/c/numeric%2Fmath%2Fround.html | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/devdocs/c/numeric%2Fmath%2Fround.html b/devdocs/c/numeric%2Fmath%2Fround.html new file mode 100644 index 00000000..119c6750 --- /dev/null +++ b/devdocs/c/numeric%2Fmath%2Fround.html @@ -0,0 +1,124 @@ + <h1 id="firstHeading" class="firstHeading">round, roundf, roundl, lround, lroundf, lroundl, llround, llroundf, llroundl</h1> <table class="t-dcl-begin"> <tr class="t-dsc-header"> <th> Defined in header <code><math.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">float roundf( float arg );</pre> +</td> <td> (1) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">double round( double arg );</pre> +</td> <td> (2) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long double roundl( long double arg );</pre> +</td> <td> (3) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dsc-header"> <th> Defined in header <code><tgmath.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">#define round( arg )</pre> +</td> <td> (4) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dsc-header"> <th> Defined in header <code><math.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long lroundf( float arg );</pre> +</td> <td> (5) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long lround( double arg );</pre> +</td> <td> (6) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long lroundl( long double arg );</pre> +</td> <td> (7) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dsc-header"> <th> Defined in header <code><tgmath.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">#define lround( arg )</pre> +</td> <td> (8) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dsc-header"> <th> Defined in header <code><math.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long long llroundf( float arg );</pre> +</td> <td> (9) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long long llround( double arg );</pre> +</td> <td> (10) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">long long llroundl( long double arg );</pre> +</td> <td> (11) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> <tr class="t-dsc-header"> <th> Defined in header <code><tgmath.h></code> </th> <th> </th> <th> </th> </tr> <tr class="t-dcl t-since-c99"> <td> <pre data-language="c">#define llround( arg )</pre> +</td> <td> (12) </td> <td> <span class="t-mark-rev t-since-c99">(since C99)</span> </td> </tr> </table> <div class="t-li1"> +<span class="t-li">1-3)</span> Computes the nearest integer value to <code>arg</code> (in floating-point format), rounding halfway cases away from zero, regardless of the current rounding mode.</div> <div class="t-li1"> +<span class="t-li">5-7, 9-11)</span> Computes the nearest integer value to <code>arg</code> (in integer format), rounding halfway cases away from zero, regardless of the current rounding mode.</div> <div class="t-li1"> +<span class="t-li">4,8,12)</span> Type-generic macros: If <code>arg</code> has type <code>long double</code>, <code>roundl</code>, <code>lroundl</code>, <code>llroundl</code> is called. Otherwise, if <code>arg</code> has integer type or the type <code>double</code>, <code>round</code>, <code>lround</code>, <code>llround</code> is called. Otherwise, <code>roundf</code>, <code>lroundf</code>, <code>llroundf</code> is called, respectively.</div> <h3 id="Parameters"> Parameters</h3> <table class="t-par-begin"> <tr class="t-par"> <td> arg </td> <td> - </td> <td> floating point value </td> +</tr> +</table> <h3 id="Return_value"> Return value</h3> <p>If no errors occur, the nearest integer value to <code>arg</code>, rounding halfway cases away from zero, is returned.</p> +<div class="t-plot"> <div class="t-plot-left">Return value</div> <div class="t-plot-image-left"><img alt="math-round away zero.svg" src="" width="200" height="200"></div> <div class="t-plot-bottom">Argument</div> </div> <p>If a domain error occurs, an implementation-defined value is returned.</p> +<h3 id="Error_handling"> Error handling</h3> <p>Errors are reported as specified in <a href="math_errhandling" title="c/numeric/math/math errhandling">math_errhandling</a>.</p> +<p>If the result of <code>lround</code> or <code>llround</code> is outside the range representable by the return type, a domain error or a range error may occur.</p> +<p>If the implementation supports IEEE floating-point arithmetic (IEC 60559), For the <code>round</code>, <code>roundf</code>, and <code>roundl</code> function:</p> +<ul> +<li> The current <a href="../fenv/fe_round" title="c/numeric/fenv/FE round">rounding mode</a> has no effect. </li> +<li> If <code>arg</code> is ±∞, it is returned, unmodified </li> +<li> If <code>arg</code> is ±0, it is returned, unmodified </li> +<li> If <code>arg</code> is NaN, NaN is returned </li> +</ul> For <code>lround</code> and <code>llround</code> families of functions: <ul> +<li> <code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INEXACT</a></code> is never raised </li> +<li> The current <a href="../fenv/fe_round" title="c/numeric/fenv/FE round">rounding mode</a> has no effect. </li> +<li> If <code>arg</code> is ±∞, <code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INVALID</a></code> is raised and an implementation-defined value is returned </li> +<li> If the result of the rounding is outside the range of the return type, <code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INVALID</a></code> is raised and an implementation-defined value is returned </li> +<li> If <code>arg</code> is NaN, <code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INVALID</a></code> is raised and an implementation-defined value is returned </li> +</ul> <h3 id="Notes"> Notes</h3> <p><code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INEXACT</a></code> may be (but isn't required to be) raised by <code>round</code> when rounding a non-integer finite value.</p> +<p>The largest representable floating-point values are exact integers in all standard floating-point formats, so <code>round</code> never overflows on its own; however the result may overflow any integer type (including <code><a href="../../types/integer" title="c/types/integer">intmax_t</a></code>), when stored in an integer variable.</p> +<p><a rel="nofollow" class="external text" href="http://pubs.opengroup.org/onlinepubs/9699919799/functions/lround.html">POSIX specifies</a> that all cases where <code>lround</code> or <code>llround</code> raise <code><a href="../fenv/fe_exceptions" title="c/numeric/fenv/FE exceptions">FE_INVALID</a></code> are domain errors.</p> +<p>The <code>double</code> version of <code>round</code> behaves as if implemented as follows:</p> +<div class="c source-c"><pre data-language="c">#include <math.h> +double round(double x) +{ + return signbit(x) ? ceil(x - 0.5) : floor(x + 0.5); +}</pre></div> <h3 id="Example"> Example</h3> <div class="t-example"> <div class="c source-c"><pre data-language="c">#include <stdio.h> +#include <math.h> +#include <fenv.h> +#include <limits.h> + +// #pragma STDC FENV_ACCESS ON + +int main(void) +{ + // round + printf("round(+2.3) = %+.1f ", round(2.3)); + printf("round(+2.5) = %+.1f ", round(2.5)); + printf("round(+2.7) = %+.1f\n", round(2.7)); + printf("round(-2.3) = %+.1f ", round(-2.3)); + printf("round(-2.5) = %+.1f ", round(-2.5)); + printf("round(-2.7) = %+.1f\n", round(-2.7)); + + printf("round(-0.0) = %+.1f\n", round(-0.0)); + printf("round(-Inf) = %+f\n", round(-INFINITY)); + + // lround + printf("lround(+2.3) = %ld ", lround(2.3)); + printf("lround(+2.5) = %ld ", lround(2.5)); + printf("lround(+2.7) = %ld\n", lround(2.7)); + printf("lround(-2.3) = %ld ", lround(-2.3)); + printf("lround(-2.5) = %ld ", lround(-2.5)); + printf("lround(-2.7) = %ld\n", lround(-2.7)); + + printf("lround(-0.0) = %ld\n", lround(-0.0)); + printf("lround(-Inf) = %ld\n", lround(-INFINITY)); // FE_INVALID raised + + // error handling + feclearexcept(FE_ALL_EXCEPT); + printf("lround(LONG_MAX+1.5) = %ld\n", lround(LONG_MAX+1.5)); + if(fetestexcept(FE_INVALID)) puts(" FE_INVALID was raised"); +}</pre></div> <p>Possible output:</p> +<div class="text source-text"><pre data-language="c">round(+2.3) = +2.0 round(+2.5) = +3.0 round(+2.7) = +3.0 +round(-2.3) = -2.0 round(-2.5) = -3.0 round(-2.7) = -3.0 +round(-0.0) = -0.0 +round(-Inf) = -inf +lround(+2.3) = 2 lround(+2.5) = 3 lround(+2.7) = 3 +lround(-2.3) = -2 lround(-2.5) = -3 lround(-2.7) = -3 +lround(-0.0) = 0 +lround(-Inf) = -9223372036854775808 +lround(LONG_MAX+1.5) = -9223372036854775808 + FE_INVALID was raised</pre></div> </div> <h3 id="References"> References</h3> <ul> +<li> C17 standard (ISO/IEC 9899:2018): </li> +<ul> +<li> 7.12.9.6 The round functions (p: 184) </li> +<li> 7.12.9.7 The lround and llround functions (p: 184-185) </li> +<li> 7.25 Type-generic math <tgmath.h> (p: 272-273) </li> +<li> F.10.6.6 The round functions (p: 384) </li> +<li> F.10.6.7 The lround and llround functions (p: 385) </li> +</ul> +<li> C11 standard (ISO/IEC 9899:2011): </li> +<ul> +<li> 7.12.9.6 The round functions (p: 253) </li> +<li> 7.12.9.7 The lround and llround functions (p: 253) </li> +<li> 7.25 Type-generic math <tgmath.h> (p: 373-375) </li> +<li> F.10.6.6 The round functions (p: 527) </li> +<li> F.10.6.7 The lround and llround functions (p: 528) </li> +</ul> +<li> C99 standard (ISO/IEC 9899:1999): </li> +<ul> +<li> 7.12.9.6 The round functions (p: 233) </li> +<li> 7.12.9.7 The lround and llround functions (p: 234) </li> +<li> 7.22 Type-generic math <tgmath.h> (p: 335-337) </li> +<li> F.9.6.6 The round functions (p: 464) </li> +<li> F.9.6.7 The lround and llround functions (p: 464) </li> +</ul> +</ul> <h3 id="See_also"> See also</h3> <table class="t-dsc-begin"> <tr class="t-dsc"> <td> <div><a href="floor" title="c/numeric/math/floor"> <span class="t-lines"><span>floor</span><span>floorf</span><span>floorl</span></span></a></div> +<div><span class="t-lines"><span><span class="t-mark-rev t-since-c99">(C99)</span></span><span><span class="t-mark-rev t-since-c99">(C99)</span></span></span></div> </td> <td> computes largest integer not greater than the given value <br> <span class="t-mark">(function)</span> </td> +</tr> <tr class="t-dsc"> <td> <div><a href="ceil" title="c/numeric/math/ceil"> <span class="t-lines"><span>ceil</span><span>ceilf</span><span>ceill</span></span></a></div> +<div><span class="t-lines"><span><span class="t-mark-rev t-since-c99">(C99)</span></span><span><span class="t-mark-rev t-since-c99">(C99)</span></span></span></div> </td> <td> computes smallest integer not less than the given value <br> <span class="t-mark">(function)</span> </td> +</tr> <tr class="t-dsc"> <td> <div><a href="trunc" title="c/numeric/math/trunc"> <span class="t-lines"><span>trunc</span><span>truncf</span><span>truncl</span></span></a></div> +<div><span class="t-lines"><span><span class="t-mark-rev t-since-c99">(C99)</span></span><span><span class="t-mark-rev t-since-c99">(C99)</span></span><span><span class="t-mark-rev t-since-c99">(C99)</span></span></span></div> </td> <td> rounds to nearest integer not greater in magnitude than the given value <br> <span class="t-mark">(function)</span> </td> +</tr> <tr class="t-dsc"> <td colspan="2"> <span><a href="https://en.cppreference.com/w/cpp/numeric/math/round" title="cpp/numeric/math/round">C++ documentation</a></span> for <code>round</code> </td> +</tr> </table> <div class="_attribution"> + <p class="_attribution-p"> + © cppreference.com<br>Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.<br> + <a href="https://en.cppreference.com/w/c/numeric/math/round" class="_attribution-link">https://en.cppreference.com/w/c/numeric/math/round</a> + </p> +</div> |
