std:: fdim, std:: fdimf, std:: fdiml
|
Definido en el encabezado
<cmath>
|
||
| (1) | ||
|
float
fdim
(
float
x,
float
y
)
;
double
fdim
(
double
x,
double
y
)
;
|
(hasta C++23) | |
|
constexpr
/*floating-point-type*/
fdim
(
/*floating-point-type*/
x,
|
(desde C++23) | |
|
float
fdimf
(
float
x,
float
y
)
;
|
(2) |
(desde C++11)
(constexpr desde C++23) |
|
long
double
fdiml
(
long
double
x,
long
double
y
)
;
|
(3) |
(desde C++11)
(constexpr desde C++23) |
|
Sobrecarga SIMD
(desde C++26)
|
||
|
Definido en el encabezado
<simd>
|
||
|
template
<
class
V0,
class
V1
>
constexpr
/*math-common-simd-t*/
<
V0, V1
>
|
(S) | (desde C++26) |
|
Sobrecargas adicionales
(desde C++11)
|
||
|
Definido en el encabezado
<cmath>
|
||
|
template
<
class
Integer
>
double fdim ( Integer x, Integer y ) ; |
(A) | (constexpr desde C++23) |
std::fdim
para todos los tipos de punto flotante sin calificación cv como tipo de los parámetros.
(since C++23)
|
S)
La sobrecarga SIMD realiza un
std::fdim
elemento por elemento en
v_x
y
v_y
.
|
(desde C++26) |
|
A)
Se proporcionan sobrecargas adicionales para todos los tipos enteros, los cuales son tratados como
double
.
|
(since C++11) |
Contenidos |
Parámetros
| x, y | - | valores de punto flotante o enteros |
Valor de retorno
Si tiene éxito, devuelve la diferencia positiva entre x y y .
Si ocurre un error de rango debido a desbordamiento,
+HUGE_VAL
,
+HUGE_VALF
, o
+HUGE_VALL
es devuelto.
Si ocurre un error de rango debido a desbordamiento inferior, se devuelve el valor correcto (después del redondeo).
Manejo de errores
Los errores se reportan como se especifica en math_errhandling .
Si la implementación soporta aritmética de punto flotante IEEE (IEC 60559),
- Si cualquiera de los argumentos es NaN, se devuelve NaN.
Notas
Equivalente a std:: fmax ( x - y, 0 ) , excepto por los requisitos de manejo de NaN.
Las sobrecargas adicionales no requieren ser proporcionadas exactamente como (A) . Solo necesitan ser suficientes para garantizar que para su primer argumento num1 y segundo argumento num2 :
|
(hasta C++23) |
|
Si
num1
y
num2
tienen tipos aritméticos, entonces
std
::
fdim
(
num1, num2
)
tiene el mismo efecto que
std
::
fdim
(
static_cast
<
/*common-floating-point-type*/
>
(
num1
)
,
Si no existe tal tipo de punto flotante con el mayor rango y subrango, entonces la resolución de sobrecarga no resulta en un candidato utilizable de las sobrecargas proporcionadas. |
(desde C++23) |
Ejemplo
#include <cerrno> #include <cfenv> #include <cmath> #include <cstring> #include <iostream> #ifndef __GNUC__ #pragma STDC FENV_ACCESS ON #endif int main() { std::cout << "fdim(4, 1) = " << std::fdim(4, 1) << '\n' << "fdim(1, 4) = " << std::fdim(1, 4) << '\n' << "fdim(4,-1) = " << std::fdim(4, -1) << '\n' << "fdim(1,-4) = " << std::fdim(1, -4) << '\n'; // manejo de errores errno = 0; std::feclearexcept(FE_ALL_EXCEPT); std::cout << "fdim(1e308, -1e308) = " << std::fdim(1e308, -1e308) << '\n'; if (errno == ERANGE) std::cout << " errno == ERANGE: " << std::strerror(errno) << '\n'; if (std::fetestexcept(FE_OVERFLOW)) std::cout << " FE_OVERFLOW raised\n"; }
Salida:
fdim(4, 1) = 3
fdim(1, 4) = 0
fdim(4,-1) = 5
fdim(1,-4) = 5
fdim(1e308, -1e308) = inf
errno == ERANGE: Numerical result out of range
FE_OVERFLOW raised
Véase también
|
(C++11)
|
calcula el valor absoluto de un valor integral (
|x|
)
(función) |
|
(C++11)
(C++11)
(C++11)
|
mayor de dos valores de punto flotante
(función) |
|
Documentación C
para
fdim
|
|