mirror of
https://github.com/intel/llvm.git
synced 2026-01-24 00:20:25 +08:00
v2: Use constant and multiplication instead of division v3: Use hex constants Signed-off-by: Jan Vesely <jan.vesely@rutgers.edu> llvm-svn: 227585
14 lines
445 B
C++
14 lines
445 B
C++
_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE log10(__CLC_GENTYPE val) {
|
|
// log10(x) = log2(x) / log2(10)
|
|
// 1 / log2(10) = 0.30102999566 = log10(2)
|
|
// SP representation is 0.30103 (0x1.344136p-2)
|
|
// DP representation is 0.301029995659999993762312442414(0x1.34413509E61D8p-2)
|
|
#if __CLC_FPSIZE == 32
|
|
return log2(val) * 0x1.344136p-2f;
|
|
#elif __CLC_FPSIZE == 64
|
|
return log2(val) * 0x1.34413509E61D8p-2;
|
|
#else
|
|
#error unknown _CLC_FPSIZE
|
|
#endif
|
|
}
|