ClickHouse/base/base/shift10.h
2022-09-10 04:08:16 +02:00

17 lines
385 B
C++

#pragma once
#include <base/types.h>
/** Almost the same as x = x * exp10(exponent), but gives more accurate result.
* Example:
* 5 * 1e-11 = 4.9999999999999995e-11
* !=
* 5e-11 = shift10(5.0, -11)
*/
double shift10(double x, int exponent);
float shift10(float x, int exponent);
long double shift10(UInt64 x, int exponent);
long double shift10(Int64 x, int exponent);