Skip to content

Commit

Permalink
Revert "[oap-native-sql] adding round support"
Browse files Browse the repository at this point in the history
This reverts commit e551b63.
  • Loading branch information
zhouyuan authored and zhztheplayer committed May 6, 2021
1 parent a98aee7 commit 9f8ae57
Show file tree
Hide file tree
Showing 4 changed files with 0 additions and 30 deletions.
3 changes: 0 additions & 3 deletions cpp/src/gandiva/function_registry_math_ops.cc
Original file line number Diff line number Diff line change
Expand Up @@ -79,9 +79,6 @@ std::vector<NativeFunction> GetMathOpsFunctionRegistry() {
UNARY_SAFE_NULL_IF_NULL(abs, {}, float32, float32),
UNARY_SAFE_NULL_IF_NULL(abs, {}, float64, float64),

BINARY_GENERIC_SAFE_NULL_IF_NULL(round, {}, float64, int32, float64),
BINARY_GENERIC_SAFE_NULL_IF_NULL(round, {}, float64, int64, float64),

// decimal functions
UNARY_SAFE_NULL_IF_NULL(abs, {}, decimal128, decimal128),
UNARY_SAFE_NULL_IF_NULL(ceil, {}, decimal128, decimal128),
Expand Down
18 changes: 0 additions & 18 deletions cpp/src/gandiva/precompiled/extended_math_ops.cc
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ extern "C" {

#include <math.h>
#include <stdio.h>
#include <stddef.h>
#include <stdlib.h>
#include <string.h>
#include "./types.h"
Expand Down Expand Up @@ -96,23 +95,6 @@ ABS_TYPES_UNARY(int64, uint64)
ABS_FTYPES_UNARY(float32, float32)
ABS_FTYPES_UNARY(float64, float64)

// round
#define ROUND_TYPES_UNARY(IN_TYPE1, IN_TYPE2, OUT_TYPE) \
FORCE_INLINE \
gdv_##OUT_TYPE round_##IN_TYPE1##_##IN_TYPE2(gdv_##IN_TYPE1 val, gdv_##IN_TYPE2 dp) { \
int charsNeeded = 1 + snprintf(NULL, 0, "%.*f", (int) dp, val); \
char* buffer = reinterpret_cast<char*>(malloc(charsNeeded)); \
snprintf(buffer, charsNeeded, "%.*f", (int) dp, nextafter(val, val*2)); \
double result = atof(buffer); \
free(buffer); \
return static_cast<gdv_##OUT_TYPE>(result); \
}

ROUND_TYPES_UNARY(float64, int32, float64)
ROUND_TYPES_UNARY(float64, int64, float64)

#undef ROUND_TYPES_UNARY

FORCE_INLINE
void set_error_for_logbase(int64_t execution_context, double base) {
char const* prefix = "divide by zero error with log of base";
Expand Down
6 changes: 0 additions & 6 deletions cpp/src/gandiva/precompiled/extended_math_ops_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -273,10 +273,4 @@ TEST(TestExtendedMathOps, TestTrigonometricFunctions) {
VerifyFuzzyEquals(cot_float64(M_PI / 2), tan(M_PI / 2 - M_PI / 2));
}

TEST(TestExtendedMathOps, TestRound) {
EXPECT_EQ(round_float64_int32(1234.56789, 4), 1234.5679);
EXPECT_EQ(round_float64_int64(1234.56789, 4), 1234.5679);
EXPECT_EQ(round_float64_int32(-1234.56789, 4), -1234.5679);
EXPECT_EQ(round_float64_int64(-1234.56789, 4), -1234.5679);
}
} // namespace gandiva
3 changes: 0 additions & 3 deletions cpp/src/gandiva/precompiled/types.h
Original file line number Diff line number Diff line change
Expand Up @@ -234,9 +234,6 @@ gdv_float64 degrees_int64(gdv_int64);
gdv_float64 degrees_float32(gdv_float32);
gdv_float64 degrees_float64(gdv_float64);

gdv_float64 round_float64_int32(gdv_float64 in1, gdv_int32 in2);
gdv_float64 round_float64_int64(gdv_float64 in1, gdv_int64 in2);

gdv_int32 bitwise_and_int32_int32(gdv_int32 in1, gdv_int32 in2);
gdv_int64 bitwise_and_int64_int64(gdv_int64 in1, gdv_int64 in2);
gdv_int32 bitwise_or_int32_int32(gdv_int32 in1, gdv_int32 in2);
Expand Down

0 comments on commit 9f8ae57

Please sign in to comment.