Skip to content

branch-4.1: [Fix](FoldConst) Preserve NaN in numeric constant folding #63870#63909

Merged
yiguolei merged 1 commit into
branch-4.1from
auto-pick-63870-branch-4.1
May 30, 2026
Merged

branch-4.1: [Fix](FoldConst) Preserve NaN in numeric constant folding #63870#63909
yiguolei merged 1 commit into
branch-4.1from
auto-pick-63870-branch-4.1

Conversation

@github-actions
Copy link
Copy Markdown
Contributor

Cherry-picked from #63870

Problem Summary:

Some numeric functions returned different results between normal
execution and FE constant folding when the input was NaN. The shared
boundary helper `inputOutOfBound()` treated `Double.NaN` as out of bound
because range comparisons with NaN are false, causing functions such as
`ln`, `log`, `log2`, `log10`, `dlog10`, and `power` to fold NaN cases
incorrectly to NULL or skip folding.

before
```sql
Doris> set debug_skip_fold_constant=true;
Doris> select log(2 ,cast('nan' as double));
+-------------------------------+
| log(2 ,cast('nan' as double)) |
+-------------------------------+
|                           NaN |
+-------------------------------+
1 row in set (0.033 sec)

Doris> set debug_skip_fold_constant=false;
Query OK, 0 rows affected (0.009 sec)

Doris> select log(2 ,cast('nan' as double));
+-------------------------------+
| log(2 ,cast('nan' as double)) |
+-------------------------------+
|                          NULL |
+-------------------------------+
1 row in set (0.008 sec)
```

now
```sql
Doris> set debug_skip_fold_constant=true;
Query OK, 0 rows affected (0.001 sec)

Doris> select log(2 ,cast('nan' as double));
+-------------------------------+
| log(2 ,cast('nan' as double)) |
+-------------------------------+
|                           NaN |
+-------------------------------+
1 row in set (0.018 sec)

Doris> set debug_skip_fold_constant=false;
Query OK, 0 rows affected (0.001 sec)

Doris> select log(2 ,cast('nan' as double));
+-------------------------------+
| log(2 ,cast('nan' as double)) |
+-------------------------------+
|                           NaN |
+-------------------------------+
1 row in set (0.003 sec)
```
@github-actions github-actions Bot requested a review from yiguolei as a code owner May 30, 2026 06:34
@hello-stephen
Copy link
Copy Markdown
Contributor

Thank you for your contribution to Apache Doris.
Don't know what should be done next? See How to process your PR.

Please clearly describe your PR:

  1. What problem was fixed (it's best to include specific error reporting information). How it was fixed.
  2. Which behaviors were modified. What was the previous behavior, what is it now, why was it modified, and what possible impacts might there be.
  3. What features were added. Why was this function added?
  4. Which code was refactored and why was this part of the code refactored?
  5. Which functions were optimized and what is the difference before and after the optimization?

@hello-stephen
Copy link
Copy Markdown
Contributor

run buildall

@hello-stephen
Copy link
Copy Markdown
Contributor

FE Regression Coverage Report

Increment line coverage 100.00% (2/2) 🎉
Increment coverage report
Complete coverage report

@yiguolei
Copy link
Copy Markdown
Contributor

skip buildall

@github-actions github-actions Bot added the approved Indicates a PR has been approved by one committer. label May 30, 2026
@github-actions
Copy link
Copy Markdown
Contributor Author

PR approved by at least one committer and no changes requested.

@github-actions
Copy link
Copy Markdown
Contributor Author

PR approved by anyone and no changes requested.

@yiguolei yiguolei merged commit d07c8ea into branch-4.1 May 30, 2026
32 of 34 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

approved Indicates a PR has been approved by one committer. reviewed

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants