From ca5e959a1e05fddf953e5e28d6451a5346ef5e80 Mon Sep 17 00:00:00 2001 From: Ganlin Zhao Date: Tue, 19 Jul 2022 11:46:17 +0800 Subject: [PATCH] fix(query): fix derivative nan value TD-17511 --- source/libs/function/src/builtinsimpl.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/source/libs/function/src/builtinsimpl.c b/source/libs/function/src/builtinsimpl.c index 4f829f2df1..9d40b15354 100644 --- a/source/libs/function/src/builtinsimpl.c +++ b/source/libs/function/src/builtinsimpl.c @@ -5661,7 +5661,12 @@ int32_t derivativeFunction(SqlFunctionCtx* pCtx) { double r = ((v - pDerivInfo->prevValue) * pDerivInfo->tsWindow) / (tsList[i] - pDerivInfo->prevTs); if (pDerivInfo->ignoreNegative && r < 0) { } else { - colDataAppend(pOutput, pos, (const char*)&r, false); + if (isinf(r) || isnan(r)) { + colDataAppendNULL(pOutput, pos); + } else { + colDataAppend(pOutput, pos, (const char*)&r, false); + } + if (pTsOutput != NULL) { colDataAppendInt64(pTsOutput, pos, &tsList[i]); } @@ -5688,7 +5693,12 @@ int32_t derivativeFunction(SqlFunctionCtx* pCtx) { double r = ((pDerivInfo->prevValue - v) * pDerivInfo->tsWindow) / (pDerivInfo->prevTs - tsList[i]); if (pDerivInfo->ignoreNegative && r < 0) { } else { - colDataAppend(pOutput, pos, (const char*)&r, false); + if (isinf(r) || isnan(r)) { + colDataAppendNULL(pOutput, pos); + } else { + colDataAppend(pOutput, pos, (const char*)&r, false); + } + if (pTsOutput != NULL) { colDataAppendInt64(pTsOutput, pos, &pDerivInfo->prevTs); } -- GitLab