Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updated EXPM1() and Tests to New Engine #215

Merged
merged 20 commits into from
Feb 13, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
e2a6901
Updated EXPM1() and tests to new engine
matthewryanwells Feb 2, 2023
e357cdd
Added EXPM1 to PPL Parser
matthewryanwells Feb 2, 2023
c152a95
Added documentation for EXPM1 PPL and fixed small mistake in EXP docu…
matthewryanwells Feb 2, 2023
b5ab93e
Added newline to fix code style issue
matthewryanwells Feb 2, 2023
2958c3e
removed unnecessary integration tests and fixed typo in another test
matthewryanwells Feb 2, 2023
3c856a3
Extracted common code from math functions into external function
matthewryanwells Feb 6, 2023
b1c9fde
Added javadoc comment to new function
matthewryanwells Feb 6, 2023
457a5a6
Improved Javadoc
matthewryanwells Feb 6, 2023
f013e7d
Pulling changes from upstream
matthewryanwells Feb 7, 2023
6d09e77
Added and improved EXPM1 tests, and improved documentation for CLI an…
matthewryanwells Feb 7, 2023
eecd489
Removed EXPM1 from PPL
matthewryanwells Feb 8, 2023
8b88d1c
Updated math base function to take any type and included more functio…
matthewryanwells Feb 8, 2023
7a028d4
Made tiny change to documentation
matthewryanwells Feb 8, 2023
4574275
reverted euler function to previous iteration as the one I made didn'…
matthewryanwells Feb 8, 2023
62cc771
fixed typo in a comment that I made in a previous commit
matthewryanwells Feb 9, 2023
689a1dc
fixed a mistake I made in fixing the typo from my last commit
matthewryanwells Feb 9, 2023
5a3b724
Fixed spacing inconsistencies in math.rst file
matthewryanwells Feb 9, 2023
8042ebe
removed the base math function so that it can be pushed in a seperate…
matthewryanwells Feb 10, 2023
a74ae35
Reverted reverted change that removes the refactoring as this will be…
matthewryanwells Feb 10, 2023
e5a7001
updated base function to have more descriptive variables
matthewryanwells Feb 10, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions core/src/main/java/org/opensearch/sql/expression/DSL.java
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,10 @@ public static FunctionExpression exp(Expression... expressions) {
return compile(FunctionProperties.None, BuiltinFunctionName.EXP, expressions);
}

public static FunctionExpression expm1(Expression... expressions) {
return compile(FunctionProperties.None, BuiltinFunctionName.EXPM1, expressions);
}

public static FunctionExpression floor(Expression... expressions) {
return compile(FunctionProperties.None, BuiltinFunctionName.FLOOR, expressions);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ public enum BuiltinFunctionName {
CRC32(FunctionName.of("crc32")),
E(FunctionName.of("e")),
EXP(FunctionName.of("exp")),
EXPM1(FunctionName.of("expm1")),
FLOOR(FunctionName.of("floor")),
LN(FunctionName.of("ln")),
LOG(FunctionName.of("log")),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ public static void register(BuiltinFunctionRepository repository) {
repository.register(crc32());
repository.register(euler());
repository.register(exp());
repository.register(expm1());
repository.register(floor());
repository.register(ln());
repository.register(log());
Expand Down Expand Up @@ -186,8 +187,8 @@ private static DefaultFunctionResolver euler() {
}

/**
* Definition of exp(x) function. Calculate exponent function e to the x The supported signature
* of exp function is INTEGER/LONG/FLOAT/DOUBLE -> DOUBLE
* Definition of exp(x) function. Calculate exponent function e to the x
* The supported signature of exp function is INTEGER/LONG/FLOAT/DOUBLE -> DOUBLE
*/
private static DefaultFunctionResolver exp() {
return FunctionDSL.define(BuiltinFunctionName.EXP.getName(),
Expand All @@ -197,6 +198,18 @@ private static DefaultFunctionResolver exp() {
type, DOUBLE)).collect(Collectors.toList()));
}

/**
* Definition of expm1(x) function. Calculate exponent function e to the x, minus 1
* The supported signature of exp function is INTEGER/LONG/FLOAT/DOUBLE -> DOUBLE
*/
private static DefaultFunctionResolver expm1() {
return FunctionDSL.define(BuiltinFunctionName.EXPM1.getName(),
ExprCoreType.numberTypes().stream()
.map(type -> FunctionDSL.impl(FunctionDSL.nullMissingHandling(
v -> new ExprDoubleValue(Math.expm1(v.doubleValue()))),
type, DOUBLE)).collect(Collectors.toList()));
}
Yury-Fridlyand marked this conversation as resolved.
Show resolved Hide resolved

/**
* Definition of floor(x) function. Calculate the next nearest whole integer that x rounds down to
* The supported signature of floor function is DOUBLE -> INTEGER
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -565,6 +565,77 @@ public void exp_missing_value() {
assertTrue(exp.valueOf(valueEnv()).isMissing());
}

/**
* Test expm1 with integer value.
*/
@ParameterizedTest(name = "expm1({0})")
matthewryanwells marked this conversation as resolved.
Show resolved Hide resolved
@ValueSource(ints = {-2, 2})
public void expm1_int_value(Integer value) {
FunctionExpression expm1 = DSL.expm1(DSL.literal(value));
assertThat(
expm1.valueOf(valueEnv()),
allOf(hasType(DOUBLE), hasValue(1 - Math.expm1(value))));
assertEquals(String.format("expm1(%s)", value.toString()), expm1.toString());
}

/**
* Test expm1 with long value.
*/
@ParameterizedTest(name = "expm1({0})")
@ValueSource(longs = {-2L, 2L})
public void expm1_long_value(Long value) {
FunctionExpression expm1 = DSL.expm1(DSL.literal(value));
assertThat(
expm1.valueOf(valueEnv()),
allOf(hasType(DOUBLE), hasValue(Math.expm1(value))));
assertEquals(String.format("expm1(%s)", value.toString()), expm1.toString());
}

/**
* Test expm1 with float value.
*/
@ParameterizedTest(name = "expm1({0})")
@ValueSource(floats = {-2F, 2F})
matthewryanwells marked this conversation as resolved.
Show resolved Hide resolved
public void expm1_float_value(Float value) {
FunctionExpression expm1 = DSL.expm1(DSL.literal(value));
assertThat(
expm1.valueOf(valueEnv()),
allOf(hasType(DOUBLE), hasValue(Math.expm1(value))));
assertEquals(String.format("expm1(%s)", value.toString()), expm1.toString());
}

/**
* Test expm1 with double value.
*/
@ParameterizedTest(name = "expm1({0})")
@ValueSource(doubles = {-2D, 2D})
public void expm1_double_value(Double value) {
FunctionExpression expm1 = DSL.expm1(DSL.literal(value));
assertThat(
expm1.valueOf(valueEnv()),
allOf(hasType(DOUBLE), hasValue(Math.expm1(value))));
assertEquals(String.format("expm1(%s)", value.toString()), expm1.toString());
}

/**
* Test expm1 with null value.
*/
@Test
public void expm1_null_value() {
Yury-Fridlyand marked this conversation as resolved.
Show resolved Hide resolved
FunctionExpression expm1 = DSL.expm1(DSL.ref(DOUBLE_TYPE_NULL_VALUE_FIELD, DOUBLE));
assertEquals(DOUBLE, expm1.type());
assertTrue(expm1.valueOf(valueEnv()).isNull());
}

/**
* Test expm1 with missing value.
*/
@Test
public void expm1_missing_value() {
FunctionExpression expm1 = DSL.expm1(DSL.ref(DOUBLE_TYPE_MISSING_VALUE_FIELD, DOUBLE));
assertEquals(DOUBLE, expm1.type());
assertTrue(expm1.valueOf(valueEnv()).isMissing());
}
/**
* Test floor with integer value.
*/
Expand Down
15 changes: 13 additions & 2 deletions docs/user/dql/functions.rst
Original file line number Diff line number Diff line change
Expand Up @@ -443,10 +443,21 @@ EXPM1
Description
>>>>>>>>>>>

Specifications:
Usage: EXPM1(T) returns the exponential of T, minus 1.

Argument type: INTEGER/LONG/FLOAT/DOUBLE

1. EXPM1(NUMBER T) -> T
Return type: DOUBLE

Example::

os> SELECT EXPM1(-1), EXPM1(0), EXPM1(1);
fetched rows / total rows = 1/1
+---------------------+------------+-------------------+
| EXPM1(-1) | EXPM1(0) | EXPM1(1) |
matthewryanwells marked this conversation as resolved.
Show resolved Hide resolved
|---------------------+------------+-------------------|
| -0.6321205588285577 | 0.0 | 1.718281828459045 |
+---------------------+------------+-------------------+

FLOOR
-----
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,13 @@ public void testE() throws IOException {
verifyDataRows(result, rows(Math.E));
}

@Test
public void testExpm1() throws IOException {
JSONObject result = executeQuery("select expm1(account_number) FROM " + TEST_INDEX_BANK + " LIMIT 2");
verifySchema(result, schema("expm1(account_number)", null, "double"));
verifyDataRows(result, rows(Math.expm1(1)), rows(Math.expm1(6)));
}

@Test
public void testMod() throws IOException {
JSONObject result = executeQuery("select mod(3, 2)");
Expand Down
2 changes: 1 addition & 1 deletion sql/src/main/antlr/OpenSearchSQLParser.g4
Original file line number Diff line number Diff line change
Expand Up @@ -406,7 +406,7 @@ aggregationFunctionName
;

mathematicalFunctionName
: ABS | CBRT | CEIL | CEILING | CONV | CRC32 | E | EXP | FLOOR | LN | LOG | LOG10 | LOG2 | MOD | PI | POW | POWER
: ABS | CBRT | CEIL | CEILING | CONV | CRC32 | E | EXP | EXPM1 | FLOOR | LN | LOG | LOG10 | LOG2 | MOD | PI | POW | POWER
| RAND | ROUND | SIGN | SQRT | TRUNCATE
| trigonometricFunctionName
;
Expand Down