csqrtf, csqrt, csqrtl
From cppreference.com
Defined in header <complex.h>
|
||
(1) | (since C99) | |
(2) | (since C99) | |
(3) | (since C99) | |
Defined in header <tgmath.h>
|
||
#define sqrt( z ) |
(4) | (since C99) |
1-3) Computes the complex square root of
z
with branch cut along the negative real axis.4) Type-generic macro: If
z
has type long double complex, csqrtl
is called. if z
has type double complex, csqrt
is called, if z
has type float complex, csqrtf
is called. If z
is real or integer, then the macro invokes the corresponding real function (sqrtf, sqrt, sqrtl). If z
is imaginary, the corresponding complex number version is called.Parameters
z | - | complex argument |
Return value
If no errors occur, returns the square root of z
, in the range of the right half-plane, including the imaginary axis ([0; +∞) along the real axis and (−∞; +∞) along the imaginary axis.)
Error handling and special values
Errors are reported consistent with math_errhandling
If the implementation supports IEEE floating-point arithmetic,
- The function is continuous onto the branch cut taking into account the sign of imaginary part
- csqrt(conj(z)) == conj(csqrt(z))
- If
z
is±0+0i
, the result is+0+0i
- If
z
isx+∞i
, the result is+∞+∞i
even if x is NaN - If
z
isx+NaNi
, the result isNaN+NaNi
(unless x is ±∞) and FE_INVALID may be raised - If
z
is-∞+yi
, the result is+0+∞i
for finite positive y - If
z
is+∞+yi
, the result is+∞+0i)
for finite positive y - If
z
is-∞+NaNi
, the result isNaN±∞
(sign of imaginary part unspecified) - If
z
is+∞+NaNi
, the result is+∞+NaNi
- If
z
isNaN+yi
, the result isNaN+NaNi
and FE_INVALID may be raised - If
z
isNaN+NaNi
, the result isNaN+NaNi