Namespaces
Variants

std:: fmax, std:: fmaxf, std:: fmaxl

From cppreference.net
Common mathematical functions
Nearest integer floating point operations
(C++11)
(C++11)
(C++11) (C++11) (C++11)
Floating point manipulation functions
(C++11) (C++11)
(C++11)
(C++11)
Classification and comparison
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Types
(C++11)
(C++11)
(C++11)
Macro constants
Definido en el encabezado <cmath>
(1)
float fmax ( float x, float y ) ;

double fmax ( double x, double y ) ;

long double fmax ( long double x, long double y ) ;
(hasta C++23)
constexpr /*floating-point-type*/

fmax ( /*floating-point-type*/ x,

/*floating-point-type*/ y ) ;
(desde C++23)
float fmaxf ( float x, float y ) ;
(2) (desde C++11)
(constexpr desde C++23)
long double fmaxl ( 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 >

fmax ( const V0 & v_x, const V1 & v_y ) ;
(S) (desde C++26)
Definido en el encabezado <cmath>
template < class Integer >
double fmax ( Integer x, Integer y ) ;
(A) (constexpr desde C++23)
1-3) Devuelve el mayor de dos argumentos de punto flotante, tratando los NaN como datos faltantes (entre un NaN y un valor numérico, se selecciona el valor numérico). La biblioteca proporciona sobrecargas de std::fmax 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::fmax elemento por elemento en v_x y v_y .
(Consulte math-common-simd-t para su definición.)
(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, retorna el mayor de dos valores de punto flotante. El valor retornado es exacto y no depende de ningún modo de redondeo.

Manejo de errores

Esta función no está sujeta a ninguna de las condiciones de error especificadas en math_errhandling .

Si la implementación soporta aritmética de punto flotante IEEE (IEC 60559),

  • Si uno de los dos argumentos es NaN, se devuelve el valor del otro argumento.
  • Solo si ambos argumentos son NaN, se devuelve NaN.

Notas

Esta función no requiere ser sensible al signo del cero, aunque algunas implementaciones adicionalmente exigen que si un argumento es + 0 y el otro es - 0 , entonces se retorne + 0 .

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 :

  • Si num1 o num2 tiene tipo long double , entonces std :: fmax ( num1, num2 ) tiene el mismo efecto que std :: fmax ( static_cast < long double > ( num1 ) ,
    static_cast < long double > ( num2 ) )
    .
  • En caso contrario, si num1 y/o num2 tiene tipo double o un tipo entero, entonces std :: fmax ( num1, num2 ) tiene el mismo efecto que std :: fmax ( static_cast < double > ( num1 ) ,
    static_cast < double > ( num2 ) )
    .
  • En caso contrario, si num1 o num2 tiene tipo float , entonces std :: fmax ( num1, num2 ) tiene el mismo efecto que std :: fmax ( static_cast < float > ( num1 ) ,
    static_cast < float > ( num2 ) )
    .
(hasta C++23)

Si num1 y num2 tienen tipos aritméticos, entonces std :: fmax ( num1, num2 ) tiene el mismo efecto que std :: fmax ( static_cast < /*common-floating-point-type*/ > ( num1 ) ,
static_cast < /*common-floating-point-type*/ > ( num2 ) )
, donde /*common-floating-point-type*/ es el tipo de punto flotante con el mayor rango de conversión de punto flotante y mayor subrango de conversión de punto flotante entre los tipos de num1 y num2 , los argumentos de tipo entero se consideran con el mismo rango de conversión de punto flotante que double .

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 <cmath>
#include <iostream>
int main()
{
    std::cout << "fmax(2,1)    = " << std::fmax(2, 1) << '\n'
              << "fmax(-Inf,0) = " << std::fmax(-INFINITY, 0) << '\n'
              << "fmax(NaN,-1) = " << std::fmax(NAN, -1) << '\n';
}

Salida:

fmax(2,1)    = 2
fmax(-Inf,0) = 0
fmax(NaN,-1) = -1

Véase también

(C++11)
comprueba si el primer argumento de punto flotante es mayor que el segundo
(función)
(C++11) (C++11) (C++11)
menor de dos valores de punto flotante
(función)
devuelve el mayor de los valores dados
(plantilla de función)
devuelve el elemento más grande en un rango
(plantilla de función)
(C++11)
devuelve el menor y el mayor de dos elementos
(plantilla de función)
devuelve los elementos más pequeño y más grande en un rango
(plantilla de función)