1 # SOME DESCRIPTIVE TITLE
2 # Copyright (C) YEAR Free Software Foundation, Inc.
3 # This file is distributed under the same license as the PACKAGE package.
4 # FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
9 "Project-Id-Version: PACKAGE VERSION\n"
10 "POT-Creation-Date: 2012-05-01 04:38+0900\n"
11 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
12 "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
13 "Language-Team: LANGUAGE <LL@li.org>\n"
16 "Content-Type: text/plain; charset=CHARSET\n"
17 "Content-Transfer-Encoding: 8bit\n"
20 #: build/C/man3/INFINITY.3:23
26 #: build/C/man3/INFINITY.3:23
32 #: build/C/man3/INFINITY.3:23 build/C/man3/abs.3:32 build/C/man3/acos.3:33 build/C/man3/acosh.3:33 build/C/man3/asin.3:33 build/C/man3/asinh.3:33 build/C/man3/atan.3:33 build/C/man3/atan2.3:33 build/C/man3/atanh.3:33 build/C/man3/cbrt.3:28 build/C/man3/ceil.3:25 build/C/man3/copysign.3:29 build/C/man3/cos.3:32 build/C/man3/cosh.3:34 build/C/man3/div.3:32 build/C/man3/erf.3:33 build/C/man3/erfc.3:24 build/C/man3/exp.3:34 build/C/man3/exp10.3:33 build/C/man3/exp2.3:34 build/C/man3/expm1.3:28 build/C/man3/fabs.3:30 build/C/man3/fdim.3:6 build/C/man3/fenv.3:26 build/C/man3/finite.3:23 build/C/man3/floor.3:25 build/C/man3/fma.3:8 build/C/man3/fmax.3:6 build/C/man3/fmin.3:6 build/C/man3/fmod.3:33 build/C/man3/fpclassify.3:6 build/C/man3/frexp.3:31 build/C/man3/gamma.3:6 build/C/man3/hypot.3:31 build/C/man3/ilogb.3:27 build/C/man3/infnan.3:31 build/C/man3/isgreater.3:6 build/C/man3/j0.3:34 build/C/man3/ldexp.3:32 build/C/man3/lgamma.3:7 build/C/man3/log.3:34 build/C/man3/log10.3:34 build/C/man3/log1p.3:27 build/C/man3/log2.3:34 build/C/man3/logb.3:27 build/C/man3/lrint.3:25 build/C/man3/lround.3:25 build/C/man7/math_error.7:24 build/C/man3/matherr.3:25 build/C/man3/modf.3:31 build/C/man3/nan.3:6 build/C/man3/nextafter.3:6 build/C/man3/pow.3:33 build/C/man3/pow10.3:23 build/C/man3/remainder.3:35 build/C/man3/remquo.3:7 build/C/man3/rint.3:25 build/C/man3/round.3:25 build/C/man3/scalb.3:25 build/C/man3/scalbln.3:25 build/C/man3/signbit.3:6 build/C/man3/significand.3:4 build/C/man3/sin.3:33 build/C/man3/sincos.3:6 build/C/man3/sinh.3:34 build/C/man3/sqrt.3:32 build/C/man3/tan.3:33 build/C/man3/tanh.3:33 build/C/man3/tgamma.3:8 build/C/man3/trunc.3:23 build/C/man3/y0.3:34
34 msgid "Linux Programmer's Manual"
38 #: build/C/man3/INFINITY.3:24 build/C/man3/abs.3:33 build/C/man3/acos.3:34 build/C/man3/acosh.3:34 build/C/man3/asin.3:34 build/C/man3/asinh.3:34 build/C/man3/atan.3:34 build/C/man3/atan2.3:34 build/C/man3/atanh.3:34 build/C/man3/cbrt.3:29 build/C/man3/ceil.3:26 build/C/man3/copysign.3:30 build/C/man3/cos.3:33 build/C/man3/cosh.3:35 build/C/man3/div.3:33 build/C/man3/erf.3:34 build/C/man3/erfc.3:25 build/C/man3/exp.3:35 build/C/man3/exp10.3:34 build/C/man3/exp2.3:35 build/C/man3/expm1.3:29 build/C/man3/fabs.3:31 build/C/man3/fdim.3:7 build/C/man3/fenv.3:27 build/C/man3/finite.3:24 build/C/man3/floor.3:26 build/C/man3/fma.3:9 build/C/man3/fmax.3:7 build/C/man3/fmin.3:7 build/C/man3/fmod.3:34 build/C/man3/fpclassify.3:7 build/C/man3/frexp.3:32 build/C/man3/gamma.3:7 build/C/man3/hypot.3:32 build/C/man3/ilogb.3:28 build/C/man3/infnan.3:32 build/C/man3/isgreater.3:7 build/C/man3/j0.3:35 build/C/man3/ldexp.3:33 build/C/man3/lgamma.3:8 build/C/man3/log.3:35 build/C/man3/log10.3:35 build/C/man3/log1p.3:28 build/C/man3/log2.3:35 build/C/man3/logb.3:28 build/C/man3/lrint.3:26 build/C/man3/lround.3:26 build/C/man7/math_error.7:25 build/C/man3/matherr.3:26 build/C/man3/modf.3:32 build/C/man3/nan.3:7 build/C/man3/nextafter.3:7 build/C/man3/pow.3:34 build/C/man3/pow10.3:24 build/C/man3/remainder.3:36 build/C/man3/remquo.3:8 build/C/man3/rint.3:26 build/C/man3/round.3:26 build/C/man3/scalb.3:26 build/C/man3/scalbln.3:26 build/C/man3/signbit.3:7 build/C/man3/significand.3:5 build/C/man3/sin.3:34 build/C/man3/sincos.3:7 build/C/man3/sinh.3:35 build/C/man3/sqrt.3:33 build/C/man3/tan.3:34 build/C/man3/tanh.3:34 build/C/man3/tgamma.3:9 build/C/man3/trunc.3:24 build/C/man3/y0.3:35
44 #: build/C/man3/INFINITY.3:26
45 msgid "INFINITY, NAN, HUGE_VAL, HUGE_VALF, HUGE_VALL - floating-point constants"
49 #: build/C/man3/INFINITY.3:26 build/C/man3/abs.3:35 build/C/man3/acos.3:36 build/C/man3/acosh.3:36 build/C/man3/asin.3:36 build/C/man3/asinh.3:36 build/C/man3/atan.3:36 build/C/man3/atan2.3:36 build/C/man3/atanh.3:36 build/C/man3/cbrt.3:31 build/C/man3/ceil.3:29 build/C/man3/copysign.3:32 build/C/man3/cos.3:35 build/C/man3/cosh.3:37 build/C/man3/div.3:36 build/C/man3/erf.3:36 build/C/man3/erfc.3:27 build/C/man3/exp.3:37 build/C/man3/exp10.3:36 build/C/man3/exp2.3:37 build/C/man3/expm1.3:31 build/C/man3/fabs.3:33 build/C/man3/fdim.3:9 build/C/man3/fenv.3:32 build/C/man3/finite.3:27 build/C/man3/floor.3:28 build/C/man3/fma.3:11 build/C/man3/fmax.3:9 build/C/man3/fmin.3:9 build/C/man3/fmod.3:36 build/C/man3/fpclassify.3:10 build/C/man3/frexp.3:35 build/C/man3/gamma.3:9 build/C/man3/hypot.3:34 build/C/man3/ilogb.3:30 build/C/man3/infnan.3:34 build/C/man3/isgreater.3:10 build/C/man3/j0.3:38 build/C/man3/ldexp.3:35 build/C/man3/lgamma.3:11 build/C/man3/log.3:37 build/C/man3/log10.3:37 build/C/man3/log1p.3:30 build/C/man3/log2.3:37 build/C/man3/logb.3:30 build/C/man3/lrint.3:28 build/C/man3/lround.3:29 build/C/man7/math_error.7:27 build/C/man3/matherr.3:28 build/C/man3/modf.3:35 build/C/man3/nan.3:9 build/C/man3/nextafter.3:10 build/C/man3/pow.3:36 build/C/man3/pow10.3:26 build/C/man3/remainder.3:39 build/C/man3/remquo.3:10 build/C/man3/rint.3:29 build/C/man3/round.3:28 build/C/man3/scalb.3:29 build/C/man3/scalbln.3:29 build/C/man3/signbit.3:9 build/C/man3/significand.3:8 build/C/man3/sin.3:36 build/C/man3/sincos.3:9 build/C/man3/sinh.3:37 build/C/man3/sqrt.3:35 build/C/man3/tan.3:36 build/C/man3/tanh.3:36 build/C/man3/tgamma.3:11 build/C/man3/trunc.3:26 build/C/man3/y0.3:38
55 #: build/C/man3/INFINITY.3:29
57 msgid "B<#define _ISOC99_SOURCE> /* See feature_test_macros(7) */\n"
61 #: build/C/man3/INFINITY.3:31 build/C/man3/acos.3:39 build/C/man3/acosh.3:39 build/C/man3/asin.3:39 build/C/man3/asinh.3:39 build/C/man3/atan.3:39 build/C/man3/atan2.3:39 build/C/man3/atanh.3:39 build/C/man3/cbrt.3:34 build/C/man3/ceil.3:32 build/C/man3/copysign.3:35 build/C/man3/cos.3:38 build/C/man3/cosh.3:40 build/C/man3/erf.3:39 build/C/man3/erfc.3:30 build/C/man3/exp.3:40 build/C/man3/exp10.3:41 build/C/man3/exp2.3:40 build/C/man3/expm1.3:34 build/C/man3/fabs.3:36 build/C/man3/finite.3:30 build/C/man3/floor.3:31 build/C/man3/fma.3:14 build/C/man3/fmod.3:39 build/C/man3/fpclassify.3:13 build/C/man3/frexp.3:38 build/C/man3/hypot.3:37 build/C/man3/infnan.3:37 build/C/man3/isgreater.3:13 build/C/man3/j0.3:41 build/C/man3/ldexp.3:38 build/C/man3/lgamma.3:14 build/C/man3/log.3:40 build/C/man3/log10.3:40 build/C/man3/log1p.3:33 build/C/man3/log2.3:40 build/C/man3/lrint.3:31 build/C/man3/lround.3:32 build/C/man3/modf.3:38 build/C/man3/pow.3:39 build/C/man3/remainder.3:42 build/C/man3/remquo.3:13 build/C/man3/rint.3:32 build/C/man3/round.3:31 build/C/man3/sin.3:39 build/C/man3/sinh.3:40 build/C/man3/sqrt.3:38 build/C/man3/tan.3:39 build/C/man3/tanh.3:39 build/C/man3/trunc.3:29 build/C/man3/y0.3:41
63 msgid "B<#include E<lt>math.hE<gt>>\n"
67 #: build/C/man3/INFINITY.3:33
73 #: build/C/man3/INFINITY.3:35
79 #: build/C/man3/INFINITY.3:37
85 #: build/C/man3/INFINITY.3:39
87 msgid "B<HUGE_VALF>\n"
91 #: build/C/man3/INFINITY.3:41
93 msgid "B<HUGE_VALL>\n"
97 #: build/C/man3/INFINITY.3:42 build/C/man3/abs.3:65 build/C/man3/acos.3:63 build/C/man3/acosh.3:75 build/C/man3/asin.3:65 build/C/man3/asinh.3:75 build/C/man3/atan.3:65 build/C/man3/atan2.3:63 build/C/man3/atanh.3:75 build/C/man3/cbrt.3:70 build/C/man3/ceil.3:58 build/C/man3/copysign.3:62 build/C/man3/cos.3:64 build/C/man3/cosh.3:66 build/C/man3/div.3:66 build/C/man3/erf.3:72 build/C/man3/erfc.3:63 build/C/man3/exp.3:66 build/C/man3/exp10.3:50 build/C/man3/exp2.3:66 build/C/man3/expm1.3:70 build/C/man3/fabs.3:62 build/C/man3/fdim.3:36 build/C/man3/fenv.3:60 build/C/man3/finite.3:88 build/C/man3/floor.3:57 build/C/man3/fma.3:41 build/C/man3/fmax.3:37 build/C/man3/fmin.3:37 build/C/man3/fmod.3:65 build/C/man3/fpclassify.3:62 build/C/man3/frexp.3:64 build/C/man3/gamma.3:37 build/C/man3/hypot.3:72 build/C/man3/ilogb.3:68 build/C/man3/infnan.3:42 build/C/man3/isgreater.3:44 build/C/man3/j0.3:87 build/C/man3/ldexp.3:64 build/C/man3/lgamma.3:67 build/C/man3/log.3:66 build/C/man3/log10.3:66 build/C/man3/log1p.3:69 build/C/man3/log2.3:66 build/C/man3/logb.3:67 build/C/man3/lrint.3:62 build/C/man3/lround.3:63 build/C/man7/math_error.7:33 build/C/man3/matherr.3:39 build/C/man3/modf.3:64 build/C/man3/nan.3:37 build/C/man3/nextafter.3:65 build/C/man3/pow.3:65 build/C/man3/pow10.3:39 build/C/man3/remainder.3:90 build/C/man3/remquo.3:40 build/C/man3/rint.3:84 build/C/man3/round.3:58 build/C/man3/scalb.3:58 build/C/man3/scalbln.3:74 build/C/man3/signbit.3:31 build/C/man3/significand.3:32 build/C/man3/sin.3:65 build/C/man3/sincos.3:22 build/C/man3/sinh.3:66 build/C/man3/sqrt.3:64 build/C/man3/tan.3:65 build/C/man3/tanh.3:65 build/C/man3/tgamma.3:39 build/C/man3/trunc.3:56 build/C/man3/y0.3:87
103 #: build/C/man3/INFINITY.3:46
105 "The macro B<INFINITY> expands to a I<float> constant representing positive "
110 #: build/C/man3/INFINITY.3:59
112 "The macro B<NAN> expands to a I<float> constant representing a quiet NaN "
113 "(when supported). A I<quiet> NaN is a NaN (\"not-a-number\") that does not "
114 "raise exceptions when it is used in arithmetic. The opposite is a "
115 "I<signaling> NaN. See IEC 60559:1989."
119 #: build/C/man3/INFINITY.3:67
121 "The macros B<HUGE_VAL>, B<HUGE_VALF>, B<HUGE_VALL> expand to constants of "
122 "types I<double>, I<float> and I<long double>, respectively, that represent a "
123 "large positive value, possibly plus infinity."
127 #: build/C/man3/INFINITY.3:67 build/C/man3/abs.3:80 build/C/man3/acos.3:108 build/C/man3/acosh.3:116 build/C/man3/asin.3:107 build/C/man3/asinh.3:101 build/C/man3/atan.3:92 build/C/man3/atan2.3:164 build/C/man3/atanh.3:135 build/C/man3/cbrt.3:87 build/C/man3/ceil.3:76 build/C/man3/copysign.3:83 build/C/man3/cos.3:98 build/C/man3/cosh.3:115 build/C/man3/div.3:89 build/C/man3/erf.3:122 build/C/man3/erfc.3:120 build/C/man3/exp.3:125 build/C/man3/exp10.3:74 build/C/man3/exp2.3:88 build/C/man3/expm1.3:132 build/C/man3/fabs.3:84 build/C/man3/fdim.3:78 build/C/man3/fenv.3:264 build/C/man3/floor.3:75 build/C/man3/fma.3:152 build/C/man3/fmax.3:55 build/C/man3/fmin.3:55 build/C/man3/fmod.3:130 build/C/man3/fpclassify.3:114 build/C/man3/frexp.3:96 build/C/man3/gamma.3:62 build/C/man3/hypot.3:156 build/C/man3/ilogb.3:144 build/C/man3/infnan.3:69 build/C/man3/isgreater.3:87 build/C/man3/j0.3:144 build/C/man3/ldexp.3:127 build/C/man3/lgamma.3:150 build/C/man3/log.3:125 build/C/man3/log10.3:86 build/C/man3/log1p.3:138 build/C/man3/log2.3:88 build/C/man3/logb.3:141 build/C/man3/lrint.3:107 build/C/man3/lround.3:110 build/C/man3/modf.3:88 build/C/man3/nan.3:70 build/C/man3/nextafter.3:163 build/C/man3/pow.3:311 build/C/man3/pow10.3:46 build/C/man3/remainder.3:178 build/C/man3/remquo.3:119 build/C/man3/rint.3:111 build/C/man3/round.3:81 build/C/man3/scalb.3:170 build/C/man3/scalbln.3:153 build/C/man3/signbit.3:56 build/C/man3/significand.3:46 build/C/man3/sin.3:102 build/C/man3/sincos.3:72 build/C/man3/sinh.3:120 build/C/man3/sqrt.3:104 build/C/man3/tan.3:127 build/C/man3/tanh.3:96 build/C/man3/tgamma.3:153 build/C/man3/trunc.3:67 build/C/man3/y0.3:215
129 msgid "CONFORMING TO"
133 #: build/C/man3/INFINITY.3:69
138 #: build/C/man3/INFINITY.3:69
144 #: build/C/man3/INFINITY.3:91
146 "On a glibc system, the macro B<HUGE_VAL> is always available. Availability "
147 "of the B<NAN> macro can be tested using B<#ifdef NAN>, and similarly for "
148 "B<INFINITY>, B<HUGE_VALF>, B<HUGE_VALL>. They will be defined by "
149 "I<E<lt>math.hE<gt>> if B<_ISOC99_SOURCE> or B<_GNU_SOURCE> is defined, or "
150 "B<__STDC_VERSION__> is defined and has a value not less than 199901L."
154 #: build/C/man3/INFINITY.3:91 build/C/man3/abs.3:124 build/C/man3/acos.3:114 build/C/man3/acosh.3:122 build/C/man3/asin.3:113 build/C/man3/asinh.3:107 build/C/man3/atan.3:98 build/C/man3/atan2.3:170 build/C/man3/atanh.3:152 build/C/man3/cbrt.3:91 build/C/man3/ceil.3:107 build/C/man3/copysign.3:93 build/C/man3/cos.3:111 build/C/man3/cosh.3:126 build/C/man3/div.3:104 build/C/man3/erf.3:128 build/C/man3/erfc.3:133 build/C/man3/exp.3:131 build/C/man3/exp10.3:76 build/C/man3/exp2.3:94 build/C/man3/expm1.3:166 build/C/man3/fabs.3:90 build/C/man3/fdim.3:80 build/C/man3/fenv.3:322 build/C/man3/finite.3:123 build/C/man3/floor.3:97 build/C/man3/fma.3:154 build/C/man3/fmax.3:57 build/C/man3/fmin.3:57 build/C/man3/fmod.3:144 build/C/man3/fpclassify.3:128 build/C/man3/frexp.3:135 build/C/man3/gamma.3:94 build/C/man3/hypot.3:162 build/C/man3/ilogb.3:146 build/C/man3/isgreater.3:94 build/C/man3/j0.3:157 build/C/man3/ldexp.3:133 build/C/man3/lgamma.3:169 build/C/man3/log.3:138 build/C/man3/log10.3:92 build/C/man3/log1p.3:141 build/C/man3/log2.3:94 build/C/man3/logb.3:143 build/C/man3/lrint.3:109 build/C/man3/lround.3:112 build/C/man7/math_error.7:254 build/C/man3/matherr.3:423 build/C/man3/modf.3:94 build/C/man3/nan.3:74 build/C/man3/nextafter.3:172 build/C/man3/pow.3:360 build/C/man3/pow10.3:51 build/C/man3/remainder.3:213 build/C/man3/remquo.3:121 build/C/man3/rint.3:133 build/C/man3/round.3:104 build/C/man3/scalb.3:193 build/C/man3/scalbln.3:171 build/C/man3/signbit.3:60 build/C/man3/significand.3:52 build/C/man3/sin.3:115 build/C/man3/sincos.3:74 build/C/man3/sinh.3:126 build/C/man3/sqrt.3:110 build/C/man3/tan.3:140 build/C/man3/tanh.3:102 build/C/man3/tgamma.3:179 build/C/man3/trunc.3:78 build/C/man3/y0.3:238
160 #: build/C/man3/INFINITY.3:94
161 msgid "B<fpclassify>(3), B<math_error>(7)"
165 #: build/C/man3/INFINITY.3:94 build/C/man3/abs.3:130 build/C/man3/acos.3:122 build/C/man3/acosh.3:129 build/C/man3/asin.3:121 build/C/man3/asinh.3:114 build/C/man3/atan.3:107 build/C/man3/atan2.3:178 build/C/man3/atanh.3:159 build/C/man3/cbrt.3:94 build/C/man3/ceil.3:114 build/C/man3/copysign.3:95 build/C/man3/cos.3:120 build/C/man3/cosh.3:133 build/C/man3/div.3:107 build/C/man3/erf.3:132 build/C/man3/erfc.3:137 build/C/man3/exp.3:137 build/C/man3/exp10.3:82 build/C/man3/exp2.3:100 build/C/man3/expm1.3:170 build/C/man3/fabs.3:97 build/C/man3/fdim.3:82 build/C/man3/fenv.3:324 build/C/man3/finite.3:125 build/C/man3/floor.3:104 build/C/man3/fma.3:157 build/C/man3/fmax.3:59 build/C/man3/fmin.3:59 build/C/man3/fmod.3:146 build/C/man3/fpclassify.3:133 build/C/man3/frexp.3:138 build/C/man3/gamma.3:98 build/C/man3/hypot.3:165 build/C/man3/ilogb.3:150 build/C/man3/infnan.3:74 build/C/man3/isgreater.3:97 build/C/man3/j0.3:159 build/C/man3/ldexp.3:137 build/C/man3/lgamma.3:171 build/C/man3/log.3:145 build/C/man3/log10.3:99 build/C/man3/log1p.3:145 build/C/man3/log2.3:100 build/C/man3/logb.3:146 build/C/man3/lrint.3:116 build/C/man3/lround.3:119 build/C/man7/math_error.7:265 build/C/man3/matherr.3:427 build/C/man3/modf.3:97 build/C/man3/nan.3:78 build/C/man3/nextafter.3:174 build/C/man3/pow.3:364 build/C/man3/pow10.3:54 build/C/man3/remainder.3:217 build/C/man3/remquo.3:125 build/C/man3/rint.3:139 build/C/man3/round.3:111 build/C/man3/scalb.3:196 build/C/man3/scalbln.3:174 build/C/man3/signbit.3:62 build/C/man3/significand.3:55 build/C/man3/sin.3:124 build/C/man3/sincos.3:78 build/C/man3/sinh.3:133 build/C/man3/sqrt.3:114 build/C/man3/tan.3:148 build/C/man3/tanh.3:109 build/C/man3/tgamma.3:182 build/C/man3/trunc.3:85 build/C/man3/y0.3:240
171 #: build/C/man3/INFINITY.3:101 build/C/man3/abs.3:137 build/C/man3/acos.3:129 build/C/man3/acosh.3:136 build/C/man3/asin.3:128 build/C/man3/asinh.3:121 build/C/man3/atan.3:114 build/C/man3/atan2.3:185 build/C/man3/atanh.3:166 build/C/man3/cbrt.3:101 build/C/man3/ceil.3:121 build/C/man3/copysign.3:102 build/C/man3/cos.3:127 build/C/man3/cosh.3:140 build/C/man3/div.3:114 build/C/man3/erf.3:139 build/C/man3/erfc.3:144 build/C/man3/exp.3:144 build/C/man3/exp10.3:89 build/C/man3/exp2.3:107 build/C/man3/expm1.3:177 build/C/man3/fabs.3:104 build/C/man3/fdim.3:89 build/C/man3/fenv.3:331 build/C/man3/finite.3:132 build/C/man3/floor.3:111 build/C/man3/fma.3:164 build/C/man3/fmax.3:66 build/C/man3/fmin.3:66 build/C/man3/fmod.3:153 build/C/man3/fpclassify.3:140 build/C/man3/frexp.3:145 build/C/man3/gamma.3:105 build/C/man3/hypot.3:172 build/C/man3/ilogb.3:157 build/C/man3/infnan.3:81 build/C/man3/isgreater.3:104 build/C/man3/j0.3:166 build/C/man3/ldexp.3:144 build/C/man3/lgamma.3:178 build/C/man3/log.3:152 build/C/man3/log10.3:106 build/C/man3/log1p.3:152 build/C/man3/log2.3:107 build/C/man3/logb.3:153 build/C/man3/lrint.3:123 build/C/man3/lround.3:126 build/C/man7/math_error.7:272 build/C/man3/matherr.3:434 build/C/man3/modf.3:104 build/C/man3/nan.3:85 build/C/man3/nextafter.3:181 build/C/man3/pow.3:371 build/C/man3/pow10.3:61 build/C/man3/remainder.3:224 build/C/man3/remquo.3:132 build/C/man3/rint.3:146 build/C/man3/round.3:118 build/C/man3/scalb.3:203 build/C/man3/scalbln.3:181 build/C/man3/signbit.3:69 build/C/man3/significand.3:62 build/C/man3/sin.3:131 build/C/man3/sincos.3:85 build/C/man3/sinh.3:140 build/C/man3/sqrt.3:121 build/C/man3/tan.3:155 build/C/man3/tanh.3:116 build/C/man3/tgamma.3:189 build/C/man3/trunc.3:92 build/C/man3/y0.3:247
173 "This page is part of release 3.40 of the Linux I<man-pages> project. A "
174 "description of the project, and information about reporting bugs, can be "
175 "found at http://www.kernel.org/doc/man-pages/."
179 #: build/C/man3/abs.3:32
185 #: build/C/man3/abs.3:32 build/C/man3/acos.3:33 build/C/man3/acosh.3:33 build/C/man3/asin.3:33 build/C/man3/asinh.3:33 build/C/man3/atan.3:33 build/C/man3/atan2.3:33 build/C/man3/cbrt.3:28 build/C/man3/ceil.3:25 build/C/man3/cosh.3:34 build/C/man3/erf.3:33 build/C/man3/erfc.3:24 build/C/man3/exp.3:34 build/C/man3/exp2.3:34 build/C/man3/fabs.3:30 build/C/man3/fdim.3:6 build/C/man3/floor.3:25 build/C/man3/fma.3:8 build/C/man3/fmax.3:6 build/C/man3/fmin.3:6 build/C/man3/fpclassify.3:6 build/C/man3/frexp.3:31 build/C/man3/hypot.3:31 build/C/man3/ilogb.3:27 build/C/man3/isgreater.3:6 build/C/man3/j0.3:34 build/C/man3/ldexp.3:32 build/C/man3/log.3:34 build/C/man3/log10.3:34 build/C/man3/log1p.3:27 build/C/man3/logb.3:27 build/C/man3/lrint.3:25 build/C/man3/lround.3:25 build/C/man3/modf.3:31 build/C/man3/nan.3:6 build/C/man3/nextafter.3:6 build/C/man3/remainder.3:35 build/C/man3/remquo.3:7 build/C/man3/rint.3:25 build/C/man3/round.3:25 build/C/man3/scalb.3:25 build/C/man3/scalbln.3:25 build/C/man3/signbit.3:6 build/C/man3/sinh.3:34 build/C/man3/sqrt.3:32 build/C/man3/tanh.3:33 build/C/man3/tgamma.3:8 build/C/man3/trunc.3:23
191 #: build/C/man3/abs.3:32 build/C/man3/asinh.3:33 build/C/man3/cbrt.3:28 build/C/man3/copysign.3:29 build/C/man3/erf.3:33 build/C/man3/erfc.3:24 build/C/man3/exp10.3:33 build/C/man3/gamma.3:6 build/C/man3/infnan.3:31 build/C/man3/nan.3:6 build/C/man3/nextafter.3:6 build/C/man3/remquo.3:7 build/C/man3/signbit.3:6 build/C/man3/significand.3:4 build/C/man3/sincos.3:6 build/C/man3/tgamma.3:8
197 #: build/C/man3/abs.3:35
198 msgid "abs, labs, llabs, imaxabs - compute the absolute value of an integer"
202 #: build/C/man3/abs.3:38 build/C/man3/div.3:39
204 msgid "B<#include E<lt>stdlib.hE<gt>>\n"
208 #: build/C/man3/abs.3:40
210 msgid "B<int abs(int >I<j>B<);>\n"
214 #: build/C/man3/abs.3:42
216 msgid "B<long int labs(long int >I<j>B<);>\n"
220 #: build/C/man3/abs.3:44
222 msgid "B<long long int llabs(long long int >I<j>B<);>\n"
226 #: build/C/man3/abs.3:46 build/C/man3/div.3:47
228 msgid "B<#include E<lt>inttypes.hE<gt>>\n"
232 #: build/C/man3/abs.3:48
234 msgid "B<intmax_t imaxabs(intmax_t >I<j>B<);>\n"
238 #: build/C/man3/abs.3:53 build/C/man3/acos.3:50 build/C/man3/acosh.3:52 build/C/man3/asin.3:52 build/C/man3/asinh.3:52 build/C/man3/atan.3:52 build/C/man3/atan2.3:50 build/C/man3/atanh.3:52 build/C/man3/cbrt.3:47 build/C/man3/ceil.3:45 build/C/man3/copysign.3:48 build/C/man3/cos.3:51 build/C/man3/cosh.3:53 build/C/man3/div.3:54 build/C/man3/erf.3:50 build/C/man3/erfc.3:41 build/C/man3/exp.3:53 build/C/man3/exp2.3:53 build/C/man3/expm1.3:47 build/C/man3/fabs.3:49 build/C/man3/fdim.3:23 build/C/man3/finite.3:53 build/C/man3/floor.3:44 build/C/man3/fma.3:27 build/C/man3/fmax.3:23 build/C/man3/fmin.3:23 build/C/man3/fmod.3:52 build/C/man3/fpclassify.3:30 build/C/man3/frexp.3:51 build/C/man3/gamma.3:23 build/C/man3/hypot.3:50 build/C/man3/ilogb.3:44 build/C/man3/isgreater.3:32 build/C/man3/j0.3:66 build/C/man3/ldexp.3:51 build/C/man3/lgamma.3:35 build/C/man3/log.3:53 build/C/man3/log10.3:53 build/C/man3/log1p.3:46 build/C/man3/log2.3:53 build/C/man3/logb.3:44 build/C/man3/lrint.3:50 build/C/man3/lround.3:51 build/C/man3/modf.3:51 build/C/man3/nan.3:23 build/C/man3/nextafter.3:30 build/C/man3/pow.3:52 build/C/man3/remainder.3:59 build/C/man3/remquo.3:26 build/C/man3/rint.3:51 build/C/man3/round.3:44 build/C/man3/scalb.3:43 build/C/man3/scalbln.3:49 build/C/man3/signbit.3:19 build/C/man3/significand.3:22 build/C/man3/sin.3:52 build/C/man3/sinh.3:53 build/C/man3/sqrt.3:51 build/C/man3/tan.3:52 build/C/man3/tanh.3:52 build/C/man3/tgamma.3:25 build/C/man3/trunc.3:42 build/C/man3/y0.3:66
239 msgid "Feature Test Macro Requirements for glibc (see B<feature_test_macros>(7)):"
243 #: build/C/man3/abs.3:57
248 #: build/C/man3/abs.3:60 build/C/man3/div.3:61 build/C/man3/exp2.3:61 build/C/man3/fdim.3:31 build/C/man3/fma.3:36 build/C/man3/fmax.3:32 build/C/man3/fmin.3:32 build/C/man3/fpclassify.3:41 build/C/man3/isgreater.3:39 build/C/man3/log2.3:61 build/C/man3/lrint.3:57 build/C/man3/lround.3:58 build/C/man3/nan.3:32 build/C/man3/nextafter.3:60 build/C/man3/remquo.3:35 build/C/man3/round.3:53 build/C/man3/scalbln.3:58 build/C/man3/signbit.3:26 build/C/man3/tgamma.3:34 build/C/man3/trunc.3:51
250 "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _ISOC99_SOURCE || _POSIX_C_SOURCE\\ E<gt>=\\ "
255 #: build/C/man3/abs.3:63 build/C/man3/acos.3:61 build/C/man3/acosh.3:63 build/C/man3/acosh.3:73 build/C/man3/asin.3:63 build/C/man3/asinh.3:63 build/C/man3/asinh.3:73 build/C/man3/atan.3:63 build/C/man3/atan2.3:61 build/C/man3/atanh.3:63 build/C/man3/atanh.3:73 build/C/man3/cbrt.3:59 build/C/man3/cbrt.3:68 build/C/man3/ceil.3:56 build/C/man3/copysign.3:60 build/C/man3/cos.3:62 build/C/man3/cosh.3:64 build/C/man3/div.3:64 build/C/man3/erf.3:60 build/C/man3/erf.3:70 build/C/man3/erfc.3:51 build/C/man3/erfc.3:61 build/C/man3/exp.3:64 build/C/man3/exp2.3:64 build/C/man3/expm1.3:58 build/C/man3/expm1.3:68 build/C/man3/fabs.3:60 build/C/man3/fdim.3:34 build/C/man3/finite.3:68 build/C/man3/finite.3:81 build/C/man3/floor.3:55 build/C/man3/fma.3:39 build/C/man3/fmax.3:35 build/C/man3/fmin.3:35 build/C/man3/fmod.3:63 build/C/man3/fpclassify.3:44 build/C/man3/fpclassify.3:52 build/C/man3/fpclassify.3:60 build/C/man3/frexp.3:62 build/C/man3/hypot.3:60 build/C/man3/hypot.3:70 build/C/man3/ilogb.3:56 build/C/man3/ilogb.3:66 build/C/man3/isgreater.3:42 build/C/man3/ldexp.3:62 build/C/man3/lgamma.3:45 build/C/man3/lgamma.3:55 build/C/man3/log.3:64 build/C/man3/log10.3:64 build/C/man3/log1p.3:57 build/C/man3/log1p.3:67 build/C/man3/log2.3:64 build/C/man3/logb.3:55 build/C/man3/logb.3:65 build/C/man3/lrint.3:60 build/C/man3/lround.3:61 build/C/man3/modf.3:62 build/C/man3/nan.3:35 build/C/man3/nextafter.3:42 build/C/man3/nextafter.3:52 build/C/man3/nextafter.3:63 build/C/man3/pow.3:63 build/C/man3/remainder.3:71 build/C/man3/remainder.3:81 build/C/man3/remquo.3:38 build/C/man3/rint.3:62 build/C/man3/rint.3:72 build/C/man3/rint.3:82 build/C/man3/round.3:56 build/C/man3/scalbln.3:61 build/C/man3/scalbln.3:72 build/C/man3/signbit.3:29 build/C/man3/sin.3:63 build/C/man3/sinh.3:64 build/C/man3/sqrt.3:62 build/C/man3/tan.3:63 build/C/man3/tanh.3:63 build/C/man3/tgamma.3:37 build/C/man3/trunc.3:54
256 msgid "or I<cc\\ -std=c99>"
260 #: build/C/man3/abs.3:77
262 "The B<abs>() function computes the absolute value of the integer argument "
263 "I<j>. The B<labs>(), B<llabs>() and B<imaxabs>() functions compute the "
264 "absolute value of the argument I<j> of the appropriate integer type for the "
269 #: build/C/man3/abs.3:77 build/C/man3/acos.3:68 build/C/man3/acosh.3:80 build/C/man3/asin.3:70 build/C/man3/asinh.3:80 build/C/man3/atan.3:70 build/C/man3/atan2.3:70 build/C/man3/atanh.3:80 build/C/man3/cbrt.3:76 build/C/man3/ceil.3:67 build/C/man3/copysign.3:73 build/C/man3/cos.3:69 build/C/man3/cosh.3:75 build/C/man3/div.3:87 build/C/man3/erf.3:79 build/C/man3/erfc.3:69 build/C/man3/exp.3:71 build/C/man3/exp10.3:55 build/C/man3/exp2.3:71 build/C/man3/expm1.3:84 build/C/man3/fabs.3:67 build/C/man3/fdim.3:39 build/C/man3/fenv.3:257 build/C/man3/floor.3:66 build/C/man3/fma.3:49 build/C/man3/fmax.3:42 build/C/man3/fmin.3:42 build/C/man3/fmod.3:72 build/C/man3/frexp.3:69 build/C/man3/gamma.3:56 build/C/man3/hypot.3:90 build/C/man3/ilogb.3:76 build/C/man3/infnan.3:52 build/C/man3/isgreater.3:77 build/C/man3/j0.3:108 build/C/man3/ldexp.3:71 build/C/man3/lgamma.3:88 build/C/man3/log.3:70 build/C/man3/log10.3:70 build/C/man3/log1p.3:79 build/C/man3/log2.3:70 build/C/man3/logb.3:92 build/C/man3/lrint.3:71 build/C/man3/lround.3:74 build/C/man3/modf.3:70 build/C/man3/nextafter.3:88 build/C/man3/pow.3:70 build/C/man3/remainder.3:116 build/C/man3/remquo.3:68 build/C/man3/rint.3:103 build/C/man3/round.3:71 build/C/man3/scalb.3:77 build/C/man3/scalbln.3:93 build/C/man3/signbit.3:48 build/C/man3/sin.3:70 build/C/man3/sincos.3:46 build/C/man3/sinh.3:75 build/C/man3/sqrt.3:68 build/C/man3/tan.3:70 build/C/man3/tanh.3:74 build/C/man3/tgamma.3:58 build/C/man3/trunc.3:59 build/C/man3/y0.3:111
275 #: build/C/man3/abs.3:80
277 "Returns the absolute value of the integer argument, of the appropriate "
278 "integer type for the function."
281 #. POSIX.1 (1996 edition) only requires the
285 #: build/C/man3/abs.3:95
287 "SVr4, POSIX.1-2001, 4.3BSD, C99. C89 only includes the B<abs>() and "
288 "B<labs>() functions; the functions B<llabs>() and B<imaxabs>() were added "
293 #: build/C/man3/abs.3:95 build/C/man3/ceil.3:82 build/C/man3/copysign.3:88 build/C/man3/erfc.3:126 build/C/man3/fenv.3:266 build/C/man3/finite.3:103 build/C/man3/floor.3:81 build/C/man3/fpclassify.3:121 build/C/man3/gamma.3:65 build/C/man3/infnan.3:71 build/C/man3/isgreater.3:89 build/C/man7/math_error.7:185 build/C/man3/pow10.3:48 build/C/man3/rint.3:113 build/C/man3/round.3:83 build/C/man3/scalbln.3:155 build/C/man3/tgamma.3:155 build/C/man3/trunc.3:69
299 #: build/C/man3/abs.3:98
301 "Trying to take the absolute value of the most negative integer is not "
306 #: build/C/man3/abs.3:107
308 "The B<llabs>() function is included in glibc since version 2.0, but is not "
309 "in libc5 or libc4. The B<imaxabs>() function is included in glibc since "
314 #: build/C/man3/abs.3:113
316 "For B<llabs>() to be declared, it may be necessary to define "
317 "B<_ISOC99_SOURCE> or B<_ISOC9X_SOURCE> (depending on the version of glibc) "
318 "before including any standard headers."
322 #: build/C/man3/abs.3:124
324 "GCC handles B<abs>() and B<labs>() as built-in functions. GCC 3.0 also "
325 "handles B<llabs>() and B<imaxabs>() as built-ins."
329 #: build/C/man3/abs.3:130
330 msgid "B<cabs>(3), B<ceil>(3), B<fabs>(3), B<floor>(3), B<rint>(3)"
334 #: build/C/man3/acos.3:33
340 #: build/C/man3/acos.3:36
341 msgid "acos, acosf, acosl - arc cosine function"
345 #: build/C/man3/acos.3:43
348 "B<double acos(double >I<x>B<);>\n"
349 "B<float acosf(float >I<x>B<);>\n"
350 "B<long double acosl(long double >I<x>B<);>\n"
354 #: build/C/man3/acos.3:46 build/C/man3/acosh.3:48 build/C/man3/asin.3:48 build/C/man3/asinh.3:48 build/C/man3/atan.3:48 build/C/man3/atan2.3:46 build/C/man3/atanh.3:48 build/C/man3/cbrt.3:43 build/C/man3/ceil.3:41 build/C/man3/copysign.3:44 build/C/man3/cos.3:47 build/C/man3/cosh.3:49 build/C/man3/erf.3:46 build/C/man3/erfc.3:37 build/C/man3/exp.3:49 build/C/man3/exp10.3:50 build/C/man3/exp2.3:49 build/C/man3/expm1.3:43 build/C/man3/fabs.3:45 build/C/man3/fdim.3:19 build/C/man3/fenv.3:60 build/C/man3/floor.3:40 build/C/man3/fma.3:23 build/C/man3/fmax.3:19 build/C/man3/fmin.3:19 build/C/man3/fmod.3:48 build/C/man3/fpclassify.3:26 build/C/man3/frexp.3:47 build/C/man3/gamma.3:19 build/C/man3/hypot.3:46 build/C/man3/ilogb.3:40 build/C/man3/infnan.3:42 build/C/man3/isgreater.3:28 build/C/man3/j0.3:62 build/C/man3/ldexp.3:47 build/C/man3/lgamma.3:31 build/C/man3/log.3:49 build/C/man3/log10.3:49 build/C/man3/log1p.3:42 build/C/man3/log2.3:49 build/C/man3/logb.3:40 build/C/man3/lrint.3:46 build/C/man3/lround.3:47 build/C/man3/matherr.3:39 build/C/man3/modf.3:47 build/C/man3/nan.3:19 build/C/man3/nextafter.3:26 build/C/man3/pow.3:48 build/C/man3/pow10.3:39 build/C/man3/remainder.3:55 build/C/man3/remquo.3:22 build/C/man3/rint.3:47 build/C/man3/round.3:40 build/C/man3/scalb.3:39 build/C/man3/scalbln.3:45 build/C/man3/signbit.3:15 build/C/man3/significand.3:18 build/C/man3/sin.3:48 build/C/man3/sincos.3:22 build/C/man3/sinh.3:49 build/C/man3/sqrt.3:47 build/C/man3/tan.3:48 build/C/man3/tanh.3:48 build/C/man3/tgamma.3:21 build/C/man3/trunc.3:38 build/C/man3/y0.3:62
355 msgid "Link with I<-lm>."
359 #: build/C/man3/acos.3:55
360 msgid "B<acosf>(), B<acosl>():"
364 #: build/C/man3/acos.3:58 build/C/man3/acosh.3:70 build/C/man3/asin.3:60 build/C/man3/asinh.3:70 build/C/man3/atan.3:60 build/C/man3/atan2.3:58 build/C/man3/atanh.3:70 build/C/man3/ceil.3:53 build/C/man3/cos.3:59 build/C/man3/cosh.3:61 build/C/man3/erf.3:67 build/C/man3/exp.3:61 build/C/man3/expm1.3:65 build/C/man3/fabs.3:57 build/C/man3/floor.3:52 build/C/man3/fmod.3:60 build/C/man3/fpclassify.3:57 build/C/man3/frexp.3:59 build/C/man3/hypot.3:67 build/C/man3/ilogb.3:63 build/C/man3/ldexp.3:59 build/C/man3/lgamma.3:52 build/C/man3/log.3:61 build/C/man3/log10.3:61 build/C/man3/log1p.3:64 build/C/man3/logb.3:62 build/C/man3/modf.3:59 build/C/man3/nextafter.3:49 build/C/man3/pow.3:60 build/C/man3/remainder.3:78 build/C/man3/rint.3:79 build/C/man3/scalbln.3:69 build/C/man3/sin.3:60 build/C/man3/sinh.3:61 build/C/man3/sqrt.3:59 build/C/man3/tan.3:60 build/C/man3/tanh.3:60
366 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600 || "
367 "_ISOC99_SOURCE || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
371 #: build/C/man3/acos.3:68
373 "The B<acos>() function calculates the arc cosine of I<x>; that is the value "
374 "whose cosine is I<x>."
378 #: build/C/man3/acos.3:72
380 "On success, these functions return the arc cosine of I<x> in radians; the "
381 "return value is in the range [0,\\ pi]."
385 #: build/C/man3/acos.3:76 build/C/man3/acosh.3:87 build/C/man3/asin.3:78 build/C/man3/asinh.3:87 build/C/man3/atan.3:78 build/C/man3/atanh.3:87 build/C/man3/cos.3:76 build/C/man3/cosh.3:82 build/C/man3/erf.3:87 build/C/man3/erfc.3:77 build/C/man3/exp.3:79 build/C/man3/expm1.3:92 build/C/man3/fabs.3:74 build/C/man3/j0.3:116 build/C/man3/ldexp.3:85 build/C/man3/lgamma.3:94 build/C/man3/log.3:78 build/C/man3/log1p.3:87 build/C/man3/logb.3:100 build/C/man3/scalbln.3:99 build/C/man3/sin.3:77 build/C/man3/sinh.3:82 build/C/man3/sqrt.3:75 build/C/man3/tan.3:77 build/C/man3/tanh.3:81 build/C/man3/tgamma.3:64 build/C/man3/y0.3:119
386 msgid "If I<x> is a NaN, a NaN is returned."
390 #: build/C/man3/acos.3:81 build/C/man3/acosh.3:91
391 msgid "If I<x> is +1, +0 is returned."
395 #: build/C/man3/acos.3:87 build/C/man3/cos.3:82 build/C/man3/sin.3:86 build/C/man3/tan.3:83
397 "If I<x> is positive infinity or negative infinity, a domain error occurs, "
398 "and a NaN is returned."
402 #. POSIX.1-2001 documents an optional range error for subnormal x;
403 #. glibc 2.8 does not do this.
405 #: build/C/man3/acos.3:93 build/C/man3/asin.3:92
407 "If I<x> is outside the range [-1,\\ 1], a domain error occurs, and a NaN is "
412 #: build/C/man3/acos.3:93 build/C/man3/acosh.3:101 build/C/man3/asin.3:92 build/C/man3/asinh.3:99 build/C/man3/atan.3:90 build/C/man3/atan2.3:160 build/C/man3/atanh.3:111 build/C/man3/cbrt.3:85 build/C/man3/ceil.3:73 build/C/man3/copysign.3:81 build/C/man3/cos.3:82 build/C/man3/cosh.3:100 build/C/man3/erf.3:102 build/C/man3/erfc.3:100 build/C/man3/exp.3:102 build/C/man3/exp10.3:62 build/C/man3/exp2.3:78 build/C/man3/expm1.3:113 build/C/man3/fabs.3:82 build/C/man3/fdim.3:56 build/C/man3/floor.3:72 build/C/man3/fma.3:113 build/C/man3/fmax.3:51 build/C/man3/fmin.3:51 build/C/man3/fmod.3:104 build/C/man3/frexp.3:94 build/C/man3/gamma.3:59 build/C/man3/hypot.3:126 build/C/man3/ilogb.3:108 build/C/man3/infnan.3:62 build/C/man3/isgreater.3:85 build/C/man3/j0.3:123 build/C/man3/ldexp.3:104 build/C/man3/lgamma.3:124 build/C/man3/log.3:102 build/C/man3/log10.3:78 build/C/man3/log1p.3:109 build/C/man3/log2.3:78 build/C/man3/logb.3:114 build/C/man3/lrint.3:85 build/C/man3/lround.3:88 build/C/man3/modf.3:86 build/C/man3/nextafter.3:133 build/C/man3/pow.3:251 build/C/man3/remainder.3:148 build/C/man3/remquo.3:96 build/C/man3/rint.3:108 build/C/man3/round.3:76 build/C/man3/scalb.3:131 build/C/man3/scalbln.3:123 build/C/man3/signbit.3:54 build/C/man3/sin.3:86 build/C/man3/sincos.3:49 build/C/man3/sinh.3:105 build/C/man3/sqrt.3:89 build/C/man3/tan.3:101 build/C/man3/tanh.3:94 build/C/man3/tgamma.3:98 build/C/man3/trunc.3:63 build/C/man3/y0.3:156
418 #: build/C/man3/acos.3:98 build/C/man3/acosh.3:106 build/C/man3/asin.3:97 build/C/man3/atanh.3:116 build/C/man3/cos.3:87 build/C/man3/cosh.3:105 build/C/man3/erf.3:107 build/C/man3/erfc.3:105 build/C/man3/exp.3:107 build/C/man3/exp10.3:67 build/C/man3/exp2.3:83 build/C/man3/expm1.3:118 build/C/man3/fdim.3:61 build/C/man3/fma.3:118 build/C/man3/fmod.3:109 build/C/man3/hypot.3:131 build/C/man3/ilogb.3:113 build/C/man3/j0.3:128 build/C/man3/ldexp.3:109 build/C/man3/lgamma.3:129 build/C/man3/log.3:107 build/C/man3/log10.3:83 build/C/man3/log1p.3:114 build/C/man3/log2.3:83 build/C/man3/logb.3:119 build/C/man3/lrint.3:90 build/C/man3/lround.3:93 build/C/man3/nextafter.3:138 build/C/man3/pow.3:276 build/C/man3/remainder.3:153 build/C/man3/remquo.3:101 build/C/man3/scalb.3:136 build/C/man3/scalbln.3:128 build/C/man3/sin.3:91 build/C/man3/sincos.3:54 build/C/man3/sinh.3:110 build/C/man3/sqrt.3:94 build/C/man3/tan.3:106 build/C/man3/tgamma.3:103 build/C/man3/y0.3:161
420 "See B<math_error>(7) for information on how to determine whether an error "
421 "has occurred when calling these functions."
425 #: build/C/man3/acos.3:100 build/C/man3/acosh.3:108 build/C/man3/asin.3:99 build/C/man3/atanh.3:118 build/C/man3/cos.3:89 build/C/man3/cosh.3:107 build/C/man3/erf.3:109 build/C/man3/erfc.3:107 build/C/man3/exp.3:109 build/C/man3/expm1.3:120 build/C/man3/fdim.3:63 build/C/man3/fma.3:120 build/C/man3/fmod.3:111 build/C/man3/hypot.3:133 build/C/man3/ilogb.3:115 build/C/man3/j0.3:130 build/C/man3/ldexp.3:111 build/C/man3/lgamma.3:131 build/C/man3/log.3:109 build/C/man3/log1p.3:116 build/C/man3/logb.3:121 build/C/man3/lrint.3:92 build/C/man3/lround.3:95 build/C/man3/nextafter.3:140 build/C/man3/pow.3:278 build/C/man3/remainder.3:155 build/C/man3/remquo.3:103 build/C/man3/scalb.3:138 build/C/man3/scalbln.3:130 build/C/man3/sin.3:93 build/C/man3/sincos.3:56 build/C/man3/sinh.3:112 build/C/man3/sqrt.3:96 build/C/man3/tan.3:108 build/C/man3/tgamma.3:105 build/C/man3/y0.3:163
426 msgid "The following errors can occur:"
430 #: build/C/man3/acos.3:100 build/C/man3/asin.3:99
432 msgid "Domain error: I<x> is outside the range [-1,\\ 1]"
436 #: build/C/man3/acos.3:108 build/C/man3/acosh.3:116 build/C/man3/asin.3:107 build/C/man3/atanh.3:126 build/C/man3/fmod.3:130 build/C/man3/log.3:117 build/C/man3/pow.3:286 build/C/man3/remainder.3:178 build/C/man3/sqrt.3:104 build/C/man3/y0.3:171
438 "I<errno> is set to B<EDOM>. An invalid floating-point exception "
439 "(B<FE_INVALID>) is raised."
443 #: build/C/man3/acos.3:114 build/C/man3/acosh.3:122 build/C/man3/asin.3:113 build/C/man3/asinh.3:107 build/C/man3/atan.3:98 build/C/man3/atan2.3:170 build/C/man3/atanh.3:141 build/C/man3/ceil.3:82 build/C/man3/exp.3:131 build/C/man3/exp2.3:94 build/C/man3/fabs.3:90 build/C/man3/floor.3:81 build/C/man3/fmod.3:136 build/C/man3/frexp.3:102 build/C/man3/ldexp.3:133 build/C/man3/log.3:131 build/C/man3/log10.3:92 build/C/man3/modf.3:94 build/C/man3/pow.3:317 build/C/man3/sin.3:108 build/C/man3/sinh.3:126 build/C/man3/sqrt.3:110 build/C/man3/tan.3:133 build/C/man3/tanh.3:102
445 "C99, POSIX.1-2001. The variant returning I<double> also conforms to SVr4, "
450 #: build/C/man3/acos.3:122
452 "B<asin>(3), B<atan>(3), B<atan2>(3), B<cacos>(3), B<cos>(3), B<sin>(3), "
457 #: build/C/man3/acosh.3:33
463 #: build/C/man3/acosh.3:36
464 msgid "acosh, acoshf, acoshl - inverse hyperbolic cosine function"
468 #: build/C/man3/acosh.3:41
470 msgid "B<double acosh(double >I<x>B<);>\n"
474 #: build/C/man3/acosh.3:43
476 msgid "B<float acoshf(float >I<x>B<);>\n"
480 #: build/C/man3/acosh.3:45
482 msgid "B<long double acoshl(long double >I<x>B<);>\n"
486 #: build/C/man3/acosh.3:56
491 #: build/C/man3/acosh.3:60 build/C/man3/asinh.3:60 build/C/man3/atanh.3:60 build/C/man3/cbrt.3:56 build/C/man3/expm1.3:55 build/C/man3/ilogb.3:53 build/C/man3/log1p.3:54 build/C/man3/logb.3:52 build/C/man3/nextafter.3:39 build/C/man3/rint.3:69
493 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 500 || "
494 "_XOPEN_SOURCE\\ &&\\ _XOPEN_SOURCE_EXTENDED || _ISOC99_SOURCE || "
495 "_POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
499 #: build/C/man3/acosh.3:67
500 msgid "B<acoshf>(), B<acoshl>():"
504 #: build/C/man3/acosh.3:80
506 "The B<acosh>() function calculates the inverse hyperbolic cosine of I<x>; "
507 "that is the value whose hyperbolic cosine is I<x>."
511 #: build/C/man3/acosh.3:83
512 msgid "On success, these functions return the inverse hyperbolic cosine of I<x>."
516 #: build/C/man3/acosh.3:95 build/C/man3/exp.3:84 build/C/man3/expm1.3:101 build/C/man3/log.3:87 build/C/man3/log1p.3:91 build/C/man3/sqrt.3:83 build/C/man3/tgamma.3:68
517 msgid "If I<x> is positive infinity, positive infinity is returned."
521 #: build/C/man3/acosh.3:101
523 "If I<x> is less than 1, a domain error occurs, and the functions return a "
528 #: build/C/man3/acosh.3:108
530 msgid "Domain error: I<x> is less than 1"
534 #: build/C/man3/acosh.3:129
535 msgid "B<asinh>(3), B<atanh>(3), B<cacosh>(3), B<cosh>(3), B<sinh>(3), B<tanh>(3)"
539 #: build/C/man3/asin.3:33
545 #: build/C/man3/asin.3:36
546 msgid "asin, asinf, asinl - arc sine function"
550 #: build/C/man3/asin.3:41
552 msgid "B<double asin(double >I<x>B<);>\n"
556 #: build/C/man3/asin.3:43
558 msgid "B<float asinf(float >I<x>B<);>\n"
562 #: build/C/man3/asin.3:45
564 msgid "B<long double asinl(long double >I<x>B<);>\n"
568 #: build/C/man3/asin.3:57
569 msgid "B<asinf>(), B<asinl>():"
573 #: build/C/man3/asin.3:70
575 "The B<asin>() function calculates the principal value of the arc sine of "
576 "I<x>; that is the value whose sine is I<x>."
580 #: build/C/man3/asin.3:74
582 "On success, these functions return the principal value of the arc sine of "
583 "I<x> in radians; the return value is in the range [-pi/2,\\ pi/2]."
587 #: build/C/man3/asin.3:83 build/C/man3/asinh.3:91 build/C/man3/atan.3:83 build/C/man3/atanh.3:91 build/C/man3/erf.3:91 build/C/man3/expm1.3:97 build/C/man3/scalbln.3:108 build/C/man3/sinh.3:86 build/C/man3/sqrt.3:79 build/C/man3/tanh.3:85
588 msgid "If I<x> is +0 (-0), +0 (-0) is returned."
592 #: build/C/man3/asin.3:121
594 "B<acos>(3), B<atan>(3), B<atan2>(3), B<casin>(3), B<cos>(3), B<sin>(3), "
599 #: build/C/man3/asinh.3:33
605 #: build/C/man3/asinh.3:36
606 msgid "asinh, asinhf, asinhl - inverse hyperbolic sine function"
610 #: build/C/man3/asinh.3:41
612 msgid "B<double asinh(double >I<x>B<);>\n"
616 #: build/C/man3/asinh.3:43
618 msgid "B<float asinhf(float >I<x>B<);>\n"
622 #: build/C/man3/asinh.3:45
624 msgid "B<long double asinhl(long double >I<x>B<);>\n"
628 #: build/C/man3/asinh.3:56
633 #: build/C/man3/asinh.3:67
634 msgid "B<asinhf>(), B<asinhl>():"
638 #: build/C/man3/asinh.3:80
640 "The B<asinh>() function calculates the inverse hyperbolic sine of I<x>; "
641 "that is the value whose hyperbolic sine is I<x>."
645 #: build/C/man3/asinh.3:83
646 msgid "On success, these functions return the inverse hyperbolic sine of I<x>."
650 #: build/C/man3/asinh.3:99 build/C/man3/ldexp.3:90 build/C/man3/scalbln.3:104 build/C/man3/sinh.3:91
652 "If I<x> is positive infinity (negative infinity), positive infinity "
653 "(negative infinity) is returned."
657 #: build/C/man3/asinh.3:101 build/C/man3/atan.3:92 build/C/man3/atan2.3:164 build/C/man3/cbrt.3:87 build/C/man3/copysign.3:83 build/C/man3/fabs.3:84 build/C/man3/fmax.3:53 build/C/man3/fmin.3:53 build/C/man3/frexp.3:96 build/C/man3/isgreater.3:87 build/C/man3/modf.3:88 build/C/man3/signbit.3:56 build/C/man3/tanh.3:96 build/C/man3/trunc.3:65
658 msgid "No errors occur."
662 #: build/C/man3/asinh.3:114
663 msgid "B<acosh>(3), B<atanh>(3), B<casinh>(3), B<cosh>(3), B<sinh>(3), B<tanh>(3)"
667 #: build/C/man3/atan.3:33
673 #: build/C/man3/atan.3:36
674 msgid "atan, atanf, atanl - arc tangent function"
678 #: build/C/man3/atan.3:41
680 msgid "B<double atan(double >I<x>B<);>\n"
684 #: build/C/man3/atan.3:43
686 msgid "B<float atanf(float >I<x>B<);>\n"
690 #: build/C/man3/atan.3:45
692 msgid "B<long double atanl( long double >I<x>B<);>\n"
696 #: build/C/man3/atan.3:57
697 msgid "B<atanf>(), B<atanl>():"
701 #: build/C/man3/atan.3:70
703 "The B<atan>() function calculates the principal value of the arc tangent of "
704 "I<x>; that is the value whose tangent is I<x>."
708 #: build/C/man3/atan.3:74
710 "On success, these functions return the principal value of the arc tangent of "
711 "I<x> in radians; the return value is in the range [-pi/2,\\ pi/2]."
715 #. POSIX.1-2001 documents an optional range error for subnormal x;
716 #. glibc 2.8 does not do this.
718 #: build/C/man3/atan.3:90
719 msgid "If I<x> is positive infinity (negative infinity), +pi/2 (-pi/2) is returned."
723 #: build/C/man3/atan.3:107
725 "B<acos>(3), B<asin>(3), B<atan2>(3), B<carg>(3), B<catan>(3), B<cos>(3), "
726 "B<sin>(3), B<tan>(3)"
730 #: build/C/man3/atan2.3:33
736 #: build/C/man3/atan2.3:36
737 msgid "atan2, atan2f, atan2l - arc tangent function of two variables"
741 #: build/C/man3/atan2.3:43
744 "B<double atan2(double >I<y>B<, double >I<x>B<);>\n"
745 "B<float atan2f(float >I<y>B<, float >I<x>B<);>\n"
746 "B<long double atan2l(long double >I<y>B<, long double >I<x>B<);>\n"
750 #: build/C/man3/atan2.3:55
751 msgid "B<atan2f>(), B<atan2l>():"
755 #: build/C/man3/atan2.3:70
757 "The B<atan2>() function calculates the principal value of the arc tangent "
758 "of I<y/x>, using the signs of the two arguments to determine the quadrant of "
763 #: build/C/man3/atan2.3:74
765 "On success, these functions return the principal value of the arc tangent of "
766 "I<y/x> in radians; the return value is in the range [-pi,\\ pi]."
770 #: build/C/man3/atan2.3:80
771 msgid "If I<y> is +0 (-0) and I<x> is less than 0, +pi (-pi) is returned."
775 #: build/C/man3/atan2.3:86
776 msgid "If I<y> is +0 (-0) and I<x> is greater than 0, +0 (-0) is returned."
780 #: build/C/man3/atan2.3:92
781 msgid "If I<y> is less than 0 and I<x> is +0 or -0, -pi/2 is returned."
785 #: build/C/man3/atan2.3:98
786 msgid "If I<y> is greater than 0 and I<x> is +0 or -0, pi/2 is returned."
792 #. is 0, a pole error shall not occur.
794 #: build/C/man3/atan2.3:109
795 msgid "If either I<x> or I<y> is NaN, a NaN is returned."
799 #. If the result underflows, a range error may occur and
801 #. should be returned.
803 #: build/C/man3/atan2.3:120
804 msgid "If I<y> is +0 (-0) and I<x> is -0, +pi (-pi) is returned."
808 #: build/C/man3/atan2.3:126
809 msgid "If I<y> is +0 (-0) and I<x> is +0, +0 (-0) is returned."
813 #: build/C/man3/atan2.3:132
815 "If I<y> is a finite value greater (less) than 0, and I<x> is negative "
816 "infinity, +pi (-pi) is returned."
820 #: build/C/man3/atan2.3:138
822 "If I<y> is a finite value greater (less) than 0, and I<x> is positive "
823 "infinity, +0 (-0) is returned."
827 #: build/C/man3/atan2.3:145
829 "If I<y> is positive infinity (negative infinity), and I<x> is finite, pi/2 "
830 "(-pi/2) is returned."
834 #: build/C/man3/atan2.3:151
836 "If I<y> is positive infinity (negative infinity) and I<x> is negative "
837 "infinity, +3*pi/4 (-3*pi/4) is returned."
842 #. If both arguments are 0, a domain error shall not occur.
844 #: build/C/man3/atan2.3:160
846 "If I<y> is positive infinity (negative infinity) and I<x> is positive "
847 "infinity, +pi/4 (-pi/4) is returned."
851 #: build/C/man3/atan2.3:178
853 "B<acos>(3), B<asin>(3), B<atan>(3), B<carg>(3), B<cos>(3), B<sin>(3), "
858 #: build/C/man3/atanh.3:33
864 #: build/C/man3/atanh.3:33 build/C/man3/cos.3:32 build/C/man3/lgamma.3:7 build/C/man3/sin.3:33 build/C/man3/tan.3:33
870 #: build/C/man3/atanh.3:36
871 msgid "atanh, atanhf, atanhl - inverse hyperbolic tangent function"
875 #: build/C/man3/atanh.3:41
877 msgid "B<double atanh(double >I<x>B<);>\n"
881 #: build/C/man3/atanh.3:43
883 msgid "B<float atanhf(float >I<x>B<);>\n"
887 #: build/C/man3/atanh.3:45
889 msgid "B<long double atanhl(long double >I<x>B<);>\n"
893 #: build/C/man3/atanh.3:56
898 #: build/C/man3/atanh.3:67
899 msgid "B<atanhf>(), B<atanhl>():"
903 #: build/C/man3/atanh.3:80
905 "The B<atanh>() function calculates the inverse hyperbolic tangent of I<x>; "
906 "that is the value whose hyperbolic tangent is I<x>."
910 #: build/C/man3/atanh.3:83
911 msgid "On success, these functions return the inverse hyperbolic tangent of I<x>."
915 #: build/C/man3/atanh.3:102
917 "If I<x> is +1 or -1, a pole error occurs, and the functions return "
918 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with the "
919 "mathematically correct sign."
923 #. POSIX.1-2001 documents an optional range error for subnormal x;
924 #. glibc 2.8 does not do this.
926 #: build/C/man3/atanh.3:111
928 "If the absolute value of I<x> is greater than 1, a domain error occurs, and "
933 #: build/C/man3/atanh.3:118
935 msgid "Domain error: I<x> less than -1 or greater than +1"
939 #: build/C/man3/atanh.3:126
941 msgid "Pole error: I<x> is +1 or -1"
945 #: build/C/man3/atanh.3:135 build/C/man3/lgamma.3:140 build/C/man3/pow.3:295
947 "I<errno> is set to B<ERANGE> (but see BUGS). A divide-by-zero "
948 "floating-point exception (B<FE_DIVBYZERO>) is raised."
952 #: build/C/man3/atanh.3:141 build/C/man3/cos.3:104 build/C/man3/cosh.3:121 build/C/man3/expm1.3:135 build/C/man3/fenv.3:311 build/C/man3/fmod.3:136 build/C/man3/j0.3:150 build/C/man3/lgamma.3:159 build/C/man3/log.3:131 build/C/man3/nextafter.3:167 build/C/man3/pow.3:317 build/C/man3/remainder.3:202 build/C/man3/sin.3:108 build/C/man3/tan.3:133 build/C/man3/tgamma.3:162 build/C/man3/y0.3:221
957 #. Bug: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6759
958 #. This can be seen in sysdeps/ieee754/k_standard.c
960 #: build/C/man3/atanh.3:152
962 "In glibc 2.9 and earlier, when a pole error occurs, I<errno> as set to "
963 "B<EDOM> instead of the POSIX-mandated B<ERANGE>. Since version 2.10, glibc "
964 "does the right thing."
968 #: build/C/man3/atanh.3:159
969 msgid "B<acosh>(3), B<asinh>(3), B<catanh>(3), B<cosh>(3), B<sinh>(3), B<tanh>(3)"
973 #: build/C/man3/cbrt.3:28
979 #: build/C/man3/cbrt.3:31
980 msgid "cbrt, cbrtf, cbrtl - cube root function"
984 #: build/C/man3/cbrt.3:36
986 msgid "B<double cbrt(double >I<x>B<);>\n"
990 #: build/C/man3/cbrt.3:38
992 msgid "B<float cbrtf(float >I<x>B<);>\n"
996 #: build/C/man3/cbrt.3:40
998 msgid "B<long double cbrtl(long double >I<x>B<);>\n"
1002 #: build/C/man3/cbrt.3:51
1007 #: build/C/man3/cbrt.3:62
1008 msgid "B<cbrtf>(), B<cbrtl>():"
1012 #: build/C/man3/cbrt.3:65
1014 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600 || "
1015 "_ISOC99_SOURCE || _POSIX_C_SOUCE\\ E<gt>=\\ 200112L;"
1019 #: build/C/man3/cbrt.3:76
1021 "The B<cbrt>() function returns the (real) cube root of I<x>. This function "
1022 "cannot fail; every representable real value has a representable real cube "
1027 #: build/C/man3/cbrt.3:79
1028 msgid "These functions return the cube root of I<x>."
1032 #: build/C/man3/cbrt.3:85
1034 "If I<x> is +0, -0, positive infinity, negative infinity, or NaN, I<x> is "
1039 #: build/C/man3/cbrt.3:91 build/C/man3/expm1.3:135 build/C/man3/fdim.3:80 build/C/man3/fma.3:154 build/C/man3/fmax.3:57 build/C/man3/fmin.3:57 build/C/man3/ilogb.3:146 build/C/man3/isgreater.3:89 build/C/man3/log1p.3:141 build/C/man3/logb.3:143 build/C/man3/lrint.3:109 build/C/man3/lround.3:112 build/C/man3/remquo.3:121 build/C/man3/rint.3:113 build/C/man3/round.3:83 build/C/man3/scalbln.3:155 build/C/man3/tgamma.3:155 build/C/man3/trunc.3:69
1040 msgid "C99, POSIX.1-2001."
1044 #: build/C/man3/cbrt.3:94
1045 msgid "B<pow>(3), B<sqrt>(3)"
1049 #: build/C/man3/ceil.3:25
1055 #: build/C/man3/ceil.3:29
1057 "ceil, ceilf, ceill - ceiling function: smallest integral value not less than "
1062 #: build/C/man3/ceil.3:34
1064 msgid "B<double ceil(double >I<x>B<);>\n"
1068 #: build/C/man3/ceil.3:36
1070 msgid "B<float ceilf(float >I<x>B<);>\n"
1074 #: build/C/man3/ceil.3:38
1076 msgid "B<long double ceill(long double >I<x>B<);>\n"
1080 #: build/C/man3/ceil.3:50
1081 msgid "B<ceilf>(), B<ceill>():"
1085 #: build/C/man3/ceil.3:61
1087 "These functions return the smallest integral value that is not less than "
1092 #: build/C/man3/ceil.3:67
1093 msgid "For example, I<ceil(0.5)> is 1.0, and I<ceil(-0.5)> is 0.0."
1097 #: build/C/man3/ceil.3:70
1098 msgid "These functions return the ceiling of I<x>."
1102 #: build/C/man3/ceil.3:73 build/C/man3/rint.3:108 build/C/man3/round.3:76
1103 msgid "If I<x> is integral, +0, -0, NaN, or infinite, I<x> itself is returned."
1107 #: build/C/man3/ceil.3:76 build/C/man3/floor.3:75 build/C/man3/rint.3:111 build/C/man3/round.3:79
1109 "No errors occur. POSIX.1-2001 documents a range error for overflows, but "
1114 #: build/C/man3/ceil.3:98 build/C/man3/floor.3:97 build/C/man3/rint.3:128
1116 "SUSv2 and POSIX.1-2001 contain text about overflow (which might set I<errno> "
1117 "to B<ERANGE>, or raise an B<FE_OVERFLOW> exception). In practice, the "
1118 "result cannot overflow on any current machine, so this error-handling stuff "
1119 "is just nonsense. (More precisely, overflow can happen only when the "
1120 "maximum value of the exponent is smaller than the number of mantissa bits. "
1121 "For the IEEE-754 standard 32-bit and 64-bit floating-point numbers the "
1122 "maximum value of the exponent is 128 (respectively, 1024), and the number of "
1123 "mantissa bits is 24 (respectively, 53).)"
1127 #: build/C/man3/ceil.3:107 build/C/man3/trunc.3:78
1129 "The integral value returned by these functions may be too large to store in "
1130 "an integer type (I<int>, I<long>, etc.). To avoid an overflow, which will "
1131 "produce undefined results, an application should perform a range check on "
1132 "the returned value before assigning it to an integer type."
1136 #: build/C/man3/ceil.3:114
1138 "B<floor>(3), B<lrint>(3), B<nearbyint>(3), B<rint>(3), B<round>(3), "
1143 #: build/C/man3/copysign.3:29
1149 #: build/C/man3/copysign.3:29
1155 #: build/C/man3/copysign.3:32
1156 msgid "copysign, copysignf, copysignl - copy sign of a number"
1160 #: build/C/man3/copysign.3:37
1162 msgid "B<double copysign(double >I<x>B<, double >I<y>B<);>\n"
1166 #: build/C/man3/copysign.3:39
1168 msgid "B<float copysignf(float >I<x>B<, float >I<y>B<);>\n"
1172 #: build/C/man3/copysign.3:41
1174 msgid "B<long double copysignl(long double >I<x>B<, long double >I<y>B<);>\n"
1178 #: build/C/man3/copysign.3:54
1179 msgid "B<copysign>(), B<copysignf>(), B<copysignl>():"
1183 #: build/C/man3/copysign.3:57
1185 "_SVID_SOURCE || _BSD_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600 || "
1186 "_ISOC99_SOURCE || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
1190 #: build/C/man3/copysign.3:67
1192 "The B<copysign>() functions return a value whose absolute value matches "
1193 "that of I<x>, but whose sign bit matches that of I<y>."
1197 #: build/C/man3/copysign.3:73
1199 "For example, I<copysign(42.0,\\ -1.0)> and I<copysign(-42.0, -1.0)> both "
1204 #: build/C/man3/copysign.3:78
1206 "On success, these functions return a value whose magnitude is taken from "
1207 "I<x> and whose sign is taken from I<y>."
1211 #: build/C/man3/copysign.3:81
1212 msgid "If I<x> is a NaN, a NaN with the sign bit of I<y> is returned."
1216 #: build/C/man3/copysign.3:88 build/C/man3/nextafter.3:167 build/C/man3/signbit.3:60
1218 "C99, POSIX.1-2001. This function is defined in IEC 559 (and the appendix "
1219 "with recommended functions in IEEE 754/IEEE 854)."
1223 #: build/C/man3/copysign.3:93
1225 "On architectures where the floating-point formats are not IEEE 754 "
1226 "compliant, the B<copysign>() functions may treat a negative zero as "
1231 #: build/C/man3/copysign.3:95
1232 msgid "B<signbit>(3)"
1236 #: build/C/man3/cos.3:32
1242 #: build/C/man3/cos.3:35
1243 msgid "cos, cosf, cosl - cosine function"
1247 #: build/C/man3/cos.3:40
1249 msgid "B<double cos(double >I<x>B<);>\n"
1253 #: build/C/man3/cos.3:42
1255 msgid "B<float cosf(float >I<x>B<);>\n"
1259 #: build/C/man3/cos.3:44
1261 msgid "B<long double cosl(long double >I<x>B<);>\n"
1265 #: build/C/man3/cos.3:56
1266 msgid "B<cosf>(), B<cosl>():"
1270 #: build/C/man3/cos.3:69
1272 "The B<cos>() function returns the cosine of I<x>, where I<x> is given in "
1277 #: build/C/man3/cos.3:72
1278 msgid "On success, these functions return the cosine of I<x>."
1282 #: build/C/man3/cos.3:89 build/C/man3/fmod.3:111 build/C/man3/ilogb.3:128 build/C/man3/sin.3:93 build/C/man3/sincos.3:56 build/C/man3/tan.3:108
1284 msgid "Domain error: I<x> is an infinity"
1288 #: build/C/man3/cos.3:98 build/C/man3/fmod.3:120 build/C/man3/sin.3:102 build/C/man3/tan.3:117
1290 "I<errno> is set to B<EDOM> (but see BUGS). An invalid floating-point "
1291 "exception (B<FE_INVALID>) is raised."
1295 #: build/C/man3/cos.3:104 build/C/man3/cosh.3:121 build/C/man3/erf.3:128 build/C/man3/erfc.3:126 build/C/man3/hypot.3:162 build/C/man3/log2.3:94
1297 "C99, POSIX.1-2001. The variant returning I<double> also conforms to SVr4, "
1301 #. http://sourceware.org/bugzilla/show_bug.cgi?id=6782
1303 #: build/C/man3/cos.3:111 build/C/man3/sin.3:115 build/C/man3/tan.3:140
1305 "Before version 2.10, the glibc implementation did not set I<errno> to "
1306 "B<EDOM> when a domain error occurred."
1310 #: build/C/man3/cos.3:120
1312 "B<acos>(3), B<asin>(3), B<atan>(3), B<atan2>(3), B<ccos>(3), B<sin>(3), "
1313 "B<sincos>(3), B<tan>(3)"
1317 #: build/C/man3/cosh.3:34
1323 #: build/C/man3/cosh.3:37
1324 msgid "cosh, coshf, coshl - hyperbolic cosine function"
1328 #: build/C/man3/cosh.3:42
1330 msgid "B<double cosh(double >I<x>B<);>\n"
1334 #: build/C/man3/cosh.3:44
1336 msgid "B<float coshf(float >I<x>B<);>\n"
1340 #: build/C/man3/cosh.3:46
1342 msgid "B<long double coshl(long double >I<x>B<);>\n"
1346 #: build/C/man3/cosh.3:58
1347 msgid "B<coshf>(), B<coshl>():"
1351 #: build/C/man3/cosh.3:71
1353 "The B<cosh>() function returns the hyperbolic cosine of I<x>, which is "
1354 "defined mathematically as:"
1358 #: build/C/man3/cosh.3:74
1360 msgid " cosh(x) = (exp(x) + exp(-x)) / 2\n"
1364 #: build/C/man3/cosh.3:78
1365 msgid "On success, these functions return the hyperbolic cosine of I<x>."
1369 #: build/C/man3/cosh.3:86 build/C/man3/erfc.3:81
1370 msgid "If I<x> is +0 or -0, 1 is returned."
1374 #: build/C/man3/cosh.3:91 build/C/man3/lgamma.3:103
1376 "If I<x> is positive infinity or negative infinity, positive infinity is "
1381 #: build/C/man3/cosh.3:100 build/C/man3/exp.3:102
1383 "If the result overflows, a range error occurs, and the functions return "
1384 "+B<HUGE_VAL>, +B<HUGE_VALF>, or +B<HUGE_VALL>, respectively."
1388 #: build/C/man3/cosh.3:107 build/C/man3/fdim.3:63 build/C/man3/fma.3:129 build/C/man3/hypot.3:133 build/C/man3/lgamma.3:140 build/C/man3/nextafter.3:140 build/C/man3/sinh.3:112 build/C/man3/tan.3:117 build/C/man3/tgamma.3:123 build/C/man3/y0.3:202
1390 msgid "Range error: result overflow"
1394 #: build/C/man3/cosh.3:115 build/C/man3/exp.3:117 build/C/man3/hypot.3:141 build/C/man3/ldexp.3:119 build/C/man3/lgamma.3:150 build/C/man3/pow.3:303 build/C/man3/sinh.3:120 build/C/man3/tgamma.3:131
1396 "I<errno> is set to B<ERANGE>. An overflow floating-point exception "
1397 "(B<FE_OVERFLOW>) is raised."
1401 #: build/C/man3/cosh.3:126
1403 "In glibc version 2.3.4 and earlier, an overflow floating-point "
1404 "(B<FE_OVERFLOW>) exception is not raised when an overflow occurs."
1408 #: build/C/man3/cosh.3:133
1409 msgid "B<acosh>(3), B<asinh>(3), B<atanh>(3), B<ccos>(3), B<sinh>(3), B<tanh>(3)"
1413 #: build/C/man3/div.3:32
1419 #: build/C/man3/div.3:32
1425 #: build/C/man3/div.3:36
1427 "div, ldiv, lldiv, imaxdiv - compute quotient and remainder of an integer "
1432 #: build/C/man3/div.3:41
1434 msgid "B<div_t div(int >I<numerator>B<, int >I<denominator>B<);>\n"
1438 #: build/C/man3/div.3:43
1440 msgid "B<ldiv_t ldiv(long >I<numerator>B<, long >I<denominator>B<);>\n"
1444 #: build/C/man3/div.3:45
1446 msgid "B<lldiv_t lldiv(long long >I<numerator>B<, long long >I<denominator>B<);>\n"
1450 #: build/C/man3/div.3:49
1453 "B<imaxdiv_t imaxdiv(intmax_t >I<numerator>B<, intmax_t "
1454 ">I<denominator>B<);>\n"
1458 #: build/C/man3/div.3:58
1463 #: build/C/man3/div.3:76
1465 "The B<div>() function computes the value I<numerator>/I<denominator> and "
1466 "returns the quotient and remainder in a structure named I<div_t> that "
1467 "contains two integer members (in unspecified order) named I<quot> and "
1468 "I<rem>. The quotient is rounded toward zero. The result satisfies "
1469 "I<quot>*I<denominator>+I<rem> = I<numerator>."
1473 #: build/C/man3/div.3:87
1475 "The B<ldiv>(), B<lldiv>(), and B<imaxdiv>() functions do the same, dividing "
1476 "numbers of the indicated type and returning the result in a structure of the "
1477 "indicated name, in all cases with fields I<quot> and I<rem> of the same type "
1478 "as the function arguments."
1482 #: build/C/man3/div.3:89
1483 msgid "The I<div_t> (etc.) structure."
1487 #: build/C/man3/div.3:96
1489 "SVr4, 4.3BSD, C89. C99. The functions B<lldiv>() and B<imaxdiv>() were "
1494 #: build/C/man3/div.3:96 build/C/man3/frexp.3:102 build/C/man3/matherr.3:273 build/C/man3/remainder.3:211
1500 #: build/C/man3/div.3:98
1505 #: build/C/man3/div.3:101
1507 msgid " div_t q = div(-5, 3);\n"
1511 #: build/C/man3/div.3:104
1512 msgid "the values I<q.quot> and I<q.rem> are -1 and -2, respectively."
1516 #: build/C/man3/div.3:107
1517 msgid "B<abs>(3), B<remainder>(3)"
1521 #: build/C/man3/erf.3:33
1527 #: build/C/man3/erf.3:36
1528 msgid "erf, erff, erfl, - error function"
1532 #: build/C/man3/erf.3:43
1535 "B<double erf(double >I<x>B<);>\n"
1536 "B<float erff(float >I<x>B<);>\n"
1537 "B<long double erfl(long double >I<x>B<);>\n"
1541 #: build/C/man3/erf.3:54
1546 #: build/C/man3/erf.3:57 build/C/man3/erfc.3:48 build/C/man3/fpclassify.3:49 build/C/man3/hypot.3:57 build/C/man3/lgamma.3:42
1548 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE || _ISOC99_SOURCE || "
1549 "_POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
1553 #: build/C/man3/erf.3:64
1554 msgid "B<erff>(), B<erfl>():"
1558 #: build/C/man3/erf.3:77
1559 msgid "The B<erf>() function returns the error function of I<x>, defined as"
1563 #: build/C/man3/erf.3:77
1565 msgid " erf(x) = 2/sqrt(pi)* integral from 0 to x of exp(-t*t) dt"
1569 #: build/C/man3/erf.3:83
1571 "On success, these functions return the error function of I<x>, a value in "
1572 "the range [-1,\\ 1]."
1576 #. POSIX.1-2001 documents an optional range error (underflow)
1578 #. glibc 2.8 does not do this.
1580 #: build/C/man3/erf.3:96 build/C/man3/tanh.3:94
1581 msgid "If I<x> is positive infinity (negative infinity), +1 (-1) is returned."
1585 #: build/C/man3/erf.3:102
1587 "If I<x> is subnormal, a range error occurs, and the return value is "
1592 #: build/C/man3/erf.3:109
1594 msgid "Range error: result underflow (I<x> is subnormal)"
1597 #. e.g., tgamma(-172.5) on glibc 2.8/x86-32
1602 #: build/C/man3/erf.3:117 build/C/man3/erfc.3:115 build/C/man3/fma.3:145 build/C/man3/hypot.3:149 build/C/man3/nextafter.3:158 build/C/man3/scalb.3:164 build/C/man3/scalbln.3:146 build/C/man3/tgamma.3:143
1603 msgid "An underflow floating-point exception (B<FE_UNDERFLOW>) is raised."
1606 #. FIXME . Is it intentional that these functions do not set errno?
1607 #. sin() and cos() also don't set errno; bugs have been raised for
1610 #: build/C/man3/erf.3:122 build/C/man3/erfc.3:120 build/C/man3/fdim.3:76 build/C/man3/fma.3:150 build/C/man3/log1p.3:138 build/C/man3/logb.3:141 build/C/man3/lrint.3:105 build/C/man3/lround.3:108 build/C/man3/nextafter.3:163 build/C/man3/remquo.3:117 build/C/man3/scalb.3:170 build/C/man3/scalbln.3:151 build/C/man3/sincos.3:70
1611 msgid "These functions do not set I<errno>."
1615 #: build/C/man3/erf.3:132
1616 msgid "B<cerf>(3), B<erfc>(3), B<exp>(3)"
1620 #: build/C/man3/erfc.3:24
1626 #: build/C/man3/erfc.3:27
1627 msgid "erfc, erfcf, erfcl - complementary error function"
1631 #: build/C/man3/erfc.3:34
1634 "B<double erfc(double >I<x>B<);>\n"
1635 "B<float erfcf(float >I<x>B<);>\n"
1636 "B<long double erfcl(long double >I<x>B<);>\n"
1640 #: build/C/man3/erfc.3:45
1645 #: build/C/man3/erfc.3:55
1646 msgid "B<erfcf>(), B<erfcl>():"
1650 #: build/C/man3/erfc.3:58
1652 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600|| _ISOC99_SOURCE "
1653 "|| _POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
1657 #: build/C/man3/erfc.3:69
1659 "The B<erfc>() function returns the complementary error function of I<x>, "
1660 "that is, 1.0 - erf(x)."
1664 #: build/C/man3/erfc.3:73
1666 "On success, these functions return the complementary error function of I<x>, "
1667 "a value in the range [0,2]."
1671 #: build/C/man3/erfc.3:86
1672 msgid "If I<x> is positive infinity, +0 is returned."
1676 #: build/C/man3/erfc.3:91
1677 msgid "If I<x> is negative infinity, +2 is returned."
1681 #: build/C/man3/erfc.3:94
1683 "If the function result underflows and produces an unrepresentable value, the "
1684 "return value is 0.0."
1687 #. e.g., erfc(27) on x86-32
1689 #: build/C/man3/erfc.3:100
1691 "If the function result underflows but produces a representable (i.e., "
1692 "subnormal) value, that value is returned, and a range error occurs."
1696 #: build/C/man3/erfc.3:107
1698 msgid "Range error: result underflow (result is subnormal)"
1702 #: build/C/man3/erfc.3:133
1704 "The B<erfc>() functions are provided to avoid the loss accuracy that would "
1705 "occur for the calculation 1-erf(x) for large values of I<x> (for which the "
1706 "value of erf(x) approaches 1)."
1710 #: build/C/man3/erfc.3:137
1711 msgid "B<cerf>(3), B<erf>(3), B<exp>(3)"
1715 #: build/C/man3/exp.3:34
1721 #: build/C/man3/exp.3:37
1722 msgid "exp, expf, expl - base-e exponential function"
1726 #: build/C/man3/exp.3:42
1728 msgid "B<double exp(double >I<x>B<);>\n"
1732 #: build/C/man3/exp.3:44
1734 msgid "B<float expf(float >I<x>B<);>\n"
1738 #: build/C/man3/exp.3:46
1740 msgid "B<long double expl(long double >I<x>B<);>\n"
1744 #: build/C/man3/exp.3:58
1745 msgid "B<expf>(), B<expl>():"
1749 #: build/C/man3/exp.3:71
1751 "The B<exp>() function returns the value of e (the base of natural "
1752 "logarithms) raised to the power of I<x>."
1756 #: build/C/man3/exp.3:74
1757 msgid "On success, these functions return the exponential value of I<x>."
1761 #: build/C/man3/exp.3:89
1762 msgid "If I<x> is negative infinity, +0 is returned."
1766 #: build/C/man3/exp.3:93 build/C/man3/ldexp.3:94
1767 msgid "If the result underflows, a range error occurs, and zero is returned."
1771 #: build/C/man3/exp.3:109 build/C/man3/expm1.3:120 build/C/man3/ldexp.3:111 build/C/man3/scalb.3:148 build/C/man3/scalbln.3:130
1773 msgid "Range error, overflow"
1777 #: build/C/man3/exp.3:117 build/C/man3/ldexp.3:119 build/C/man3/scalb.3:156 build/C/man3/scalbln.3:138
1779 msgid "Range error, underflow"
1783 #: build/C/man3/exp.3:125 build/C/man3/ldexp.3:127 build/C/man3/pow.3:311
1785 "I<errno> is set to B<ERANGE>. An underflow floating-point exception "
1786 "(B<FE_UNDERFLOW>) is raised."
1790 #: build/C/man3/exp.3:137
1791 msgid "B<cbrt>(3), B<cexp>(3), B<exp10>(3), B<exp2>(3), B<sqrt>(3)"
1795 #: build/C/man3/exp10.3:33
1801 #: build/C/man3/exp10.3:33 build/C/man7/math_error.7:24 build/C/man3/pow10.3:23 build/C/man3/sincos.3:6
1807 #: build/C/man3/exp10.3:36
1808 msgid "exp10, exp10f, exp10l - base-10 exponential function"
1812 #: build/C/man3/exp10.3:39 build/C/man3/fenv.3:289
1814 msgid "B<#define _GNU_SOURCE> /* See feature_test_macros(7) */\n"
1818 #: build/C/man3/exp10.3:43
1820 msgid "B<double exp10(double >I<x>B<);>\n"
1824 #: build/C/man3/exp10.3:45
1826 msgid "B<float exp10f(float >I<x>B<);>\n"
1830 #: build/C/man3/exp10.3:47
1832 msgid "B<long double exp10l(long double >I<x>B<);>\n"
1836 #: build/C/man3/exp10.3:55
1838 "The B<exp10>() function returns the value of 10 raised to the power of "
1843 #: build/C/man3/exp10.3:58
1844 msgid "On success, these functions return the base-10 exponential value of I<x>."
1848 #: build/C/man3/exp10.3:62 build/C/man3/exp2.3:78
1850 "For various special cases, including the handling of infinity and NaN, as "
1851 "well as overflows and underflows, see B<exp>(3)."
1855 #: build/C/man3/exp10.3:72 build/C/man3/exp2.3:86
1857 "For a discussion of the errors that can occur for these functions, see "
1862 #: build/C/man3/exp10.3:72 build/C/man3/exp2.3:86 build/C/man3/fdim.3:76 build/C/man3/fenv.3:262 build/C/man3/fma.3:150 build/C/man3/fmax.3:53 build/C/man3/fmin.3:53 build/C/man3/log2.3:86 build/C/man3/lrint.3:105 build/C/man3/lround.3:108 build/C/man3/nan.3:68 build/C/man3/pow10.3:44 build/C/man3/remquo.3:117 build/C/man3/round.3:79 build/C/man3/scalbln.3:151 build/C/man3/sincos.3:70 build/C/man3/tgamma.3:151 build/C/man3/trunc.3:65
1868 #: build/C/man3/exp10.3:74 build/C/man3/exp2.3:88 build/C/man3/fdim.3:78 build/C/man3/fenv.3:264 build/C/man3/fma.3:152 build/C/man3/fmax.3:55 build/C/man3/fmin.3:55 build/C/man3/log2.3:88 build/C/man3/lrint.3:107 build/C/man3/lround.3:110 build/C/man3/nan.3:70 build/C/man3/pow10.3:46 build/C/man3/remquo.3:119 build/C/man3/round.3:81 build/C/man3/scalbln.3:153 build/C/man3/sincos.3:72 build/C/man3/tgamma.3:153 build/C/man3/trunc.3:67
1869 msgid "These functions first appeared in glibc in version 2.1."
1873 #: build/C/man3/exp10.3:76
1874 msgid "These functions are GNU extensions."
1878 #: build/C/man3/exp10.3:82
1879 msgid "B<cbrt>(3), B<exp>(3), B<exp2>(3), B<log10>(3), B<sqrt>(3)"
1883 #: build/C/man3/exp2.3:34
1889 #: build/C/man3/exp2.3:37
1890 msgid "exp2, exp2f, exp2l - base-2 exponential function"
1894 #: build/C/man3/exp2.3:42
1896 msgid "B<double exp2(double >I<x>B<);>\n"
1900 #: build/C/man3/exp2.3:44
1902 msgid "B<float exp2f(float >I<x>B<);>\n"
1906 #: build/C/man3/exp2.3:46
1908 msgid "B<long double exp2l(long double >I<x>B<);>\n"
1912 #: build/C/man3/exp2.3:59
1913 msgid "B<exp2>(), B<exp2f>(), B<exp2l>():"
1917 #: build/C/man3/exp2.3:71
1918 msgid "The B<exp2>() function returns the value of 2 raised to the power of I<x>."
1922 #: build/C/man3/exp2.3:74
1923 msgid "On success, these functions return the base-2 exponential value of I<x>."
1927 #: build/C/man3/exp2.3:100
1928 msgid "B<cbrt>(3), B<cexp2>(3), B<exp>(3), B<exp10>(3), B<sqrt>(3)"
1932 #: build/C/man3/expm1.3:28
1938 #: build/C/man3/expm1.3:28 build/C/man3/log2.3:34 build/C/man3/pow.3:33
1944 #: build/C/man3/expm1.3:31
1945 msgid "expm1, expm1f, expm1l - exponential minus 1"
1949 #: build/C/man3/expm1.3:36
1951 msgid "B<double expm1(double >I<x>B<);>\n"
1955 #: build/C/man3/expm1.3:38
1957 msgid "B<float expm1f(float >I<x>B<);>\n"
1961 #: build/C/man3/expm1.3:40
1963 msgid "B<long double expm1l(long double >I<x>B<);>\n"
1967 #: build/C/man3/expm1.3:51
1972 #: build/C/man3/expm1.3:62
1973 msgid "B<expm1f>(), B<expm1l>():"
1977 #: build/C/man3/expm1.3:73
1978 msgid "I<expm1(x)> returns a value equivalent to"
1982 #: build/C/man3/expm1.3:76
1984 msgid " exp(x) - 1\n"
1988 #: build/C/man3/expm1.3:84
1990 "It is computed in a way that is accurate even if the value of I<x> is near "
1991 "zero\\(ema case where I<exp(x) - 1> would be inaccurate due to subtraction "
1992 "of two numbers that are nearly equal."
1996 #: build/C/man3/expm1.3:87
1997 msgid "On success, these functions return I<exp(x)\\ -\\ 1>."
2001 #: build/C/man3/expm1.3:105
2002 msgid "If I<x> is negative infinity, -1 is returned."
2006 #: build/C/man3/expm1.3:113
2008 "If the result overflows, a range error occurs, and the functions return "
2009 "-B<HUGE_VAL>, -B<HUGE_VALF>, or -B<HUGE_VALL>, respectively."
2013 #. POSIX.1 specifies an optional range error (underflow) if
2014 #. x is subnormal. Glibc does not implement this.
2016 #: build/C/man3/expm1.3:132
2018 "I<errno> is set to B<ERANGE> (but see BUGS). An overflow floating-point "
2019 "exception (B<FE_OVERFLOW>) is raised."
2023 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6778
2025 #: build/C/man3/expm1.3:143
2027 "For some large negative I<x> values (where the function result approaches "
2028 "-1), B<expm1>() raises a bogus underflow floating-point exception."
2032 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6814
2033 #. e.g., expm1(1e5) through expm1(1.00199970127e5),
2034 #. but not expm1(1.00199970128e5) and beyond.
2036 #: build/C/man3/expm1.3:154
2038 "For some large positive I<x> values, B<expm1>() raises a bogus invalid "
2039 "floating-point exception in addition to the expected overflow exception, and "
2040 "returns a NaN instead of positive infinity."
2043 #. It looks like the fix was in 2.11, or possibly 2.12.
2044 #. I have no test system for 2.11, but 2.12 passes.
2045 #. From the source (sysdeps/i386/fpu/s_expm1.S) it looks
2046 #. like the changes were in 2.11.
2047 #. http://sources.redhat.com/bugzilla/show_bug.cgi?id=6788
2049 #: build/C/man3/expm1.3:166
2051 "Before version 2.11, the glibc implementation did not set I<errno> to "
2052 "B<ERANGE> when a range error occurred."
2056 #: build/C/man3/expm1.3:170
2057 msgid "B<exp>(3), B<log>(3), B<log1p>(3)"
2061 #: build/C/man3/fabs.3:30
2067 #: build/C/man3/fabs.3:33
2068 msgid "fabs, fabsf, fabsl - absolute value of floating-point number"
2072 #: build/C/man3/fabs.3:38
2074 msgid "B<double fabs(double >I<x>B<);>\n"
2078 #: build/C/man3/fabs.3:40
2080 msgid "B<float fabsf(float >I<x>B<);>\n"
2084 #: build/C/man3/fabs.3:42
2086 msgid "B<long double fabsl(long double >I<x>B<);>\n"
2090 #: build/C/man3/fabs.3:54
2091 msgid "B<fabsf>(), B<fabsl>():"
2095 #: build/C/man3/fabs.3:67
2097 "The B<fabs>() functions return the absolute value of the floating-point "
2102 #: build/C/man3/fabs.3:70
2103 msgid "These functions return the absolute value of I<x>."
2107 #: build/C/man3/fabs.3:78
2108 msgid "If I<x> is -0, +0 is returned."
2112 #: build/C/man3/fabs.3:82
2114 "If I<x> is negative infinity or positive infinity, positive infinity is "
2119 #: build/C/man3/fabs.3:97
2120 msgid "B<abs>(3), B<cabs>(3), B<ceil>(3), B<floor>(3), B<labs>(3), B<rint>(3)"
2124 #: build/C/man3/fdim.3:6
2130 #: build/C/man3/fdim.3:9
2131 msgid "fdim, fdimf, fdiml - positive difference"
2135 #: build/C/man3/fdim.3:11 build/C/man3/fmax.3:11 build/C/man3/fmin.3:11 build/C/man3/gamma.3:11 build/C/man3/ilogb.3:32 build/C/man3/logb.3:32 build/C/man3/nan.3:11 build/C/man3/nextafter.3:12 build/C/man3/scalb.3:31 build/C/man3/scalbln.3:31 build/C/man3/signbit.3:11 build/C/man3/significand.3:10 build/C/man3/tgamma.3:13
2136 msgid "B<#include E<lt>math.hE<gt>>"
2140 #: build/C/man3/fdim.3:13
2141 msgid "B<double fdim(double >I<x>B<, double >I<y>B<);>"
2145 #: build/C/man3/fdim.3:15
2146 msgid "B<float fdimf(float >I<x>B<, float >I<y>B<);>"
2150 #: build/C/man3/fdim.3:17
2151 msgid "B<long double fdiml(long double >I<x>B<, long double >I<y>B<);>"
2155 #: build/C/man3/fdim.3:28
2156 msgid "B<fdimf>(), B<fdiml>():"
2160 #: build/C/man3/fdim.3:39
2162 "These functions return the positive difference, max(I<x>-I<y>,0), between "
2167 #: build/C/man3/fdim.3:41
2168 msgid "On success, these functions return the positive difference."
2172 #: build/C/man3/fdim.3:47 build/C/man3/fma.3:59 build/C/man3/fmod.3:86 build/C/man3/nextafter.3:111 build/C/man3/remainder.3:128 build/C/man3/remquo.3:78
2173 msgid "If I<x> or I<y> is a NaN, a NaN is returned."
2177 #: build/C/man3/fdim.3:56 build/C/man3/hypot.3:120
2179 "If the result overflows, a range error occurs, and the functions return "
2180 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively."
2183 #. Unable to test this case, since the best approximation of
2184 #. pi/2 in double precision only yields a tan() value of 1.633e16.
2189 #: build/C/man3/fdim.3:71 build/C/man3/fma.3:137 build/C/man3/nextafter.3:149 build/C/man3/scalb.3:156 build/C/man3/scalbln.3:138 build/C/man3/tan.3:127
2190 msgid "An overflow floating-point exception (B<FE_OVERFLOW>) is raised."
2194 #: build/C/man3/fdim.3:82 build/C/man3/fmin.3:59
2199 #: build/C/man3/fenv.3:26
2205 #: build/C/man3/fenv.3:26
2211 #: build/C/man3/fenv.3:26 build/C/man7/math_error.7:24 build/C/man3/matherr.3:25
2217 #: build/C/man3/fenv.3:32
2219 "feclearexcept, fegetexceptflag, feraiseexcept, fesetexceptflag, "
2220 "fetestexcept, fegetenv, fegetround, feholdexcept, fesetround, fesetenv, "
2221 "feupdateenv, feenableexcept, fedisableexcept, fegetexcept - floating-point "
2222 "rounding and exception handling"
2226 #: build/C/man3/fenv.3:35 build/C/man3/fenv.3:291
2228 msgid "B<#include E<lt>fenv.hE<gt>>\n"
2232 #: build/C/man3/fenv.3:37
2234 msgid "B<int feclearexcept(int >I<excepts>B<);>\n"
2238 #: build/C/man3/fenv.3:39
2240 msgid "B<int fegetexceptflag(fexcept_t *>I<flagp>B<, int >I<excepts>B<);>\n"
2244 #: build/C/man3/fenv.3:41
2246 msgid "B<int feraiseexcept(int >I<excepts>B<);>\n"
2250 #: build/C/man3/fenv.3:43
2252 msgid "B<int fesetexceptflag(const fexcept_t *>I<flagp>B<, int >I<excepts>B<);>\n"
2256 #: build/C/man3/fenv.3:45
2258 msgid "B<int fetestexcept(int >I<excepts>B<);>\n"
2262 #: build/C/man3/fenv.3:47
2264 msgid "B<int fegetround(void);>\n"
2268 #: build/C/man3/fenv.3:49
2270 msgid "B<int fesetround(int >I<rounding_mode>B<);>\n"
2274 #: build/C/man3/fenv.3:51
2276 msgid "B<int fegetenv(fenv_t *>I<envp>B<);>\n"
2280 #: build/C/man3/fenv.3:53
2282 msgid "B<int feholdexcept(fenv_t *>I<envp>B<);>\n"
2286 #: build/C/man3/fenv.3:55
2288 msgid "B<int fesetenv(const fenv_t *>I<envp>B<);>\n"
2292 #: build/C/man3/fenv.3:57
2294 msgid "B<int feupdateenv(const fenv_t *>I<envp>B<);>\n"
2298 #: build/C/man3/fenv.3:63
2300 "These eleven functions were defined in C99, and describe the handling of "
2301 "floating-point rounding and exceptions (overflow, zero-divide etc.)."
2305 #: build/C/man3/fenv.3:63
2311 #: build/C/man3/fenv.3:68
2313 "The I<divide-by-zero> exception occurs when an operation on finite numbers "
2314 "produces infinity as exact answer."
2318 #: build/C/man3/fenv.3:74
2320 "The I<overflow> exception occurs when a result has to be represented as a "
2321 "floating-point number, but has (much) larger absolute value than the largest "
2322 "(finite) floating-point number that is representable."
2326 #: build/C/man3/fenv.3:81
2328 "The I<underflow> exception occurs when a result has to be represented as a "
2329 "floating-point number, but has smaller absolute value than the smallest "
2330 "positive normalized floating-point number (and would lose much accuracy when "
2331 "represented as a denormalized number)."
2335 #: build/C/man3/fenv.3:91
2337 "The I<inexact> exception occurs when the rounded result of an operation is "
2338 "not equal to the infinite precision result. It may occur whenever "
2339 "I<overflow> or I<underflow> occurs."
2343 #: build/C/man3/fenv.3:96
2345 "The I<invalid> exception occurs when there is no well-defined result for an "
2346 "operation, as for 0/0 or infinity - infinity or sqrt(-1)."
2350 #: build/C/man3/fenv.3:96
2352 msgid "Exception handling"
2356 #: build/C/man3/fenv.3:102
2358 "Exceptions are represented in two ways: as a single bit (exception "
2359 "present/absent), and these bits correspond in some implementation-defined "
2360 "way with bit positions in an integer, and also as an opaque structure that "
2361 "may contain more information about the exception (perhaps the code address "
2362 "where it occurred)."
2366 #: build/C/man3/fenv.3:118
2368 "Each of the macros B<FE_DIVBYZERO>, B<FE_INEXACT>, B<FE_INVALID>, "
2369 "B<FE_OVERFLOW>, B<FE_UNDERFLOW> is defined when the implementation supports "
2370 "handling of the corresponding exception, and if so then defines the "
2371 "corresponding bit(s), so that one can call exception handling functions, for "
2372 "example, using the integer argument B<FE_OVERFLOW>|B<FE_UNDERFLOW>. Other "
2373 "exceptions may be supported. The macro B<FE_ALL_EXCEPT> is the bitwise OR "
2374 "of all bits corresponding to supported exceptions."
2378 #: build/C/man3/fenv.3:123
2380 "The B<feclearexcept>() function clears the supported exceptions represented "
2381 "by the bits in its argument."
2385 #: build/C/man3/fenv.3:131
2387 "The B<fegetexceptflag>() function stores a representation of the state of "
2388 "the exception flags represented by the argument I<excepts> in the opaque "
2393 #: build/C/man3/fenv.3:136
2395 "The B<feraiseexcept>() function raises the supported exceptions represented "
2396 "by the bits in I<excepts>."
2400 #: build/C/man3/fenv.3:147
2402 "The B<fesetexceptflag>() function sets the complete status for the "
2403 "exceptions represented by I<excepts> to the value I<*flagp>. This value "
2404 "must have been obtained by an earlier call of B<fegetexceptflag>() with a "
2405 "last argument that contained all bits in I<excepts>."
2409 #: build/C/man3/fenv.3:154
2411 "The B<fetestexcept>() function returns a word in which the bits are set "
2412 "that were set in the argument I<excepts> and for which the corresponding "
2413 "exception is currently set."
2417 #: build/C/man3/fenv.3:154
2419 msgid "Rounding mode"
2423 #: build/C/man3/fenv.3:162
2425 "The rounding mode determines how the result of floating-point operations is "
2426 "treated when the result cannot be exactly represented in the significand. "
2427 "Various rounding modes may be provided: round to nearest (the default), "
2428 "round up (toward positive infinity), round down (toward negative infinity), "
2429 "and round toward zero."
2433 #: build/C/man3/fenv.3:171
2435 "Each of the macros B<FE_TONEAREST>, B<FE_UPWARD>, B<FE_DOWNWARD>, and "
2436 "B<FE_TOWARDZERO> is defined when the implementation supports getting and "
2437 "setting the corresponding rounding direction."
2441 #: build/C/man3/fenv.3:176
2443 "The B<fegetround>() function returns the macro corresponding to the current "
2448 #: build/C/man3/fenv.3:181
2450 "The B<fesetround>() function sets the rounding mode as specified by its "
2451 "argument and returns zero when it was successful."
2455 #: build/C/man3/fenv.3:189
2457 "C99 and POSIX.1-2008 specify an identifier, B<FLT_ROUNDS>, defined in "
2458 "I<E<lt>float.hE<gt>>, which indicates the implementation-defined rounding "
2459 "behavior for floating-point addition. This identifier has one of the "
2464 #: build/C/man3/fenv.3:189
2470 #: build/C/man3/fenv.3:191
2471 msgid "The rounding mode is not determinable."
2475 #: build/C/man3/fenv.3:191
2481 #: build/C/man3/fenv.3:193
2482 msgid "Rounding is toward 0."
2486 #: build/C/man3/fenv.3:193
2492 #: build/C/man3/fenv.3:195
2493 msgid "Rounding is toward nearest number."
2497 #: build/C/man3/fenv.3:195
2503 #: build/C/man3/fenv.3:197
2504 msgid "Rounding is toward positive infinity."
2508 #: build/C/man3/fenv.3:197
2514 #: build/C/man3/fenv.3:199
2515 msgid "Rounding is toward negative infinity."
2519 #: build/C/man3/fenv.3:201
2520 msgid "Other values represent machine-dependent, nonstandard rounding modes."
2524 #: build/C/man3/fenv.3:207
2526 "The value of B<FLT_ROUNDS> should reflect the current rounding mode as set "
2527 "by B<fesetround>() (but see BUGS)."
2531 #: build/C/man3/fenv.3:207
2533 msgid "Floating-point environment"
2537 #: build/C/man3/fenv.3:219
2539 "The entire floating-point environment, including control modes and status "
2540 "flags, can be handled as one opaque object, of type I<fenv_t>. The default "
2541 "environment is denoted by B<FE_DFL_ENV> (of type I<const fenv_t *>). This "
2542 "is the environment setup at program start and it is defined by ISO C to have "
2543 "round to nearest, all exceptions cleared and a nonstop (continue on "
2548 #: build/C/man3/fenv.3:224
2550 "The B<fegetenv>() function saves the current floating-point environment in "
2551 "the object I<*envp>."
2555 #: build/C/man3/fenv.3:231
2557 "The B<feholdexcept>() function does the same, then clears all exception "
2558 "flags, and sets a nonstop (continue on exceptions) mode, if available. It "
2559 "returns zero when successful."
2563 #: build/C/man3/fenv.3:244
2565 "The B<fesetenv>() function restores the floating-point environment from the "
2566 "object I<*envp>. This object must be known to be valid, for example, the "
2567 "result of a call to B<fegetenv>() or B<feholdexcept>() or equal to "
2568 "B<FE_DFL_ENV>. This call does not raise exceptions."
2572 #: build/C/man3/fenv.3:257
2574 "The B<feupdateenv>() function installs the floating-point environment "
2575 "represented by the object I<*envp>, except that currently raised exceptions "
2576 "are not cleared. After calling this function, the raised exceptions will be "
2577 "a bitwise OR of those previously set with those in I<*envp>. As before, the "
2578 "object I<*envp> must be known to be valid."
2581 #. Earlier seven of these functions were listed as returning void.
2582 #. This was corrected in Corrigendum 1 (ISO/IEC 9899:1999/Cor.1:2001(E))
2583 #. of the C99 Standard.
2585 #: build/C/man3/fenv.3:262
2586 msgid "These functions return zero on success and nonzero if an error occurred."
2590 #: build/C/man3/fenv.3:266
2591 msgid "IEC 60559 (IEC 559:1989), ANSI/IEEE 854, C99, POSIX.1-2001."
2595 #: build/C/man3/fenv.3:267
2601 #: build/C/man3/fenv.3:286
2603 "If possible, the GNU C Library defines a macro B<FE_NOMASK_ENV> which "
2604 "represents an environment where every exception raised causes a trap to "
2605 "occur. You can test for this macro using B<#ifdef>. It is only defined if "
2606 "B<_GNU_SOURCE> is defined. The C99 standard does not define a way to set "
2607 "individual bits in the floating-point mask, for example, to trap on specific "
2608 "flags. Since version 2.2, glibc supports the functions B<feenableexcept>() "
2609 "and B<fedisableexcept>() to set individual floating-point traps, and "
2610 "B<fegetexcept>() to query the state."
2614 #: build/C/man3/fenv.3:293
2616 msgid "B<int feenableexcept(int >I<excepts>B<);>\n"
2620 #: build/C/man3/fenv.3:295
2622 msgid "B<int fedisableexcept(int >I<excepts>B<);>\n"
2626 #: build/C/man3/fenv.3:297
2628 msgid "B<int fegetexcept(void);>\n"
2632 #: build/C/man3/fenv.3:311
2634 "The B<feenableexcept>() and B<fedisableexcept>() functions enable "
2635 "(disable) traps for each of the exceptions represented by I<excepts> and "
2636 "return the previous set of enabled exceptions when successful, and -1 "
2637 "otherwise. The B<fegetexcept>() function returns the set of all currently "
2638 "enabled exceptions."
2641 #. Aug 08, glibc 2.8
2642 #. See http://gcc.gnu.org/ml/gcc/2002-02/msg01535.html
2644 #: build/C/man3/fenv.3:322
2646 "C99 specifies that the value of B<FLT_ROUNDS> should reflect changes to the "
2647 "current rounding mode, as set by B<fesetround>(). Currently, this does not "
2648 "occur: B<FLT_ROUNDS> always has the value 1."
2652 #: build/C/man3/fenv.3:324
2653 msgid "B<math_error>(7)"
2657 #: build/C/man3/finite.3:23
2663 #: build/C/man3/finite.3:23 build/C/man3/gamma.3:6
2669 #: build/C/man3/finite.3:27
2671 "finite, finitef, finitel, isinf, isinff, isinfl, isnan, isnanf, isnanl - BSD "
2672 "floating-point classification functions"
2676 #: build/C/man3/finite.3:32
2678 msgid "B<int finite(double >I<x>B<);>\n"
2682 #: build/C/man3/finite.3:34
2684 msgid "B<int finitef(float >I<x>B<);>\n"
2688 #: build/C/man3/finite.3:36
2690 msgid "B<int finitel(long double >I<x>B<);>\n"
2694 #: build/C/man3/finite.3:38
2696 msgid "B<int isinf(double >I<x>B<);>\n"
2700 #: build/C/man3/finite.3:40
2702 msgid "B<int isinff(float >I<x>B<);>\n"
2706 #: build/C/man3/finite.3:42
2708 msgid "B<int isinfl(long double >I<x>B<);>\n"
2712 #: build/C/man3/finite.3:44
2714 msgid "B<int isnan(double >I<x>B<);>\n"
2718 #: build/C/man3/finite.3:46
2720 msgid "B<int isnanf(float >I<x>B<);>\n"
2724 #: build/C/man3/finite.3:48
2726 msgid "B<int isnanl(long double >I<x>B<);>\n"
2730 #: build/C/man3/finite.3:59
2731 msgid "B<finite>(), B<finitef>(), B<finitel>():"
2735 #: build/C/man3/finite.3:61 build/C/man3/finite.3:74 build/C/man3/lgamma.3:61
2736 msgid "_BSD_SOURCE || _SVID_SOURCE"
2740 #: build/C/man3/finite.3:63 build/C/man3/fpclassify.3:54
2745 #: build/C/man3/finite.3:65
2747 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600 || "
2752 #: build/C/man3/finite.3:72
2753 msgid "B<isinff>(), B<isinfl>():"
2757 #: build/C/man3/finite.3:76 build/C/man3/fpclassify.3:46
2762 #: build/C/man3/finite.3:78
2763 msgid "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE || _ISOC99_SOURCE;"
2767 #: build/C/man3/finite.3:84
2768 msgid "B<isnanf>(), B<isnanl>():"
2772 #: build/C/man3/finite.3:86 build/C/man3/gamma.3:35 build/C/man3/scalb.3:56
2773 msgid "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600"
2777 #: build/C/man3/finite.3:93
2779 "The B<finite>() functions return a nonzero value if I<x> is neither "
2780 "infinite nor a \"not-a-number\" (NaN) value, and 0 otherwise."
2784 #: build/C/man3/finite.3:98
2786 "The B<isnan>() functions return a nonzero value if I<x> is a NaN value, and "
2791 #: build/C/man3/finite.3:103
2793 "The B<isinf>() functions return 1 if I<x> is positive infinity, -1 if I<x> "
2794 "is negative infinity, and 0 otherwise."
2798 #. finite* not on HP-UX; they exist on Tru64.
2802 #. function occurs in 4.3BSD.
2803 #. see IEEE.3 in the 4.3BSD manual
2805 #: build/C/man3/finite.3:123
2807 "Note that these functions are obsolete. C99 defines macros B<isfinite>(), "
2808 "B<isinf>(), and B<isnan>() (for all types) replacing them. Further note "
2809 "that the C99 B<isinf>() has weaker guarantees on the return value. See "
2814 #: build/C/man3/finite.3:125
2815 msgid "B<fpclassify>(3)"
2819 #: build/C/man3/floor.3:25
2825 #: build/C/man3/floor.3:28
2826 msgid "floor, floorf, floorl - largest integral value not greater than argument"
2830 #: build/C/man3/floor.3:33
2832 msgid "B<double floor(double >I<x>B<);>\n"
2836 #: build/C/man3/floor.3:35
2838 msgid "B<float floorf(float >I<x>B<);>\n"
2842 #: build/C/man3/floor.3:37
2844 msgid "B<long double floorl(long double >I<x>B<);>\n"
2848 #: build/C/man3/floor.3:49
2849 msgid "B<floorf>(), B<floorl>():"
2853 #: build/C/man3/floor.3:60
2855 "These functions return the largest integral value that is not greater than "
2860 #: build/C/man3/floor.3:66
2861 msgid "For example, I<floor(0.5)> is 0.0, and I<floor(-0.5)> is -1.0."
2865 #: build/C/man3/floor.3:69
2866 msgid "These functions return the floor of I<x>."
2870 #: build/C/man3/floor.3:72
2871 msgid "If I<x> is integral, +0, -0, NaN, or an infinity, I<x> itself is returned."
2875 #: build/C/man3/floor.3:104
2877 "B<ceil>(3), B<lrint>(3), B<nearbyint>(3), B<rint>(3), B<round>(3), "
2882 #: build/C/man3/fma.3:8
2888 #: build/C/man3/fma.3:11
2889 msgid "fma, fmaf, fmal - floating-point multiply and add"
2893 #: build/C/man3/fma.3:16
2895 msgid "B<double fma(double >I<x>B<, double >I<y>B<, double >I<z>B<);>\n"
2899 #: build/C/man3/fma.3:18
2901 msgid "B<float fmaf(float >I<x>B<, float >I<y>B<, float >I<z>B<);>\n"
2905 #: build/C/man3/fma.3:20
2908 "B<long double fmal(long double >I<x>B<, long double >I<y>B<, long double "
2913 #: build/C/man3/fma.3:33
2914 msgid "B<fma>(), B<fmaf>(), B<fmal>():"
2918 #: build/C/man3/fma.3:49
2920 "The B<fma>() function computes I<x> * I<y> + I<z>. The result is rounded "
2921 "as one ternary operation according to the current rounding mode (see "
2926 #: build/C/man3/fma.3:53
2928 "These functions return the value of I<x> * I<y> + I<z>, rounded as one "
2929 "ternary operation."
2933 #: build/C/man3/fma.3:69
2935 "If I<x> times I<y> is an exact infinity, and I<z> is an infinity with the "
2936 "opposite sign, a domain error occurs, and a NaN is returned."
2939 #. POSIX.1-2008 allows some possible differences for the following two
2940 #. domain error cases, but on Linux they are treated the same (AFAICS).
2941 #. Nevertheless, we'll mirror POSIX.1 and describe the two cases
2943 #. POSIX.1 says that a NaN or an implementation-defined value shall
2944 #. be returned for this case.
2946 #: build/C/man3/fma.3:85
2948 "If one of I<x> or I<y> is an infinity, the other is 0, and I<z> is not a "
2949 "NaN, a domain error occurs, and a NaN is returned."
2952 #. POSIX.1 makes the domain error optional for this case.
2954 #: build/C/man3/fma.3:96
2956 "If one of I<x> or I<y> is an infinity, and the other is 0, and I<z> is a "
2957 "NaN, a domain error occurs, and a NaN is returned."
2961 #: build/C/man3/fma.3:105
2963 "If I<x> times I<y> is not an infinity times zero (or vice versa), and I<z> "
2964 "is a NaN, a NaN is returned."
2968 #: build/C/man3/fma.3:109
2970 "If the result overflows, a range error occurs, and an infinity with the "
2971 "correct sign is returned."
2975 #: build/C/man3/fma.3:113
2976 msgid "If the result underflows, a range error occurs, and a signed 0 is returned."
2980 #: build/C/man3/fma.3:120
2983 "Domain error: I<x> * I<y> + I<z>, or I<x> * I<y> is invalid and I<z> is not "
2991 #: build/C/man3/fma.3:129 build/C/man3/ilogb.3:123 build/C/man3/log1p.3:124 build/C/man3/lrint.3:100 build/C/man3/lround.3:103 build/C/man3/remainder.3:163 build/C/man3/remquo.3:112 build/C/man3/scalb.3:148 build/C/man3/sincos.3:64
2992 msgid "An invalid floating-point exception (B<FE_INVALID>) is raised."
2996 #: build/C/man3/fma.3:137 build/C/man3/hypot.3:141 build/C/man3/tgamma.3:134 build/C/man3/y0.3:186
2998 msgid "Range error: result underflow"
3002 #: build/C/man3/fma.3:157
3003 msgid "B<remainder>(3), B<remquo>(3)"
3007 #: build/C/man3/fmax.3:6
3013 #: build/C/man3/fmax.3:9
3014 msgid "fmax, fmaxf, fmaxl - determine maximum of two floating-point numbers"
3018 #: build/C/man3/fmax.3:13
3019 msgid "B<double fmax(double >I<x>B<, double >I<y>B<);>"
3023 #: build/C/man3/fmax.3:15
3024 msgid "B<float fmaxf(float >I<x>B<, float >I<y>B<);>"
3028 #: build/C/man3/fmax.3:17
3029 msgid "B<long double fmaxl(long double >I<x>B<, long double >I<y>B<);>"
3033 #: build/C/man3/fmax.3:29
3034 msgid "B<fmax>(), B<fmaxf>(), B<fmaxl>():"
3038 #: build/C/man3/fmax.3:42
3039 msgid "These functions return the larger value of I<x> and I<y>."
3043 #: build/C/man3/fmax.3:47
3044 msgid "These functions return the maximum of I<x> and I<y>."
3048 #: build/C/man3/fmax.3:49 build/C/man3/fmin.3:49
3049 msgid "If one argument is a NaN, the other argument is returned."
3053 #: build/C/man3/fmax.3:51 build/C/man3/fmin.3:51
3054 msgid "If both arguments are NaN, a NaN is returned."
3058 #: build/C/man3/fmax.3:59
3063 #: build/C/man3/fmin.3:6
3069 #: build/C/man3/fmin.3:9
3070 msgid "fmin, fminf, fminl - determine minimum of two floating-point numbers"
3074 #: build/C/man3/fmin.3:13
3075 msgid "B<double fmin(double >I<x>B<, double >I<y>B<);>"
3079 #: build/C/man3/fmin.3:15
3080 msgid "B<float fminf(float >I<x>B<, float >I<y>B<);>"
3084 #: build/C/man3/fmin.3:17
3085 msgid "B<long double fminl(long double >I<x>B<, long double >I<y>B<);>"
3089 #: build/C/man3/fmin.3:29
3090 msgid "B<fmin>(), B<fminf>(), B<fminl>():"
3094 #: build/C/man3/fmin.3:42
3095 msgid "These functions the lesser value of I<x> and I<y>."
3099 #: build/C/man3/fmin.3:47
3100 msgid "These functions return the minimum of I<x> and I<y>."
3104 #: build/C/man3/fmod.3:33
3110 #: build/C/man3/fmod.3:33
3116 #: build/C/man3/fmod.3:36
3117 msgid "fmod, fmodf, fmodl - floating-point remainder function"
3121 #: build/C/man3/fmod.3:41
3123 msgid "B<double fmod(double >I<x>B<, double >I<y>B<);>\n"
3127 #: build/C/man3/fmod.3:43
3129 msgid "B<float fmodf(float >I<x>B<, float >I<y>B<);>\n"
3133 #: build/C/man3/fmod.3:45
3135 msgid "B<long double fmodl(long double >I<x>B<, long double >I<y>B<);>\n"
3139 #: build/C/man3/fmod.3:57
3140 msgid "B<fmodf>(), B<fmodl>():"
3144 #: build/C/man3/fmod.3:72
3146 "The B<fmod>() function computes the floating-point remainder of dividing "
3147 "I<x> by I<y>. The return value is I<x> - I<n> * I<y>, where I<n> is the "
3148 "quotient of I<x> / I<y>, rounded toward zero to an integer."
3152 #: build/C/man3/fmod.3:80
3154 "On success, these functions return the value I<x>\\ -\\ I<n>*I<y>, for some "
3155 "integer I<n>, such that the returned value has the same sign as I<x> and a "
3156 "magnitude less than the magnitude of I<y>."
3160 #: build/C/man3/fmod.3:92
3161 msgid "If I<x> is an infinity, a domain error occurs, and a NaN is returned."
3165 #: build/C/man3/fmod.3:98
3166 msgid "If I<y> is zero, a domain error occurs, and a NaN is returned."
3170 #: build/C/man3/fmod.3:104
3171 msgid "If I<x> is +0 (-0), and I<y> is not zero, +0 (-0) is returned."
3174 #. [XXX see bug above] and \fIx\fP is not a NaN
3176 #: build/C/man3/fmod.3:120 build/C/man3/remainder.3:170
3178 msgid "Domain error: I<y> is zero"
3181 #. http://sources.redhat.com/bugzilla/show_bug.cgi?id=6784
3183 #: build/C/man3/fmod.3:144
3185 "Before version 2.10, the glibc implementation did not set I<errno> to "
3186 "B<EDOM> when a domain error occurred for an infinite I<x>."
3190 #: build/C/man3/fmod.3:146
3191 msgid "B<remainder>(3)"
3195 #: build/C/man3/fpclassify.3:6
3201 #: build/C/man3/fpclassify.3:10
3203 "fpclassify, isfinite, isnormal, isnan, isinf - floating-point classification "
3208 #: build/C/man3/fpclassify.3:15
3210 msgid "B<int fpclassify(>I<x>B<);>\n"
3214 #: build/C/man3/fpclassify.3:17
3216 msgid "B<int isfinite(>I<x>B<);>\n"
3220 #: build/C/man3/fpclassify.3:19
3222 msgid "B<int isnormal(>I<x>B<);>\n"
3226 #: build/C/man3/fpclassify.3:21
3228 msgid "B<int isnan(>I<x>B<);>\n"
3232 #: build/C/man3/fpclassify.3:23
3234 msgid "B<int isinf(>I<x>B<);>\n"
3238 #: build/C/man3/fpclassify.3:38
3239 msgid "B<fpclassify>(), B<isfinite>(), B<isnormal>():"
3243 #: build/C/man3/fpclassify.3:72
3245 "Floating point numbers can have special values, such as infinite or NaN. "
3246 "With the macro B<fpclassify(>I<x>B<)> you can find out what type I<x> is. "
3247 "The macro takes any floating-point expression as argument. The result is "
3248 "one of the following values:"
3252 #: build/C/man3/fpclassify.3:72
3258 #: build/C/man3/fpclassify.3:76
3259 msgid "I<x> is \"Not a Number\"."
3263 #: build/C/man3/fpclassify.3:76
3265 msgid "B<FP_INFINITE>"
3269 #: build/C/man3/fpclassify.3:80
3270 msgid "I<x> is either positive infinity or negative infinity."
3274 #: build/C/man3/fpclassify.3:80
3280 #: build/C/man3/fpclassify.3:84
3281 msgid "I<x> is zero."
3285 #: build/C/man3/fpclassify.3:84
3287 msgid "B<FP_SUBNORMAL>"
3291 #: build/C/man3/fpclassify.3:88
3292 msgid "I<x> is too small to be represented in normalized format."
3296 #: build/C/man3/fpclassify.3:88
3298 msgid "B<FP_NORMAL>"
3302 #: build/C/man3/fpclassify.3:92
3304 "if nothing of the above is correct then it must be a normal floating-point "
3309 #: build/C/man3/fpclassify.3:94
3310 msgid "The other macros provide a short answer to some standard questions."
3314 #: build/C/man3/fpclassify.3:94
3316 msgid "B<isfinite(>I<x>B<)>"
3320 #: build/C/man3/fpclassify.3:97
3321 msgid "returns a nonzero value if"
3325 #: build/C/man3/fpclassify.3:99
3326 msgid "(fpclassify(x) != FP_NAN && fpclassify(x) != FP_INFINITE)"
3330 #: build/C/man3/fpclassify.3:99
3332 msgid "B<isnormal(>I<x>B<)>"
3336 #: build/C/man3/fpclassify.3:103
3337 msgid "returns a nonzero value if (fpclassify(x) == FP_NORMAL)"
3341 #: build/C/man3/fpclassify.3:103
3343 msgid "B<isnan(>I<x>B<)>"
3347 #: build/C/man3/fpclassify.3:107
3348 msgid "returns a nonzero value if (fpclassify(x) == FP_NAN)"
3352 #: build/C/man3/fpclassify.3:107
3354 msgid "B<isinf(>I<x>B<)>"
3358 #: build/C/man3/fpclassify.3:114
3359 msgid "returns 1 if I<x> is positive infinity, and -1 if I<x> is negative infinity."
3363 #: build/C/man3/fpclassify.3:116
3364 msgid "C99, POSIX.1."
3368 #: build/C/man3/fpclassify.3:121
3370 "For B<isinf>(), the standards merely say that the return value is nonzero if "
3371 "and only if the argument has an infinite value."
3375 #: build/C/man3/fpclassify.3:128
3377 "In glibc 2.01 and earlier, B<isinf>() returns a nonzero value (actually: 1) "
3378 "if I<x> is positive infinity or negative infinity. (This is all that C99 "
3383 #: build/C/man3/fpclassify.3:133
3384 msgid "B<finite>(3), B<INFINITY>(3), B<isgreater>(3), B<signbit>(3)"
3388 #: build/C/man3/frexp.3:31
3394 #: build/C/man3/frexp.3:35
3396 "frexp, frexpf, frexpl - convert floating-point number to fractional and "
3397 "integral components"
3401 #: build/C/man3/frexp.3:40
3403 msgid "B<double frexp(double >I<x>B<, int *>I<exp>B<);>\n"
3407 #: build/C/man3/frexp.3:42
3409 msgid "B<float frexpf(float >I<x>B<, int *>I<exp>B<);>\n"
3413 #: build/C/man3/frexp.3:44
3415 msgid "B<long double frexpl(long double >I<x>B<, int *>I<exp>B<);>\n"
3419 #: build/C/man3/frexp.3:56
3420 msgid "B<frexpf>(), B<frexpl>():"
3424 #: build/C/man3/frexp.3:69
3426 "The B<frexp>() function is used to split the number I<x> into a normalized "
3427 "fraction and an exponent which is stored in I<exp>."
3431 #: build/C/man3/frexp.3:77
3433 "The B<frexp>() function returns the normalized fraction. If the argument "
3434 "I<x> is not zero, the normalized fraction is I<x> times a power of two, and "
3435 "its absolute value is always in the range 1/2 (inclusive) to 1 (exclusive), "
3440 #: build/C/man3/frexp.3:80
3442 "If I<x> is zero, then the normalized fraction is zero and zero is stored in "
3447 #: build/C/man3/frexp.3:87
3449 "If I<x> is a NaN, a NaN is returned, and the value of I<*exp> is "
3454 #: build/C/man3/frexp.3:94
3456 "If I<x> is positive infinity (negative infinity), positive infinity "
3457 "(negative infinity) is returned, and the value of I<*exp> is unspecified."
3461 #: build/C/man3/frexp.3:104
3462 msgid "The program below produces results such as the following:"
3466 #: build/C/man3/frexp.3:111
3469 "$B< ./a.out 2560>\n"
3470 "frexp(2560, &e) = 0.625: 0.625 * 2^12 = 2560\n"
3472 "frexp(-4, &e) = -0.5: -0.5 * 2^3 = -4\n"
3476 #: build/C/man3/frexp.3:113 build/C/man3/matherr.3:358
3478 msgid "Program source"
3482 #: build/C/man3/frexp.3:120
3485 "#include E<lt>math.hE<gt>\n"
3486 "#include E<lt>float.hE<gt>\n"
3487 "#include E<lt>stdio.hE<gt>\n"
3488 "#include E<lt>stdlib.hE<gt>\n"
3492 #: build/C/man3/frexp.3:126
3496 "main(int argc, char *argv[])\n"
3503 #: build/C/man3/frexp.3:129
3506 " x = strtod(argv[1], NULL);\n"
3507 " r = frexp(x, &exp);\n"
3511 #: build/C/man3/frexp.3:134
3514 " printf(\"frexp(%g, &e) = %g: %g * %d^%d = %g\\en\",\n"
3515 " x, r, r, FLT_RADIX, exp, x);\n"
3516 " exit(EXIT_SUCCESS);\n"
3521 #: build/C/man3/frexp.3:138
3522 msgid "B<ldexp>(3), B<modf>(3)"
3526 #: build/C/man3/gamma.3:6
3532 #: build/C/man3/gamma.3:9
3533 msgid "gamma, gammaf, gammal - (logarithm of the) gamma function"
3537 #: build/C/man3/gamma.3:13
3538 msgid "B<double gamma(double >I<x>B<);>"
3542 #: build/C/man3/gamma.3:15
3543 msgid "B<float gammaf(float >I<x>B<);>"
3547 #: build/C/man3/gamma.3:17
3548 msgid "B<long double gammal(long double >I<x>B<);>"
3552 #: build/C/man3/gamma.3:27
3557 #: build/C/man3/gamma.3:29 build/C/man3/lgamma.3:65
3558 msgid "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE"
3562 #: build/C/man3/gamma.3:32
3563 msgid "B<gammaf>(), B<gammal>():"
3567 #: build/C/man3/gamma.3:43
3569 "These functions are deprecated: instead, use either the B<tgamma>(3) or the "
3570 "B<lgamma>(3) functions, as appropriate."
3574 #: build/C/man3/gamma.3:46 build/C/man3/lgamma.3:70
3575 msgid "For the definition of the Gamma function, see B<tgamma>(3)."
3579 #: build/C/man3/gamma.3:46
3581 msgid "*BSD version"
3585 #: build/C/man3/gamma.3:50
3587 "The libm in 4.4BSD and some versions of FreeBSD had a B<gamma>() function "
3588 "that computes the Gamma function, as one would expect."
3592 #: build/C/man3/gamma.3:50
3594 msgid "glibc version"
3598 #: build/C/man3/gamma.3:56
3600 "Glibc has a B<gamma>() function that is equivalent to B<lgamma>(3) and "
3601 "computes the natural logarithm of the Gamma function."
3605 #: build/C/man3/gamma.3:59 build/C/man3/gamma.3:62
3606 msgid "See B<lgamma>(3)."
3610 #: build/C/man3/gamma.3:65
3612 "Because of historical variations in behavior across systems, this function "
3613 "is not specified in any standard."
3617 #: build/C/man3/gamma.3:66
3623 #: build/C/man3/gamma.3:78
3625 "4.2BSD had a B<gamma>() that computed ln(|Gamma(|I<x>|)|), leaving the sign "
3626 "of Gamma(|I<x>|) in the external integer I<signgam>. In 4.3BSD the name "
3627 "was changed to B<lgamma>(3), and the man page promises"
3631 #: build/C/man3/gamma.3:82
3633 "At some time in the future the name gamma will be rehabilitated and used for "
3634 "the Gamma function"
3637 #. The FreeBSD man page says about gamma() that it is like lgamma()
3638 #. except that is does not set signgam.
3639 #. Also, that 4.4BSD has a gamma() that computes the true gamma function.
3641 #: build/C/man3/gamma.3:94
3643 "This did indeed happen in 4.4BSD, where B<gamma>() computes the Gamma "
3644 "function (with no effect on I<signgam>). However, this came too late, and "
3645 "we now have B<tgamma>(3), the \"true gamma\" function."
3649 #: build/C/man3/gamma.3:98
3650 msgid "B<lgamma>(3), B<signgam>(3), B<tgamma>(3)"
3654 #: build/C/man3/hypot.3:31
3660 #: build/C/man3/hypot.3:34
3661 msgid "hypot, hypotf, hypotl - Euclidean distance function"
3665 #: build/C/man3/hypot.3:39
3667 msgid "B<double hypot(double >I<x>B<, double >I<y>B<);>\n"
3671 #: build/C/man3/hypot.3:41
3673 msgid "B<float hypotf(float >I<x>B<, float >I<y>B<);>\n"
3677 #: build/C/man3/hypot.3:43
3679 msgid "B<long double hypotl(long double >I<x>B<, long double >I<y>B<);>\n"
3683 #: build/C/man3/hypot.3:54
3688 #: build/C/man3/hypot.3:64
3689 msgid "B<hypotf>(), B<hypotl>():"
3693 #: build/C/man3/hypot.3:85
3695 "The B<hypot>() function returns sqrt(I<x>*I<x>+I<y>*I<y>). This is the "
3696 "length of the hypotenuse of a right-angled triangle with sides of length "
3697 "I<x> and I<y>, or the distance of the point (I<x>,I<y>) from the origin."
3700 #. e.g., hypot(DBL_MIN, DBL_MIN) does the right thing, as does, say
3701 #. hypot(DBL_MAX/2.0, DBL_MAX/2.0).
3703 #: build/C/man3/hypot.3:90
3705 "The calculation is performed without undue overflow or underflow during the "
3706 "intermediate steps of the calculation."
3710 #: build/C/man3/hypot.3:96
3712 "On success, these functions return the length of a right-angled triangle "
3713 "with sides of length I<x> and I<y>."
3717 #: build/C/man3/hypot.3:103
3718 msgid "If I<x> or I<y> is an infinity, positive infinity is returned."
3722 #: build/C/man3/hypot.3:111
3724 "If I<x> or I<y> is a NaN, and the other argument is not an infinity, a NaN "
3728 #. Actually, could the result not be subnormal if both arguments
3729 #. are subnormal? I think not -- mtk, Jul 2008
3731 #: build/C/man3/hypot.3:126
3733 "If both arguments are subnormal, and the result is subnormal, a range error "
3734 "occurs, and the correct result is returned."
3737 #. FIXME . Is it intentional that these functions do not set errno?
3738 #. They do set errno for the y == 0 case, below.
3739 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6783
3741 #: build/C/man3/hypot.3:156 build/C/man3/ilogb.3:128 build/C/man3/remainder.3:170
3742 msgid "These functions do not set I<errno> for this case."
3746 #: build/C/man3/hypot.3:165
3747 msgid "B<cabs>(3), B<sqrt>(3)"
3751 #: build/C/man3/ilogb.3:27
3757 #: build/C/man3/ilogb.3:30
3758 msgid "ilogb, ilogbf, ilogbl - get integer exponent of a floating-point value"
3762 #: build/C/man3/ilogb.3:34
3763 msgid "B<int ilogb(double >I<x>B<);>"
3767 #: build/C/man3/ilogb.3:36
3768 msgid "B<int ilogbf(float >I<x>B<);>"
3772 #: build/C/man3/ilogb.3:38
3773 msgid "B<int ilogbl(long double >I<x>B<);>"
3777 #: build/C/man3/ilogb.3:48
3782 #: build/C/man3/ilogb.3:60
3783 msgid "B<ilogbf>(), B<ilogbl>():"
3787 #: build/C/man3/ilogb.3:76
3789 "These functions return the exponent part of their argument as a signed "
3790 "integer. When no error occurs, these functions are equivalent to the "
3791 "corresponding B<logb>(3) functions, cast to I<int>."
3795 #: build/C/man3/ilogb.3:80
3797 "On success, these functions return the exponent of I<x>, as a signed "
3801 #. the POSIX.1 spec for logb() says logb() gives pole error for this
3802 #. case, but for ilogb() it says domain error.
3803 #. glibc: The numeric value is either `INT_MIN' or `-INT_MAX'.
3805 #: build/C/man3/ilogb.3:88
3807 "If I<x> is zero, then a domain error occurs, and the functions return "
3811 #. glibc: The numeric value is either `INT_MIN' or `INT_MAX'.
3812 #. On i386, FP_ILOGB0 and FP_ILOGBNAN have the same value.
3814 #: build/C/man3/ilogb.3:95
3816 "If I<x> is a NaN, then a domain error occurs, and the functions return "
3821 #. POSIX.1-2001 also says:
3822 #. If the correct value is greater than {INT_MAX}, {INT_MAX}
3823 #. shall be returned and a domain error shall occur.
3825 #. If the correct value is less than {INT_MIN}, {INT_MIN}
3826 #. shall be returned and a domain error shall occur.
3828 #: build/C/man3/ilogb.3:108
3830 "If I<x> is negative infinity or positive infinity, then a domain error "
3831 "occurs, and the functions return B<INT_MAX>."
3835 #: build/C/man3/ilogb.3:115
3837 msgid "Domain error: I<x> is 0 or a NaN"
3840 #. FIXME . Is it intentional that these functions do not set errno,
3841 #. or raise an exception?
3842 #. log(), log2(), log10() do set errno
3843 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6794
3845 #: build/C/man3/ilogb.3:144
3846 msgid "These functions do not set I<errno> or raise an exception for this case."
3850 #: build/C/man3/ilogb.3:150
3851 msgid "B<log>(3), B<logb>(3), B<significand>(3)"
3855 #: build/C/man3/infnan.3:31
3861 #: build/C/man3/infnan.3:31
3867 #: build/C/man3/infnan.3:34
3868 msgid "infnan - deal with infinite or not-a-number (NaN) result"
3872 #: build/C/man3/infnan.3:39
3874 msgid "B<double infnan(int >I<error>B<);>\n"
3878 #: build/C/man3/infnan.3:52
3880 "The B<infnan>() function returns a suitable value for infinity and "
3881 "\"not-a-number\" (NaN) results. The value of I<error> can be B<ERANGE> to "
3882 "represent infinity or anything else to represent NaN. I<errno> is also set."
3886 #: build/C/man3/infnan.3:58
3887 msgid "If I<error> is B<ERANGE> (Infinity), B<HUGE_VAL> is returned."
3891 #: build/C/man3/infnan.3:60
3892 msgid "If I<error> is -B<ERANGE> (-Infinity), -B<HUGE_VAL> is returned."
3896 #: build/C/man3/infnan.3:62
3897 msgid "If I<error> is anything else, NAN is returned."
3901 #: build/C/man3/infnan.3:63
3907 #: build/C/man3/infnan.3:66
3908 msgid "The value of I<error> is \"not-a-number\" (NaN)."
3912 #: build/C/man3/infnan.3:66
3918 #: build/C/man3/infnan.3:69
3919 msgid "The value of I<error> is positive infinity or negative infinity."
3923 #: build/C/man3/infnan.3:71
3928 #: build/C/man3/infnan.3:74
3930 "This obsolete function was provided in libc4 and libc5, but is not available "
3935 #: build/C/man3/isgreater.3:6
3941 #: build/C/man3/isgreater.3:10
3943 "isgreater, isgreaterequal, isless, islessequal, islessgreater, isunordered - "
3944 "floating-point relational tests without exception for NaN"
3948 #: build/C/man3/isgreater.3:15
3950 msgid "B<int isgreater(>I<x>B<, >I<y>B<);>\n"
3954 #: build/C/man3/isgreater.3:17
3956 msgid "B<int isgreaterequal(>I<x>B<, >I<y>B<);>\n"
3960 #: build/C/man3/isgreater.3:19
3962 msgid "B<int isless(>I<x>B<, >I<y>B<);>\n"
3966 #: build/C/man3/isgreater.3:21
3968 msgid "B<int islessequal(>I<x>B<, >I<y>B<);>\n"
3972 #: build/C/man3/isgreater.3:23
3974 msgid "B<int islessgreater(>I<x>B<, >I<y>B<);>\n"
3978 #: build/C/man3/isgreater.3:25
3980 msgid "B<int isunordered(>I<x>B<, >I<y>B<);>\n"
3984 #: build/C/man3/isgreater.3:36
3985 msgid "All functions described here:"
3989 #: build/C/man3/isgreater.3:51
3991 "The normal relation operations (like B<E<lt>>, \"less than\") will fail if "
3992 "one of the operands is NaN. This will cause an exception. To avoid this, "
3993 "C99 defines these macros. The macros are guaranteed to evaluate their "
3994 "operands only once. The operands can be of any real floating-point type."
3998 #: build/C/man3/isgreater.3:51
4000 msgid "B<isgreater>()"
4004 #: build/C/man3/isgreater.3:55
4005 msgid "determines I<(x)\\ E<gt>\\ (y)> without an exception if I<x> or I<y> is NaN."
4009 #: build/C/man3/isgreater.3:55
4011 msgid "B<isgreaterequal>()"
4015 #: build/C/man3/isgreater.3:59
4017 "determines I<(x)\\ E<gt>=\\ (y)> without an exception if I<x> or I<y> is "
4022 #: build/C/man3/isgreater.3:59
4028 #: build/C/man3/isgreater.3:63
4029 msgid "determines I<(x)\\ E<lt>\\ (y)> without an exception if I<x> or I<y> is NaN."
4033 #: build/C/man3/isgreater.3:63
4035 msgid "B<islessequal>()"
4039 #: build/C/man3/isgreater.3:67
4041 "determines I<(x)\\ E<lt>=\\ (y)> without an exception if I<x> or I<y> is "
4046 #: build/C/man3/isgreater.3:67
4048 msgid "B<islessgreater>()"
4052 #: build/C/man3/isgreater.3:73
4054 "determines I<(x)\\ E<lt> (y) || (x) E<gt>\\ (y)> without an exception if "
4055 "I<x> or I<y> is NaN. This macro is not equivalent to I<x\\ !=\\ y> because "
4056 "that expression is true if I<x> or I<y> is NaN."
4060 #: build/C/man3/isgreater.3:73
4062 msgid "B<isunordered>()"
4066 #: build/C/man3/isgreater.3:77
4068 "determines whether its arguments are unordered, that is, whether at least "
4069 "one of the arguments is a NaN."
4073 #: build/C/man3/isgreater.3:82
4075 "The macros other than B<isunordered>() return the result of the relational "
4076 "comparison; these macros return 0 if either argument is a NaN."
4080 #: build/C/man3/isgreater.3:85
4081 msgid "B<isunordered>() returns 1 if I<x> or I<y> is NaN and 0 otherwise."
4085 #: build/C/man3/isgreater.3:94
4087 "Not all hardware supports these functions, and where hardware support isn't "
4088 "provided, they will be emulated by macros. This will result in a "
4089 "performance penalty. Don't use these functions if NaN is of no concern for "
4094 #: build/C/man3/isgreater.3:97
4095 msgid "B<fpclassify>(3), B<isnan>(3)"
4099 #: build/C/man3/j0.3:34
4105 #: build/C/man3/j0.3:38
4107 "j0, j0f, j0l, j1, j1f, j1l, jn, jnf, jnl - Bessel functions of the first "
4112 #: build/C/man3/j0.3:44
4113 msgid "B<double j0(double >I<x>B<);>"
4117 #: build/C/man3/j0.3:46
4118 msgid "B<double j1(double >I<x>B<);>"
4122 #: build/C/man3/j0.3:48
4123 msgid "B<double jn(int >I<n>B<, double >I<x>B<);>"
4127 #: build/C/man3/j0.3:50
4128 msgid "B<float j0f(float >I<x>B<);>"
4132 #: build/C/man3/j0.3:52
4133 msgid "B<float j1f(float >I<x>B<);>"
4137 #: build/C/man3/j0.3:54
4138 msgid "B<float jnf(int >I<n>B<, float >I<x>B<);>"
4142 #: build/C/man3/j0.3:56
4143 msgid "B<long double j0l(long double >I<x>B<);>"
4147 #: build/C/man3/j0.3:58
4148 msgid "B<long double j1l(long double >I<x>B<);>"
4152 #: build/C/man3/j0.3:60
4153 msgid "B<long double jnl(int >I<n>B<, long double >I<x>B<);>"
4157 #: build/C/man3/j0.3:72
4158 msgid "B<j0>(), B<j1>(), B<jn>():"
4162 #: build/C/man3/j0.3:74 build/C/man3/y0.3:74
4163 msgid "_SVID_SOURCE || _BSD_SOURCE || _XOPEN_SOURCE"
4167 #: build/C/man3/j0.3:82
4168 msgid "B<j0f>(), B<j0l>(), B<j1f>(), B<j1l>(), B<jnf>(), B<jnl>():"
4171 #. Also seems to work: -std=c99 -D_XOPEN_SOURCE
4173 #: build/C/man3/j0.3:85 build/C/man3/y0.3:85
4174 msgid "_SVID_SOURCE || _BSD_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 600"
4178 #: build/C/man3/j0.3:98
4180 "The B<j0>() and B<j1>() functions return Bessel functions of I<x> of the "
4181 "first kind of orders 0 and 1, respectively. The B<jn>() function returns "
4182 "the Bessel function of I<x> of the first kind of order I<n>."
4186 #: build/C/man3/j0.3:108
4188 "The B<j0f>() etc. and B<j0l>() etc. functions are versions that take and "
4189 "return I<float> and I<long double> values, respectively."
4193 #: build/C/man3/j0.3:112
4195 "On success, these functions return the appropriate Bessel value of the first "
4200 #: build/C/man3/j0.3:123
4202 "If I<x> is too large in magnitude, or the result underflows, a range error "
4203 "occurs, and the return value is 0."
4207 #: build/C/man3/j0.3:130
4209 msgid "Range error: result underflow, or I<x> is too large in magnitude"
4212 #. An underflow floating-point exception
4213 #. .RB ( FE_UNDERFLOW )
4216 #: build/C/man3/j0.3:138
4217 msgid "I<errno> is set to B<ERANGE>."
4220 #. FIXME . Is it intentional that these functions do not raise exceptions?
4222 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6805
4224 #: build/C/man3/j0.3:144
4225 msgid "These functions do not raise exceptions for B<fetestexcept>(3)."
4229 #: build/C/man3/j0.3:150 build/C/man3/y0.3:221
4231 "The functions returning I<double> conform to SVr4, 4.3BSD, POSIX.1-2001. "
4232 "The others are nonstandard functions that also exist on the BSDs."
4236 #: build/C/man3/j0.3:157
4238 "There are errors of up to 2e-16 in the values returned by B<j0>(), B<j1>() "
4239 "and B<jn>() for values of I<x> between -8 and 8."
4243 #: build/C/man3/j0.3:159
4248 #: build/C/man3/ldexp.3:32
4254 #: build/C/man3/ldexp.3:35
4256 "ldexp, ldexpf, ldexpl - multiply floating-point number by integral power of "
4261 #: build/C/man3/ldexp.3:40
4263 msgid "B<double ldexp(double >I<x>B<, int >I<exp>B<);>\n"
4267 #: build/C/man3/ldexp.3:42
4269 msgid "B<float ldexpf(float >I<x>B<, int >I<exp>B<);>\n"
4273 #: build/C/man3/ldexp.3:44
4275 msgid "B<long double ldexpl(long double >I<x>B<, int >I<exp>B<);>\n"
4279 #: build/C/man3/ldexp.3:56
4280 msgid "B<ldexpf>(), B<ldexpl>():"
4284 #: build/C/man3/ldexp.3:71
4286 "The B<ldexp>() function returns the result of multiplying the "
4287 "floating-point number I<x> by 2 raised to the power I<exp>."
4291 #: build/C/man3/ldexp.3:74
4292 msgid "On success, these functions return I<x * (2^exp)>."
4296 #: build/C/man3/ldexp.3:80
4297 msgid "If I<exp> is zero, then I<x> is returned."
4301 #: build/C/man3/ldexp.3:104 build/C/man3/scalb.3:126 build/C/man3/scalbln.3:118
4303 "If the result overflows, a range error occurs, and the functions return "
4304 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with a sign the "
4309 #: build/C/man3/ldexp.3:137
4310 msgid "B<frexp>(3), B<modf>(3), B<scalbln>(3)"
4314 #: build/C/man3/lgamma.3:7
4320 #: build/C/man3/lgamma.3:11
4322 "lgamma, lgammaf, lgammal, lgamma_r, lgammaf_r, lgammal_r, signgam - log "
4327 #: build/C/man3/lgamma.3:16
4329 msgid "B<double lgamma(double >I<x>B<);>\n"
4333 #: build/C/man3/lgamma.3:18
4335 msgid "B<float lgammaf(float >I<x>B<);>\n"
4339 #: build/C/man3/lgamma.3:20
4341 msgid "B<long double lgammal(long double >I<x>B<);>\n"
4345 #: build/C/man3/lgamma.3:22
4347 msgid "B<double lgamma_r(double >I<x>B<, int *>I<signp>B<);>\n"
4351 #: build/C/man3/lgamma.3:24
4353 msgid "B<float lgammaf_r(float >I<x>B<, int *>I<signp>B<);>\n"
4357 #: build/C/man3/lgamma.3:26
4359 msgid "B<long double lgammal_r(long double >I<x>B<, int *>I<signp>B<);>\n"
4363 #: build/C/man3/lgamma.3:28
4365 msgid "B<extern int >I<signgam>B<;>\n"
4369 #: build/C/man3/lgamma.3:39
4370 msgid "B<lgamma>():"
4374 #: build/C/man3/lgamma.3:49
4375 msgid "B<lgammaf>(), B<lgammal>():"
4379 #: build/C/man3/lgamma.3:59
4380 msgid "B<lgamma_r>(), B<lgammaf_r>(), B<lgammal_r>():"
4384 #: build/C/man3/lgamma.3:63
4389 #: build/C/man3/lgamma.3:80
4391 "The B<lgamma>() function returns the natural logarithm of the absolute "
4392 "value of the Gamma function. The sign of the Gamma function is returned in "
4393 "the external integer I<signgam> declared in I<E<lt>math.hE<gt>>. It is 1 "
4394 "when the Gamma function is positive or zero, -1 when it is negative."
4398 #: build/C/man3/lgamma.3:88
4400 "Since using a constant location I<signgam> is not thread-safe, the functions "
4401 "B<lgamma_r>() etc. have been introduced; they return the sign via the "
4402 "argument I<signp>."
4406 #: build/C/man3/lgamma.3:90
4407 msgid "On success, these functions return the natural logarithm of Gamma(x)."
4411 #: build/C/man3/lgamma.3:98
4412 msgid "If I<x> is 1 or 2, +0 is returned."
4416 #: build/C/man3/lgamma.3:114
4418 "If I<x> is a nonpositive integer, a pole error occurs, and the functions "
4419 "return +B<HUGE_VAL>, +B<HUGE_VALF>, or +B<HUGE_VALL>, respectively."
4423 #: build/C/man3/lgamma.3:124 build/C/man3/tgamma.3:83
4425 "If the result overflows, a range error occurs, and the functions return "
4426 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with the correct "
4427 "mathematical sign."
4431 #: build/C/man3/lgamma.3:131
4433 msgid "Pole error: I<x> is a nonpositive integer"
4437 #: build/C/man3/lgamma.3:159
4439 "The B<lgamma>() functions are specified in C99 and POSIX.1-2001. "
4440 "I<signgam> is specified in POSIX.1-2001, but not in C99. The B<lgamma_r>() "
4441 "functions are nonstandard, but present on several other systems."
4444 #. http://sources.redhat.com/bugzilla/show_bug.cgi?id=6777
4446 #: build/C/man3/lgamma.3:169
4448 "In glibc 2.9 and earlier, when a pole error occurs, I<errno> is set to "
4449 "B<EDOM>; instead of the POSIX-mandated B<ERANGE>. Since version 2.10, glibc "
4450 "does the right thing."
4454 #: build/C/man3/lgamma.3:171
4455 msgid "B<tgamma>(3)"
4459 #: build/C/man3/log.3:34
4465 #: build/C/man3/log.3:37
4466 msgid "log, logf, logl - natural logarithmic function"
4470 #: build/C/man3/log.3:42
4472 msgid "B<double log(double >I<x>B<);>\n"
4476 #: build/C/man3/log.3:44
4478 msgid "B<float logf(float >I<x>B<);>\n"
4482 #: build/C/man3/log.3:46
4484 msgid "B<long double logl(long double >I<x>B<);>\n"
4488 #: build/C/man3/log.3:58
4489 msgid "B<logf>(), B<logl>():"
4493 #: build/C/man3/log.3:70
4494 msgid "The B<log>() function returns the natural logarithm of I<x>."
4498 #: build/C/man3/log.3:73
4499 msgid "On success, these functions return the natural logarithm of I<x>."
4503 #: build/C/man3/log.3:82
4504 msgid "If I<x> is 1, the result is +0."
4508 #: build/C/man3/log.3:97 build/C/man3/logb.3:109
4510 "If I<x> is zero, then a pole error occurs, and the functions return "
4511 "-B<HUGE_VAL>, -B<HUGE_VALF>, or -B<HUGE_VALL>, respectively."
4515 #: build/C/man3/log.3:102
4517 "If I<x> is negative (including negative infinity), then a domain error "
4518 "occurs, and a NaN (not a number) is returned."
4522 #: build/C/man3/log.3:109 build/C/man3/y0.3:163
4524 msgid "Domain error: I<x> is negative"
4528 #: build/C/man3/log.3:117
4530 msgid "Pole error: I<x> is zero"
4534 #: build/C/man3/log.3:125 build/C/man3/tgamma.3:123
4536 "I<errno> is set to B<ERANGE>. A divide-by-zero floating-point exception "
4537 "(B<FE_DIVBYZERO>) is raised."
4541 #: build/C/man3/log.3:138
4543 "In glibc 2.5 and earlier, taking the B<log>() of a NaN produces a bogus "
4544 "invalid floating-point (B<FE_INVALID>) exception."
4548 #: build/C/man3/log.3:145
4549 msgid "B<cbrt>(3), B<clog>(3), B<log10>(3), B<log1p>(3), B<log2>(3), B<sqrt>(3)"
4553 #: build/C/man3/log10.3:34
4559 #: build/C/man3/log10.3:37
4560 msgid "log10, log10f, log10l - base-10 logarithmic function"
4564 #: build/C/man3/log10.3:42
4566 msgid "B<double log10(double >I<x>B<);>\n"
4570 #: build/C/man3/log10.3:44
4572 msgid "B<float log10f(float >I<x>B<);>\n"
4576 #: build/C/man3/log10.3:46
4578 msgid "B<long double log10l(long double >I<x>B<);>\n"
4582 #: build/C/man3/log10.3:58
4583 msgid "B<log10f>(), B<log10l>():"
4587 #: build/C/man3/log10.3:70
4588 msgid "The B<log10>() function returns the base 10 logarithm of I<x>."
4592 #: build/C/man3/log10.3:73
4593 msgid "On success, these functions return the base 10 logarithm of I<x>."
4597 #: build/C/man3/log10.3:78 build/C/man3/log2.3:78
4599 "For special cases, including where I<x> is 0, 1, negative, infinity, or NaN, "
4604 #: build/C/man3/log10.3:86 build/C/man3/log2.3:86
4606 "For a discussion of the errors that can occur for these functions, see "
4611 #: build/C/man3/log10.3:99
4612 msgid "B<cbrt>(3), B<clog10>(3), B<exp10>(3), B<log>(3), B<log2>(3), B<sqrt>(3)"
4616 #: build/C/man3/log1p.3:27
4622 #: build/C/man3/log1p.3:30
4623 msgid "log1p, log1pf, log1pl - logarithm of 1 plus argument"
4627 #: build/C/man3/log1p.3:35
4629 msgid "B<double log1p(double >I<x>B<);>\n"
4633 #: build/C/man3/log1p.3:37
4635 msgid "B<float log1pf(float >I<x>B<);>\n"
4639 #: build/C/man3/log1p.3:39
4641 msgid "B<long double log1pl(long double >I<x>B<);>\n"
4645 #: build/C/man3/log1p.3:50
4650 #: build/C/man3/log1p.3:61
4651 msgid "B<log1pf>(), B<log1pl>():"
4655 #: build/C/man3/log1p.3:72
4656 msgid "I<log1p(x)> returns a value equivalent to"
4660 #: build/C/man3/log1p.3:75
4662 msgid " log (1 + I<x>)\n"
4666 #: build/C/man3/log1p.3:79
4668 "It is computed in a way that is accurate even if the value of I<x> is near "
4673 #: build/C/man3/log1p.3:82
4674 msgid "On success, these functions return the natural logarithm of I<(1\\ +\\ x)>."
4678 #: build/C/man3/log1p.3:101
4680 "If I<x> is -1, a pole error occurs, and the functions return -B<HUGE_VAL>, "
4681 "-B<HUGE_VALF>, or -B<HUGE_VALL>, respectively."
4684 #. POSIX.1 specifies a possible range error if x is subnormal
4685 #. glibc 2.8 doesn't do this
4687 #: build/C/man3/log1p.3:109
4689 "If I<x> is less than -1 (including negative infinity), a domain error "
4690 "occurs, and a NaN (not a number) is returned."
4694 #: build/C/man3/log1p.3:116
4696 msgid "Domain error: I<x> is less than -1"
4700 #: build/C/man3/log1p.3:124
4702 msgid "Pole error: I<x> is -1"
4709 #: build/C/man3/log1p.3:132 build/C/man3/logb.3:129
4710 msgid "A divide-by-zero floating-point exception (B<FE_DIVBYZERO>) is raised."
4714 #: build/C/man3/log1p.3:145
4715 msgid "B<exp>(3), B<expm1>(3), B<log>(3)"
4719 #: build/C/man3/log2.3:34
4725 #: build/C/man3/log2.3:37
4726 msgid "log2, log2f, log2l - base-2 logarithmic function"
4730 #: build/C/man3/log2.3:42
4732 msgid "B<double log2(double >I<x>B<);>\n"
4736 #: build/C/man3/log2.3:44
4738 msgid "B<float log2f(float >I<x>B<);>\n"
4742 #: build/C/man3/log2.3:46
4744 msgid "B<long double log2l(long double >I<x>B<);>\n"
4748 #: build/C/man3/log2.3:59
4749 msgid "B<log2>(), B<log2f>(), B<log2l>():"
4753 #: build/C/man3/log2.3:70
4754 msgid "The B<log2>() function returns the base 2 logarithm of I<x>."
4758 #: build/C/man3/log2.3:73
4759 msgid "On success, these functions return the base 2 logarithm of I<x>."
4763 #: build/C/man3/log2.3:100
4764 msgid "B<cbrt>(3), B<clog2>(3), B<log>(3), B<log10>(3), B<sqrt>(3)"
4768 #: build/C/man3/logb.3:27
4774 #: build/C/man3/logb.3:30
4775 msgid "logb, logbf, logbl - get exponent of a floating-point value"
4779 #: build/C/man3/logb.3:34
4780 msgid "B<double logb(double >I<x>B<);>"
4784 #: build/C/man3/logb.3:36
4785 msgid "B<float logbf(float >I<x>B<);>"
4789 #: build/C/man3/logb.3:38
4790 msgid "B<long double logbl(long double >I<x>B<);>"
4794 #: build/C/man3/logb.3:48
4799 #: build/C/man3/logb.3:59
4800 msgid "B<logbf>(), B<logbl>():"
4804 #: build/C/man3/logb.3:84
4806 "These functions extract the exponent from the internal floating-point "
4807 "representation of I<x> and return it as a floating-point value. The integer "
4808 "constant B<FLT_RADIX>, defined in I<E<lt>float.hE<gt>>, indicates the radix "
4809 "used for the system's floating-point representation. If B<FLT_RADIX> is 2, "
4810 "B<logb(>I<x>B<)> is equal to B<floor(log2(>I<x>B<))>, except that it is "
4815 #: build/C/man3/logb.3:92
4817 "If I<x> is subnormal, B<logb>() returns the exponent I<x> would have if it "
4822 #: build/C/man3/logb.3:95
4823 msgid "On success, these functions return the exponent of I<x>."
4827 #: build/C/man3/logb.3:114
4829 "If I<x> is negative infinity or positive infinity, then positive infinity is "
4834 #: build/C/man3/logb.3:121
4836 msgid "Pole error: I<x> is 0"
4840 #: build/C/man3/logb.3:146
4841 msgid "B<ilogb>(3), B<log>(3)"
4845 #: build/C/man3/lrint.3:25
4851 #: build/C/man3/lrint.3:28
4852 msgid "lrint, lrintf, lrintl, llrint, llrintf, llrintl - round to nearest integer"
4856 #: build/C/man3/lrint.3:33
4858 msgid "B<long int lrint(double >I<x>B<);>\n"
4862 #: build/C/man3/lrint.3:35
4864 msgid "B<long int lrintf(float >I<x>B<);>\n"
4868 #: build/C/man3/lrint.3:37
4870 msgid "B<long int lrintl(long double >I<x>B<);>\n"
4874 #: build/C/man3/lrint.3:39
4876 msgid "B<long long int llrint(double >I<x>B<);>\n"
4880 #: build/C/man3/lrint.3:41
4882 msgid "B<long long int llrintf(float >I<x>B<);>\n"
4886 #: build/C/man3/lrint.3:43
4888 msgid "B<long long int llrintl(long double >I<x>B<);>\n"
4892 #: build/C/man3/lrint.3:54 build/C/man3/lround.3:55
4893 msgid "All functions shown above:"
4897 #: build/C/man3/lrint.3:66
4899 "These functions round their argument to the nearest integer value, using the "
4900 "current rounding direction (see B<fesetround>(3))."
4904 #: build/C/man3/lrint.3:71
4906 "Note that unlike B<rint>(3), etc., the return type of these functions "
4907 "differs from that of their arguments."
4911 #: build/C/man3/lrint.3:73 build/C/man3/lround.3:76 build/C/man3/rint.3:105 build/C/man3/round.3:73 build/C/man3/trunc.3:61
4912 msgid "These functions return the rounded integer value."
4915 #. The return value is -(LONG_MAX - 1) or -(LLONG_MAX -1)
4917 #: build/C/man3/lrint.3:85 build/C/man3/lround.3:88
4919 "If I<x> is a NaN or an infinity, or the rounded value is too large to be "
4920 "stored in a I<long> (I<long long> in the case of the B<ll*> functions) then "
4921 "a domain error occurs, and the return value is unspecified."
4925 #: build/C/man3/lrint.3:92 build/C/man3/lround.3:95
4927 msgid "Domain error: I<x> is a NaN or infinite, or the rounded value is too large"
4931 #: build/C/man3/lrint.3:116
4933 "B<ceil>(3), B<floor>(3), B<lround>(3), B<nearbyint>(3), B<rint>(3), "
4938 #: build/C/man3/lround.3:25
4944 #: build/C/man3/lround.3:29
4946 "lround, lroundf, lroundl, llround, llroundf, llroundl - round to nearest "
4947 "integer, away from zero"
4951 #: build/C/man3/lround.3:34
4953 msgid "B<long int lround(double >I<x>B<);>\n"
4957 #: build/C/man3/lround.3:36
4959 msgid "B<long int lroundf(float >I<x>B<);>\n"
4963 #: build/C/man3/lround.3:38
4965 msgid "B<long int lroundl(long double >I<x>B<);>\n"
4969 #: build/C/man3/lround.3:40
4971 msgid "B<long long int llround(double >I<x>B<);>\n"
4975 #: build/C/man3/lround.3:42
4977 msgid "B<long long int llroundf(float >I<x>B<);>\n"
4981 #: build/C/man3/lround.3:44
4983 msgid "B<long long int llroundl(long double >I<x>B<);>\n"
4987 #: build/C/man3/lround.3:68
4989 "These functions round their argument to the nearest integer value, rounding "
4990 "away from zero, regardless of the current rounding direction (see "
4995 #: build/C/man3/lround.3:74
4997 "Note that unlike B<round>(3), B<ceil>(3), etc., the return type of these "
4998 "functions differs from that of their arguments."
5002 #: build/C/man3/lround.3:119 build/C/man3/trunc.3:85
5004 "B<ceil>(3), B<floor>(3), B<lrint>(3), B<nearbyint>(3), B<rint>(3), "
5009 #: build/C/man7/math_error.7:24
5015 #: build/C/man7/math_error.7:27
5016 msgid "math_error - detecting errors from mathematical functions"
5020 #: build/C/man7/math_error.7:32
5023 "B<#include E<lt>math.hE<gt>>\n"
5024 "B<#include E<lt>errno.hE<gt>>\n"
5025 "B<#include E<lt>fenv.hE<gt>>\n"
5029 #: build/C/man7/math_error.7:51
5031 "When an error occurs, most library functions indicate this fact by returning "
5032 "a special value (e.g., -1 or NULL). Because they typically return a "
5033 "floating-point number, the mathematical functions declared in "
5034 "I<E<lt>math.hE<gt>> indicate an error using other mechanisms. There are two "
5035 "error-reporting mechanisms: the older one sets I<errno>; the newer one uses "
5036 "the floating-point exception mechanism (the use of B<feclearexcept>(3) and "
5037 "B<fetestexcept>(3), as outlined below) described in B<fenv>(3)."
5041 #: build/C/man7/math_error.7:56
5043 "A portable program that needs to check for an error from a mathematical "
5044 "function should set I<errno> to zero, and make the following call"
5048 #: build/C/man7/math_error.7:60
5050 msgid "feclearexcept(FE_ALL_EXCEPT);\n"
5054 #: build/C/man7/math_error.7:64
5055 msgid "before calling a mathematical function."
5059 #: build/C/man7/math_error.7:70
5061 "Upon return from the mathematical function, if I<errno> is nonzero, or the "
5062 "following call (see B<fenv>(3)) returns nonzero"
5066 #: build/C/man7/math_error.7:75
5069 "fetestexcept(FE_INVALID | FE_DIVBYZERO | FE_OVERFLOW |\n"
5075 #. FE_INVALID = 0x01,
5076 #. __FE_DENORM = 0x02,
5077 #. FE_DIVBYZERO = 0x04,
5078 #. FE_OVERFLOW = 0x08,
5079 #. FE_UNDERFLOW = 0x10,
5080 #. FE_INEXACT = 0x20
5083 #: build/C/man7/math_error.7:88
5084 msgid "then an error occurred in the mathematical function."
5088 #: build/C/man7/math_error.7:91
5090 "The error conditions that can occur for mathematical functions are described "
5095 #: build/C/man7/math_error.7:91
5097 msgid "Domain Error"
5101 #: build/C/man7/math_error.7:107
5103 "A I<domain error> occurs when a mathematical function is supplied with an "
5104 "argument whose value falls outside the domain for which the function is "
5105 "defined (e.g., giving a negative argument to B<log>(3)). When a domain "
5106 "error occurs, math functions commonly return a NaN (though some functions "
5107 "return a different value in this case); I<errno> is set to B<EDOM>, and an "
5108 "\"invalid\" (B<FE_INVALID>) floating-point exception is raised."
5112 #: build/C/man7/math_error.7:107
5118 #: build/C/man7/math_error.7:131
5120 "A I<pole error> occurs when the mathematical result of a function is an "
5121 "exact infinity (e.g., the logarithm of 0 is negative infinity). When a pole "
5122 "error occurs, the function returns the (signed) value B<HUGE_VAL>, "
5123 "B<HUGE_VALF>, or B<HUGE_VALL>, depending on whether the function result type "
5124 "is I<double>, I<float>, or I<long double>. The sign of the result is that "
5125 "which is mathematically correct for the function. I<errno> is set to "
5126 "B<ERANGE>, and a \"divide-by-zero\" (B<FE_DIVBYZERO>) floating-point "
5127 "exception is raised."
5131 #: build/C/man7/math_error.7:131
5137 #: build/C/man7/math_error.7:138
5139 "A I<range error> occurs when the magnitude of the function result means that "
5140 "it cannot be represented in the result type of the function. The return "
5141 "value of the function depends on whether the range error was an overflow or "
5146 #: build/C/man7/math_error.7:160
5148 "A floating result I<overflows> if the result is finite, but is too large to "
5149 "represented in the result type. When an overflow occurs, the function "
5150 "returns the value B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, depending on "
5151 "whether the function result type is I<double>, I<float>, or I<long double>. "
5152 "I<errno> is set to B<ERANGE>, and an \"overflow\" (B<FE_OVERFLOW>) "
5153 "floating-point exception is raised."
5157 #: build/C/man7/math_error.7:175
5159 "A floating result I<underflows> if the result is too small to be represented "
5160 "in the result type. If an underflow occurs, a mathematical function "
5161 "typically returns 0.0 (C99 says a function shall return \"an "
5162 "implementation-defined value whose magnitude is no greater than the smallest "
5163 "normalized positive number in the specified type\"). I<errno> may be set to "
5164 "B<ERANGE>, and an \"overflow\" (B<FE_UNDERFLOW>) floating-point exception "
5169 #: build/C/man7/math_error.7:185
5171 "Some functions deliver a range error if the supplied argument value, or the "
5172 "correct function result, would be I<subnormal>. A subnormal value is one "
5173 "that is nonzero, but with a magnitude that is so small that it can't be "
5174 "presented in normalized form (i.e., with a 1 in the most significant bit of "
5175 "the significand). The representation of a subnormal number will contain one "
5176 "or more leading zeros in the significand."
5179 #. See CONFORMANCE in the glibc 2.8 (and earlier) source.
5181 #: build/C/man7/math_error.7:207
5183 "The I<math_errhandling> identifier specified by C99 and POSIX.1-2001 is not "
5184 "supported by glibc. This identifier is supposed to indicate which of the "
5185 "two error-notification mechanisms (I<errno>, exceptions retrievable via "
5186 "B<fettestexcept>(3)) is in use. The standards require that at least one be "
5187 "in use, but permit both to be available. The current (version 2.8) "
5188 "situation under glibc is messy. Most (but not all) functions raise "
5189 "exceptions on errors. Some also set I<errno>. A few functions set "
5190 "I<errno>, but don't raise an exception. A very few functions do neither. "
5191 "See the individual manual pages for details."
5194 #. http://www.securecoding.cert.org/confluence/display/seccode/FLP32-C.+Prevent+or+detect+domain+and+range+errors+in+math+functions
5196 #: build/C/man7/math_error.7:220
5198 "To avoid the complexities of using I<errno> and B<fetestexcept>(3) for "
5199 "error checking, it is often advised that one should instead check for bad "
5200 "argument values before each call. For example, the following code ensures "
5201 "that B<log>(3)'s argument is not a NaN and is not zero (a pole error) or "
5202 "less than zero (a domain error):"
5206 #: build/C/man7/math_error.7:224
5208 msgid "double x, r;\n"
5212 #: build/C/man7/math_error.7:228
5215 "if (isnan(x) || islessequal(x, 0)) {\n"
5216 " /* Deal with NaN / pole error / domain error */\n"
5221 #: build/C/man7/math_error.7:230
5223 msgid "r = log(x);\n"
5227 #: build/C/man7/math_error.7:238
5229 "The discussion on this page does not apply to the complex mathematical "
5230 "functions (i.e., those declared by I<E<lt>complex.hE<gt>>), which in general "
5231 "are not required to return errors by C99 and POSIX.1-2001."
5235 #: build/C/man7/math_error.7:254
5237 "The B<gcc>(1) I<-fno-math-errno> option causes the executable to employ "
5238 "implementations of some mathematical functions that are faster than the "
5239 "standard implementations, but do not set I<errno> on error. (The B<gcc>(1) "
5240 "I<-ffast-math> option also enables I<-fno-math-errno>.) An error can still "
5241 "be tested for using B<fetestexcept>(3)."
5245 #: build/C/man7/math_error.7:263
5247 "B<gcc>(1), B<errno>(3), B<fenv>(3), B<fpclassify>(3), B<INFINITY>(3), "
5248 "B<isgreater>(3), B<matherr>(3), B<nan>(3)"
5252 #: build/C/man7/math_error.7:265
5253 msgid "I<info libc>"
5257 #: build/C/man3/matherr.3:25
5263 #: build/C/man3/matherr.3:25
5269 #: build/C/man3/matherr.3:28
5270 msgid "matherr - SVID math library exception handling"
5274 #: build/C/man3/matherr.3:32
5277 "B<#define _SVID_SOURCE> /* See feature_test_macros(7) */\n"
5278 "B<#include E<lt>math.hE<gt>>\n"
5282 #: build/C/man3/matherr.3:34
5284 msgid "B<int matherr(struct exception *>I<exc>B<);>\n"
5288 #: build/C/man3/matherr.3:36
5290 msgid "B<extern _LIB_VERSION_TYPE _LIB_VERSION;>\n"
5294 #: build/C/man3/matherr.3:49
5296 "The System V Interface Definition (SVID) specifies that various math "
5297 "functions should invoke a function called B<matherr>() if a math exception "
5298 "is detected. This function is called before the math function returns; "
5299 "after B<matherr>() returns, the system then returns to the math function, "
5300 "which in turn returns to the caller."
5304 #: build/C/man3/matherr.3:60
5306 "The B<matherr>() mechanism is supported by glibc, but is now obsolete: new "
5307 "applications should use the techniques described in B<math_error>(7) and "
5308 "B<fenv>(3). This page documents the glibc B<matherr>() mechanism as an aid "
5309 "for maintaining and porting older applications."
5313 #: build/C/man3/matherr.3:73
5315 "To employ B<matherr>(), the programmer must define the B<_SVID_SOURCE> "
5316 "feature test macro (before including I<any> header files), and assign the "
5317 "value B<_SVID_> to the external variable B<_LIB_VERSION>."
5321 #: build/C/man3/matherr.3:85
5323 "The system provides a default version of B<matherr>(). This version does "
5324 "nothing, and returns zero (see below for the significance of this). The "
5325 "default B<matherr>() can be overridden by a programmer-defined version, "
5326 "which will be invoked when an exception occurs. The function is invoked "
5327 "with one argument, a pointer to an I<exception> structure, defined as "
5332 #: build/C/man3/matherr.3:95
5335 "struct exception {\n"
5336 " int type; /* Exception type */\n"
5337 " char *name; /* Name of function causing exception */\n"
5338 " double arg1; /* 1st argument to function */\n"
5339 " double arg2; /* 2nd argument to function */\n"
5340 " double retval; /* Function return value */\n"
5345 #: build/C/man3/matherr.3:101
5346 msgid "The I<type> field has one of the following values:"
5350 #: build/C/man3/matherr.3:101
5356 #: build/C/man3/matherr.3:109
5358 "A domain error occurred (the function argument was outside the range for "
5359 "which the function is defined). The return value depends on the function; "
5360 "I<errno> is set to B<EDOM>."
5364 #: build/C/man3/matherr.3:109
5370 #: build/C/man3/matherr.3:120
5372 "A pole error occurred (the function result is an infinity). The return "
5373 "value in most cases is B<HUGE> (the largest single precision floating-point "
5374 "number), appropriately signed. In most cases, I<errno> is set to B<EDOM>."
5378 #: build/C/man3/matherr.3:120
5384 #: build/C/man3/matherr.3:129
5386 "An overflow occurred. In most cases, the value B<HUGE> is returned, and "
5387 "I<errno> is set to B<ERANGE>."
5391 #: build/C/man3/matherr.3:129
5393 msgid "B<UNDERFLOW>"
5397 #: build/C/man3/matherr.3:136
5398 msgid "An underflow occurred. 0.0 is returned, and I<errno> is set to B<ERANGE>."
5402 #: build/C/man3/matherr.3:136
5408 #: build/C/man3/matherr.3:143
5410 "Total loss of significance. 0.0 is returned, and I<errno> is set to "
5415 #: build/C/man3/matherr.3:143
5421 #: build/C/man3/matherr.3:148
5423 "Partial loss of significance. This value is unused on glibc (and many other "
5428 #: build/C/man3/matherr.3:156
5430 "The I<arg1> and I<arg2> fields are the arguments supplied to the function "
5431 "(I<arg2> is undefined for functions that take only one argument)."
5435 #: build/C/man3/matherr.3:164
5437 "The I<retval> field specifies the return value that the math function will "
5438 "return to its caller. The programmer-defined B<matherr>() can modify this "
5439 "field to change the return value of the math function."
5443 #: build/C/man3/matherr.3:171
5445 "If the B<matherr>() function returns zero, then the system sets I<errno> as "
5446 "described above, and may print an error message on standard error (see "
5451 #: build/C/man3/matherr.3:177
5453 "If the B<matherr>() function returns a nonzero value, then the system does "
5454 "not set I<errno>, and doesn't print an error message."
5458 #: build/C/man3/matherr.3:177
5460 msgid "Math functions that employ matherr()"
5464 #: build/C/man3/matherr.3:187
5466 "The table below lists the functions and circumstances in which B<matherr>() "
5467 "is called. The \"Type\" column indicates the value assigned to "
5468 "I<exc-E<gt>type> when calling B<matherr>(). The \"Result\" column is the "
5469 "default return value assigned to I<exc-E<gt>retval>."
5473 #: build/C/man3/matherr.3:193
5475 "The \"Msg?\" and \"errno\" columns describe the default behavior if "
5476 "B<matherr>() returns zero. If the \"Msg?\" columns contains \"y\", then "
5477 "the system prints an error message on standard error."
5481 #: build/C/man3/matherr.3:195
5482 msgid "The table uses the following notations and abbreviations:"
5486 #: build/C/man3/matherr.3:207
5489 "x first argument to function\n"
5490 "y second argument to function\n"
5491 "fin finite value for argument\n"
5492 "neg negative value for argument\n"
5493 "int integral value for argument\n"
5494 "o/f result overflowed\n"
5495 "u/f result underflowed\n"
5496 "|x| absolute value of x\n"
5497 "X_TLOSS is a constant defined in I<E<lt>math.hE<gt>>\n"
5501 #: build/C/man3/matherr.3:214
5503 msgid "Function\tType\tResult\tMsg?\terrno\n"
5507 #: build/C/man3/matherr.3:215
5509 msgid "acos(|x|E<gt>1)\tDOMAIN\tHUGE\ty\tEDOM\n"
5513 #: build/C/man3/matherr.3:216
5515 msgid "asin(|x|E<gt>1)\tDOMAIN\tHUGE\ty\tEDOM\n"
5519 #: build/C/man3/matherr.3:217
5521 msgid "atan2(0,0)\tDOMAIN\tHUGE\ty\tEDOM\n"
5524 #. retval is 0.0/0.0
5526 #: build/C/man3/matherr.3:218
5528 msgid "acosh(xE<lt>1)\tDOMAIN\tNAN\ty\tEDOM \n"
5531 #. retval is 0.0/0.0
5533 #: build/C/man3/matherr.3:219
5535 msgid "atanh(|x|E<gt>1)\tDOMAIN\tNAN\ty\tEDOM \n"
5540 #: build/C/man3/matherr.3:220
5542 msgid "atanh(|x|==1)\tSING\t(xE<gt>0.0)?\ty\tEDOM \n"
5546 #: build/C/man3/matherr.3:221 build/C/man3/matherr.3:266
5548 msgid "\\ \t\\ \tHUGE_VAL :\n"
5552 #: build/C/man3/matherr.3:222 build/C/man3/matherr.3:267
5554 msgid "\\ \t\\ \t-HUGE_VAL\n"
5558 #: build/C/man3/matherr.3:223
5560 msgid "cosh(fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5564 #: build/C/man3/matherr.3:224
5566 msgid "sinh(fin) o/f\tOVERFLOW\t(xE<gt>0.0) ?\tn\tERANGE\n"
5570 #: build/C/man3/matherr.3:225
5572 msgid "\\ \t\\ \tHUGE : -HUGE\n"
5576 #: build/C/man3/matherr.3:226
5578 msgid "sqrt(xE<lt>0)\tDOMAIN\t0.0\ty\tEDOM\n"
5582 #: build/C/man3/matherr.3:227
5584 msgid "hypot(fin,fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5588 #: build/C/man3/matherr.3:228
5590 msgid "exp(fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5594 #: build/C/man3/matherr.3:229
5596 msgid "exp(fin) u/f\tUNDERFLOW\t0.0\tn\tERANGE\n"
5600 #: build/C/man3/matherr.3:230
5602 msgid "exp2(fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5606 #: build/C/man3/matherr.3:231
5608 msgid "exp2(fin) u/f\tUNDERFLOW\t0.0\tn\tERANGE\n"
5612 #: build/C/man3/matherr.3:232
5614 msgid "exp10(fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5618 #: build/C/man3/matherr.3:233
5620 msgid "exp10(fin) u/f\tUNDERFLOW\t0.0\tn\tERANGE\n"
5624 #: build/C/man3/matherr.3:234
5626 msgid "j0(|x|E<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5630 #: build/C/man3/matherr.3:235
5632 msgid "j1(|x|E<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5636 #: build/C/man3/matherr.3:236
5638 msgid "jn(|x|E<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5642 #: build/C/man3/matherr.3:237
5644 msgid "y0(xE<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5648 #: build/C/man3/matherr.3:238
5650 msgid "y1(xE<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5654 #: build/C/man3/matherr.3:239
5656 msgid "yn(xE<gt>X_TLOSS)\tTLOSS\t0.0\ty\tERANGE\n"
5660 #: build/C/man3/matherr.3:240
5662 msgid "y0(0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5666 #: build/C/man3/matherr.3:241
5668 msgid "y0(xE<lt>0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5672 #: build/C/man3/matherr.3:242
5674 msgid "y1(0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5678 #: build/C/man3/matherr.3:243
5680 msgid "y1(xE<lt>0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5684 #: build/C/man3/matherr.3:244
5686 msgid "yn(n,0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5690 #: build/C/man3/matherr.3:245
5692 msgid "yn(xE<lt>0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5696 #: build/C/man3/matherr.3:246
5698 msgid "lgamma(fin) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5702 #: build/C/man3/matherr.3:247
5704 msgid "lgamma(-int) or\tSING\tHUGE\ty\tEDOM\n"
5708 #: build/C/man3/matherr.3:248
5710 msgid "\\ \\ lgamma(0)\n"
5714 #: build/C/man3/matherr.3:249
5716 msgid "tgamma(fin) o/f\tOVERFLOW\tHUGE_VAL\tn\tERANGE\n"
5720 #: build/C/man3/matherr.3:250
5722 msgid "tgamma(-int)\tSING\tNAN\ty\tEDOM\n"
5726 #: build/C/man3/matherr.3:251
5728 msgid "tgamma(0)\tSING\tcopysign(\ty\tERANGE\n"
5732 #: build/C/man3/matherr.3:252
5734 msgid "\\ \t\\ \tHUGE_VAL,x)\n"
5738 #: build/C/man3/matherr.3:253
5740 msgid "log(0)\tSING\t-HUGE\ty\tEDOM\n"
5744 #: build/C/man3/matherr.3:254
5746 msgid "log(xE<lt>0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5749 #. different from log()
5751 #: build/C/man3/matherr.3:255
5753 msgid "log2(0)\tSING\t-HUGE\tn\tEDOM\t\n"
5756 #. different from log()
5758 #: build/C/man3/matherr.3:256
5760 msgid "log2(xE<lt>0)\tDOMAIN\t-HUGE\tn\tEDOM\t\n"
5764 #: build/C/man3/matherr.3:257
5766 msgid "log10(0)\tSING\t-HUGE\ty\tEDOM\n"
5770 #: build/C/man3/matherr.3:258
5772 msgid "log10(xE<lt>0)\tDOMAIN\t-HUGE\ty\tEDOM\n"
5776 #: build/C/man3/matherr.3:259
5778 msgid "pow(0.0,0.0)\tDOMAIN\t0.0\ty\tEDOM\n"
5782 #: build/C/man3/matherr.3:260
5784 msgid "pow(x,y) o/f\tOVERFLOW\tHUGE\tn\tERANGE\n"
5788 #: build/C/man3/matherr.3:261
5790 msgid "pow(x,y) u/f\tUNDERFLOW\t0.0\tn\tERANGE\n"
5794 #: build/C/man3/matherr.3:262
5796 msgid "pow(NaN,0.0)\tDOMAIN\tx\tn\tEDOM\n"
5801 #: build/C/man3/matherr.3:263
5803 msgid "0**neg\tDOMAIN\t0.0\ty\tEDOM\t\n"
5807 #: build/C/man3/matherr.3:264
5809 msgid "neg**non-int\tDOMAIN\t0.0\ty\tEDOM\n"
5813 #: build/C/man3/matherr.3:265
5815 msgid "scalb() o/f\tOVERFLOW\t(xE<gt>0.0) ?\tn\tERANGE\n"
5819 #: build/C/man3/matherr.3:268
5821 msgid "scalb() u/f\tUNDERFLOW\tcopysign(\tn\tERANGE\n"
5825 #: build/C/man3/matherr.3:269
5827 msgid "\\ \t\\ \t\\ \\ 0.0,x)\n"
5831 #: build/C/man3/matherr.3:270
5833 msgid "fmod(x,0)\tDOMAIN\tx\ty\tEDOM\n"
5836 #. retval is 0.0/0.0
5838 #: build/C/man3/matherr.3:271
5840 msgid "remainder(x,0)\tDOMAIN\tNAN\ty\tEDOM \n"
5844 #: build/C/man3/matherr.3:294
5846 "The example program demonstrates the use of B<matherr>() when calling "
5847 "B<log>(3). The program takes up to three command-line arguments. The first "
5848 "argument is the floating-point number to be given to B<log>(3). If the "
5849 "optional second argument is provided, then B<_LIB_VERSION> is set to "
5850 "B<_SVID_> so that B<matherr>() is called, and the integer supplied in the "
5851 "command-line argument is used as the return value from B<matherr>(). If the "
5852 "optional third command-line argument is supplied, then it specifies an "
5853 "alternative return value that B<matherr>() should assign as the return "
5854 "value of the math function."
5858 #: build/C/man3/matherr.3:299
5860 "The following example run, where B<log>(3) is given an argument of 0.0, "
5861 "does not use B<matherr>():"
5865 #: build/C/man3/matherr.3:305
5868 "$B< ./a.out 0.0>\n"
5869 "errno: Numerical result out of range\n"
5874 #: build/C/man3/matherr.3:311
5875 msgid "In the following run, B<matherr>() is called, and returns 0:"
5879 #: build/C/man3/matherr.3:321
5882 "$B< ./a.out 0.0 0>\n"
5883 "matherr SING exception in log() function\n"
5884 " args: 0.000000, 0.000000\n"
5885 " retval: -340282346638528859811704183484516925440.000000\n"
5887 "errno: Numerical argument out of domain\n"
5888 "x=-340282346638528859811704183484516925440.000000\n"
5892 #: build/C/man3/matherr.3:325
5893 msgid "The message \"log: SING error\" was printed by the C library."
5897 #: build/C/man3/matherr.3:329
5898 msgid "In the following run, B<matherr>() is called, and returns a nonzero value:"
5902 #: build/C/man3/matherr.3:337
5905 "$B< ./a.out 0.0 1>\n"
5906 "matherr SING exception in log() function\n"
5907 " args: 0.000000, 0.000000\n"
5908 " retval: -340282346638528859811704183484516925440.000000\n"
5909 "x=-340282346638528859811704183484516925440.000000\n"
5913 #: build/C/man3/matherr.3:343
5915 "In this case, the C library did not print a message, and I<errno> was not "
5920 #: build/C/man3/matherr.3:348
5922 "In the following run, B<matherr>() is called, changes the return value of "
5923 "the math function, and returns a nonzero value:"
5927 #: build/C/man3/matherr.3:356
5930 "$B< ./a.out 0.0 1 12345.0>\n"
5931 "matherr SING exception in log() function\n"
5932 " args: 0.000000, 0.000000\n"
5933 " retval: -340282346638528859811704183484516925440.000000\n"
5938 #: build/C/man3/matherr.3:366
5941 "#define _SVID_SOURCE\n"
5942 "#include E<lt>errno.hE<gt>\n"
5943 "#include E<lt>math.hE<gt>\n"
5944 "#include E<lt>stdio.hE<gt>\n"
5945 "#include E<lt>stdlib.hE<gt>\n"
5949 #: build/C/man3/matherr.3:372
5952 "static int matherr_ret = 0; /* Value that matherr()\n"
5953 " should return */\n"
5954 "static int change_retval = 0; /* Should matherr() change\n"
5955 " function\\(aqs return value? */\n"
5956 "static double new_retval; /* New function return value */\n"
5960 #: build/C/man3/matherr.3:387
5964 "matherr(struct exception *exc)\n"
5966 " fprintf(stderr, \"matherr %s exception in %s() function\\en\",\n"
5967 " (exc-E<gt>type == DOMAIN) ? \"DOMAIN\" :\n"
5968 " (exc-E<gt>type == OVERFLOW) ? \"OVERFLOW\" :\n"
5969 " (exc-E<gt>type == UNDERFLOW) ? \"UNDERFLOW\" :\n"
5970 " (exc-E<gt>type == SING) ? \"SING\" :\n"
5971 " (exc-E<gt>type == TLOSS) ? \"TLOSS\" :\n"
5972 " (exc-E<gt>type == PLOSS) ? \"PLOSS\" : \"???\",\n"
5973 " exc-E<gt>name);\n"
5974 " fprintf(stderr, \" args: %f, %f\\en\",\n"
5975 " exc-E<gt>arg1, exc-E<gt>arg2);\n"
5976 " fprintf(stderr, \" retval: %f\\en\", exc-E<gt>retval);\n"
5980 #: build/C/man3/matherr.3:390
5983 " if (change_retval)\n"
5984 " exc-E<gt>retval = new_retval;\n"
5988 #: build/C/man3/matherr.3:393
5991 " return matherr_ret;\n"
5996 #: build/C/man3/matherr.3:398
6000 "main(int argc, char *argv[])\n"
6006 #: build/C/man3/matherr.3:404
6009 " if (argc E<lt> 2) {\n"
6010 " fprintf(stderr, \"Usage: %s E<lt>argvalE<gt>\"\n"
6011 " \" [E<lt>matherr-retE<gt> "
6012 "[E<lt>new-func-retvalE<gt>]]\\en\", argv[0]);\n"
6013 " exit(EXIT_FAILURE);\n"
6018 #: build/C/man3/matherr.3:409
6021 " if (argc E<gt> 2) {\n"
6022 " _LIB_VERSION = _SVID_;\n"
6023 " matherr_ret = atoi(argv[2]);\n"
6028 #: build/C/man3/matherr.3:414
6031 " if (argc E<gt> 3) {\n"
6032 " change_retval = 1;\n"
6033 " new_retval = atof(argv[3]);\n"
6038 #: build/C/man3/matherr.3:418
6041 " x = log(atof(argv[1]));\n"
6042 " if (errno != 0)\n"
6043 " perror(\"errno\");\n"
6047 #: build/C/man3/matherr.3:422
6050 " printf(\"x=%f\\en\", x);\n"
6051 " exit(EXIT_SUCCESS);\n"
6056 #: build/C/man3/matherr.3:427
6057 msgid "B<fenv>(3), B<math_error>(7), B<standards>(7)"
6061 #: build/C/man3/modf.3:31
6067 #: build/C/man3/modf.3:35
6069 "modf, modff, modfl - extract signed integral and fractional values from "
6070 "floating-point number"
6074 #: build/C/man3/modf.3:40
6076 msgid "B<double modf(double >I<x>B<, double *>I<iptr>B<);>\n"
6080 #: build/C/man3/modf.3:42
6082 msgid "B<float modff(float >I<x>B<, float *>I<iptr>B<);>\n"
6086 #: build/C/man3/modf.3:44
6088 msgid "B<long double modfl(long double >I<x>B<, long double *>I<iptr>B<);>\n"
6092 #: build/C/man3/modf.3:56
6093 msgid "B<modf>(), B<modfl>():"
6097 #: build/C/man3/modf.3:70
6099 "The B<modf>() function breaks the argument I<x> into an integral part and a "
6100 "fractional part, each of which has the same sign as I<x>. The integral part "
6101 "is stored in the location pointed to by I<iptr>."
6105 #: build/C/man3/modf.3:74
6106 msgid "The B<modf>() function returns the fractional part of I<x>."
6110 #: build/C/man3/modf.3:80
6111 msgid "If I<x> is a NaN, a NaN is returned, and I<*iptr> is set to a NaN."
6115 #: build/C/man3/modf.3:86
6117 "If I<x> is positive infinity (negative infinity), +0 (-0) is returned, and "
6118 "I<*iptr> is set to positive infinity (negative infinity)."
6122 #: build/C/man3/modf.3:97
6123 msgid "B<frexp>(3), B<ldexp>(3)"
6127 #: build/C/man3/nan.3:6
6133 #: build/C/man3/nan.3:9
6134 msgid "nan, nanf, nanl - return 'Not a Number'"
6138 #: build/C/man3/nan.3:13
6139 msgid "B<double nan(const char *>I<tagp>B<);>"
6143 #: build/C/man3/nan.3:15
6144 msgid "B<float nanf(const char *>I<tagp>B<);>"
6148 #: build/C/man3/nan.3:17
6149 msgid "B<long double nanl(const char *>I<tagp>B<);>"
6153 #: build/C/man3/nan.3:29
6154 msgid "B<nan>(), B<nanf>(), B<nanl>():"
6158 #: build/C/man3/nan.3:43
6160 "These functions return a representation (determined by I<tagp>) of a quiet "
6161 "NaN. If the implementation does not support quiet NaNs, these functions "
6166 #: build/C/man3/nan.3:47
6167 msgid "The call I<nan(\"char-sequence\")> is equivalent to:"
6171 #: build/C/man3/nan.3:50
6173 msgid " strtod(\"NAN(char-sequence)\", NULL);\n"
6177 #: build/C/man3/nan.3:60
6179 "Similarly, calls to B<nanf>() and B<nanl>() are equivalent to analogous "
6180 "calls to B<strtof>(3) and B<strtold>(3)."
6184 #: build/C/man3/nan.3:68
6186 "The argument I<tagp> is used in an unspecified manner. On IEEE 754 systems, "
6187 "there are many representations of NaN, and I<tagp> selects one. On other "
6188 "systems it may do nothing."
6192 #: build/C/man3/nan.3:74
6194 "C99, POSIX.1-2001. See also IEC 559 and the appendix with recommended "
6195 "functions in IEEE 754/IEEE 854."
6199 #: build/C/man3/nan.3:78
6200 msgid "B<isnan>(3), B<strtod>(3), B<math_error>(7)"
6204 #: build/C/man3/nextafter.3:6
6210 #: build/C/man3/nextafter.3:10
6212 "nextafter, nextafterf, nextafterl, nexttoward, nexttowardf, nexttowardl - "
6213 "floating-point number manipulation"
6217 #: build/C/man3/nextafter.3:14
6218 msgid "B<double nextafter(double >I<x>B<, double >I<y>B<);>"
6222 #: build/C/man3/nextafter.3:16
6223 msgid "B<float nextafterf(float >I<x>B<, float >I<y>B<);>"
6227 #: build/C/man3/nextafter.3:18
6228 msgid "B<long double nextafterl(long double >I<x>B<, long double >I<y>B<);>"
6232 #: build/C/man3/nextafter.3:20
6233 msgid "B<double nexttoward(double >I<x>B<, long double >I<y>B<);>"
6237 #: build/C/man3/nextafter.3:22
6238 msgid "B<float nexttowardf(float >I<x>B<, long double >I<y>B<);>"
6242 #: build/C/man3/nextafter.3:24
6243 msgid "B<long double nexttowardl(long double >I<x>B<, long double >I<y>B<);>"
6247 #: build/C/man3/nextafter.3:34
6248 msgid "B<nextafter>():"
6252 #: build/C/man3/nextafter.3:46
6253 msgid "B<nextafterf>(), B<nextafterl>():"
6257 #: build/C/man3/nextafter.3:57
6258 msgid "B<nexttoward>(), B<nexttowardf>(), B<nexttowardl>():"
6262 #: build/C/man3/nextafter.3:78
6264 "The B<nextafter>() functions return the next representable floating-point "
6265 "value following I<x> in the direction of I<y>. If I<y> is less than I<x>, "
6266 "these functions will return the largest representable number less than I<x>."
6270 #: build/C/man3/nextafter.3:80
6271 msgid "If I<x> equals I<y>, the functions return I<y>."
6275 #: build/C/man3/nextafter.3:88
6277 "The B<nexttoward>() functions do the same as the B<nextafter>() functions, "
6278 "except that they have a I<long double> second argument."
6282 #: build/C/man3/nextafter.3:94
6284 "On success, these functions return the next representable floating-point "
6285 "value after I<x> in the direction of I<y>."
6289 #: build/C/man3/nextafter.3:104
6290 msgid "If I<x> equals I<y>, then I<y> (cast to the same type as I<x>) is returned."
6295 #: build/C/man3/nextafter.3:124
6297 "If I<x> is finite, and the result would overflow, a range error occurs, and "
6298 "the functions return B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, "
6299 "respectively, with the correct mathematical sign."
6303 #: build/C/man3/nextafter.3:133
6305 "If I<x> is not equal to I<y>, and the correct function result would be "
6306 "subnormal, zero, or underflow, a range error occurs, and either the correct "
6307 "value (if it can be represented), or 0.0, is returned."
6311 #: build/C/man3/nextafter.3:149
6313 msgid "Range error: result is subnormal or underflows"
6317 #: build/C/man3/nextafter.3:172
6319 "In glibc version 2.5 and earlier, these functions do not raise an underflow "
6320 "floating-point (B<FE_UNDERFLOW>) exception when an underflow occurs."
6324 #: build/C/man3/nextafter.3:174
6325 msgid "B<nearbyint>(3)"
6329 #: build/C/man3/pow.3:33
6335 #: build/C/man3/pow.3:36
6336 msgid "pow, powf, powl - power functions"
6340 #: build/C/man3/pow.3:41
6342 msgid "B<double pow(double >I<x>B<, double >I<y>B<);>\n"
6346 #: build/C/man3/pow.3:43
6348 msgid "B<float powf(float >I<x>B<, float >I<y>B<);>\n"
6352 #: build/C/man3/pow.3:45
6354 msgid "B<long double powl(long double >I<x>B<, long double >I<y>B<);>\n"
6358 #: build/C/man3/pow.3:57
6359 msgid "B<powf>(), B<powl>():"
6363 #: build/C/man3/pow.3:70
6365 "The B<pow>() function returns the value of I<x> raised to the power of "
6370 #: build/C/man3/pow.3:75
6371 msgid "On success, these functions return the value of I<x> to the power of I<y>."
6374 #. The domain error is generated at least as far back as glibc 2.4
6376 #: build/C/man3/pow.3:83
6378 "If I<x> is a finite value less than 0, and I<y> is a finite noninteger, a "
6379 "domain error occurs, and a NaN is returned."
6382 #. The range error is generated at least as far back as glibc 2.4
6384 #: build/C/man3/pow.3:93
6386 "If the result overflows, a range error occurs, and the functions return "
6387 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with the "
6388 "mathematically correct sign."
6391 #. POSIX.1 does not specify the sign of the zero,
6392 #. but http://sources.redhat.com/bugzilla/show_bug.cgi?id=2678
6393 #. points out that the zero has the wrong sign in some cases.
6395 #: build/C/man3/pow.3:100
6397 "If result underflows, and is not representable, a range error occurs, and "
6402 #: build/C/man3/pow.3:106
6403 msgid "Except as specified below, if I<x> or I<y> is a NaN, the result is a NaN."
6407 #: build/C/man3/pow.3:112
6408 msgid "If I<x> is +1, the result is 1.0 (even if I<y> is a NaN)."
6412 #: build/C/man3/pow.3:118
6413 msgid "If I<y> is 0, the result is 1.0 (even if I<x> is a NaN)."
6417 #: build/C/man3/pow.3:126
6419 "If I<x> is +0 (-0), and I<y> is an odd integer greater than 0, the result is "
6424 #: build/C/man3/pow.3:134
6426 "If I<x> is 0, and I<y> greater than 0 and not an odd integer, the result is "
6431 #: build/C/man3/pow.3:142
6433 "If I<x> is -1, and I<y> is positive infinity or negative infinity, the "
6438 #: build/C/man3/pow.3:150
6440 "If the absolute value of I<x> is less than 1, and I<y> is negative infinity, "
6441 "the result is positive infinity."
6445 #: build/C/man3/pow.3:158
6447 "If the absolute value of I<x> is greater than 1, and I<y> is negative "
6448 "infinity, the result is +0."
6452 #: build/C/man3/pow.3:166
6454 "If the absolute value of I<x> is less than 1, and I<y> is positive infinity, "
6459 #: build/C/man3/pow.3:174
6461 "If the absolute value of I<x> is greater than 1, and I<y> is positive "
6462 "infinity, the result is positive infinity."
6466 #: build/C/man3/pow.3:182
6468 "If I<x> is negative infinity, and I<y> is an odd integer less than 0, the "
6473 #: build/C/man3/pow.3:190
6475 "If I<x> is negative infinity, and I<y> less than 0 and not an odd integer, "
6480 #: build/C/man3/pow.3:198
6482 "If I<x> is negative infinity, and I<y> is an odd integer greater than 0, the "
6483 "result is negative infinity."
6487 #: build/C/man3/pow.3:206
6489 "If I<x> is negative infinity, and I<y> greater than 0 and not an odd "
6490 "integer, the result is positive infinity."
6494 #: build/C/man3/pow.3:214
6495 msgid "If I<x> is positive infinity, and I<y> less than 0, the result is +0."
6499 #: build/C/man3/pow.3:222
6501 "If I<x> is positive infinity, and I<y> greater than 0, the result is "
6502 "positive infinity."
6506 #: build/C/man3/pow.3:237
6508 "If I<x> is +0 or -0, and I<y> is an odd integer less than 0, a pole error "
6509 "occurs and B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, is returned, with the "
6510 "same sign as I<x>."
6513 #. The pole error is generated at least as far back as glibc 2.4
6515 #: build/C/man3/pow.3:251
6517 "If I<x> is +0 or -0, and I<y> is less than 0 and not an odd integer, a pole "
6518 "error occurs and +B<HUGE_VAL>, +B<HUGE_VALF>, or +B<HUGE_VALL>, is returned."
6522 #: build/C/man3/pow.3:278
6524 msgid "Domain error: I<x> is negative, and I<y> is a finite noninteger"
6528 #: build/C/man3/pow.3:286
6530 msgid "Pole error: I<x> is zero, and I<y> is negative"
6534 #: build/C/man3/pow.3:295
6536 msgid "Range error: the result overflows"
6540 #: build/C/man3/pow.3:303
6542 msgid "Range error: the result underflows"
6546 #. http://sources.redhat.com/bugzilla/show_bug.cgi?id=6776
6547 #. or possibly 2.9, I haven't found the source code change
6548 #. and I don't have a 2.9 system to test
6550 #: build/C/man3/pow.3:331
6552 "In glibc 2.9 and earlier, when a pole error occurs, I<errno> is set to "
6553 "B<EDOM> instead of the POSIX-mandated B<ERANGE>. Since version 2.10, glibc "
6554 "does the right thing."
6557 #. see bug http://sources.redhat.com/bugzilla/show_bug.cgi?id=3866
6558 #. and http://sources.redhat.com/bugzilla/show_bug.cgi?id=369
6560 #: build/C/man3/pow.3:351
6562 "If I<x> is negative, then large negative or positive I<y> values yield a NaN "
6563 "as the function result, with I<errno> set to B<EDOM>, and an invalid "
6564 "(B<FE_INVALID>) floating-point exception. For example, with B<pow>(), one "
6565 "sees this behavior when the absolute value of I<y> is greater than about "
6569 #. FIXME . Actually, 2.3.2 is the earliest test result I have; so yet
6570 #. to confirm if this error occurs only in 2.3.2.
6572 #: build/C/man3/pow.3:360
6574 "In version 2.3.2 and earlier, when an overflow or underflow error occurs, "
6575 "glibc's B<pow>() generates a bogus invalid floating-point exception "
6576 "(B<FE_INVALID>) in addition to the overflow or underflow exception."
6580 #: build/C/man3/pow.3:364
6581 msgid "B<cbrt>(3), B<cpow>(3), B<sqrt>(3)"
6585 #: build/C/man3/pow10.3:23
6591 #: build/C/man3/pow10.3:26
6592 msgid "pow10, pow10f, pow10l - base-10 power functions"
6596 #: build/C/man3/pow10.3:30 build/C/man3/sincos.3:13
6599 "B<#define _GNU_SOURCE> /* See feature_test_macros(7) */\n"
6600 "B<#include E<lt>math.hE<gt>>\n"
6604 #: build/C/man3/pow10.3:32
6606 msgid "B<double pow10(double >I<x>B<);>\n"
6610 #: build/C/man3/pow10.3:34
6612 msgid "B<float pow10f(float >I<x>B<);>\n"
6616 #: build/C/man3/pow10.3:36
6618 msgid "B<long double pow10l(long double >I<x>B<);>\n"
6622 #: build/C/man3/pow10.3:44
6623 msgid "The B<pow10>() function returns the value of 10 raised to the power I<x>."
6627 #: build/C/man3/pow10.3:48
6628 msgid "This is a GNU extension."
6632 #: build/C/man3/pow10.3:51
6633 msgid "These functions are identical to the functions listed under B<exp10>(3)."
6637 #: build/C/man3/pow10.3:54
6638 msgid "B<exp10>(3), B<pow>(3)"
6642 #: build/C/man3/remainder.3:35
6648 #: build/C/man3/remainder.3:39
6650 "drem, dremf, dreml, remainder, remainderf, remainderl - floating-point "
6651 "remainder function"
6655 #: build/C/man3/remainder.3:47
6658 "/* The C99 versions */\n"
6659 "B<double remainder(double >I<x>B<, double >I<y>B<);>\n"
6660 "B<float remainderf(float >I<x>B<, float >I<y>B<);>\n"
6661 "B<long double remainderl(long double >I<x>B<, long double >I<y>B<);>\n"
6665 #: build/C/man3/remainder.3:52
6668 "/* Obsolete synonyms */\n"
6669 "B<double drem(double >I<x>B<, double >I<y>B<);>\n"
6670 "B<float dremf(float >I<x>B<, float >I<y>B<);>\n"
6671 "B<long double dreml(long double >I<x>B<, long double >I<y>B<);>\n"
6675 #: build/C/man3/remainder.3:63
6676 msgid "B<remainder>():"
6680 #: build/C/man3/remainder.3:68
6682 "_SVID_SOURCE || _BSD_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 500 || "
6683 "_XOPEN_SOURCE\\ &&\\ _XOPEN_SOURCE_EXTENDED || _ISOC99_SOURCE || "
6684 "_POSIX_C_SOURCE\\ E<gt>=\\ 200112L;"
6688 #: build/C/man3/remainder.3:75
6689 msgid "B<remainderf>(), B<remainderl>():"
6693 #: build/C/man3/remainder.3:86
6694 msgid "B<drem>(), B<dremf>(), B<dreml>():"
6698 #: build/C/man3/remainder.3:88 build/C/man3/significand.3:30
6699 msgid "_SVID_SOURCE || _BSD_SOURCE"
6703 #: build/C/man3/remainder.3:109
6705 "The B<remainder>() function computes the remainder of dividing I<x> by "
6706 "I<y>. The return value is I<x>-I<n>*I<y>, where I<n> is the value I<x\\ /\\ "
6707 "y>, rounded to the nearest integer. If the absolute value of I<x>-I<n>*I<y> "
6708 "is 0.5, I<n> is chosen to be even."
6712 #: build/C/man3/remainder.3:112
6714 "These functions are unaffected by the current rounding mode (see "
6719 #: build/C/man3/remainder.3:116
6720 msgid "The B<drem>() function does precisely the same thing."
6724 #: build/C/man3/remainder.3:122
6726 "On success, these functions return the floating-point remainder, "
6727 "I<x>-I<n>*I<y>. If the return value is 0, it has the sign of I<x>."
6731 #: build/C/man3/remainder.3:137 build/C/man3/remquo.3:87
6733 "If I<x> is an infinity, and I<y> is not a NaN, a domain error occurs, and a "
6738 #: build/C/man3/remainder.3:148 build/C/man3/remquo.3:96
6740 "If I<y> is zero, and I<x> is not a NaN, a domain error occurs, and a NaN is "
6745 #: build/C/man3/remainder.3:155
6747 msgid "Domain error: I<x> is an infinity and I<y> is not a NaN"
6752 #: build/C/man3/remainder.3:186
6754 "The functions B<remainder>(), B<remainderf>(), and B<remainderl>() are "
6755 "specified in C99 and POSIX.1-2001."
6759 #: build/C/man3/remainder.3:202
6761 "The function B<drem>() is from 4.3BSD. The I<float> and I<long double> "
6762 "variants B<dremf>() and B<dreml>() exist on some systems, such as Tru64 "
6763 "and glibc2. Avoid the use of these functions in favor of B<remainder>() "
6768 #: build/C/man3/remainder.3:204
6773 #: build/C/man3/remainder.3:206
6775 msgid " remainder(nan(\"\"), 0);\n"
6778 #. FIXME . this bug occurs as at glibc 2.8.
6779 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6779
6781 #: build/C/man3/remainder.3:211
6783 "returns a NaN, as expected, but wrongly causes a domain error; it should "
6784 "yield a silent NaN."
6788 #: build/C/man3/remainder.3:213
6789 msgid "The call \"remainder(29.0, 3.0)\" returns -1."
6793 #: build/C/man3/remainder.3:217
6794 msgid "B<div>(3), B<fmod>(3), B<remquo>(3)"
6798 #: build/C/man3/remquo.3:7
6804 #: build/C/man3/remquo.3:10
6805 msgid "remquo, remquof, remquol - remainder and part of quotient"
6809 #: build/C/man3/remquo.3:15
6811 msgid "B<double remquo(double >I<x>B<, double >I<y>B<, int *>I<quo>B<);>\n"
6815 #: build/C/man3/remquo.3:17
6817 msgid "B<float remquof(float >I<x>B<, float >I<y>B<, int *>I<quo>B<);>\n"
6821 #: build/C/man3/remquo.3:19
6824 "B<long double remquol(long double >I<x>B<, long double >I<y>B<, int "
6829 #: build/C/man3/remquo.3:32
6830 msgid "B<remquo>(), B<remquof>(), B<remquol>():"
6834 #: build/C/man3/remquo.3:50
6836 "These functions compute the remainder and part of the quotient upon division "
6837 "of I<x> by I<y>. A few bits of the quotient are stored via the I<quo> "
6838 "pointer. The remainder is returned as the function result."
6842 #: build/C/man3/remquo.3:54
6844 "The value of the remainder is the same as that computed by the "
6845 "B<remainder>(3) function."
6849 #: build/C/man3/remquo.3:60
6851 "The value stored via the I<quo> pointer has the sign of I<x\\ /\\ y> and "
6852 "agrees with the quotient in at least the low order 3 bits."
6855 #. A possible application of this function might be the computation
6856 #. of sin(x). Compute remquo(x, pi/2, &quo) or so.
6858 #. glibc, UnixWare: return 3 bits
6859 #. MacOS 10: return 7 bits
6861 #: build/C/man3/remquo.3:68
6863 "For example, I<remquo(29.0,\\ 3.0)> returns -1.0 and might store 2. Note "
6864 "that the actual quotient might not fit in an integer."
6868 #: build/C/man3/remquo.3:72
6870 "On success, these functions return the same value as the analogous functions "
6871 "described in B<remainder>(3)."
6875 #: build/C/man3/remquo.3:103
6878 "Domain error: I<x> is an infinity or I<y> is 0, and the other argument is "
6883 #: build/C/man3/remquo.3:125
6884 msgid "B<fmod>(3), B<logb>(3), B<remainder>(3)"
6888 #: build/C/man3/rint.3:25
6894 #: build/C/man3/rint.3:29
6896 "nearbyint, nearbyintf, nearbyintl, rint, rintf, rintl - round to nearest "
6901 #: build/C/man3/rint.3:34
6903 msgid "B<double nearbyint(double >I<x>B<);>\n"
6907 #: build/C/man3/rint.3:36
6909 msgid "B<float nearbyintf(float >I<x>B<);>\n"
6913 #: build/C/man3/rint.3:38
6915 msgid "B<long double nearbyintl(long double >I<x>B<);>\n"
6919 #: build/C/man3/rint.3:40
6921 msgid "B<double rint(double >I<x>B<);>\n"
6925 #: build/C/man3/rint.3:42
6927 msgid "B<float rintf(float >I<x>B<);>\n"
6931 #: build/C/man3/rint.3:44
6933 msgid "B<long double rintl(long double >I<x>B<);>\n"
6937 #: build/C/man3/rint.3:57
6938 msgid "B<nearbyint>(), B<nearbyintf>(), B<nearbyintl>():"
6942 #: build/C/man3/rint.3:59
6944 "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L || "
6949 #: build/C/man3/rint.3:65
6954 #: build/C/man3/rint.3:76
6955 msgid "B<rintf>(), B<rintl>():"
6959 #: build/C/man3/rint.3:93
6961 "The B<nearbyint>() functions round their argument to an integer value in "
6962 "floating-point format, using the current rounding direction (see "
6963 "B<fesetround>(3)) and without raising the I<inexact> exception."
6967 #: build/C/man3/rint.3:103
6969 "The B<rint>() functions do the same, but will raise the I<inexact> "
6970 "exception (B<FE_INEXACT>, checkable via B<fetestexcept>(3)) when the result "
6971 "differs in value from the argument."
6975 #: build/C/man3/rint.3:133
6977 "If you want to store the rounded value in an integer type, you probably want "
6978 "to use one of the functions described in B<lrint>(3) instead."
6982 #: build/C/man3/rint.3:139
6983 msgid "B<ceil>(3), B<floor>(3), B<lrint>(3), B<round>(3), B<trunc>(3)"
6987 #: build/C/man3/round.3:25
6993 #: build/C/man3/round.3:28
6994 msgid "round, roundf, roundl - round to nearest integer, away from zero"
6998 #: build/C/man3/round.3:33
7000 msgid "B<double round(double >I<x>B<);>\n"
7004 #: build/C/man3/round.3:35
7006 msgid "B<float roundf(float >I<x>B<);>\n"
7010 #: build/C/man3/round.3:37
7012 msgid "B<long double roundl(long double >I<x>B<);>\n"
7016 #: build/C/man3/round.3:50
7017 msgid "B<round>(), B<roundf>(), B<roundl>():"
7021 #: build/C/man3/round.3:65
7023 "These functions round I<x> to the nearest integer, but round halfway cases "
7024 "away from zero (regardless of the current rounding direction, see "
7025 "B<fenv>(3)), instead of to the nearest even integer like B<rint>(3)."
7029 #: build/C/man3/round.3:71
7030 msgid "For example, I<round(0.5)> is 1.0, and I<round(-0.5)> is -1.0."
7033 #. The POSIX.1-2001 APPLICATION USAGE SECTION discusses this point.
7035 #: build/C/man3/round.3:99
7037 "POSIX.1-2001 contains text about overflow (which might set I<errno> to "
7038 "B<ERANGE>, or raise an B<FE_OVERFLOW> exception). In practice, the result "
7039 "cannot overflow on any current machine, so this error-handling stuff is just "
7040 "nonsense. (More precisely, overflow can happen only when the maximum value "
7041 "of the exponent is smaller than the number of mantissa bits. For the "
7042 "IEEE-754 standard 32-bit and 64-bit floating-point numbers the maximum value "
7043 "of the exponent is 128 (respectively, 1024), and the number of mantissa bits "
7044 "is 24 (respectively, 53).)"
7048 #: build/C/man3/round.3:104
7050 "If you want to store the rounded value in an integer type, you probably want "
7051 "to use one of the functions described in B<lround>(3) instead."
7055 #: build/C/man3/round.3:111
7057 "B<ceil>(3), B<floor>(3), B<lround>(3), B<nearbyint>(3), B<rint>(3), "
7062 #: build/C/man3/scalb.3:25
7068 #: build/C/man3/scalb.3:29
7070 "scalb, scalbf, scalbl - multiply floating-point number by integral power of "
7075 #: build/C/man3/scalb.3:33
7076 msgid "B<double scalb(double >I<x>B<, double >I<exp>B<);>"
7080 #: build/C/man3/scalb.3:35
7081 msgid "B<float scalbf(float >I<x>B<, double >I<exp>B<);>"
7085 #: build/C/man3/scalb.3:37
7086 msgid "B<long double scalbl(long double >I<x>B<, double >I<exp>B<);>"
7090 #: build/C/man3/scalb.3:47
7095 #: build/C/man3/scalb.3:50
7097 "_BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE\\ E<gt>=\\ 500 || "
7098 "_XOPEN_SOURCE\\ &&\\ _XOPEN_SOURCE_EXTENDED"
7102 #: build/C/man3/scalb.3:54
7103 msgid "B<scalbf>(), B<scalbl>():"
7107 #: build/C/man3/scalb.3:67 build/C/man3/scalbln.3:83
7109 "These functions multiply their first argument I<x> by B<FLT_RADIX> (probably "
7110 "2) to the power of I<exp>, that is:"
7114 #: build/C/man3/scalb.3:70 build/C/man3/scalbln.3:86
7116 msgid " x * FLT_RADIX ** exp\n"
7119 #. not in /usr/include but in a gcc lib
7121 #: build/C/man3/scalb.3:77 build/C/man3/scalbln.3:93
7123 "The definition of B<FLT_RADIX> can be obtained by including "
7124 "I<E<lt>float.hE<gt>>."
7128 #: build/C/man3/scalb.3:79 build/C/man3/scalbln.3:95
7129 msgid "On success, these functions return I<x> * B<FLT_RADIX> ** I<exp>."
7133 #: build/C/man3/scalb.3:85
7134 msgid "If I<x> or I<exp> is a NaN, a NaN is returned."
7138 #: build/C/man3/scalb.3:93
7140 "If I<x> is positive infinity (negative infinity), and I<exp> is not negative "
7141 "infinity, positive infinity (negative infinity) is returned."
7145 #: build/C/man3/scalb.3:99
7147 "If I<x> is +0 (-0), and I<exp> is not positive infinity, +0 (-0) is "
7152 #: build/C/man3/scalb.3:107
7154 "If I<x> is zero, and I<exp> is positive infinity, a domain error occurs, and "
7155 "a NaN is returned."
7159 #: build/C/man3/scalb.3:116
7161 "If I<x> is an infinity, and I<exp> is negative infinity, a domain error "
7162 "occurs, and a NaN is returned."
7166 #: build/C/man3/scalb.3:131 build/C/man3/scalbln.3:123
7168 "If the result underflows, a range error occurs, and the functions return "
7169 "zero, with a sign the same as I<x>."
7173 #: build/C/man3/scalb.3:138
7176 "Domain error: I<x> is 0, and I<exp> is positive infinity, or I<x> is "
7177 "positive infinity and I<exp> is negative infinity and the other argument is "
7182 #: build/C/man3/scalb.3:184
7184 "B<scalb>() is specified in POSIX.1-2001, but marked obsolescent. "
7185 "POSIX.1-2008 removes the specification of B<scalb>(), recommending the use "
7186 "of B<scalbln>(3), B<scalblnf>(3), or B<scalblnl>(3) instead. The "
7187 "B<scalb>() function is from 4.3BSD."
7190 #. Looking at header files: scalbf() is present on the
7191 #. BSDs, Tru64, HP-UX 11, Irix 6.5; scalbl() is on HP-UX 11 and Tru64.
7193 #: build/C/man3/scalb.3:193
7195 "B<scalbf>() and B<scalbl>() are unstandardized; B<scalbf>() is "
7196 "nevertheless present on several other systems"
7200 #: build/C/man3/scalb.3:196
7201 msgid "B<ldexp>(3), B<scalbln>(3)"
7205 #: build/C/man3/scalbln.3:25
7211 #: build/C/man3/scalbln.3:29
7213 "scalbn, scalbnf, scalbnl, scalbln, scalblnf, scalblnl - multiply "
7214 "floating-point number by integral power of radix"
7218 #: build/C/man3/scalbln.3:33
7219 msgid "B<double scalbln(double >I<x>B<, long int >I<exp>B<);>"
7223 #: build/C/man3/scalbln.3:35
7224 msgid "B<float scalblnf(float >I<x>B<, long int >I<exp>B<);>"
7228 #: build/C/man3/scalbln.3:37
7229 msgid "B<long double scalblnl(long double >I<x>B<, long int >I<exp>B<);>"
7233 #: build/C/man3/scalbln.3:39
7234 msgid "B<double scalbn(double >I<x>B<, int >I<exp>B<);>"
7238 #: build/C/man3/scalbln.3:41
7239 msgid "B<float scalbnf(float >I<x>B<, int >I<exp>B<);>"
7243 #: build/C/man3/scalbln.3:43
7244 msgid "B<long double scalbnl(long double >I<x>B<, int >I<exp>B<);>"
7248 #: build/C/man3/scalbln.3:55
7249 msgid "B<scalbln>(), B<scalblnf>(), B<scalblnl>():"
7253 #: build/C/man3/scalbln.3:66
7254 msgid "B<scalbn>(), B<scalbnf>(), B<scalbnl>():"
7258 #: build/C/man3/scalbln.3:164
7260 "These functions differ from the obsolete functions described in B<scalb>(3) "
7261 "in the type of their second argument. The functions described on this page "
7262 "have a second argument of an integral type, while those in B<scalb>(3) have "
7263 "a second argument of type I<double>."
7267 #: build/C/man3/scalbln.3:171
7269 "If B<FLT_RADIX> equals 2 (which is usual), then B<scalbn>() is equivalent "
7274 #: build/C/man3/scalbln.3:174
7275 msgid "B<ldexp>(3), B<scalb>(3)"
7279 #: build/C/man3/signbit.3:6
7285 #: build/C/man3/signbit.3:9
7286 msgid "signbit - test sign of a real floating-point number"
7290 #: build/C/man3/signbit.3:13
7291 msgid "B<int signbit(>I<x>B<);>"
7295 #: build/C/man3/signbit.3:23
7296 msgid "B<signbit>():"
7300 #: build/C/man3/signbit.3:37
7302 "B<signbit>() is a generic macro which can work on all real floating-point "
7303 "types. It returns a nonzero value if the value of I<x> has its sign bit "
7308 #: build/C/man3/signbit.3:46
7310 "This is not the same as I<x E<lt> 0.0>, because IEEE 754 floating point "
7311 "allows zero to be signed. The comparison I<-0.0 E<lt> 0.0> is false, but "
7312 "I<signbit(-0.0)> will return a nonzero value."
7316 #: build/C/man3/signbit.3:48
7317 msgid "NaNs and infinities have a sign bit."
7321 #: build/C/man3/signbit.3:54
7323 "The B<signbit>() macro returns nonzero if the sign of I<x> is negative; "
7324 "otherwise it returns zero."
7328 #: build/C/man3/signbit.3:62
7329 msgid "B<copysign>(3)"
7333 #: build/C/man3/significand.3:4
7339 #: build/C/man3/significand.3:4
7345 #: build/C/man3/significand.3:8
7347 "significand, significandf, significandl - get mantissa of floating-point "
7352 #: build/C/man3/significand.3:12
7353 msgid "B<double significand(double >I<x>B<);>"
7357 #: build/C/man3/significand.3:14
7358 msgid "B<float significandf(float >I<x>B<);>"
7362 #: build/C/man3/significand.3:16
7363 msgid "B<long double significandl(long double >I<x>B<);>"
7367 #: build/C/man3/significand.3:28
7368 msgid "B<significand>(), B<significandf>(), B<significandl>():"
7372 #: build/C/man3/significand.3:39
7374 "The B<significand>() function returns the mantissa of I<x> scaled to the "
7375 "range [1,2). It is equivalent to"
7379 #: build/C/man3/significand.3:42
7380 msgid "scalb(x, (double) -ilogb(x))"
7384 #: build/C/man3/significand.3:46
7386 "This function exists mainly for use in certain standardized tests for IEEE "
7391 #. This function came from BSD.
7393 #: build/C/man3/significand.3:52
7395 "These functions are nonstandard; the I<double> version is available on a "
7396 "number of other systems."
7400 #: build/C/man3/significand.3:55
7401 msgid "B<ilogb>(3), B<scalb>(3)"
7405 #: build/C/man3/sin.3:33
7411 #: build/C/man3/sin.3:36
7412 msgid "sin, sinf, sinl - sine function"
7416 #: build/C/man3/sin.3:41
7418 msgid "B<double sin(double >I<x>B<);>\n"
7422 #: build/C/man3/sin.3:43
7424 msgid "B<float sinf(float >I<x>B<);>\n"
7428 #: build/C/man3/sin.3:45
7430 msgid "B<long double sinl(long double >I<x>B<);>\n"
7434 #: build/C/man3/sin.3:57
7435 msgid "B<sinf>(), B<sinl>():"
7439 #: build/C/man3/sin.3:70
7441 "The B<sin>() function returns the sine of I<x>, where I<x> is given in "
7446 #: build/C/man3/sin.3:73
7447 msgid "On success, these functions return the sine of I<x>."
7451 #: build/C/man3/sin.3:124
7453 "B<acos>(3), B<asin>(3), B<atan>(3), B<atan2>(3), B<cos>(3), B<csin>(3), "
7454 "B<sincos>(3), B<tan>(3)"
7458 #: build/C/man3/sincos.3:6
7464 #: build/C/man3/sincos.3:9
7465 msgid "sincos, sincosf, sincosl - calculate sin and cos simultaneously"
7469 #: build/C/man3/sincos.3:15
7471 msgid "B<void sincos(double >I<x>B<, double *>I<sin>B<, double *>I<cos>B<);>\n"
7475 #: build/C/man3/sincos.3:17
7477 msgid "B<void sincosf(float >I<x>B<, float *>I<sin>B<, float *>I<cos>B<);>\n"
7481 #: build/C/man3/sincos.3:19
7484 "B<void sincosl(long double >I<x>B<, long double *>I<sin>B<, long double "
7489 #: build/C/man3/sincos.3:29
7491 "Several applications need sine and cosine of the same angle I<x>. This "
7492 "function computes both at the same time, and stores the results in I<*sin> "
7497 #: build/C/man3/sincos.3:37
7498 msgid "If I<x> is a NaN, a NaN is returned in I<*sin> and I<*cos>."
7502 #: build/C/man3/sincos.3:46
7504 "If I<x> is positive infinity or negative infinity, a domain error occurs, "
7505 "and a NaN is returned in I<*sin> and I<*cos>."
7509 #: build/C/man3/sincos.3:49
7510 msgid "These functions return I<void>."
7514 #: build/C/man3/sincos.3:74
7515 msgid "This function is a GNU extension."
7519 #: build/C/man3/sincos.3:78
7520 msgid "B<cos>(3), B<sin>(3), B<tan>(3)"
7524 #: build/C/man3/sinh.3:34
7530 #: build/C/man3/sinh.3:37
7531 msgid "sinh, sinhf, sinhl - hyperbolic sine function"
7535 #: build/C/man3/sinh.3:42
7537 msgid "B<double sinh(double >I<x>B<);>\n"
7541 #: build/C/man3/sinh.3:44
7543 msgid "B<float sinhf(float >I<x>B<);>\n"
7547 #: build/C/man3/sinh.3:46
7549 msgid "B<long double sinhl(long double >I<x>B<);>\n"
7553 #: build/C/man3/sinh.3:58
7554 msgid "B<sinhf>(), B<sinhl>():"
7558 #: build/C/man3/sinh.3:71
7560 "The B<sinh>() function returns the hyperbolic sine of I<x>, which is "
7561 "defined mathematically as:"
7565 #: build/C/man3/sinh.3:74
7567 msgid " sinh(x) = (exp(x) - exp(-x)) / 2\n"
7571 #: build/C/man3/sinh.3:78
7572 msgid "On success, these functions return the hyperbolic sine of I<x>."
7576 #. POSIX.1-2001 documents an optional range error (underflow)
7578 #. glibc 2.8 does not do this.
7580 #: build/C/man3/sinh.3:105
7582 "If the result overflows, a range error occurs, and the functions return "
7583 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with the same sign "
7588 #: build/C/man3/sinh.3:133
7589 msgid "B<acosh>(3), B<asinh>(3), B<atanh>(3), B<cosh>(3), B<csinh>(3), B<tanh>(3)"
7593 #: build/C/man3/sqrt.3:32
7599 #: build/C/man3/sqrt.3:35
7600 msgid "sqrt, sqrtf, sqrtl - square root function"
7604 #: build/C/man3/sqrt.3:40
7606 msgid "B<double sqrt(double >I<x>B<);>\n"
7610 #: build/C/man3/sqrt.3:42
7612 msgid "B<float sqrtf(float >I<x>B<);>\n"
7616 #: build/C/man3/sqrt.3:44
7618 msgid "B<long double sqrtl(long double >I<x>B<);>\n"
7622 #: build/C/man3/sqrt.3:56
7623 msgid "B<sqrtf>(), B<sqrtl>():"
7627 #: build/C/man3/sqrt.3:68
7628 msgid "The B<sqrt>() function returns the nonnegative square root of I<x>."
7632 #: build/C/man3/sqrt.3:71
7633 msgid "On success, these functions return the square root of I<x>."
7637 #: build/C/man3/sqrt.3:89
7638 msgid "If I<x> is less than -0, a domain error occurs, and a NaN is returned."
7642 #: build/C/man3/sqrt.3:96
7644 msgid "Domain error: I<x> less than -0"
7648 #: build/C/man3/sqrt.3:114
7649 msgid "B<cbrt>(3), B<csqrt>(3), B<hypot>(3)"
7653 #: build/C/man3/tan.3:33
7659 #: build/C/man3/tan.3:36
7660 msgid "tan, tanf, tanl - tangent function"
7664 #: build/C/man3/tan.3:41
7666 msgid "B<double tan(double >I<x>B<);>\n"
7670 #: build/C/man3/tan.3:43
7672 msgid "B<float tanf(float >I<x>B<);>\n"
7676 #: build/C/man3/tan.3:45
7678 msgid "B<long double tanl(long double >I<x>B<);>\n"
7682 #: build/C/man3/tan.3:57
7683 msgid "B<tanf>(), B<tanl>():"
7687 #: build/C/man3/tan.3:70
7689 "The B<tan>() function returns the tangent of I<x>, where I<x> is given in "
7694 #: build/C/man3/tan.3:73
7695 msgid "On success, these functions return the tangent of I<x>."
7698 #. I think overflow can't occur, because the closest floating-point
7699 #. representation of pi/2 is still not close enough to pi/2 to
7700 #. produce a large enough value to overflow.
7701 #. Testing certainly seems to bear this out. -- mtk, Jul 08
7703 #. POSIX.1 allows an optional underflow error;
7704 #. glibc 2.8 doesn't do this
7705 #. POSIX.1 an optional range error for subnormal x;
7706 #. glibc 2.8 doesn't do this
7708 #: build/C/man3/tan.3:101
7710 "If the correct result would overflow, a range error occurs, and the "
7711 "functions return B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, "
7712 "with the mathematically correct sign."
7716 #: build/C/man3/tan.3:148
7718 "B<acos>(3), B<asin>(3), B<atan>(3), B<atan2>(3), B<cos>(3), B<ctan>(3), "
7723 #: build/C/man3/tanh.3:33
7729 #: build/C/man3/tanh.3:36
7730 msgid "tanh, tanhf, tanhl - hyperbolic tangent function"
7734 #: build/C/man3/tanh.3:41
7736 msgid "B<double tanh(double >I<x>B<);>\n"
7740 #: build/C/man3/tanh.3:43
7742 msgid "B<float tanhf(float >I<x>B<);>\n"
7746 #: build/C/man3/tanh.3:45
7748 msgid "B<long double tanhl(long double >I<x>B<);>\n"
7752 #: build/C/man3/tanh.3:57
7753 msgid "B<tanhf>(), B<tanhl>():"
7757 #: build/C/man3/tanh.3:70
7759 "The B<tanh>() function returns the hyperbolic tangent of I<x>, which is "
7760 "defined mathematically as:"
7764 #: build/C/man3/tanh.3:73
7766 msgid " tanh(x) = sinh(x) / cosh(x)\n"
7770 #: build/C/man3/tanh.3:77
7771 msgid "On success, these functions return the hyperbolic tangent of I<x>."
7775 #: build/C/man3/tanh.3:109
7776 msgid "B<acosh>(3), B<asinh>(3), B<atanh>(3), B<cosh>(3), B<ctanh>(3), B<sinh>(3)"
7780 #: build/C/man3/tgamma.3:8
7786 #: build/C/man3/tgamma.3:11
7787 msgid "tgamma, tgammaf, tgammal - true gamma function"
7791 #: build/C/man3/tgamma.3:15
7792 msgid "B<double tgamma(double >I<x>B<);>"
7796 #: build/C/man3/tgamma.3:17
7797 msgid "B<float tgammaf(float >I<x>B<);>"
7801 #: build/C/man3/tgamma.3:19
7802 msgid "B<long double tgammal(long double >I<x>B<);>"
7806 #: build/C/man3/tgamma.3:31
7807 msgid "B<tgamma>(), B<tgammaf>(), B<tgammal>():"
7811 #: build/C/man3/tgamma.3:41
7812 msgid "The Gamma function is defined by"
7816 #: build/C/man3/tgamma.3:43
7818 msgid " Gamma(x) = integral from 0 to infinity of t^(x-1) e^-t dt\n"
7822 #: build/C/man3/tgamma.3:46
7824 "It is defined for every real number except for nonpositive integers. For "
7825 "nonnegative integral I<m> one has"
7829 #: build/C/man3/tgamma.3:48
7831 msgid " Gamma(m+1) = m!\n"
7835 #: build/C/man3/tgamma.3:50
7836 msgid "and, more generally, for all I<x>:"
7840 #: build/C/man3/tgamma.3:52
7842 msgid " Gamma(x+1) = x * Gamma(x)\n"
7846 #: build/C/man3/tgamma.3:55
7848 "Furthermore, the following is valid for all values of I<x> outside the "
7853 #: build/C/man3/tgamma.3:57
7855 msgid " Gamma(x) * Gamma(1 - x) = PI / sin(PI * x)\n"
7859 #: build/C/man3/tgamma.3:60
7860 msgid "On success, these functions return Gamma(x)."
7864 #: build/C/man3/tgamma.3:74
7866 "If I<x> is a negative integer, or is negative infinity, a domain error "
7867 "occurs, and a NaN is returned."
7871 #: build/C/man3/tgamma.3:87
7873 "If the result underflows, a range error occurs, and the functions return 0, "
7874 "with the correct mathematical sign."
7878 #: build/C/man3/tgamma.3:98
7880 "If I<x> is -0 or +0, a pole error occurs, and the functions return "
7881 "B<HUGE_VAL>, B<HUGE_VALF>, or B<HUGE_VALL>, respectively, with the same sign "
7886 #: build/C/man3/tgamma.3:105
7888 msgid "Domain error: I<x> is a negative integer, or negative infinity"
7891 #. FIXME . errno is not set to EDOM for x == -inf
7892 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6809
7894 #: build/C/man3/tgamma.3:115
7896 "I<errno> is set to B<EDOM>. An invalid floating-point exception "
7897 "(B<FE_INVALID>) is raised (but see BUGS)."
7901 #: build/C/man3/tgamma.3:115
7903 msgid "Pole error: I<x> is +0 or -0"
7907 #: build/C/man3/tgamma.3:134
7909 "glibc also gives the following error which is not specified in C99 or "
7913 #. FIXME . Is it intentional that errno is not set:
7914 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6810
7916 #. glibc (as at 2.8) also supports and an inexact
7917 #. exception for various cases.
7919 #: build/C/man3/tgamma.3:151
7920 msgid "I<errno> is not set for this case."
7924 #: build/C/man3/tgamma.3:162
7926 "This function had to be called \"true gamma function\" since there is "
7927 "already a function B<gamma>(3) that returns something else (see B<gamma>(3) "
7931 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6809
7933 #: build/C/man3/tgamma.3:170
7935 "If I<x> is negative infinity, I<errno> is not set (it should be set to "
7940 #: build/C/man3/tgamma.3:179
7942 "In glibc versions 2.3.3 and earlier, an argument of +0 or -0 incorrectly "
7943 "produced a domain error (I<errno> set to B<EDOM> and an B<FE_INVALID> "
7944 "exception raised), rather than a pole error."
7948 #: build/C/man3/tgamma.3:182
7949 msgid "B<gamma>(3), B<lgamma>(3)"
7953 #: build/C/man3/trunc.3:23
7959 #: build/C/man3/trunc.3:26
7960 msgid "trunc, truncf, truncl - round to integer, toward zero"
7964 #: build/C/man3/trunc.3:31
7966 msgid "B<double trunc(double >I<x>B<);>\n"
7970 #: build/C/man3/trunc.3:33
7972 msgid "B<float truncf(float >I<x>B<);>\n"
7976 #: build/C/man3/trunc.3:35
7978 msgid "B<long double truncl(long double >I<x>B<);>\n"
7982 #: build/C/man3/trunc.3:48
7983 msgid "B<trunc>(), B<truncf>(), B<truncl>():"
7987 #: build/C/man3/trunc.3:59
7989 "These functions round I<x> to the nearest integer not larger in absolute "
7994 #: build/C/man3/trunc.3:63
7995 msgid "If I<x> is integral, infinite, or NaN, I<x> itself is returned."
7999 #: build/C/man3/y0.3:34
8005 #: build/C/man3/y0.3:34
8011 #: build/C/man3/y0.3:38
8013 "y0, y0f, y0l, y1, y1f, y1l, yn, ynf, ynl - Bessel functions of the second "
8018 #: build/C/man3/y0.3:43
8020 msgid "B<double y0(double >I<x>B<);>\n"
8024 #: build/C/man3/y0.3:45
8026 msgid "B<double y1(double >I<x>B<);>\n"
8030 #: build/C/man3/y0.3:47
8032 msgid "B<double yn(int >I<n>B<, double >I<x>B<);>\n"
8036 #: build/C/man3/y0.3:49
8038 msgid "B<float y0f(float >I<x>B<);>\n"
8042 #: build/C/man3/y0.3:51
8044 msgid "B<float y1f(float >I<x>B<);>\n"
8048 #: build/C/man3/y0.3:53
8050 msgid "B<float ynf(int >I<n>B<, float >I<x>B<);>\n"
8054 #: build/C/man3/y0.3:55
8056 msgid "B<long double y0l(long double >I<x>B<);>\n"
8060 #: build/C/man3/y0.3:57
8062 msgid "B<long double y1l(long double >I<x>B<);>\n"
8066 #: build/C/man3/y0.3:59
8068 msgid "B<long double ynl(int >I<n>B<, long double >I<x>B<);>\n"
8072 #: build/C/man3/y0.3:72
8073 msgid "B<y0>(), B<y1>(), B<yn>():"
8077 #: build/C/man3/y0.3:82
8078 msgid "B<y0f>(), B<y0l>(), B<y1f>(), B<y1l>(), B<ynf>(), B<ynl>():"
8082 #: build/C/man3/y0.3:99
8084 "The B<y0>() and B<y1>() functions return Bessel functions of I<x> of the "
8085 "second kind of orders 0 and 1, respectively. The B<yn>() function returns "
8086 "the Bessel function of I<x> of the second kind of order I<n>."
8090 #: build/C/man3/y0.3:101
8091 msgid "The value of I<x> must be positive."
8095 #: build/C/man3/y0.3:111
8097 "The B<y0f>() etc. and B<y0l>() etc. functions are versions that take and "
8098 "return I<float> and I<long double> values, respectively."
8102 #: build/C/man3/y0.3:115
8104 "On success, these functions return the appropriate Bessel value of the "
8105 "second kind for I<x>."
8109 #: build/C/man3/y0.3:131
8111 "If I<x> is negative, a domain error occurs, and the functions return "
8112 "-B<HUGE_VAL>, -B<HUGE_VALF>, or -B<HUGE_VALL>, respectively. (POSIX.1-2001 "
8113 "also allows a NaN return for this case.)"
8117 #: build/C/man3/y0.3:142
8119 "If I<x> is 0.0, a pole error occurs, and the functions return -B<HUGE_VAL>, "
8120 "-B<HUGE_VALF>, or -B<HUGE_VALL>, respectively."
8124 #: build/C/man3/y0.3:146
8125 msgid "If the result underflows, a range error occurs, and the functions return 0.0"
8129 #: build/C/man3/y0.3:156
8131 "If the result overflows, a range error occurs, and the functions return "
8132 "-B<HUGE_VAL>, -B<HUGE_VALF>, or -B<HUGE_VALL>, respectively. (POSIX.1-2001 "
8133 "also allows a 0.0 return for this case.)"
8137 #: build/C/man3/y0.3:171
8139 msgid "Pole error: I<x> is 0.0"
8142 #. Before POSIX.1-2001 TC2, this was (inconsistently) specified
8143 #. as a range error.
8144 #. FIXME . y0(0.0) gives EDOM
8145 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6808
8147 #: build/C/man3/y0.3:186
8149 "I<errno> is set to B<ERANGE> (but see BUGS). No B<FE_DIVBYZERO> exception "
8150 "is returned by B<fetestexcept>(3) for this case."
8153 #. e.g., y0(1e33) on glibc 2.8/x86-32
8154 #. An underflow floating-point exception
8155 #. .RB ( FE_UNDERFLOW )
8157 #. FIXME . Is it intentional that these functions do not use FE_*?
8158 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6806
8160 #: build/C/man3/y0.3:202
8162 "I<errno> is set to B<ERANGE>. No B<FE_UNDERFLOW> exception is returned by "
8163 "B<fetestexcept>(3) for this case."
8166 #. e.g., yn(10, 1e-40) on glibc 2.8/x86-32
8170 #. FIXME . Is it intentional that errno is not set?
8171 #. Bug raised: http://sources.redhat.com/bugzilla/show_bug.cgi?id=6808
8173 #: build/C/man3/y0.3:215
8175 "I<errno> is not set for this case. An overflow floating-point exception "
8176 "(B<FE_OVERFLOW>) is raised."
8180 #. Bug raised: http://sourceware.org/bugzilla/show_bug.cgi?id=6807
8182 #: build/C/man3/y0.3:231
8184 "On a pole error, these functions set I<errno> to B<EDOM>, instead of "
8185 "B<ERANGE> as POSIX.1-2004 requires."
8188 #. FIXME . Actually, 2.3.2 is the earliest test result I have; so yet
8189 #. to confirm if this error occurs only in 2.3.2.
8191 #: build/C/man3/y0.3:238
8193 "In glibc version 2.3.2 and earlier, these functions do not raise an invalid "
8194 "floating-point exception (B<FE_INVALID>) when a domain error occurs."
8198 #: build/C/man3/y0.3:240