Coverage Report

Created: 2026-06-20 11:34

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/function/if.h
Line
Count
Source
1
// Licensed to the Apache Software Foundation (ASF) under one
2
// or more contributor license agreements.  See the NOTICE file
3
// distributed with this work for additional information
4
// regarding copyright ownership.  The ASF licenses this file
5
// to you under the Apache License, Version 2.0 (the
6
// "License"); you may not use this file except in compliance
7
// with the License.  You may obtain a copy of the License at
8
//
9
//   http://www.apache.org/licenses/LICENSE-2.0
10
//
11
// Unless required by applicable law or agreed to in writing,
12
// software distributed under the License is distributed on an
13
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
// KIND, either express or implied.  See the License for the
15
// specific language governing permissions and limitations
16
// under the License.
17
// This file is copied from
18
// https://github.com/ClickHouse/ClickHouse/blob/master/src/Functions/If.cpp
19
// and modified by Doris
20
21
#include <glog/logging.h>
22
#include <stddef.h>
23
24
#include <boost/iterator/iterator_facade.hpp>
25
26
#include "core/column/column.h"
27
#include "core/column/column_vector.h"
28
#include "core/data_type/data_type.h"
29
#include "core/data_type/primitive_type.h"
30
#include "core/pod_array_fwd.h"
31
#include "core/types.h"
32
#include "exprs/function/function_helpers.h"
33
34
#ifdef __ARM_NEON
35
#include <arm_acle.h>
36
#include <arm_neon.h>
37
#endif
38
39
namespace doris {
40
41
template <PrimitiveType PType>
42
struct NumIfImpl {
43
private:
44
    using Type = typename PrimitiveTypeTraits<PType>::CppType;
45
    using ArrayCond = PaddedPODArray<UInt8>;
46
    using Array = PaddedPODArray<Type>;
47
    using ColVecT = typename PrimitiveTypeTraits<PType>::ColumnType;
48
49
public:
50
1.21k
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
1.21k
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
1.21k
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
180
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
180
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
180
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
760
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
760
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
760
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
4
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
4
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
96
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
96
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
96
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
69
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
69
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
69
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
4
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
4
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
4
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
4
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
50
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
50
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
50
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE26get_data_from_column_constEPKNS_11ColumnConstE
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
7
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
7
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE26get_data_from_column_constEPKNS_11ColumnConstE
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
33
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
33
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
33
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE26get_data_from_column_constEPKNS_11ColumnConstE
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE26get_data_from_column_constEPKNS_11ColumnConstE
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
7
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
7
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE26get_data_from_column_constEPKNS_11ColumnConstE
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE26get_data_from_column_constEPKNS_11ColumnConstE
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE26get_data_from_column_constEPKNS_11ColumnConstE
Line
Count
Source
50
4
    static const Array& get_data_from_column_const(const ColumnConst* column) {
51
4
        return assert_cast<const ColVecT&>(column->get_data_column()).get_data();
52
4
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE26get_data_from_column_constEPKNS_11ColumnConstE
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE26get_data_from_column_constEPKNS_11ColumnConstE
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE26get_data_from_column_constEPKNS_11ColumnConstE
53
54
1.01k
    static auto create_column(const ArrayCond& cond, int scale) {
55
1.01k
        if constexpr (is_decimal(PType)) {
56
42
            return ColVecT::create(cond.size(), scale);
57
976
        } else {
58
976
            return ColVecT::create(cond.size());
59
976
        }
60
1.01k
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
252
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
252
        } else {
58
252
            return ColVecT::create(cond.size());
59
252
        }
60
252
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
401
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
401
        } else {
58
401
            return ColVecT::create(cond.size());
59
401
        }
60
401
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
6
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
6
        } else {
58
6
            return ColVecT::create(cond.size());
59
6
        }
60
6
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
137
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
137
        } else {
58
137
            return ColVecT::create(cond.size());
59
137
        }
60
137
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
80
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
80
        } else {
58
80
            return ColVecT::create(cond.size());
59
80
        }
60
80
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
4
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
4
        } else {
58
4
            return ColVecT::create(cond.size());
59
4
        }
60
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
4
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
4
        } else {
58
4
            return ColVecT::create(cond.size());
59
4
        }
60
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
61
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
61
        } else {
58
61
            return ColVecT::create(cond.size());
59
61
        }
60
61
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
7
    static auto create_column(const ArrayCond& cond, int scale) {
55
7
        if constexpr (is_decimal(PType)) {
56
7
            return ColVecT::create(cond.size(), scale);
57
        } else {
58
            return ColVecT::create(cond.size());
59
        }
60
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
34
    static auto create_column(const ArrayCond& cond, int scale) {
55
34
        if constexpr (is_decimal(PType)) {
56
34
            return ColVecT::create(cond.size(), scale);
57
        } else {
58
            return ColVecT::create(cond.size());
59
        }
60
34
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
1
    static auto create_column(const ArrayCond& cond, int scale) {
55
1
        if constexpr (is_decimal(PType)) {
56
1
            return ColVecT::create(cond.size(), scale);
57
        } else {
58
            return ColVecT::create(cond.size());
59
        }
60
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
18
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
18
        } else {
58
18
            return ColVecT::create(cond.size());
59
18
        }
60
18
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
9
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
9
        } else {
58
9
            return ColVecT::create(cond.size());
59
9
        }
60
9
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Line
Count
Source
54
4
    static auto create_column(const ArrayCond& cond, int scale) {
55
        if constexpr (is_decimal(PType)) {
56
            return ColVecT::create(cond.size(), scale);
57
4
        } else {
58
4
            return ColVecT::create(cond.size());
59
4
        }
60
4
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE13create_columnERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEi
61
62
    static ColumnPtr execute_if(const ArrayCond& cond, const ColumnPtr& then_col,
63
1.02k
                                const ColumnPtr& else_col, int result_scale) {
64
1.02k
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
349
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
183
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
183
                                                  result_scale);
68
183
            } else if (const auto* col_const_else =
69
166
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
166
                return execute_impl<false, true>(cond, col_then->get_data(),
71
166
                                                 get_data_from_column_const(col_const_else),
72
166
                                                 result_scale);
73
166
            }
74
671
        } else if (const auto* col_const_then =
75
671
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
670
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
288
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
288
                                                 col_else->get_data(), result_scale);
79
382
            } else if (const auto* col_const_else =
80
382
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
382
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
382
                                                get_data_from_column_const(col_const_else),
83
382
                                                result_scale);
84
382
            }
85
670
        }
86
1
        return nullptr;
87
1.02k
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
253
                                const ColumnPtr& else_col, int result_scale) {
64
253
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
125
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
72
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
72
                                                  result_scale);
68
72
            } else if (const auto* col_const_else =
69
53
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
53
                return execute_impl<false, true>(cond, col_then->get_data(),
71
53
                                                 get_data_from_column_const(col_const_else),
72
53
                                                 result_scale);
73
53
            }
74
128
        } else if (const auto* col_const_then =
75
128
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
127
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
127
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
127
                                                 col_else->get_data(), result_scale);
79
127
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
127
        }
86
1
        return nullptr;
87
253
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
401
                                const ColumnPtr& else_col, int result_scale) {
64
401
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
8
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
5
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
5
                                                  result_scale);
68
5
            } else if (const auto* col_const_else =
69
3
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
3
                return execute_impl<false, true>(cond, col_then->get_data(),
71
3
                                                 get_data_from_column_const(col_const_else),
72
3
                                                 result_scale);
73
3
            }
74
393
        } else if (const auto* col_const_then =
75
393
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
393
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
29
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
29
                                                 col_else->get_data(), result_scale);
79
364
            } else if (const auto* col_const_else =
80
364
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
364
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
364
                                                get_data_from_column_const(col_const_else),
83
364
                                                result_scale);
84
364
            }
85
393
        }
86
0
        return nullptr;
87
401
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
6
                                const ColumnPtr& else_col, int result_scale) {
64
6
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
4
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
3
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
3
                                                  result_scale);
68
3
            } else if (const auto* col_const_else =
69
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
1
                return execute_impl<false, true>(cond, col_then->get_data(),
71
1
                                                 get_data_from_column_const(col_const_else),
72
1
                                                 result_scale);
73
1
            }
74
4
        } else if (const auto* col_const_then =
75
2
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
2
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
1
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
1
                                                 col_else->get_data(), result_scale);
79
1
            } else if (const auto* col_const_else =
80
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
1
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
1
                                                get_data_from_column_const(col_const_else),
83
1
                                                result_scale);
84
1
            }
85
2
        }
86
0
        return nullptr;
87
6
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
137
                                const ColumnPtr& else_col, int result_scale) {
64
137
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
66
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
52
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
52
                                                  result_scale);
68
52
            } else if (const auto* col_const_else =
69
14
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
14
                return execute_impl<false, true>(cond, col_then->get_data(),
71
14
                                                 get_data_from_column_const(col_const_else),
72
14
                                                 result_scale);
73
14
            }
74
71
        } else if (const auto* col_const_then =
75
71
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
71
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
60
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
60
                                                 col_else->get_data(), result_scale);
79
60
            } else if (const auto* col_const_else =
80
11
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
11
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
11
                                                get_data_from_column_const(col_const_else),
83
11
                                                result_scale);
84
11
            }
85
71
        }
86
0
        return nullptr;
87
137
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
81
                                const ColumnPtr& else_col, int result_scale) {
64
81
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
32
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
15
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
15
                                                  result_scale);
68
17
            } else if (const auto* col_const_else =
69
17
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
17
                return execute_impl<false, true>(cond, col_then->get_data(),
71
17
                                                 get_data_from_column_const(col_const_else),
72
17
                                                 result_scale);
73
17
            }
74
49
        } else if (const auto* col_const_then =
75
49
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
49
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
46
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
46
                                                 col_else->get_data(), result_scale);
79
46
            } else if (const auto* col_const_else =
80
3
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
3
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
3
                                                get_data_from_column_const(col_const_else),
83
3
                                                result_scale);
84
3
            }
85
49
        }
86
0
        return nullptr;
87
81
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
4
                                const ColumnPtr& else_col, int result_scale) {
64
4
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
2
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
1
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
1
                                                  result_scale);
68
1
            } else if (const auto* col_const_else =
69
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
1
                return execute_impl<false, true>(cond, col_then->get_data(),
71
1
                                                 get_data_from_column_const(col_const_else),
72
1
                                                 result_scale);
73
1
            }
74
2
        } else if (const auto* col_const_then =
75
2
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
2
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
1
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
1
                                                 col_else->get_data(), result_scale);
79
1
            } else if (const auto* col_const_else =
80
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
1
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
1
                                                get_data_from_column_const(col_const_else),
83
1
                                                result_scale);
84
1
            }
85
2
        }
86
0
        return nullptr;
87
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
4
                                const ColumnPtr& else_col, int result_scale) {
64
4
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
2
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
1
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
1
                                                  result_scale);
68
1
            } else if (const auto* col_const_else =
69
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
1
                return execute_impl<false, true>(cond, col_then->get_data(),
71
1
                                                 get_data_from_column_const(col_const_else),
72
1
                                                 result_scale);
73
1
            }
74
2
        } else if (const auto* col_const_then =
75
2
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
2
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
1
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
1
                                                 col_else->get_data(), result_scale);
79
1
            } else if (const auto* col_const_else =
80
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
1
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
1
                                                get_data_from_column_const(col_const_else),
83
1
                                                result_scale);
84
1
            }
85
2
        }
86
0
        return nullptr;
87
4
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
61
                                const ColumnPtr& else_col, int result_scale) {
64
61
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
54
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
12
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
12
                                                  result_scale);
68
42
            } else if (const auto* col_const_else =
69
42
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
42
                return execute_impl<false, true>(cond, col_then->get_data(),
71
42
                                                 get_data_from_column_const(col_const_else),
72
42
                                                 result_scale);
73
42
            }
74
54
        } else if (const auto* col_const_then =
75
7
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
7
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
6
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
6
                                                 col_else->get_data(), result_scale);
79
6
            } else if (const auto* col_const_else =
80
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
1
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
1
                                                get_data_from_column_const(col_const_else),
83
1
                                                result_scale);
84
1
            }
85
7
        }
86
0
        return nullptr;
87
61
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
7
                                const ColumnPtr& else_col, int result_scale) {
64
7
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
1
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
0
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
0
                                                  result_scale);
68
1
            } else if (const auto* col_const_else =
69
1
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
1
                return execute_impl<false, true>(cond, col_then->get_data(),
71
1
                                                 get_data_from_column_const(col_const_else),
72
1
                                                 result_scale);
73
1
            }
74
6
        } else if (const auto* col_const_then =
75
6
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
6
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
6
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
6
                                                 col_else->get_data(), result_scale);
79
6
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
6
        }
86
0
        return nullptr;
87
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
34
                                const ColumnPtr& else_col, int result_scale) {
64
34
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
34
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
1
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
1
                                                  result_scale);
68
33
            } else if (const auto* col_const_else =
69
33
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
33
                return execute_impl<false, true>(cond, col_then->get_data(),
71
33
                                                 get_data_from_column_const(col_const_else),
72
33
                                                 result_scale);
73
33
            }
74
34
        } else if (const auto* col_const_then =
75
0
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
0
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
0
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
0
                                                 col_else->get_data(), result_scale);
79
0
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
0
        }
86
0
        return nullptr;
87
34
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
1
                                const ColumnPtr& else_col, int result_scale) {
64
1
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
1
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
1
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
1
                                                  result_scale);
68
1
            } else if (const auto* col_const_else =
69
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
0
                return execute_impl<false, true>(cond, col_then->get_data(),
71
0
                                                 get_data_from_column_const(col_const_else),
72
0
                                                 result_scale);
73
0
            }
74
1
        } else if (const auto* col_const_then =
75
0
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
0
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
0
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
0
                                                 col_else->get_data(), result_scale);
79
0
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
0
        }
86
0
        return nullptr;
87
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
18
                                const ColumnPtr& else_col, int result_scale) {
64
18
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
11
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
11
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
11
                                                  result_scale);
68
11
            } else if (const auto* col_const_else =
69
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
0
                return execute_impl<false, true>(cond, col_then->get_data(),
71
0
                                                 get_data_from_column_const(col_const_else),
72
0
                                                 result_scale);
73
0
            }
74
11
        } else if (const auto* col_const_then =
75
7
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
7
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
7
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
7
                                                 col_else->get_data(), result_scale);
79
7
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
7
        }
86
0
        return nullptr;
87
18
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
9
                                const ColumnPtr& else_col, int result_scale) {
64
9
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
9
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
9
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
9
                                                  result_scale);
68
9
            } else if (const auto* col_const_else =
69
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
0
                return execute_impl<false, true>(cond, col_then->get_data(),
71
0
                                                 get_data_from_column_const(col_const_else),
72
0
                                                 result_scale);
73
0
            }
74
9
        } else if (const auto* col_const_then =
75
0
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
0
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
0
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
0
                                                 col_else->get_data(), result_scale);
79
0
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
0
        }
86
0
        return nullptr;
87
9
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Line
Count
Source
63
4
                                const ColumnPtr& else_col, int result_scale) {
64
4
        if (const auto* col_then = check_and_get_column<ColVecT>(then_col.get())) {
65
0
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
66
0
                return execute_impl<false, false>(cond, col_then->get_data(), col_else->get_data(),
67
0
                                                  result_scale);
68
0
            } else if (const auto* col_const_else =
69
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
70
0
                return execute_impl<false, true>(cond, col_then->get_data(),
71
0
                                                 get_data_from_column_const(col_const_else),
72
0
                                                 result_scale);
73
0
            }
74
4
        } else if (const auto* col_const_then =
75
4
                           check_and_get_column_const<ColVecT>(then_col.get())) {
76
4
            if (const auto* col_else = check_and_get_column<ColVecT>(else_col.get())) {
77
4
                return execute_impl<true, false>(cond, get_data_from_column_const(col_const_then),
78
4
                                                 col_else->get_data(), result_scale);
79
4
            } else if (const auto* col_const_else =
80
0
                               check_and_get_column_const<ColVecT>(else_col.get())) {
81
0
                return execute_impl<true, true>(cond, get_data_from_column_const(col_const_then),
82
0
                                                get_data_from_column_const(col_const_else),
83
0
                                                result_scale);
84
0
            }
85
4
        }
86
0
        return nullptr;
87
4
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE10execute_ifERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS_3COWINS_7IColumnEE13immutable_ptrISB_EESG_i
88
89
private:
90
    template <bool is_const_a, bool is_const_b>
91
    static ColumnPtr execute_impl(const ArrayCond& cond, const Array& a, const Array& b,
92
1.01k
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1.01k
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1.01k
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
92
72
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
72
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
72
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
92
53
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
53
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
53
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
92
127
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
127
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
127
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
5
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
5
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
5
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
3
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
3
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
29
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
29
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
29
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
364
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
364
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
364
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
3
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
3
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
52
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
52
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
52
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
14
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
14
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
14
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
60
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
60
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
60
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
11
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
11
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
11
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
15
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
15
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
15
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
17
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
17
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
17
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
46
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
46
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
46
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
3
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
3
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
12
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
12
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
12
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
42
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
42
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
42
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
6
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
6
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
6
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Line
Count
Source
92
6
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
6
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
6
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Line
Count
Source
92
33
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
33
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
33
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Line
Count
Source
92
1
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
1
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
92
11
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
11
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
11
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
92
7
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
7
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
92
9
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
9
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
9
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
92
4
                                  int result_scale) {
93
#ifdef __ARM_NEON
94
        if constexpr (can_use_neon_opt()) {
95
            auto col_res = create_column(cond, result_scale);
96
            auto res = col_res->get_data().data();
97
            neon_execute<is_const_a, is_const_b>(cond.data(), res, a.data(), b.data(), cond.size());
98
            return col_res;
99
        }
100
#endif
101
4
        return native_execute<is_const_a, is_const_b>(cond, a, b, result_scale);
102
4
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE12execute_implILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE12execute_implILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE12execute_implILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE12execute_implILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
103
104
    // res[i] = cond[i] ? a[i] : b[i];
105
    template <bool is_const_a, bool is_const_b>
106
    static ColumnPtr native_execute(const ArrayCond& cond, const Array& a, const Array& b,
107
1.01k
                                    int result_scale) {
108
1.01k
        size_t size = cond.size();
109
1.01k
        auto col_res = create_column(cond, result_scale);
110
1.01k
        auto& res = col_res->get_data();
111
144k
        for (size_t i = 0; i < size; ++i) {
112
143k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
143k
                             : b[index_check_const<is_const_b>(i)];
114
143k
        }
115
1.01k
        return col_res;
116
1.01k
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
107
72
                                    int result_scale) {
108
72
        size_t size = cond.size();
109
72
        auto col_res = create_column(cond, result_scale);
110
72
        auto& res = col_res->get_data();
111
341
        for (size_t i = 0; i < size; ++i) {
112
269
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
269
                             : b[index_check_const<is_const_b>(i)];
114
269
        }
115
72
        return col_res;
116
72
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
107
53
                                    int result_scale) {
108
53
        size_t size = cond.size();
109
53
        auto col_res = create_column(cond, result_scale);
110
53
        auto& res = col_res->get_data();
111
7.86k
        for (size_t i = 0; i < size; ++i) {
112
7.80k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
7.80k
                             : b[index_check_const<is_const_b>(i)];
114
7.80k
        }
115
53
        return col_res;
116
53
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
Line
Count
Source
107
127
                                    int result_scale) {
108
127
        size_t size = cond.size();
109
127
        auto col_res = create_column(cond, result_scale);
110
127
        auto& res = col_res->get_data();
111
945
        for (size_t i = 0; i < size; ++i) {
112
818
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
818
                             : b[index_check_const<is_const_b>(i)];
114
818
        }
115
127
        return col_res;
116
127
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE2EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESF_SF_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
5
                                    int result_scale) {
108
5
        size_t size = cond.size();
109
5
        auto col_res = create_column(cond, result_scale);
110
5
        auto& res = col_res->get_data();
111
1.07k
        for (size_t i = 0; i < size; ++i) {
112
1.06k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.06k
                             : b[index_check_const<is_const_b>(i)];
114
1.06k
        }
115
5
        return col_res;
116
5
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
3
                                    int result_scale) {
108
3
        size_t size = cond.size();
109
3
        auto col_res = create_column(cond, result_scale);
110
3
        auto& res = col_res->get_data();
111
1.06k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
3
        return col_res;
116
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
29
                                    int result_scale) {
108
29
        size_t size = cond.size();
109
29
        auto col_res = create_column(cond, result_scale);
110
29
        auto& res = col_res->get_data();
111
1.17k
        for (size_t i = 0; i < size; ++i) {
112
1.14k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.14k
                             : b[index_check_const<is_const_b>(i)];
114
1.14k
        }
115
29
        return col_res;
116
29
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE3EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IaLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
364
                                    int result_scale) {
108
364
        size_t size = cond.size();
109
364
        auto col_res = create_column(cond, result_scale);
110
364
        auto& res = col_res->get_data();
111
60.6k
        for (size_t i = 0; i < size; ++i) {
112
60.3k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
60.3k
                             : b[index_check_const<is_const_b>(i)];
114
60.3k
        }
115
364
        return col_res;
116
364
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
3
                                    int result_scale) {
108
3
        size_t size = cond.size();
109
3
        auto col_res = create_column(cond, result_scale);
110
3
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
3
        return col_res;
116
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE4EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IsLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
52
                                    int result_scale) {
108
52
        size_t size = cond.size();
109
52
        auto col_res = create_column(cond, result_scale);
110
52
        auto& res = col_res->get_data();
111
2.29k
        for (size_t i = 0; i < size; ++i) {
112
2.23k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
2.23k
                             : b[index_check_const<is_const_b>(i)];
114
2.23k
        }
115
52
        return col_res;
116
52
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
14
                                    int result_scale) {
108
14
        size_t size = cond.size();
109
14
        auto col_res = create_column(cond, result_scale);
110
14
        auto& res = col_res->get_data();
111
1.11k
        for (size_t i = 0; i < size; ++i) {
112
1.09k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.09k
                             : b[index_check_const<is_const_b>(i)];
114
1.09k
        }
115
14
        return col_res;
116
14
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
60
                                    int result_scale) {
108
60
        size_t size = cond.size();
109
60
        auto col_res = create_column(cond, result_scale);
110
60
        auto& res = col_res->get_data();
111
1.37k
        for (size_t i = 0; i < size; ++i) {
112
1.31k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.31k
                             : b[index_check_const<is_const_b>(i)];
114
1.31k
        }
115
60
        return col_res;
116
60
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE5EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IiLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
11
                                    int result_scale) {
108
11
        size_t size = cond.size();
109
11
        auto col_res = create_column(cond, result_scale);
110
11
        auto& res = col_res->get_data();
111
1.09k
        for (size_t i = 0; i < size; ++i) {
112
1.08k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.08k
                             : b[index_check_const<is_const_b>(i)];
114
1.08k
        }
115
11
        return col_res;
116
11
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
15
                                    int result_scale) {
108
15
        size_t size = cond.size();
109
15
        auto col_res = create_column(cond, result_scale);
110
15
        auto& res = col_res->get_data();
111
1.14k
        for (size_t i = 0; i < size; ++i) {
112
1.12k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.12k
                             : b[index_check_const<is_const_b>(i)];
114
1.12k
        }
115
15
        return col_res;
116
15
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
17
                                    int result_scale) {
108
17
        size_t size = cond.size();
109
17
        auto col_res = create_column(cond, result_scale);
110
17
        auto& res = col_res->get_data();
111
29.2k
        for (size_t i = 0; i < size; ++i) {
112
29.2k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
29.2k
                             : b[index_check_const<is_const_b>(i)];
114
29.2k
        }
115
17
        return col_res;
116
17
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
46
                                    int result_scale) {
108
46
        size_t size = cond.size();
109
46
        auto col_res = create_column(cond, result_scale);
110
46
        auto& res = col_res->get_data();
111
1.28k
        for (size_t i = 0; i < size; ++i) {
112
1.24k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.24k
                             : b[index_check_const<is_const_b>(i)];
114
1.24k
        }
115
46
        return col_res;
116
46
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE6EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IlLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
3
                                    int result_scale) {
108
3
        size_t size = cond.size();
109
3
        auto col_res = create_column(cond, result_scale);
110
3
        auto& res = col_res->get_data();
111
1.08k
        for (size_t i = 0; i < size; ++i) {
112
1.07k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.07k
                             : b[index_check_const<is_const_b>(i)];
114
1.07k
        }
115
3
        return col_res;
116
3
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE7EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_InLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE8EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IfLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
12
                                    int result_scale) {
108
12
        size_t size = cond.size();
109
12
        auto col_res = create_column(cond, result_scale);
110
12
        auto& res = col_res->get_data();
111
1.09k
        for (size_t i = 0; i < size; ++i) {
112
1.08k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.08k
                             : b[index_check_const<is_const_b>(i)];
114
1.08k
        }
115
12
        return col_res;
116
12
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
42
                                    int result_scale) {
108
42
        size_t size = cond.size();
109
42
        auto col_res = create_column(cond, result_scale);
110
42
        auto& res = col_res->get_data();
111
8.84k
        for (size_t i = 0; i < size; ++i) {
112
8.80k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
8.80k
                             : b[index_check_const<is_const_b>(i)];
114
8.80k
        }
115
42
        return col_res;
116
42
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
6
                                    int result_scale) {
108
6
        size_t size = cond.size();
109
6
        auto col_res = create_column(cond, result_scale);
110
6
        auto& res = col_res->get_data();
111
1.06k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
6
        return col_res;
116
6
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE9EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
1.05k
        for (size_t i = 0; i < size; ++i) {
112
1.05k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1.05k
                             : b[index_check_const<is_const_b>(i)];
114
1.05k
        }
115
1
        return col_res;
116
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE28EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIiEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
6
        for (size_t i = 0; i < size; ++i) {
112
5
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
5
                             : b[index_check_const<is_const_b>(i)];
114
5
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Line
Count
Source
107
6
                                    int result_scale) {
108
6
        size_t size = cond.size();
109
6
        auto col_res = create_column(cond, result_scale);
110
6
        auto& res = col_res->get_data();
111
27
        for (size_t i = 0; i < size; ++i) {
112
21
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
21
                             : b[index_check_const<is_const_b>(i)];
114
21
        }
115
6
        return col_res;
116
6
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE29EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIlEELm4096ESC_Lm16ELm15EEESK_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE20EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_14DecimalV2ValueELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
2
        for (size_t i = 0; i < size; ++i) {
112
1
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1
                             : b[index_check_const<is_const_b>(i)];
114
1
        }
115
1
        return col_res;
116
1
    }
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Line
Count
Source
107
33
                                    int result_scale) {
108
33
        size_t size = cond.size();
109
33
        auto col_res = create_column(cond, result_scale);
110
33
        auto& res = col_res->get_data();
111
8.08k
        for (size_t i = 0; i < size; ++i) {
112
8.04k
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
8.04k
                             : b[index_check_const<is_const_b>(i)];
114
8.04k
        }
115
33
        return col_res;
116
33
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE30EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_12Decimal128V3ELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Line
Count
Source
107
1
                                    int result_scale) {
108
1
        size_t size = cond.size();
109
1
        auto col_res = create_column(cond, result_scale);
110
1
        auto& res = col_res->get_data();
111
2
        for (size_t i = 0; i < size; ++i) {
112
1
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
1
                             : b[index_check_const<is_const_b>(i)];
114
1
        }
115
1
        return col_res;
116
1
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE35EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_7DecimalIN4wide7integerILm256EiEEEELm4096ESC_Lm16ELm15EEESN_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE11EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
107
11
                                    int result_scale) {
108
11
        size_t size = cond.size();
109
11
        auto col_res = create_column(cond, result_scale);
110
11
        auto& res = col_res->get_data();
111
47
        for (size_t i = 0; i < size; ++i) {
112
36
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
36
                             : b[index_check_const<is_const_b>(i)];
114
36
        }
115
11
        return col_res;
116
11
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
107
7
                                    int result_scale) {
108
7
        size_t size = cond.size();
109
7
        auto col_res = create_column(cond, result_scale);
110
7
        auto& res = col_res->get_data();
111
34
        for (size_t i = 0; i < size; ++i) {
112
27
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
27
                             : b[index_check_const<is_const_b>(i)];
114
27
        }
115
7
        return col_res;
116
7
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE25EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_15DateV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Line
Count
Source
107
9
                                    int result_scale) {
108
9
        size_t size = cond.size();
109
9
        auto col_res = create_column(cond, result_scale);
110
9
        auto& res = col_res->get_data();
111
51
        for (size_t i = 0; i < size; ++i) {
112
42
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
42
                             : b[index_check_const<is_const_b>(i)];
114
42
        }
115
9
        return col_res;
116
9
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE26EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_11DateV2ValueINS_19DateTimeV2ValueTypeEEELm4096ESC_Lm16ELm15EEESL_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE12EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16VecDateTimeValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
_ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Line
Count
Source
107
4
                                    int result_scale) {
108
4
        size_t size = cond.size();
109
4
        auto col_res = create_column(cond, result_scale);
110
4
        auto& res = col_res->get_data();
111
8
        for (size_t i = 0; i < size; ++i) {
112
4
            res[i] = cond[i] ? a[index_check_const<is_const_a>(i)]
113
4
                             : b[index_check_const<is_const_b>(i)];
114
4
        }
115
4
        return col_res;
116
4
    }
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE27EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IdLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE42EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_INS_16TimestampTzValueELm4096ESC_Lm16ELm15EEESJ_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE36EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IjLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE14native_executeILb0ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE14native_executeILb0ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE14native_executeILb1ELb0EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
Unexecuted instantiation: _ZN5doris9NumIfImplILNS_13PrimitiveTypeE37EE14native_executeILb1ELb1EEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS9_IoLm4096ESC_Lm16ELm15EEESI_i
117
118
#ifdef __ARM_NEON
119
    constexpr static bool can_use_neon_opt() {
120
        return sizeof(Type) == 1 || sizeof(Type) == 2 || sizeof(Type) == 4 || sizeof(Type) == 8;
121
    }
122
123
    template <bool is_a_const, bool is_b_const>
124
    static void neon_execute(const uint8_t* cond, Type* res, const Type* a, const Type* b,
125
                             size_t size) {
126
        const Type* res_end = res + size;
127
        constexpr int data_size = sizeof(Type);
128
        constexpr int elements_per_process = 16;
129
130
        // Process 16 element of data at a time
131
        while (res + elements_per_process < res_end) {
132
            // Load 16 cond masks
133
            uint8x16_t loaded_mask = vld1q_u8(cond);
134
            //[1, 0, 1, 0, 1, 0, 1, 0, ...]
135
136
            loaded_mask = vceqq_u8(loaded_mask, vdupq_n_u8(0));
137
            //[0, FF, 0, FF, 0, FF, 0, FF, ...]
138
139
            loaded_mask = vmvnq_u8(loaded_mask);
140
            //[FF, 0, FF, 0, FF, 0, FF, 0, ...]
141
142
            if constexpr (data_size == 1) {
143
                uint8x16_t vec_a;
144
                if constexpr (!is_a_const) {
145
                    vec_a = vld1q_u8(reinterpret_cast<const uint8_t*>(a));
146
                } else {
147
                    vec_a = vdupq_n_u8(*reinterpret_cast<const uint8_t*>(a));
148
                }
149
150
                uint8x16_t vec_b;
151
                if constexpr (!is_b_const) {
152
                    vec_b = vld1q_u8(reinterpret_cast<const uint8_t*>(b));
153
                } else {
154
                    vec_b = vdupq_n_u8(*reinterpret_cast<const uint8_t*>(b));
155
                }
156
157
                uint8x16_t result = vbslq_u8(loaded_mask, vec_a, vec_b);
158
159
                vst1q_u8(reinterpret_cast<uint8_t*>(res), result);
160
161
            } else if constexpr (data_size == 2) {
162
                // Process 2 groups, each handling 8 int16
163
                for (int i = 0; i < 2; i++) {
164
                    uint16x8_t vec_a;
165
                    if constexpr (!is_a_const) {
166
                        vec_a = vld1q_u16(reinterpret_cast<const uint16_t*>(a) + i * 8);
167
                    } else {
168
                        vec_a = vdupq_n_u16(*reinterpret_cast<const uint16_t*>(a));
169
                    }
170
171
                    uint16x8_t vec_b;
172
                    if constexpr (!is_b_const) {
173
                        vec_b = vld1q_u16(reinterpret_cast<const uint16_t*>(b) + i * 8);
174
                    } else {
175
                        vec_b = vdupq_n_u16(*reinterpret_cast<const uint16_t*>(b));
176
                    }
177
178
                    uint8x16_t index = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7};
179
                    uint8x16_t mask = vqtbl1q_u8(loaded_mask, index);
180
                    // loaded_mask = [A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P] : u8
181
                    // index       = [0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7] : u8
182
                    // mask        = [A, A, B, B, C, C, D, D, E, E, F, F, G, G, H, H] : u8
183
184
                    uint16x8_t result = vbslq_u16(vreinterpretq_u16_u8(mask), vec_a, vec_b);
185
186
                    vst1q_u16(reinterpret_cast<uint16_t*>(res) + i * 8, result);
187
                    loaded_mask = vextq_u8(loaded_mask, loaded_mask, 8);
188
                }
189
            } else if constexpr (data_size == 4) {
190
                // Process 4 groups, each handling 4 int32
191
                for (int i = 0; i < 4; i++) {
192
                    uint32x4_t vec_a;
193
                    if constexpr (!is_a_const) {
194
                        vec_a = vld1q_u32(reinterpret_cast<const uint32_t*>(a) + i * 4);
195
                    } else {
196
                        vec_a = vdupq_n_u32(*reinterpret_cast<const uint32_t*>(a));
197
                    }
198
199
                    uint32x4_t vec_b;
200
                    if constexpr (!is_b_const) {
201
                        vec_b = vld1q_u32(reinterpret_cast<const uint32_t*>(b) + i * 4);
202
                    } else {
203
                        vec_b = vdupq_n_u32(*reinterpret_cast<const uint32_t*>(b));
204
                    }
205
206
                    uint8x16_t index = {0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3};
207
                    uint8x16_t mask = vqtbl1q_u8(loaded_mask, index);
208
209
                    uint32x4_t result = vbslq_u32(vreinterpretq_u32_u8(mask), vec_a, vec_b);
210
211
                    vst1q_u32(reinterpret_cast<uint32_t*>(res) + i * 4, result);
212
                    loaded_mask = vextq_u8(loaded_mask, loaded_mask, 4);
213
                }
214
            } else if constexpr (data_size == 8) {
215
                // Process 8 groups, each handling 2 int64
216
                for (int i = 0; i < 8; i++) {
217
                    uint64x2_t vec_a;
218
                    if constexpr (!is_a_const) {
219
                        vec_a = vld1q_u64(reinterpret_cast<const uint64_t*>(a) + i * 2);
220
                    } else {
221
                        vec_a = vdupq_n_u64(*reinterpret_cast<const uint64_t*>(a));
222
                    }
223
224
                    uint64x2_t vec_b;
225
                    if constexpr (!is_b_const) {
226
                        vec_b = vld1q_u64(reinterpret_cast<const uint64_t*>(b) + i * 2);
227
                    } else {
228
                        vec_b = vdupq_n_u64(*reinterpret_cast<const uint64_t*>(b));
229
                    }
230
231
                    uint8x16_t index = {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1};
232
                    uint8x16_t mask = vqtbl1q_u8(loaded_mask, index);
233
234
                    uint64x2_t result = vbslq_u64(vreinterpretq_u64_u8(mask), vec_a, vec_b);
235
236
                    vst1q_u64(reinterpret_cast<uint64_t*>(res) + i * 2, result);
237
238
                    loaded_mask = vextq_u8(loaded_mask, loaded_mask, 2);
239
                }
240
            }
241
242
            res += elements_per_process;
243
            cond += elements_per_process;
244
            if (!is_a_const) {
245
                a += elements_per_process;
246
            }
247
            if (!is_b_const) {
248
                b += elements_per_process;
249
            }
250
        }
251
252
        // for the remaining data
253
        while (res < res_end) {
254
            *res = *cond ? *a : *b;
255
            res++;
256
            cond++;
257
            if (!is_a_const) {
258
                a++;
259
            }
260
            if (!is_b_const) {
261
                b++;
262
            }
263
        }
264
    }
265
266
#endif
267
};
268
269
} // namespace doris