double cbrt(x) double x;
{ int e, rem, sign; double z;
#ifdef NANS if (isnan(x)) return x; #endif #ifdef INFINITIES if (!isfinite(x)) return x; #endif if (x == 0) return (x); if (x > 0)
sign = 1; else {
sign = -1;
x = -x;
}
z = x; /* extract power of 2, leaving *mantissabetween0.5and1
*/
x = frexp(x, &e);
/* Approximate cube root of number between .5 and 1, *peakrelativeerror=9.2e-6
*/
x = (((-1.3466110473359520655053e-1 * x + 5.4664601366395524503440e-1) * x - 9.5438224771509446525043e-1) *
x + 1.1399983354717293273738e0) *
x + 4.0238979564544752126924e-1;
/* exponent divided by 3 */ if (e >= 0) {
rem = e;
e /= 3;
rem -= 3 * e; if (rem == 1)
x *= CBRT2; elseif (rem == 2)
x *= CBRT4;
}
/* argument less than 1 */
else {
e = -e;
rem = e;
e /= 3;
rem -= 3 * e; if (rem == 1)
x *= CBRT2I; elseif (rem == 2)
x *= CBRT4I;
e = -e;
}
/* multiply by power of 2 */
x = ldexp(x, e);
/* Newton iteration */
x -= (x - (z / (x * x))) * 0.33333333333333333333; #ifdef DEC
x -= (x - (z / (x * x))) / 3.0; #else
x -= (x - (z / (x * x))) * 0.33333333333333333333; #endif
if (sign < 0)
x = -x; return (x);
}
Messung V0.5 in Prozent
¤ Dauer der Verarbeitung: 0.0 Sekunden
(vorverarbeitet am 2026-06-10)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.