summaryrefslogblamecommitdiff
path: root/src/math/logb.c
blob: 624425a81165b219a973dee4c3d0f6cbe2c3c43c (plain) (tree)
1
2
3
4
5
6
7
8
9



                 
                                             

                          

  


                         
                             


                                
 
#include "libm.h"

/*
special cases:
	logb(+-0) = -inf, and raise divbyzero
	logb(+-inf) = +inf
	logb(nan) = nan
*/

double logb(double x)
{
	if (!isfinite(x))
		return x * x;
	if (x == 0)
		return -1/(x+0);
	return ilogb(x);
}