Coverage Report

Created: 2026-07-05 03:19

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/function/functions_comparison.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/FunctionsComparison.h
19
// and modified by Doris
20
21
#pragma once
22
23
#include <compare>
24
#include <limits>
25
#include <optional>
26
#include <string_view>
27
#include <type_traits>
28
29
#include "common/check.h"
30
#include "common/logging.h"
31
#include "core/accurate_comparison.h"
32
#include "core/assert_cast.h"
33
#include "core/column/column_const.h"
34
#include "core/column/column_decimal.h"
35
#include "core/column/column_nullable.h"
36
#include "core/column/column_string.h"
37
#include "core/data_type/data_type_nullable.h"
38
#include "core/data_type/data_type_number.h"
39
#include "core/data_type/data_type_string.h"
40
#include "core/data_type/define_primitive_type.h"
41
#include "core/decimal_comparison.h"
42
#include "core/field.h"
43
#include "core/memcmp_small.h"
44
#include "core/value/vdatetime_value.h"
45
#include "exprs/expr_zonemap_filter.h"
46
#include "exprs/function/function.h"
47
#include "exprs/function/function_helpers.h"
48
#include "exprs/function/functions_logical.h"
49
#include "exprs/vexpr.h"
50
#include "storage/index/index_reader_helper.h"
51
52
namespace doris {
53
/** Comparison functions: ==, !=, <, >, <=, >=.
54
  * The comparison functions always return 0 or 1 (UInt8).
55
  *
56
  * You can compare the following types:
57
  * - numbers and decimals;
58
  * - strings and fixed strings;
59
  * - dates;
60
  * - datetimes;
61
  *   within each group, but not from different groups;
62
  * - tuples (lexicographic comparison).
63
  *
64
  * Exception: You can compare the date and datetime with a constant string. Example: EventDate = '2015-01-01'.
65
  */
66
67
template <typename A, typename B, typename Op>
68
struct NumComparisonImpl {
69
    /// If you don't specify NO_INLINE, the compiler will inline this function, but we don't need this as this function contains tight loop inside.
70
    static void NO_INLINE vector_vector(const PaddedPODArray<A>& a, const PaddedPODArray<B>& b,
71
8.45k
                                        PaddedPODArray<UInt8>& c) {
72
8.45k
        size_t size = a.size();
73
8.45k
        const A* __restrict a_pos = a.data();
74
8.45k
        const B* __restrict b_pos = b.data();
75
8.45k
        UInt8* __restrict c_pos = c.data();
76
8.45k
        const A* __restrict a_end = a_pos + size;
77
78
5.57M
        while (a_pos < a_end) {
79
5.56M
            *c_pos = Op::apply(*a_pos, *b_pos);
80
5.56M
            ++a_pos;
81
5.56M
            ++b_pos;
82
5.56M
            ++c_pos;
83
5.56M
        }
84
8.45k
    }
_ZN5doris17NumComparisonImplIhhNS_8EqualsOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
Line
Count
Source
71
76
                                        PaddedPODArray<UInt8>& c) {
72
76
        size_t size = a.size();
73
76
        const A* __restrict a_pos = a.data();
74
76
        const B* __restrict b_pos = b.data();
75
76
        UInt8* __restrict c_pos = c.data();
76
76
        const A* __restrict a_end = a_pos + size;
77
78
152
        while (a_pos < a_end) {
79
76
            *c_pos = Op::apply(*a_pos, *b_pos);
80
76
            ++a_pos;
81
76
            ++b_pos;
82
76
            ++c_pos;
83
76
        }
84
76
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
369
                                        PaddedPODArray<UInt8>& c) {
72
369
        size_t size = a.size();
73
369
        const A* __restrict a_pos = a.data();
74
369
        const B* __restrict b_pos = b.data();
75
369
        UInt8* __restrict c_pos = c.data();
76
369
        const A* __restrict a_end = a_pos + size;
77
78
1.59k
        while (a_pos < a_end) {
79
1.22k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1.22k
            ++a_pos;
81
1.22k
            ++b_pos;
82
1.22k
            ++c_pos;
83
1.22k
        }
84
369
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
278
                                        PaddedPODArray<UInt8>& c) {
72
278
        size_t size = a.size();
73
278
        const A* __restrict a_pos = a.data();
74
278
        const B* __restrict b_pos = b.data();
75
278
        UInt8* __restrict c_pos = c.data();
76
278
        const A* __restrict a_end = a_pos + size;
77
78
574
        while (a_pos < a_end) {
79
296
            *c_pos = Op::apply(*a_pos, *b_pos);
80
296
            ++a_pos;
81
296
            ++b_pos;
82
296
            ++c_pos;
83
296
        }
84
278
    }
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_8EqualsOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
71
3
                                        PaddedPODArray<UInt8>& c) {
72
3
        size_t size = a.size();
73
3
        const A* __restrict a_pos = a.data();
74
3
        const B* __restrict b_pos = b.data();
75
3
        UInt8* __restrict c_pos = c.data();
76
3
        const A* __restrict a_end = a_pos + size;
77
78
13
        while (a_pos < a_end) {
79
10
            *c_pos = Op::apply(*a_pos, *b_pos);
80
10
            ++a_pos;
81
10
            ++b_pos;
82
10
            ++c_pos;
83
10
        }
84
3
    }
_ZN5doris17NumComparisonImplIaaNS_8EqualsOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
175
                                        PaddedPODArray<UInt8>& c) {
72
175
        size_t size = a.size();
73
175
        const A* __restrict a_pos = a.data();
74
175
        const B* __restrict b_pos = b.data();
75
175
        UInt8* __restrict c_pos = c.data();
76
175
        const A* __restrict a_end = a_pos + size;
77
78
492
        while (a_pos < a_end) {
79
317
            *c_pos = Op::apply(*a_pos, *b_pos);
80
317
            ++a_pos;
81
317
            ++b_pos;
82
317
            ++c_pos;
83
317
        }
84
175
    }
_ZN5doris17NumComparisonImplIssNS_8EqualsOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
96
                                        PaddedPODArray<UInt8>& c) {
72
96
        size_t size = a.size();
73
96
        const A* __restrict a_pos = a.data();
74
96
        const B* __restrict b_pos = b.data();
75
96
        UInt8* __restrict c_pos = c.data();
76
96
        const A* __restrict a_end = a_pos + size;
77
78
192
        while (a_pos < a_end) {
79
96
            *c_pos = Op::apply(*a_pos, *b_pos);
80
96
            ++a_pos;
81
96
            ++b_pos;
82
96
            ++c_pos;
83
96
        }
84
96
    }
_ZN5doris17NumComparisonImplIiiNS_8EqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
259
                                        PaddedPODArray<UInt8>& c) {
72
259
        size_t size = a.size();
73
259
        const A* __restrict a_pos = a.data();
74
259
        const B* __restrict b_pos = b.data();
75
259
        UInt8* __restrict c_pos = c.data();
76
259
        const A* __restrict a_end = a_pos + size;
77
78
1.66k
        while (a_pos < a_end) {
79
1.40k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1.40k
            ++a_pos;
81
1.40k
            ++b_pos;
82
1.40k
            ++c_pos;
83
1.40k
        }
84
259
    }
_ZN5doris17NumComparisonImplIllNS_8EqualsOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
149
                                        PaddedPODArray<UInt8>& c) {
72
149
        size_t size = a.size();
73
149
        const A* __restrict a_pos = a.data();
74
149
        const B* __restrict b_pos = b.data();
75
149
        UInt8* __restrict c_pos = c.data();
76
149
        const A* __restrict a_end = a_pos + size;
77
78
1.48k
        while (a_pos < a_end) {
79
1.33k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1.33k
            ++a_pos;
81
1.33k
            ++b_pos;
82
1.33k
            ++c_pos;
83
1.33k
        }
84
149
    }
_ZN5doris17NumComparisonImplInnNS_8EqualsOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
86
                                        PaddedPODArray<UInt8>& c) {
72
86
        size_t size = a.size();
73
86
        const A* __restrict a_pos = a.data();
74
86
        const B* __restrict b_pos = b.data();
75
86
        UInt8* __restrict c_pos = c.data();
76
86
        const A* __restrict a_end = a_pos + size;
77
78
172
        while (a_pos < a_end) {
79
86
            *c_pos = Op::apply(*a_pos, *b_pos);
80
86
            ++a_pos;
81
86
            ++b_pos;
82
86
            ++c_pos;
83
86
        }
84
86
    }
_ZN5doris17NumComparisonImplIjjNS_8EqualsOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
16
                                        PaddedPODArray<UInt8>& c) {
72
16
        size_t size = a.size();
73
16
        const A* __restrict a_pos = a.data();
74
16
        const B* __restrict b_pos = b.data();
75
16
        UInt8* __restrict c_pos = c.data();
76
16
        const A* __restrict a_end = a_pos + size;
77
78
32
        while (a_pos < a_end) {
79
16
            *c_pos = Op::apply(*a_pos, *b_pos);
80
16
            ++a_pos;
81
16
            ++b_pos;
82
16
            ++c_pos;
83
16
        }
84
16
    }
_ZN5doris17NumComparisonImplIooNS_8EqualsOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
24
                                        PaddedPODArray<UInt8>& c) {
72
24
        size_t size = a.size();
73
24
        const A* __restrict a_pos = a.data();
74
24
        const B* __restrict b_pos = b.data();
75
24
        UInt8* __restrict c_pos = c.data();
76
24
        const A* __restrict a_end = a_pos + size;
77
78
48
        while (a_pos < a_end) {
79
24
            *c_pos = Op::apply(*a_pos, *b_pos);
80
24
            ++a_pos;
81
24
            ++b_pos;
82
24
            ++c_pos;
83
24
        }
84
24
    }
_ZN5doris17NumComparisonImplIffNS_8EqualsOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
118
                                        PaddedPODArray<UInt8>& c) {
72
118
        size_t size = a.size();
73
118
        const A* __restrict a_pos = a.data();
74
118
        const B* __restrict b_pos = b.data();
75
118
        UInt8* __restrict c_pos = c.data();
76
118
        const A* __restrict a_end = a_pos + size;
77
78
255
        while (a_pos < a_end) {
79
137
            *c_pos = Op::apply(*a_pos, *b_pos);
80
137
            ++a_pos;
81
137
            ++b_pos;
82
137
            ++c_pos;
83
137
        }
84
118
    }
_ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
107
                                        PaddedPODArray<UInt8>& c) {
72
107
        size_t size = a.size();
73
107
        const A* __restrict a_pos = a.data();
74
107
        const B* __restrict b_pos = b.data();
75
107
        UInt8* __restrict c_pos = c.data();
76
107
        const A* __restrict a_end = a_pos + size;
77
78
235
        while (a_pos < a_end) {
79
128
            *c_pos = Op::apply(*a_pos, *b_pos);
80
128
            ++a_pos;
81
128
            ++b_pos;
82
128
            ++c_pos;
83
128
        }
84
107
    }
_ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
4
                                        PaddedPODArray<UInt8>& c) {
72
4
        size_t size = a.size();
73
4
        const A* __restrict a_pos = a.data();
74
4
        const B* __restrict b_pos = b.data();
75
4
        UInt8* __restrict c_pos = c.data();
76
4
        const A* __restrict a_end = a_pos + size;
77
78
8
        while (a_pos < a_end) {
79
4
            *c_pos = Op::apply(*a_pos, *b_pos);
80
4
            ++a_pos;
81
4
            ++b_pos;
82
4
            ++c_pos;
83
4
        }
84
4
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_11NotEqualsOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
39
                                        PaddedPODArray<UInt8>& c) {
72
39
        size_t size = a.size();
73
39
        const A* __restrict a_pos = a.data();
74
39
        const B* __restrict b_pos = b.data();
75
39
        UInt8* __restrict c_pos = c.data();
76
39
        const A* __restrict a_end = a_pos + size;
77
78
108
        while (a_pos < a_end) {
79
69
            *c_pos = Op::apply(*a_pos, *b_pos);
80
69
            ++a_pos;
81
69
            ++b_pos;
82
69
            ++c_pos;
83
69
        }
84
39
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_11NotEqualsOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_11NotEqualsOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
56
                                        PaddedPODArray<UInt8>& c) {
72
56
        size_t size = a.size();
73
56
        const A* __restrict a_pos = a.data();
74
56
        const B* __restrict b_pos = b.data();
75
56
        UInt8* __restrict c_pos = c.data();
76
56
        const A* __restrict a_end = a_pos + size;
77
78
252
        while (a_pos < a_end) {
79
196
            *c_pos = Op::apply(*a_pos, *b_pos);
80
196
            ++a_pos;
81
196
            ++b_pos;
82
196
            ++c_pos;
83
196
        }
84
56
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_11NotEqualsOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
864
                                        PaddedPODArray<UInt8>& c) {
72
864
        size_t size = a.size();
73
864
        const A* __restrict a_pos = a.data();
74
864
        const B* __restrict b_pos = b.data();
75
864
        UInt8* __restrict c_pos = c.data();
76
864
        const A* __restrict a_end = a_pos + size;
77
78
395k
        while (a_pos < a_end) {
79
394k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
394k
            ++a_pos;
81
394k
            ++b_pos;
82
394k
            ++c_pos;
83
394k
        }
84
864
    }
_ZN5doris17NumComparisonImplIllNS_11NotEqualsOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
377
                                        PaddedPODArray<UInt8>& c) {
72
377
        size_t size = a.size();
73
377
        const A* __restrict a_pos = a.data();
74
377
        const B* __restrict b_pos = b.data();
75
377
        UInt8* __restrict c_pos = c.data();
76
377
        const A* __restrict a_end = a_pos + size;
77
78
7.55k
        while (a_pos < a_end) {
79
7.17k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
7.17k
            ++a_pos;
81
7.17k
            ++b_pos;
82
7.17k
            ++c_pos;
83
7.17k
        }
84
377
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_11NotEqualsOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_11NotEqualsOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_11NotEqualsOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIffNS_11NotEqualsOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
_ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_9GreaterOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
1.11k
                                        PaddedPODArray<UInt8>& c) {
72
1.11k
        size_t size = a.size();
73
1.11k
        const A* __restrict a_pos = a.data();
74
1.11k
        const B* __restrict b_pos = b.data();
75
1.11k
        UInt8* __restrict c_pos = c.data();
76
1.11k
        const A* __restrict a_end = a_pos + size;
77
78
3.91M
        while (a_pos < a_end) {
79
3.91M
            *c_pos = Op::apply(*a_pos, *b_pos);
80
3.91M
            ++a_pos;
81
3.91M
            ++b_pos;
82
3.91M
            ++c_pos;
83
3.91M
        }
84
1.11k
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_9GreaterOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
71
2
                                        PaddedPODArray<UInt8>& c) {
72
2
        size_t size = a.size();
73
2
        const A* __restrict a_pos = a.data();
74
2
        const B* __restrict b_pos = b.data();
75
2
        UInt8* __restrict c_pos = c.data();
76
2
        const A* __restrict a_end = a_pos + size;
77
78
11
        while (a_pos < a_end) {
79
9
            *c_pos = Op::apply(*a_pos, *b_pos);
80
9
            ++a_pos;
81
9
            ++b_pos;
82
9
            ++c_pos;
83
9
        }
84
2
    }
_ZN5doris17NumComparisonImplIaaNS_9GreaterOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
40
                                        PaddedPODArray<UInt8>& c) {
72
40
        size_t size = a.size();
73
40
        const A* __restrict a_pos = a.data();
74
40
        const B* __restrict b_pos = b.data();
75
40
        UInt8* __restrict c_pos = c.data();
76
40
        const A* __restrict a_end = a_pos + size;
77
78
324
        while (a_pos < a_end) {
79
284
            *c_pos = Op::apply(*a_pos, *b_pos);
80
284
            ++a_pos;
81
284
            ++b_pos;
82
284
            ++c_pos;
83
284
        }
84
40
    }
_ZN5doris17NumComparisonImplIssNS_9GreaterOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
112
                                        PaddedPODArray<UInt8>& c) {
72
112
        size_t size = a.size();
73
112
        const A* __restrict a_pos = a.data();
74
112
        const B* __restrict b_pos = b.data();
75
112
        UInt8* __restrict c_pos = c.data();
76
112
        const A* __restrict a_end = a_pos + size;
77
78
376
        while (a_pos < a_end) {
79
264
            *c_pos = Op::apply(*a_pos, *b_pos);
80
264
            ++a_pos;
81
264
            ++b_pos;
82
264
            ++c_pos;
83
264
        }
84
112
    }
_ZN5doris17NumComparisonImplIiiNS_9GreaterOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
49
                                        PaddedPODArray<UInt8>& c) {
72
49
        size_t size = a.size();
73
49
        const A* __restrict a_pos = a.data();
74
49
        const B* __restrict b_pos = b.data();
75
49
        UInt8* __restrict c_pos = c.data();
76
49
        const A* __restrict a_end = a_pos + size;
77
78
271
        while (a_pos < a_end) {
79
222
            *c_pos = Op::apply(*a_pos, *b_pos);
80
222
            ++a_pos;
81
222
            ++b_pos;
82
222
            ++c_pos;
83
222
        }
84
49
    }
_ZN5doris17NumComparisonImplIllNS_9GreaterOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
65
                                        PaddedPODArray<UInt8>& c) {
72
65
        size_t size = a.size();
73
65
        const A* __restrict a_pos = a.data();
74
65
        const B* __restrict b_pos = b.data();
75
65
        UInt8* __restrict c_pos = c.data();
76
65
        const A* __restrict a_end = a_pos + size;
77
78
581
        while (a_pos < a_end) {
79
516
            *c_pos = Op::apply(*a_pos, *b_pos);
80
516
            ++a_pos;
81
516
            ++b_pos;
82
516
            ++c_pos;
83
516
        }
84
65
    }
_ZN5doris17NumComparisonImplInnNS_9GreaterOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
3
                                        PaddedPODArray<UInt8>& c) {
72
3
        size_t size = a.size();
73
3
        const A* __restrict a_pos = a.data();
74
3
        const B* __restrict b_pos = b.data();
75
3
        UInt8* __restrict c_pos = c.data();
76
3
        const A* __restrict a_end = a_pos + size;
77
78
9
        while (a_pos < a_end) {
79
6
            *c_pos = Op::apply(*a_pos, *b_pos);
80
6
            ++a_pos;
81
6
            ++b_pos;
82
6
            ++c_pos;
83
6
        }
84
3
    }
_ZN5doris17NumComparisonImplIjjNS_9GreaterOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
2
        while (a_pos < a_end) {
79
1
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1
            ++a_pos;
81
1
            ++b_pos;
82
1
            ++c_pos;
83
1
        }
84
1
    }
_ZN5doris17NumComparisonImplIooNS_9GreaterOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
2
        while (a_pos < a_end) {
79
1
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1
            ++a_pos;
81
1
            ++b_pos;
82
1
            ++c_pos;
83
1
        }
84
1
    }
_ZN5doris17NumComparisonImplIffNS_9GreaterOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
_ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
26
                                        PaddedPODArray<UInt8>& c) {
72
26
        size_t size = a.size();
73
26
        const A* __restrict a_pos = a.data();
74
26
        const B* __restrict b_pos = b.data();
75
26
        UInt8* __restrict c_pos = c.data();
76
26
        const A* __restrict a_end = a_pos + size;
77
78
96
        while (a_pos < a_end) {
79
70
            *c_pos = Op::apply(*a_pos, *b_pos);
80
70
            ++a_pos;
81
70
            ++b_pos;
82
70
            ++c_pos;
83
70
        }
84
26
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
2
        while (a_pos < a_end) {
79
1
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1
            ++a_pos;
81
1
            ++b_pos;
82
1
            ++c_pos;
83
1
        }
84
1
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
6
                                        PaddedPODArray<UInt8>& c) {
72
6
        size_t size = a.size();
73
6
        const A* __restrict a_pos = a.data();
74
6
        const B* __restrict b_pos = b.data();
75
6
        UInt8* __restrict c_pos = c.data();
76
6
        const A* __restrict a_end = a_pos + size;
77
78
70
        while (a_pos < a_end) {
79
64
            *c_pos = Op::apply(*a_pos, *b_pos);
80
64
            ++a_pos;
81
64
            ++b_pos;
82
64
            ++c_pos;
83
64
        }
84
6
    }
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
71
2
                                        PaddedPODArray<UInt8>& c) {
72
2
        size_t size = a.size();
73
2
        const A* __restrict a_pos = a.data();
74
2
        const B* __restrict b_pos = b.data();
75
2
        UInt8* __restrict c_pos = c.data();
76
2
        const A* __restrict a_end = a_pos + size;
77
78
11
        while (a_pos < a_end) {
79
9
            *c_pos = Op::apply(*a_pos, *b_pos);
80
9
            ++a_pos;
81
9
            ++b_pos;
82
9
            ++c_pos;
83
9
        }
84
2
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIaaNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
5
                                        PaddedPODArray<UInt8>& c) {
72
5
        size_t size = a.size();
73
5
        const A* __restrict a_pos = a.data();
74
5
        const B* __restrict b_pos = b.data();
75
5
        UInt8* __restrict c_pos = c.data();
76
5
        const A* __restrict a_end = a_pos + size;
77
78
21
        while (a_pos < a_end) {
79
16
            *c_pos = Op::apply(*a_pos, *b_pos);
80
16
            ++a_pos;
81
16
            ++b_pos;
82
16
            ++c_pos;
83
16
        }
84
5
    }
_ZN5doris17NumComparisonImplIllNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
9
                                        PaddedPODArray<UInt8>& c) {
72
9
        size_t size = a.size();
73
9
        const A* __restrict a_pos = a.data();
74
9
        const B* __restrict b_pos = b.data();
75
9
        UInt8* __restrict c_pos = c.data();
76
9
        const A* __restrict a_end = a_pos + size;
77
78
65
        while (a_pos < a_end) {
79
56
            *c_pos = Op::apply(*a_pos, *b_pos);
80
56
            ++a_pos;
81
56
            ++b_pos;
82
56
            ++c_pos;
83
56
        }
84
9
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIjjNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
2
        while (a_pos < a_end) {
79
1
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1
            ++a_pos;
81
1
            ++b_pos;
82
1
            ++c_pos;
83
1
        }
84
1
    }
_ZN5doris17NumComparisonImplIooNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
2
        while (a_pos < a_end) {
79
1
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1
            ++a_pos;
81
1
            ++b_pos;
82
1
            ++c_pos;
83
1
        }
84
1
    }
_ZN5doris17NumComparisonImplIffNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
_ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
23
                                        PaddedPODArray<UInt8>& c) {
72
23
        size_t size = a.size();
73
23
        const A* __restrict a_pos = a.data();
74
23
        const B* __restrict b_pos = b.data();
75
23
        UInt8* __restrict c_pos = c.data();
76
23
        const A* __restrict a_end = a_pos + size;
77
78
66
        while (a_pos < a_end) {
79
43
            *c_pos = Op::apply(*a_pos, *b_pos);
80
43
            ++a_pos;
81
43
            ++b_pos;
82
43
            ++c_pos;
83
43
        }
84
23
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIhhNS_6LessOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
Line
Count
Source
71
101
                                        PaddedPODArray<UInt8>& c) {
72
101
        size_t size = a.size();
73
101
        const A* __restrict a_pos = a.data();
74
101
        const B* __restrict b_pos = b.data();
75
101
        UInt8* __restrict c_pos = c.data();
76
101
        const A* __restrict a_end = a_pos + size;
77
78
376
        while (a_pos < a_end) {
79
275
            *c_pos = Op::apply(*a_pos, *b_pos);
80
275
            ++a_pos;
81
275
            ++b_pos;
82
275
            ++c_pos;
83
275
        }
84
101
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
1.80k
                                        PaddedPODArray<UInt8>& c) {
72
1.80k
        size_t size = a.size();
73
1.80k
        const A* __restrict a_pos = a.data();
74
1.80k
        const B* __restrict b_pos = b.data();
75
1.80k
        UInt8* __restrict c_pos = c.data();
76
1.80k
        const A* __restrict a_end = a_pos + size;
77
78
1.22M
        while (a_pos < a_end) {
79
1.22M
            *c_pos = Op::apply(*a_pos, *b_pos);
80
1.22M
            ++a_pos;
81
1.22M
            ++b_pos;
82
1.22M
            ++c_pos;
83
1.22M
        }
84
1.80k
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
258
                                        PaddedPODArray<UInt8>& c) {
72
258
        size_t size = a.size();
73
258
        const A* __restrict a_pos = a.data();
74
258
        const B* __restrict b_pos = b.data();
75
258
        UInt8* __restrict c_pos = c.data();
76
258
        const A* __restrict a_end = a_pos + size;
77
78
864
        while (a_pos < a_end) {
79
606
            *c_pos = Op::apply(*a_pos, *b_pos);
80
606
            ++a_pos;
81
606
            ++b_pos;
82
606
            ++c_pos;
83
606
        }
84
258
    }
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_6LessOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
71
2
                                        PaddedPODArray<UInt8>& c) {
72
2
        size_t size = a.size();
73
2
        const A* __restrict a_pos = a.data();
74
2
        const B* __restrict b_pos = b.data();
75
2
        UInt8* __restrict c_pos = c.data();
76
2
        const A* __restrict a_end = a_pos + size;
77
78
11
        while (a_pos < a_end) {
79
9
            *c_pos = Op::apply(*a_pos, *b_pos);
80
9
            ++a_pos;
81
9
            ++b_pos;
82
9
            ++c_pos;
83
9
        }
84
2
    }
_ZN5doris17NumComparisonImplIaaNS_6LessOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
156
                                        PaddedPODArray<UInt8>& c) {
72
156
        size_t size = a.size();
73
156
        const A* __restrict a_pos = a.data();
74
156
        const B* __restrict b_pos = b.data();
75
156
        UInt8* __restrict c_pos = c.data();
76
156
        const A* __restrict a_end = a_pos + size;
77
78
486
        while (a_pos < a_end) {
79
330
            *c_pos = Op::apply(*a_pos, *b_pos);
80
330
            ++a_pos;
81
330
            ++b_pos;
82
330
            ++c_pos;
83
330
        }
84
156
    }
_ZN5doris17NumComparisonImplIssNS_6LessOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
136
                                        PaddedPODArray<UInt8>& c) {
72
136
        size_t size = a.size();
73
136
        const A* __restrict a_pos = a.data();
74
136
        const B* __restrict b_pos = b.data();
75
136
        UInt8* __restrict c_pos = c.data();
76
136
        const A* __restrict a_end = a_pos + size;
77
78
448
        while (a_pos < a_end) {
79
312
            *c_pos = Op::apply(*a_pos, *b_pos);
80
312
            ++a_pos;
81
312
            ++b_pos;
82
312
            ++c_pos;
83
312
        }
84
136
    }
_ZN5doris17NumComparisonImplIiiNS_6LessOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
173
                                        PaddedPODArray<UInt8>& c) {
72
173
        size_t size = a.size();
73
173
        const A* __restrict a_pos = a.data();
74
173
        const B* __restrict b_pos = b.data();
75
173
        UInt8* __restrict c_pos = c.data();
76
173
        const A* __restrict a_end = a_pos + size;
77
78
1.03k
        while (a_pos < a_end) {
79
863
            *c_pos = Op::apply(*a_pos, *b_pos);
80
863
            ++a_pos;
81
863
            ++b_pos;
82
863
            ++c_pos;
83
863
        }
84
173
    }
_ZN5doris17NumComparisonImplIllNS_6LessOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
214
                                        PaddedPODArray<UInt8>& c) {
72
214
        size_t size = a.size();
73
214
        const A* __restrict a_pos = a.data();
74
214
        const B* __restrict b_pos = b.data();
75
214
        UInt8* __restrict c_pos = c.data();
76
214
        const A* __restrict a_end = a_pos + size;
77
78
5.41k
        while (a_pos < a_end) {
79
5.20k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
5.20k
            ++a_pos;
81
5.20k
            ++b_pos;
82
5.20k
            ++c_pos;
83
5.20k
        }
84
214
    }
_ZN5doris17NumComparisonImplInnNS_6LessOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
144
                                        PaddedPODArray<UInt8>& c) {
72
144
        size_t size = a.size();
73
144
        const A* __restrict a_pos = a.data();
74
144
        const B* __restrict b_pos = b.data();
75
144
        UInt8* __restrict c_pos = c.data();
76
144
        const A* __restrict a_end = a_pos + size;
77
78
462
        while (a_pos < a_end) {
79
318
            *c_pos = Op::apply(*a_pos, *b_pos);
80
318
            ++a_pos;
81
318
            ++b_pos;
82
318
            ++c_pos;
83
318
        }
84
144
    }
_ZN5doris17NumComparisonImplIjjNS_6LessOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
16
                                        PaddedPODArray<UInt8>& c) {
72
16
        size_t size = a.size();
73
16
        const A* __restrict a_pos = a.data();
74
16
        const B* __restrict b_pos = b.data();
75
16
        UInt8* __restrict c_pos = c.data();
76
16
        const A* __restrict a_end = a_pos + size;
77
78
32
        while (a_pos < a_end) {
79
16
            *c_pos = Op::apply(*a_pos, *b_pos);
80
16
            ++a_pos;
81
16
            ++b_pos;
82
16
            ++c_pos;
83
16
        }
84
16
    }
_ZN5doris17NumComparisonImplIooNS_6LessOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
16
                                        PaddedPODArray<UInt8>& c) {
72
16
        size_t size = a.size();
73
16
        const A* __restrict a_pos = a.data();
74
16
        const B* __restrict b_pos = b.data();
75
16
        UInt8* __restrict c_pos = c.data();
76
16
        const A* __restrict a_end = a_pos + size;
77
78
32
        while (a_pos < a_end) {
79
16
            *c_pos = Op::apply(*a_pos, *b_pos);
80
16
            ++a_pos;
81
16
            ++b_pos;
82
16
            ++c_pos;
83
16
        }
84
16
    }
_ZN5doris17NumComparisonImplIffNS_6LessOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
154
                                        PaddedPODArray<UInt8>& c) {
72
154
        size_t size = a.size();
73
154
        const A* __restrict a_pos = a.data();
74
154
        const B* __restrict b_pos = b.data();
75
154
        UInt8* __restrict c_pos = c.data();
76
154
        const A* __restrict a_end = a_pos + size;
77
78
501
        while (a_pos < a_end) {
79
347
            *c_pos = Op::apply(*a_pos, *b_pos);
80
347
            ++a_pos;
81
347
            ++b_pos;
82
347
            ++c_pos;
83
347
        }
84
154
    }
_ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
143
                                        PaddedPODArray<UInt8>& c) {
72
143
        size_t size = a.size();
73
143
        const A* __restrict a_pos = a.data();
74
143
        const B* __restrict b_pos = b.data();
75
143
        UInt8* __restrict c_pos = c.data();
76
143
        const A* __restrict a_end = a_pos + size;
77
78
486
        while (a_pos < a_end) {
79
343
            *c_pos = Op::apply(*a_pos, *b_pos);
80
343
            ++a_pos;
81
343
            ++b_pos;
82
343
            ++c_pos;
83
343
        }
84
143
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_14LessOrEqualsOpILNS_13PrimitiveTypeE2EEEE13vector_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE25EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
71
419
                                        PaddedPODArray<UInt8>& c) {
72
419
        size_t size = a.size();
73
419
        const A* __restrict a_pos = a.data();
74
419
        const B* __restrict b_pos = b.data();
75
419
        UInt8* __restrict c_pos = c.data();
76
419
        const A* __restrict a_end = a_pos + size;
77
78
6.72k
        while (a_pos < a_end) {
79
6.30k
            *c_pos = Op::apply(*a_pos, *b_pos);
80
6.30k
            ++a_pos;
81
6.30k
            ++b_pos;
82
6.30k
            ++c_pos;
83
6.30k
        }
84
419
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE26EEEE13vector_vectorERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESE_RNS8_IhLm4096ESB_Lm16ELm15EEE
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE42EEEE13vector_vectorERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESC_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
71
2
                                        PaddedPODArray<UInt8>& c) {
72
2
        size_t size = a.size();
73
2
        const A* __restrict a_pos = a.data();
74
2
        const B* __restrict b_pos = b.data();
75
2
        UInt8* __restrict c_pos = c.data();
76
2
        const A* __restrict a_end = a_pos + size;
77
78
11
        while (a_pos < a_end) {
79
9
            *c_pos = Op::apply(*a_pos, *b_pos);
80
9
            ++a_pos;
81
9
            ++b_pos;
82
9
            ++c_pos;
83
9
        }
84
2
    }
_ZN5doris17NumComparisonImplIaaNS_14LessOrEqualsOpILNS_13PrimitiveTypeE3EEEE13vector_vectorERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
1
                                        PaddedPODArray<UInt8>& c) {
72
1
        size_t size = a.size();
73
1
        const A* __restrict a_pos = a.data();
74
1
        const B* __restrict b_pos = b.data();
75
1
        UInt8* __restrict c_pos = c.data();
76
1
        const A* __restrict a_end = a_pos + size;
77
78
5
        while (a_pos < a_end) {
79
4
            *c_pos = Op::apply(*a_pos, *b_pos);
80
4
            ++a_pos;
81
4
            ++b_pos;
82
4
            ++c_pos;
83
4
        }
84
1
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_14LessOrEqualsOpILNS_13PrimitiveTypeE4EEEE13vector_vectorERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
10
                                        PaddedPODArray<UInt8>& c) {
72
10
        size_t size = a.size();
73
10
        const A* __restrict a_pos = a.data();
74
10
        const B* __restrict b_pos = b.data();
75
10
        UInt8* __restrict c_pos = c.data();
76
10
        const A* __restrict a_end = a_pos + size;
77
78
33
        while (a_pos < a_end) {
79
23
            *c_pos = Op::apply(*a_pos, *b_pos);
80
23
            ++a_pos;
81
23
            ++b_pos;
82
23
            ++c_pos;
83
23
        }
84
10
    }
_ZN5doris17NumComparisonImplIllNS_14LessOrEqualsOpILNS_13PrimitiveTypeE6EEEE13vector_vectorERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
31
                                        PaddedPODArray<UInt8>& c) {
72
31
        size_t size = a.size();
73
31
        const A* __restrict a_pos = a.data();
74
31
        const B* __restrict b_pos = b.data();
75
31
        UInt8* __restrict c_pos = c.data();
76
31
        const A* __restrict a_end = a_pos + size;
77
78
69
        while (a_pos < a_end) {
79
38
            *c_pos = Op::apply(*a_pos, *b_pos);
80
38
            ++a_pos;
81
38
            ++b_pos;
82
38
            ++c_pos;
83
38
        }
84
31
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_14LessOrEqualsOpILNS_13PrimitiveTypeE7EEEE13vector_vectorERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_14LessOrEqualsOpILNS_13PrimitiveTypeE36EEEE13vector_vectorERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_14LessOrEqualsOpILNS_13PrimitiveTypeE37EEEE13vector_vectorERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIffNS_14LessOrEqualsOpILNS_13PrimitiveTypeE8EEEE13vector_vectorERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
_ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE9EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
71
20
                                        PaddedPODArray<UInt8>& c) {
72
20
        size_t size = a.size();
73
20
        const A* __restrict a_pos = a.data();
74
20
        const B* __restrict b_pos = b.data();
75
20
        UInt8* __restrict c_pos = c.data();
76
20
        const A* __restrict a_end = a_pos + size;
77
78
59
        while (a_pos < a_end) {
79
39
            *c_pos = Op::apply(*a_pos, *b_pos);
80
39
            ++a_pos;
81
39
            ++b_pos;
82
39
            ++c_pos;
83
39
        }
84
20
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE27EEEE13vector_vectorERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEESB_RNS5_IhLm4096ES8_Lm16ELm15EEE
85
86
    static void NO_INLINE vector_constant(const PaddedPODArray<A>& a, B b,
87
122k
                                          PaddedPODArray<UInt8>& c) {
88
122k
        size_t size = a.size();
89
122k
        const A* __restrict a_pos = a.data();
90
122k
        UInt8* __restrict c_pos = c.data();
91
122k
        const A* __restrict a_end = a_pos + size;
92
93
34.2M
        while (a_pos < a_end) {
94
34.0M
            *c_pos = Op::apply(*a_pos, b);
95
34.0M
            ++a_pos;
96
34.0M
            ++c_pos;
97
34.0M
        }
98
122k
    }
_ZN5doris17NumComparisonImplIhhNS_8EqualsOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
Line
Count
Source
87
24
                                          PaddedPODArray<UInt8>& c) {
88
24
        size_t size = a.size();
89
24
        const A* __restrict a_pos = a.data();
90
24
        UInt8* __restrict c_pos = c.data();
91
24
        const A* __restrict a_end = a_pos + size;
92
93
166
        while (a_pos < a_end) {
94
142
            *c_pos = Op::apply(*a_pos, b);
95
142
            ++a_pos;
96
142
            ++c_pos;
97
142
        }
98
24
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
664
                                          PaddedPODArray<UInt8>& c) {
88
664
        size_t size = a.size();
89
664
        const A* __restrict a_pos = a.data();
90
664
        UInt8* __restrict c_pos = c.data();
91
664
        const A* __restrict a_end = a_pos + size;
92
93
205k
        while (a_pos < a_end) {
94
204k
            *c_pos = Op::apply(*a_pos, b);
95
204k
            ++a_pos;
96
204k
            ++c_pos;
97
204k
        }
98
664
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
166
                                          PaddedPODArray<UInt8>& c) {
88
166
        size_t size = a.size();
89
166
        const A* __restrict a_pos = a.data();
90
166
        UInt8* __restrict c_pos = c.data();
91
166
        const A* __restrict a_end = a_pos + size;
92
93
100k
        while (a_pos < a_end) {
94
100k
            *c_pos = Op::apply(*a_pos, b);
95
100k
            ++a_pos;
96
100k
            ++c_pos;
97
100k
        }
98
166
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_8EqualsOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_8EqualsOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
4.76k
                                          PaddedPODArray<UInt8>& c) {
88
4.76k
        size_t size = a.size();
89
4.76k
        const A* __restrict a_pos = a.data();
90
4.76k
        UInt8* __restrict c_pos = c.data();
91
4.76k
        const A* __restrict a_end = a_pos + size;
92
93
9.13M
        while (a_pos < a_end) {
94
9.12M
            *c_pos = Op::apply(*a_pos, b);
95
9.12M
            ++a_pos;
96
9.12M
            ++c_pos;
97
9.12M
        }
98
4.76k
    }
_ZN5doris17NumComparisonImplIssNS_8EqualsOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
305
                                          PaddedPODArray<UInt8>& c) {
88
305
        size_t size = a.size();
89
305
        const A* __restrict a_pos = a.data();
90
305
        UInt8* __restrict c_pos = c.data();
91
305
        const A* __restrict a_end = a_pos + size;
92
93
101k
        while (a_pos < a_end) {
94
100k
            *c_pos = Op::apply(*a_pos, b);
95
100k
            ++a_pos;
96
100k
            ++c_pos;
97
100k
        }
98
305
    }
_ZN5doris17NumComparisonImplIiiNS_8EqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
25.8k
                                          PaddedPODArray<UInt8>& c) {
88
25.8k
        size_t size = a.size();
89
25.8k
        const A* __restrict a_pos = a.data();
90
25.8k
        UInt8* __restrict c_pos = c.data();
91
25.8k
        const A* __restrict a_end = a_pos + size;
92
93
239k
        while (a_pos < a_end) {
94
213k
            *c_pos = Op::apply(*a_pos, b);
95
213k
            ++a_pos;
96
213k
            ++c_pos;
97
213k
        }
98
25.8k
    }
_ZN5doris17NumComparisonImplIllNS_8EqualsOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
2.82k
                                          PaddedPODArray<UInt8>& c) {
88
2.82k
        size_t size = a.size();
89
2.82k
        const A* __restrict a_pos = a.data();
90
2.82k
        UInt8* __restrict c_pos = c.data();
91
2.82k
        const A* __restrict a_end = a_pos + size;
92
93
857k
        while (a_pos < a_end) {
94
854k
            *c_pos = Op::apply(*a_pos, b);
95
854k
            ++a_pos;
96
854k
            ++c_pos;
97
854k
        }
98
2.82k
    }
_ZN5doris17NumComparisonImplInnNS_8EqualsOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
31
                                          PaddedPODArray<UInt8>& c) {
88
31
        size_t size = a.size();
89
31
        const A* __restrict a_pos = a.data();
90
31
        UInt8* __restrict c_pos = c.data();
91
31
        const A* __restrict a_end = a_pos + size;
92
93
100k
        while (a_pos < a_end) {
94
100k
            *c_pos = Op::apply(*a_pos, b);
95
100k
            ++a_pos;
96
100k
            ++c_pos;
97
100k
        }
98
31
    }
_ZN5doris17NumComparisonImplIjjNS_8EqualsOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
15
                                          PaddedPODArray<UInt8>& c) {
88
15
        size_t size = a.size();
89
15
        const A* __restrict a_pos = a.data();
90
15
        UInt8* __restrict c_pos = c.data();
91
15
        const A* __restrict a_end = a_pos + size;
92
93
129
        while (a_pos < a_end) {
94
114
            *c_pos = Op::apply(*a_pos, b);
95
114
            ++a_pos;
96
114
            ++c_pos;
97
114
        }
98
15
    }
_ZN5doris17NumComparisonImplIooNS_8EqualsOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
6
                                          PaddedPODArray<UInt8>& c) {
88
6
        size_t size = a.size();
89
6
        const A* __restrict a_pos = a.data();
90
6
        UInt8* __restrict c_pos = c.data();
91
6
        const A* __restrict a_end = a_pos + size;
92
93
12
        while (a_pos < a_end) {
94
6
            *c_pos = Op::apply(*a_pos, b);
95
6
            ++a_pos;
96
6
            ++c_pos;
97
6
        }
98
6
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_8EqualsOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
621
                                          PaddedPODArray<UInt8>& c) {
88
621
        size_t size = a.size();
89
621
        const A* __restrict a_pos = a.data();
90
621
        UInt8* __restrict c_pos = c.data();
91
621
        const A* __restrict a_end = a_pos + size;
92
93
713k
        while (a_pos < a_end) {
94
713k
            *c_pos = Op::apply(*a_pos, b);
95
713k
            ++a_pos;
96
713k
            ++c_pos;
97
713k
        }
98
621
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_11NotEqualsOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
31
                                          PaddedPODArray<UInt8>& c) {
88
31
        size_t size = a.size();
89
31
        const A* __restrict a_pos = a.data();
90
31
        UInt8* __restrict c_pos = c.data();
91
31
        const A* __restrict a_end = a_pos + size;
92
93
82
        while (a_pos < a_end) {
94
51
            *c_pos = Op::apply(*a_pos, b);
95
51
            ++a_pos;
96
51
            ++c_pos;
97
51
        }
98
31
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_11NotEqualsOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_11NotEqualsOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
28
                                          PaddedPODArray<UInt8>& c) {
88
28
        size_t size = a.size();
89
28
        const A* __restrict a_pos = a.data();
90
28
        UInt8* __restrict c_pos = c.data();
91
28
        const A* __restrict a_end = a_pos + size;
92
93
78
        while (a_pos < a_end) {
94
50
            *c_pos = Op::apply(*a_pos, b);
95
50
            ++a_pos;
96
50
            ++c_pos;
97
50
        }
98
28
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_11NotEqualsOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
249
                                          PaddedPODArray<UInt8>& c) {
88
249
        size_t size = a.size();
89
249
        const A* __restrict a_pos = a.data();
90
249
        UInt8* __restrict c_pos = c.data();
91
249
        const A* __restrict a_end = a_pos + size;
92
93
1.88k
        while (a_pos < a_end) {
94
1.63k
            *c_pos = Op::apply(*a_pos, b);
95
1.63k
            ++a_pos;
96
1.63k
            ++c_pos;
97
1.63k
        }
98
249
    }
_ZN5doris17NumComparisonImplIllNS_11NotEqualsOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
497
                                          PaddedPODArray<UInt8>& c) {
88
497
        size_t size = a.size();
89
497
        const A* __restrict a_pos = a.data();
90
497
        UInt8* __restrict c_pos = c.data();
91
497
        const A* __restrict a_end = a_pos + size;
92
93
3.63k
        while (a_pos < a_end) {
94
3.13k
            *c_pos = Op::apply(*a_pos, b);
95
3.13k
            ++a_pos;
96
3.13k
            ++c_pos;
97
3.13k
        }
98
497
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_11NotEqualsOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_11NotEqualsOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_11NotEqualsOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIffNS_11NotEqualsOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
28
                                          PaddedPODArray<UInt8>& c) {
88
28
        size_t size = a.size();
89
28
        const A* __restrict a_pos = a.data();
90
28
        UInt8* __restrict c_pos = c.data();
91
28
        const A* __restrict a_end = a_pos + size;
92
93
70
        while (a_pos < a_end) {
94
42
            *c_pos = Op::apply(*a_pos, b);
95
42
            ++a_pos;
96
42
            ++c_pos;
97
42
        }
98
28
    }
_ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
40
                                          PaddedPODArray<UInt8>& c) {
88
40
        size_t size = a.size();
89
40
        const A* __restrict a_pos = a.data();
90
40
        UInt8* __restrict c_pos = c.data();
91
40
        const A* __restrict a_end = a_pos + size;
92
93
282
        while (a_pos < a_end) {
94
242
            *c_pos = Op::apply(*a_pos, b);
95
242
            ++a_pos;
96
242
            ++c_pos;
97
242
        }
98
40
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_9GreaterOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_6LessOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
41
                                          PaddedPODArray<UInt8>& c) {
88
41
        size_t size = a.size();
89
41
        const A* __restrict a_pos = a.data();
90
41
        UInt8* __restrict c_pos = c.data();
91
41
        const A* __restrict a_end = a_pos + size;
92
93
149
        while (a_pos < a_end) {
94
108
            *c_pos = Op::apply(*a_pos, b);
95
108
            ++a_pos;
96
108
            ++c_pos;
97
108
        }
98
41
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
391
                                          PaddedPODArray<UInt8>& c) {
88
391
        size_t size = a.size();
89
391
        const A* __restrict a_pos = a.data();
90
391
        UInt8* __restrict c_pos = c.data();
91
391
        const A* __restrict a_end = a_pos + size;
92
93
1.67M
        while (a_pos < a_end) {
94
1.67M
            *c_pos = Op::apply(*a_pos, b);
95
1.67M
            ++a_pos;
96
1.67M
            ++c_pos;
97
1.67M
        }
98
391
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
2
                                          PaddedPODArray<UInt8>& c) {
88
2
        size_t size = a.size();
89
2
        const A* __restrict a_pos = a.data();
90
2
        UInt8* __restrict c_pos = c.data();
91
2
        const A* __restrict a_end = a_pos + size;
92
93
6
        while (a_pos < a_end) {
94
4
            *c_pos = Op::apply(*a_pos, b);
95
4
            ++a_pos;
96
4
            ++c_pos;
97
4
        }
98
2
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
59
                                          PaddedPODArray<UInt8>& c) {
88
59
        size_t size = a.size();
89
59
        const A* __restrict a_pos = a.data();
90
59
        UInt8* __restrict c_pos = c.data();
91
59
        const A* __restrict a_end = a_pos + size;
92
93
269
        while (a_pos < a_end) {
94
210
            *c_pos = Op::apply(*a_pos, b);
95
210
            ++a_pos;
96
210
            ++c_pos;
97
210
        }
98
59
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_9GreaterOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_6LessOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
Line
Count
Source
87
1
                                          PaddedPODArray<UInt8>& c) {
88
1
        size_t size = a.size();
89
1
        const A* __restrict a_pos = a.data();
90
1
        UInt8* __restrict c_pos = c.data();
91
1
        const A* __restrict a_end = a_pos + size;
92
93
8
        while (a_pos < a_end) {
94
7
            *c_pos = Op::apply(*a_pos, b);
95
7
            ++a_pos;
96
7
            ++c_pos;
97
7
        }
98
1
    }
_ZN5doris17NumComparisonImplIaaNS_9GreaterOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.33k
                                          PaddedPODArray<UInt8>& c) {
88
1.33k
        size_t size = a.size();
89
1.33k
        const A* __restrict a_pos = a.data();
90
1.33k
        UInt8* __restrict c_pos = c.data();
91
1.33k
        const A* __restrict a_end = a_pos + size;
92
93
7.19k
        while (a_pos < a_end) {
94
5.85k
            *c_pos = Op::apply(*a_pos, b);
95
5.85k
            ++a_pos;
96
5.85k
            ++c_pos;
97
5.85k
        }
98
1.33k
    }
_ZN5doris17NumComparisonImplIaaNS_6LessOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.98k
                                          PaddedPODArray<UInt8>& c) {
88
1.98k
        size_t size = a.size();
89
1.98k
        const A* __restrict a_pos = a.data();
90
1.98k
        UInt8* __restrict c_pos = c.data();
91
1.98k
        const A* __restrict a_end = a_pos + size;
92
93
5.52k
        while (a_pos < a_end) {
94
3.53k
            *c_pos = Op::apply(*a_pos, b);
95
3.53k
            ++a_pos;
96
3.53k
            ++c_pos;
97
3.53k
        }
98
1.98k
    }
_ZN5doris17NumComparisonImplIssNS_9GreaterOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.45k
                                          PaddedPODArray<UInt8>& c) {
88
1.45k
        size_t size = a.size();
89
1.45k
        const A* __restrict a_pos = a.data();
90
1.45k
        UInt8* __restrict c_pos = c.data();
91
1.45k
        const A* __restrict a_end = a_pos + size;
92
93
6.26k
        while (a_pos < a_end) {
94
4.81k
            *c_pos = Op::apply(*a_pos, b);
95
4.81k
            ++a_pos;
96
4.81k
            ++c_pos;
97
4.81k
        }
98
1.45k
    }
_ZN5doris17NumComparisonImplIssNS_6LessOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
242
                                          PaddedPODArray<UInt8>& c) {
88
242
        size_t size = a.size();
89
242
        const A* __restrict a_pos = a.data();
90
242
        UInt8* __restrict c_pos = c.data();
91
242
        const A* __restrict a_end = a_pos + size;
92
93
1.20k
        while (a_pos < a_end) {
94
958
            *c_pos = Op::apply(*a_pos, b);
95
958
            ++a_pos;
96
958
            ++c_pos;
97
958
        }
98
242
    }
_ZN5doris17NumComparisonImplIiiNS_9GreaterOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
4.78k
                                          PaddedPODArray<UInt8>& c) {
88
4.78k
        size_t size = a.size();
89
4.78k
        const A* __restrict a_pos = a.data();
90
4.78k
        UInt8* __restrict c_pos = c.data();
91
4.78k
        const A* __restrict a_end = a_pos + size;
92
93
959k
        while (a_pos < a_end) {
94
954k
            *c_pos = Op::apply(*a_pos, b);
95
954k
            ++a_pos;
96
954k
            ++c_pos;
97
954k
        }
98
4.78k
    }
_ZN5doris17NumComparisonImplIiiNS_6LessOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
63.4k
                                          PaddedPODArray<UInt8>& c) {
88
63.4k
        size_t size = a.size();
89
63.4k
        const A* __restrict a_pos = a.data();
90
63.4k
        UInt8* __restrict c_pos = c.data();
91
63.4k
        const A* __restrict a_end = a_pos + size;
92
93
5.32M
        while (a_pos < a_end) {
94
5.25M
            *c_pos = Op::apply(*a_pos, b);
95
5.25M
            ++a_pos;
96
5.25M
            ++c_pos;
97
5.25M
        }
98
63.4k
    }
_ZN5doris17NumComparisonImplIllNS_9GreaterOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.20k
                                          PaddedPODArray<UInt8>& c) {
88
1.20k
        size_t size = a.size();
89
1.20k
        const A* __restrict a_pos = a.data();
90
1.20k
        UInt8* __restrict c_pos = c.data();
91
1.20k
        const A* __restrict a_end = a_pos + size;
92
93
97.7k
        while (a_pos < a_end) {
94
96.5k
            *c_pos = Op::apply(*a_pos, b);
95
96.5k
            ++a_pos;
96
96.5k
            ++c_pos;
97
96.5k
        }
98
1.20k
    }
_ZN5doris17NumComparisonImplIllNS_6LessOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.03k
                                          PaddedPODArray<UInt8>& c) {
88
1.03k
        size_t size = a.size();
89
1.03k
        const A* __restrict a_pos = a.data();
90
1.03k
        UInt8* __restrict c_pos = c.data();
91
1.03k
        const A* __restrict a_end = a_pos + size;
92
93
11.7k
        while (a_pos < a_end) {
94
10.6k
            *c_pos = Op::apply(*a_pos, b);
95
10.6k
            ++a_pos;
96
10.6k
            ++c_pos;
97
10.6k
        }
98
1.03k
    }
_ZN5doris17NumComparisonImplInnNS_9GreaterOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
268
                                          PaddedPODArray<UInt8>& c) {
88
268
        size_t size = a.size();
89
268
        const A* __restrict a_pos = a.data();
90
268
        UInt8* __restrict c_pos = c.data();
91
268
        const A* __restrict a_end = a_pos + size;
92
93
1.90k
        while (a_pos < a_end) {
94
1.63k
            *c_pos = Op::apply(*a_pos, b);
95
1.63k
            ++a_pos;
96
1.63k
            ++c_pos;
97
1.63k
        }
98
268
    }
_ZN5doris17NumComparisonImplInnNS_6LessOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
60
                                          PaddedPODArray<UInt8>& c) {
88
60
        size_t size = a.size();
89
60
        const A* __restrict a_pos = a.data();
90
60
        UInt8* __restrict c_pos = c.data();
91
60
        const A* __restrict a_end = a_pos + size;
92
93
86.2k
        while (a_pos < a_end) {
94
86.1k
            *c_pos = Op::apply(*a_pos, b);
95
86.1k
            ++a_pos;
96
86.1k
            ++c_pos;
97
86.1k
        }
98
60
    }
_ZN5doris17NumComparisonImplIjjNS_9GreaterOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
3
                                          PaddedPODArray<UInt8>& c) {
88
3
        size_t size = a.size();
89
3
        const A* __restrict a_pos = a.data();
90
3
        UInt8* __restrict c_pos = c.data();
91
3
        const A* __restrict a_end = a_pos + size;
92
93
31
        while (a_pos < a_end) {
94
28
            *c_pos = Op::apply(*a_pos, b);
95
28
            ++a_pos;
96
28
            ++c_pos;
97
28
        }
98
3
    }
_ZN5doris17NumComparisonImplIjjNS_6LessOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
2
                                          PaddedPODArray<UInt8>& c) {
88
2
        size_t size = a.size();
89
2
        const A* __restrict a_pos = a.data();
90
2
        UInt8* __restrict c_pos = c.data();
91
2
        const A* __restrict a_end = a_pos + size;
92
93
22
        while (a_pos < a_end) {
94
20
            *c_pos = Op::apply(*a_pos, b);
95
20
            ++a_pos;
96
20
            ++c_pos;
97
20
        }
98
2
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_9GreaterOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_6LessOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIffNS_9GreaterOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
200
                                          PaddedPODArray<UInt8>& c) {
88
200
        size_t size = a.size();
89
200
        const A* __restrict a_pos = a.data();
90
200
        UInt8* __restrict c_pos = c.data();
91
200
        const A* __restrict a_end = a_pos + size;
92
93
2.61k
        while (a_pos < a_end) {
94
2.41k
            *c_pos = Op::apply(*a_pos, b);
95
2.41k
            ++a_pos;
96
2.41k
            ++c_pos;
97
2.41k
        }
98
200
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_6LessOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
504
                                          PaddedPODArray<UInt8>& c) {
88
504
        size_t size = a.size();
89
504
        const A* __restrict a_pos = a.data();
90
504
        UInt8* __restrict c_pos = c.data();
91
504
        const A* __restrict a_end = a_pos + size;
92
93
7.44k
        while (a_pos < a_end) {
94
6.94k
            *c_pos = Op::apply(*a_pos, b);
95
6.94k
            ++a_pos;
96
6.94k
            ++c_pos;
97
6.94k
        }
98
504
    }
_ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
236
                                          PaddedPODArray<UInt8>& c) {
88
236
        size_t size = a.size();
89
236
        const A* __restrict a_pos = a.data();
90
236
        UInt8* __restrict c_pos = c.data();
91
236
        const A* __restrict a_end = a_pos + size;
92
93
607k
        while (a_pos < a_end) {
94
607k
            *c_pos = Op::apply(*a_pos, b);
95
607k
            ++a_pos;
96
607k
            ++c_pos;
97
607k
        }
98
236
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIhhNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
Line
Count
Source
87
24
                                          PaddedPODArray<UInt8>& c) {
88
24
        size_t size = a.size();
89
24
        const A* __restrict a_pos = a.data();
90
24
        UInt8* __restrict c_pos = c.data();
91
24
        const A* __restrict a_end = a_pos + size;
92
93
120k
        while (a_pos < a_end) {
94
120k
            *c_pos = Op::apply(*a_pos, b);
95
120k
            ++a_pos;
96
120k
            ++c_pos;
97
120k
        }
98
24
    }
_ZN5doris17NumComparisonImplIhhNS_14LessOrEqualsOpILNS_13PrimitiveTypeE2EEEE15vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEhRS9_
Line
Count
Source
87
18
                                          PaddedPODArray<UInt8>& c) {
88
18
        size_t size = a.size();
89
18
        const A* __restrict a_pos = a.data();
90
18
        UInt8* __restrict c_pos = c.data();
91
18
        const A* __restrict a_end = a_pos + size;
92
93
60.3k
        while (a_pos < a_end) {
94
60.3k
            *c_pos = Op::apply(*a_pos, b);
95
60.3k
            ++a_pos;
96
60.3k
            ++c_pos;
97
60.3k
        }
98
18
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
510
                                          PaddedPODArray<UInt8>& c) {
88
510
        size_t size = a.size();
89
510
        const A* __restrict a_pos = a.data();
90
510
        UInt8* __restrict c_pos = c.data();
91
510
        const A* __restrict a_end = a_pos + size;
92
93
1.84M
        while (a_pos < a_end) {
94
1.84M
            *c_pos = Op::apply(*a_pos, b);
95
1.84M
            ++a_pos;
96
1.84M
            ++c_pos;
97
1.84M
        }
98
510
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE25EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
156
                                          PaddedPODArray<UInt8>& c) {
88
156
        size_t size = a.size();
89
156
        const A* __restrict a_pos = a.data();
90
156
        UInt8* __restrict c_pos = c.data();
91
156
        const A* __restrict a_end = a_pos + size;
92
93
721k
        while (a_pos < a_end) {
94
720k
            *c_pos = Op::apply(*a_pos, b);
95
720k
            ++a_pos;
96
720k
            ++c_pos;
97
720k
        }
98
156
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
136
                                          PaddedPODArray<UInt8>& c) {
88
136
        size_t size = a.size();
89
136
        const A* __restrict a_pos = a.data();
90
136
        UInt8* __restrict c_pos = c.data();
91
136
        const A* __restrict a_end = a_pos + size;
92
93
511
        while (a_pos < a_end) {
94
375
            *c_pos = Op::apply(*a_pos, b);
95
375
            ++a_pos;
96
375
            ++c_pos;
97
375
        }
98
136
    }
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE26EEEE15vector_constantERKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES3_RNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
87
57
                                          PaddedPODArray<UInt8>& c) {
88
57
        size_t size = a.size();
89
57
        const A* __restrict a_pos = a.data();
90
57
        UInt8* __restrict c_pos = c.data();
91
57
        const A* __restrict a_end = a_pos + size;
92
93
240
        while (a_pos < a_end) {
94
183
            *c_pos = Op::apply(*a_pos, b);
95
183
            ++a_pos;
96
183
            ++c_pos;
97
183
        }
98
57
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE42EEEE15vector_constantERKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEES1_RNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
45
                                          PaddedPODArray<UInt8>& c) {
88
45
        size_t size = a.size();
89
45
        const A* __restrict a_pos = a.data();
90
45
        UInt8* __restrict c_pos = c.data();
91
45
        const A* __restrict a_end = a_pos + size;
92
93
140k
        while (a_pos < a_end) {
94
140k
            *c_pos = Op::apply(*a_pos, b);
95
140k
            ++a_pos;
96
140k
            ++c_pos;
97
140k
        }
98
45
    }
_ZN5doris17NumComparisonImplIaaNS_14LessOrEqualsOpILNS_13PrimitiveTypeE3EEEE15vector_constantERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEaRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
47
                                          PaddedPODArray<UInt8>& c) {
88
47
        size_t size = a.size();
89
47
        const A* __restrict a_pos = a.data();
90
47
        UInt8* __restrict c_pos = c.data();
91
47
        const A* __restrict a_end = a_pos + size;
92
93
120k
        while (a_pos < a_end) {
94
120k
            *c_pos = Op::apply(*a_pos, b);
95
120k
            ++a_pos;
96
120k
            ++c_pos;
97
120k
        }
98
47
    }
_ZN5doris17NumComparisonImplIssNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
60
                                          PaddedPODArray<UInt8>& c) {
88
60
        size_t size = a.size();
89
60
        const A* __restrict a_pos = a.data();
90
60
        UInt8* __restrict c_pos = c.data();
91
60
        const A* __restrict a_end = a_pos + size;
92
93
130k
        while (a_pos < a_end) {
94
130k
            *c_pos = Op::apply(*a_pos, b);
95
130k
            ++a_pos;
96
130k
            ++c_pos;
97
130k
        }
98
60
    }
_ZN5doris17NumComparisonImplIssNS_14LessOrEqualsOpILNS_13PrimitiveTypeE4EEEE15vector_constantERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEsRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
65
                                          PaddedPODArray<UInt8>& c) {
88
65
        size_t size = a.size();
89
65
        const A* __restrict a_pos = a.data();
90
65
        UInt8* __restrict c_pos = c.data();
91
65
        const A* __restrict a_end = a_pos + size;
92
93
103k
        while (a_pos < a_end) {
94
102k
            *c_pos = Op::apply(*a_pos, b);
95
102k
            ++a_pos;
96
102k
            ++c_pos;
97
102k
        }
98
65
    }
_ZN5doris17NumComparisonImplIiiNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
1.10k
                                          PaddedPODArray<UInt8>& c) {
88
1.10k
        size_t size = a.size();
89
1.10k
        const A* __restrict a_pos = a.data();
90
1.10k
        UInt8* __restrict c_pos = c.data();
91
1.10k
        const A* __restrict a_end = a_pos + size;
92
93
2.56M
        while (a_pos < a_end) {
94
2.56M
            *c_pos = Op::apply(*a_pos, b);
95
2.56M
            ++a_pos;
96
2.56M
            ++c_pos;
97
2.56M
        }
98
1.10k
    }
_ZN5doris17NumComparisonImplIiiNS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEiRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
6.11k
                                          PaddedPODArray<UInt8>& c) {
88
6.11k
        size_t size = a.size();
89
6.11k
        const A* __restrict a_pos = a.data();
90
6.11k
        UInt8* __restrict c_pos = c.data();
91
6.11k
        const A* __restrict a_end = a_pos + size;
92
93
6.58M
        while (a_pos < a_end) {
94
6.58M
            *c_pos = Op::apply(*a_pos, b);
95
6.58M
            ++a_pos;
96
6.58M
            ++c_pos;
97
6.58M
        }
98
6.11k
    }
_ZN5doris17NumComparisonImplIllNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
210
                                          PaddedPODArray<UInt8>& c) {
88
210
        size_t size = a.size();
89
210
        const A* __restrict a_pos = a.data();
90
210
        UInt8* __restrict c_pos = c.data();
91
210
        const A* __restrict a_end = a_pos + size;
92
93
607
        while (a_pos < a_end) {
94
397
            *c_pos = Op::apply(*a_pos, b);
95
397
            ++a_pos;
96
397
            ++c_pos;
97
397
        }
98
210
    }
_ZN5doris17NumComparisonImplIllNS_14LessOrEqualsOpILNS_13PrimitiveTypeE6EEEE15vector_constantERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEElRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
213
                                          PaddedPODArray<UInt8>& c) {
88
213
        size_t size = a.size();
89
213
        const A* __restrict a_pos = a.data();
90
213
        UInt8* __restrict c_pos = c.data();
91
213
        const A* __restrict a_end = a_pos + size;
92
93
2.73k
        while (a_pos < a_end) {
94
2.52k
            *c_pos = Op::apply(*a_pos, b);
95
2.52k
            ++a_pos;
96
2.52k
            ++c_pos;
97
2.52k
        }
98
213
    }
_ZN5doris17NumComparisonImplInnNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
18
                                          PaddedPODArray<UInt8>& c) {
88
18
        size_t size = a.size();
89
18
        const A* __restrict a_pos = a.data();
90
18
        UInt8* __restrict c_pos = c.data();
91
18
        const A* __restrict a_end = a_pos + size;
92
93
90.5k
        while (a_pos < a_end) {
94
90.5k
            *c_pos = Op::apply(*a_pos, b);
95
90.5k
            ++a_pos;
96
90.5k
            ++c_pos;
97
90.5k
        }
98
18
    }
_ZN5doris17NumComparisonImplInnNS_14LessOrEqualsOpILNS_13PrimitiveTypeE7EEEE15vector_constantERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEnRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
43
                                          PaddedPODArray<UInt8>& c) {
88
43
        size_t size = a.size();
89
43
        const A* __restrict a_pos = a.data();
90
43
        UInt8* __restrict c_pos = c.data();
91
43
        const A* __restrict a_end = a_pos + size;
92
93
180k
        while (a_pos < a_end) {
94
180k
            *c_pos = Op::apply(*a_pos, b);
95
180k
            ++a_pos;
96
180k
            ++c_pos;
97
180k
        }
98
43
    }
_ZN5doris17NumComparisonImplIjjNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
10
                                          PaddedPODArray<UInt8>& c) {
88
10
        size_t size = a.size();
89
10
        const A* __restrict a_pos = a.data();
90
10
        UInt8* __restrict c_pos = c.data();
91
10
        const A* __restrict a_end = a_pos + size;
92
93
110
        while (a_pos < a_end) {
94
100
            *c_pos = Op::apply(*a_pos, b);
95
100
            ++a_pos;
96
100
            ++c_pos;
97
100
        }
98
10
    }
_ZN5doris17NumComparisonImplIjjNS_14LessOrEqualsOpILNS_13PrimitiveTypeE36EEEE15vector_constantERKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
10
                                          PaddedPODArray<UInt8>& c) {
88
10
        size_t size = a.size();
89
10
        const A* __restrict a_pos = a.data();
90
10
        UInt8* __restrict c_pos = c.data();
91
10
        const A* __restrict a_end = a_pos + size;
92
93
110
        while (a_pos < a_end) {
94
100
            *c_pos = Op::apply(*a_pos, b);
95
100
            ++a_pos;
96
100
            ++c_pos;
97
100
        }
98
10
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_14LessOrEqualsOpILNS_13PrimitiveTypeE37EEEE15vector_constantERKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEoRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIffNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
4
                                          PaddedPODArray<UInt8>& c) {
88
4
        size_t size = a.size();
89
4
        const A* __restrict a_pos = a.data();
90
4
        UInt8* __restrict c_pos = c.data();
91
4
        const A* __restrict a_end = a_pos + size;
92
93
10
        while (a_pos < a_end) {
94
6
            *c_pos = Op::apply(*a_pos, b);
95
6
            ++a_pos;
96
6
            ++c_pos;
97
6
        }
98
4
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_14LessOrEqualsOpILNS_13PrimitiveTypeE8EEEE15vector_constantERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEfRNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
196
                                          PaddedPODArray<UInt8>& c) {
88
196
        size_t size = a.size();
89
196
        const A* __restrict a_pos = a.data();
90
196
        UInt8* __restrict c_pos = c.data();
91
196
        const A* __restrict a_end = a_pos + size;
92
93
681k
        while (a_pos < a_end) {
94
681k
            *c_pos = Op::apply(*a_pos, b);
95
681k
            ++a_pos;
96
681k
            ++c_pos;
97
681k
        }
98
196
    }
_ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE9EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
87
128
                                          PaddedPODArray<UInt8>& c) {
88
128
        size_t size = a.size();
89
128
        const A* __restrict a_pos = a.data();
90
128
        UInt8* __restrict c_pos = c.data();
91
128
        const A* __restrict a_end = a_pos + size;
92
93
600k
        while (a_pos < a_end) {
94
600k
            *c_pos = Op::apply(*a_pos, b);
95
600k
            ++a_pos;
96
600k
            ++c_pos;
97
600k
        }
98
128
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE27EEEE15vector_constantERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEdRNS5_IhLm4096ES8_Lm16ELm15EEE
99
100
78.8k
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
78.8k
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
78.8k
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_8EqualsOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_8EqualsOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_8EqualsOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_8EqualsOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
276
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
276
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
276
    }
_ZN5doris17NumComparisonImplIssNS_8EqualsOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
36
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
36
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
36
    }
_ZN5doris17NumComparisonImplIiiNS_8EqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
12.4k
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
12.4k
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
12.4k
    }
_ZN5doris17NumComparisonImplIllNS_8EqualsOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
1.19k
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
1.19k
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
1.19k
    }
_ZN5doris17NumComparisonImplInnNS_8EqualsOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
4
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
4
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
4
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_8EqualsOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_8EqualsOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_8EqualsOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_8EqualsOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_11NotEqualsOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_11NotEqualsOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_11NotEqualsOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIaaNS_11NotEqualsOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_11NotEqualsOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIiiNS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIllNS_11NotEqualsOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
476
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
476
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
476
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_11NotEqualsOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_11NotEqualsOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_11NotEqualsOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_11NotEqualsOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_11NotEqualsOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_9GreaterOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_9GreaterOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_9GreaterOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_9GreaterOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
228
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
228
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
228
    }
_ZN5doris17NumComparisonImplIssNS_9GreaterOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
228
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
228
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
228
    }
_ZN5doris17NumComparisonImplIiiNS_9GreaterOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
62.5k
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
62.5k
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
62.5k
    }
_ZN5doris17NumComparisonImplIllNS_9GreaterOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
518
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
518
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
518
    }
_ZN5doris17NumComparisonImplInnNS_9GreaterOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
18
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
18
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
18
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_9GreaterOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_9GreaterOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_9GreaterOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_9GreaterOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
100
6
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
6
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
6
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIaaNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIiiNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIllNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_6LessOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_6LessOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_6LessOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIaaNS_6LessOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
240
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
240
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
240
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_6LessOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_6LessOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
193
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
193
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
193
    }
_ZN5doris17NumComparisonImplIllNS_6LessOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
80
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
80
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
80
    }
_ZN5doris17NumComparisonImplInnNS_6LessOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
66
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
66
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
66
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_6LessOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_6LessOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_6LessOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_6LessOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIhhNS_14LessOrEqualsOpILNS_13PrimitiveTypeE2EEEE15constant_vectorEhRKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERS9_
_ZN5doris17NumComparisonImplINS_11DateV2ValueINS_15DateV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE25EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Line
Count
Source
100
5
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
5
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
5
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEES3_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE26EEEE15constant_vectorES3_RKNS_8PODArrayIS3_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS8_IhLm4096ESB_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplINS_16TimestampTzValueES1_NS_14LessOrEqualsOpILNS_13PrimitiveTypeE42EEEE15constant_vectorES1_RKNS_8PODArrayIS1_Lm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS6_IhLm4096ES9_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIaaNS_14LessOrEqualsOpILNS_13PrimitiveTypeE3EEEE15constant_vectorEaRKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIssNS_14LessOrEqualsOpILNS_13PrimitiveTypeE4EEEE15constant_vectorEsRKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIiiNS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorEiRKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
231
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
231
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
231
    }
_ZN5doris17NumComparisonImplIllNS_14LessOrEqualsOpILNS_13PrimitiveTypeE6EEEE15constant_vectorElRKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
48
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
48
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
48
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplInnNS_14LessOrEqualsOpILNS_13PrimitiveTypeE7EEEE15constant_vectorEnRKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIjjNS_14LessOrEqualsOpILNS_13PrimitiveTypeE36EEEE15constant_vectorEjRKNS_8PODArrayIjLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIooNS_14LessOrEqualsOpILNS_13PrimitiveTypeE37EEEE15constant_vectorEoRKNS_8PODArrayIoLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Unexecuted instantiation: _ZN5doris17NumComparisonImplIffNS_14LessOrEqualsOpILNS_13PrimitiveTypeE8EEEE15constant_vectorEfRKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
_ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE9EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
Line
Count
Source
100
1
    static void constant_vector(A a, const PaddedPODArray<B>& b, PaddedPODArray<UInt8>& c) {
101
1
        NumComparisonImpl<B, A, typename Op::SymmetricOp>::vector_constant(b, a, c);
102
1
    }
Unexecuted instantiation: _ZN5doris17NumComparisonImplIddNS_14LessOrEqualsOpILNS_13PrimitiveTypeE27EEEE15constant_vectorEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERNS5_IhLm4096ES8_Lm16ELm15EEE
103
};
104
105
/// Generic version, implemented for columns of same type.
106
template <typename Op>
107
struct GenericComparisonImpl {
108
9
    static void vector_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
109
20
        for (size_t i = 0, size = a.size(); i < size; ++i) {
110
11
            c[i] = Op::apply(a.compare_at(i, i, b, 1), 0);
111
11
        }
112
9
    }
_ZN5doris21GenericComparisonImplINS_8EqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
108
4
    static void vector_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
109
10
        for (size_t i = 0, size = a.size(); i < size; ++i) {
110
6
            c[i] = Op::apply(a.compare_at(i, i, b, 1), 0);
111
6
        }
112
4
    }
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
_ZN5doris21GenericComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
108
1
    static void vector_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
109
2
        for (size_t i = 0, size = a.size(); i < size; ++i) {
110
1
            c[i] = Op::apply(a.compare_at(i, i, b, 1), 0);
111
1
        }
112
1
    }
_ZN5doris21GenericComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
108
1
    static void vector_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
109
2
        for (size_t i = 0, size = a.size(); i < size; ++i) {
110
1
            c[i] = Op::apply(a.compare_at(i, i, b, 1), 0);
111
1
        }
112
1
    }
_ZN5doris21GenericComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
108
3
    static void vector_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
109
6
        for (size_t i = 0, size = a.size(); i < size; ++i) {
110
3
            c[i] = Op::apply(a.compare_at(i, i, b, 1), 0);
111
3
        }
112
3
    }
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE13vector_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
113
114
142
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
142
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
494k
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
494k
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
494k
        }
119
142
    }
_ZN5doris21GenericComparisonImplINS_8EqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
13
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
13
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
31
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
18
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
18
        }
119
13
    }
_ZN5doris21GenericComparisonImplINS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
8
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
8
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
16
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
8
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
8
        }
119
8
    }
_ZN5doris21GenericComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
8
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
8
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
16
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
8
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
8
        }
119
8
    }
_ZN5doris21GenericComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
8
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
8
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
16
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
8
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
8
        }
119
8
    }
_ZN5doris21GenericComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
46
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
46
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
218k
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
218k
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
218k
        }
119
46
    }
_ZN5doris21GenericComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE15vector_constantERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Line
Count
Source
114
59
    static void vector_constant(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
115
59
        const auto& col_right = assert_cast<const ColumnConst&>(b).get_data_column();
116
276k
        for (size_t i = 0, size = a.size(); i < size; ++i) {
117
276k
            c[i] = Op::apply(a.compare_at(i, 0, col_right, 1), 0);
118
276k
        }
119
59
    }
120
121
0
    static void constant_vector(const IColumn& a, const IColumn& b, PaddedPODArray<UInt8>& c) {
122
0
        GenericComparisonImpl<typename Op::SymmetricOp>::vector_constant(b, a, c);
123
0
    }
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_8EqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_11NotEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
Unexecuted instantiation: _ZN5doris21GenericComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE15constant_vectorERKNS_7IColumnES7_RNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEE
124
};
125
126
template <typename Op>
127
struct StringComparisonImpl {
128
    static void NO_INLINE string_vector_string_vector(const ColumnString::Chars& a_data,
129
                                                      const ColumnString::Offsets& a_offsets,
130
                                                      const ColumnString::Chars& b_data,
131
                                                      const ColumnString::Offsets& b_offsets,
132
531
                                                      PaddedPODArray<UInt8>& c) {
133
531
        size_t size = a_offsets.size();
134
531
        ColumnString::Offset prev_a_offset = 0;
135
531
        ColumnString::Offset prev_b_offset = 0;
136
531
        const auto* a_pos = a_data.data();
137
531
        const auto* b_pos = b_data.data();
138
139
1.78k
        for (size_t i = 0; i < size; ++i) {
140
1.25k
            c[i] = Op::apply(memcmp_small_allow_overflow15(
141
1.25k
                                     a_pos + prev_a_offset, a_offsets[i] - prev_a_offset,
142
1.25k
                                     b_pos + prev_b_offset, b_offsets[i] - prev_b_offset),
143
1.25k
                             0);
144
145
1.25k
            prev_a_offset = a_offsets[i];
146
1.25k
            prev_b_offset = b_offsets[i];
147
1.25k
        }
148
531
    }
_ZN5doris20StringComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_SE_RS9_
Line
Count
Source
132
2
                                                      PaddedPODArray<UInt8>& c) {
133
2
        size_t size = a_offsets.size();
134
2
        ColumnString::Offset prev_a_offset = 0;
135
2
        ColumnString::Offset prev_b_offset = 0;
136
2
        const auto* a_pos = a_data.data();
137
2
        const auto* b_pos = b_data.data();
138
139
49
        for (size_t i = 0; i < size; ++i) {
140
47
            c[i] = Op::apply(memcmp_small_allow_overflow15(
141
47
                                     a_pos + prev_a_offset, a_offsets[i] - prev_a_offset,
142
47
                                     b_pos + prev_b_offset, b_offsets[i] - prev_b_offset),
143
47
                             0);
144
145
47
            prev_a_offset = a_offsets[i];
146
47
            prev_b_offset = b_offsets[i];
147
47
        }
148
2
    }
_ZN5doris20StringComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_SE_RS9_
Line
Count
Source
132
36
                                                      PaddedPODArray<UInt8>& c) {
133
36
        size_t size = a_offsets.size();
134
36
        ColumnString::Offset prev_a_offset = 0;
135
36
        ColumnString::Offset prev_b_offset = 0;
136
36
        const auto* a_pos = a_data.data();
137
36
        const auto* b_pos = b_data.data();
138
139
230
        for (size_t i = 0; i < size; ++i) {
140
194
            c[i] = Op::apply(memcmp_small_allow_overflow15(
141
194
                                     a_pos + prev_a_offset, a_offsets[i] - prev_a_offset,
142
194
                                     b_pos + prev_b_offset, b_offsets[i] - prev_b_offset),
143
194
                             0);
144
145
194
            prev_a_offset = a_offsets[i];
146
194
            prev_b_offset = b_offsets[i];
147
194
        }
148
36
    }
_ZN5doris20StringComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_SE_RS9_
Line
Count
Source
132
493
                                                      PaddedPODArray<UInt8>& c) {
133
493
        size_t size = a_offsets.size();
134
493
        ColumnString::Offset prev_a_offset = 0;
135
493
        ColumnString::Offset prev_b_offset = 0;
136
493
        const auto* a_pos = a_data.data();
137
493
        const auto* b_pos = b_data.data();
138
139
1.50k
        for (size_t i = 0; i < size; ++i) {
140
1.01k
            c[i] = Op::apply(memcmp_small_allow_overflow15(
141
1.01k
                                     a_pos + prev_a_offset, a_offsets[i] - prev_a_offset,
142
1.01k
                                     b_pos + prev_b_offset, b_offsets[i] - prev_b_offset),
143
1.01k
                             0);
144
145
1.01k
            prev_a_offset = a_offsets[i];
146
1.01k
            prev_b_offset = b_offsets[i];
147
1.01k
        }
148
493
    }
Unexecuted instantiation: _ZN5doris20StringComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_SE_RS9_
149
150
    static void NO_INLINE string_vector_constant(const ColumnString::Chars& a_data,
151
                                                 const ColumnString::Offsets& a_offsets,
152
                                                 const ColumnString::Chars& b_data,
153
                                                 ColumnString::Offset b_size,
154
706
                                                 PaddedPODArray<UInt8>& c) {
155
706
        size_t size = a_offsets.size();
156
706
        ColumnString::Offset prev_a_offset = 0;
157
706
        const auto* a_pos = a_data.data();
158
706
        const auto* b_pos = b_data.data();
159
160
1.40M
        for (size_t i = 0; i < size; ++i) {
161
1.40M
            c[i] = Op::apply(
162
1.40M
                    memcmp_small_allow_overflow15(a_pos + prev_a_offset,
163
1.40M
                                                  a_offsets[i] - prev_a_offset, b_pos, b_size),
164
1.40M
                    0);
165
166
1.40M
            prev_a_offset = a_offsets[i];
167
1.40M
        }
168
706
    }
_ZN5doris20StringComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_jRS9_
Line
Count
Source
154
180
                                                 PaddedPODArray<UInt8>& c) {
155
180
        size_t size = a_offsets.size();
156
180
        ColumnString::Offset prev_a_offset = 0;
157
180
        const auto* a_pos = a_data.data();
158
180
        const auto* b_pos = b_data.data();
159
160
324k
        for (size_t i = 0; i < size; ++i) {
161
324k
            c[i] = Op::apply(
162
324k
                    memcmp_small_allow_overflow15(a_pos + prev_a_offset,
163
324k
                                                  a_offsets[i] - prev_a_offset, b_pos, b_size),
164
324k
                    0);
165
166
324k
            prev_a_offset = a_offsets[i];
167
324k
        }
168
180
    }
_ZN5doris20StringComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_jRS9_
Line
Count
Source
154
96
                                                 PaddedPODArray<UInt8>& c) {
155
96
        size_t size = a_offsets.size();
156
96
        ColumnString::Offset prev_a_offset = 0;
157
96
        const auto* a_pos = a_data.data();
158
96
        const auto* b_pos = b_data.data();
159
160
146k
        for (size_t i = 0; i < size; ++i) {
161
145k
            c[i] = Op::apply(
162
145k
                    memcmp_small_allow_overflow15(a_pos + prev_a_offset,
163
145k
                                                  a_offsets[i] - prev_a_offset, b_pos, b_size),
164
145k
                    0);
165
166
145k
            prev_a_offset = a_offsets[i];
167
145k
        }
168
96
    }
_ZN5doris20StringComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_jRS9_
Line
Count
Source
154
220
                                                 PaddedPODArray<UInt8>& c) {
155
220
        size_t size = a_offsets.size();
156
220
        ColumnString::Offset prev_a_offset = 0;
157
220
        const auto* a_pos = a_data.data();
158
220
        const auto* b_pos = b_data.data();
159
160
432k
        for (size_t i = 0; i < size; ++i) {
161
432k
            c[i] = Op::apply(
162
432k
                    memcmp_small_allow_overflow15(a_pos + prev_a_offset,
163
432k
                                                  a_offsets[i] - prev_a_offset, b_pos, b_size),
164
432k
                    0);
165
166
432k
            prev_a_offset = a_offsets[i];
167
432k
        }
168
220
    }
_ZN5doris20StringComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IjLm4096ES8_Lm16ELm15EEESB_jRS9_
Line
Count
Source
154
210
                                                 PaddedPODArray<UInt8>& c) {
155
210
        size_t size = a_offsets.size();
156
210
        ColumnString::Offset prev_a_offset = 0;
157
210
        const auto* a_pos = a_data.data();
158
210
        const auto* b_pos = b_data.data();
159
160
502k
        for (size_t i = 0; i < size; ++i) {
161
502k
            c[i] = Op::apply(
162
502k
                    memcmp_small_allow_overflow15(a_pos + prev_a_offset,
163
502k
                                                  a_offsets[i] - prev_a_offset, b_pos, b_size),
164
502k
                    0);
165
166
502k
            prev_a_offset = a_offsets[i];
167
502k
        }
168
210
    }
169
170
    static void constant_string_vector(const ColumnString::Chars& a_data,
171
                                       ColumnString::Offset a_size,
172
                                       const ColumnString::Chars& b_data,
173
                                       const ColumnString::Offsets& b_offsets,
174
4
                                       PaddedPODArray<UInt8>& c) {
175
4
        StringComparisonImpl<typename Op::SymmetricOp>::string_vector_constant(b_data, b_offsets,
176
4
                                                                               a_data, a_size, c);
177
4
    }
Unexecuted instantiation: _ZN5doris20StringComparisonImplINS_9GreaterOpILNS_13PrimitiveTypeE5EEEE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjSB_RKNS5_IjLm4096ES8_Lm16ELm15EEERS9_
Unexecuted instantiation: _ZN5doris20StringComparisonImplINS_17GreaterOrEqualsOpILNS_13PrimitiveTypeE5EEEE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjSB_RKNS5_IjLm4096ES8_Lm16ELm15EEERS9_
_ZN5doris20StringComparisonImplINS_6LessOpILNS_13PrimitiveTypeE5EEEE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjSB_RKNS5_IjLm4096ES8_Lm16ELm15EEERS9_
Line
Count
Source
174
4
                                       PaddedPODArray<UInt8>& c) {
175
4
        StringComparisonImpl<typename Op::SymmetricOp>::string_vector_constant(b_data, b_offsets,
176
4
                                                                               a_data, a_size, c);
177
4
    }
Unexecuted instantiation: _ZN5doris20StringComparisonImplINS_14LessOrEqualsOpILNS_13PrimitiveTypeE5EEEE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjSB_RKNS5_IjLm4096ES8_Lm16ELm15EEERS9_
178
};
179
180
template <bool positive>
181
struct StringEqualsImpl {
182
    static void NO_INLINE string_vector_string_vector(const ColumnString::Chars& a_data,
183
                                                      const ColumnString::Offsets& a_offsets,
184
                                                      const ColumnString::Chars& b_data,
185
                                                      const ColumnString::Offsets& b_offsets,
186
554
                                                      PaddedPODArray<UInt8>& c) {
187
554
        size_t size = a_offsets.size();
188
554
        ColumnString::Offset prev_a_offset = 0;
189
554
        ColumnString::Offset prev_b_offset = 0;
190
554
        const auto* a_pos = a_data.data();
191
554
        const auto* b_pos = b_data.data();
192
193
1.58k
        for (size_t i = 0; i < size; ++i) {
194
1.03k
            auto a_size = a_offsets[i] - prev_a_offset;
195
1.03k
            auto b_size = b_offsets[i] - prev_b_offset;
196
197
1.03k
            c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
198
1.03k
                                                               b_pos + prev_b_offset, b_size);
199
200
1.03k
            prev_a_offset = a_offsets[i];
201
1.03k
            prev_b_offset = b_offsets[i];
202
1.03k
        }
203
554
    }
_ZN5doris16StringEqualsImplILb1EE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS2_IjLm4096ES5_Lm16ELm15EEES8_SB_RS6_
Line
Count
Source
186
553
                                                      PaddedPODArray<UInt8>& c) {
187
553
        size_t size = a_offsets.size();
188
553
        ColumnString::Offset prev_a_offset = 0;
189
553
        ColumnString::Offset prev_b_offset = 0;
190
553
        const auto* a_pos = a_data.data();
191
553
        const auto* b_pos = b_data.data();
192
193
1.58k
        for (size_t i = 0; i < size; ++i) {
194
1.02k
            auto a_size = a_offsets[i] - prev_a_offset;
195
1.02k
            auto b_size = b_offsets[i] - prev_b_offset;
196
197
1.02k
            c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
198
1.02k
                                                               b_pos + prev_b_offset, b_size);
199
200
1.02k
            prev_a_offset = a_offsets[i];
201
1.02k
            prev_b_offset = b_offsets[i];
202
1.02k
        }
203
553
    }
_ZN5doris16StringEqualsImplILb0EE27string_vector_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS2_IjLm4096ES5_Lm16ELm15EEES8_SB_RS6_
Line
Count
Source
186
1
                                                      PaddedPODArray<UInt8>& c) {
187
1
        size_t size = a_offsets.size();
188
1
        ColumnString::Offset prev_a_offset = 0;
189
1
        ColumnString::Offset prev_b_offset = 0;
190
1
        const auto* a_pos = a_data.data();
191
1
        const auto* b_pos = b_data.data();
192
193
5
        for (size_t i = 0; i < size; ++i) {
194
4
            auto a_size = a_offsets[i] - prev_a_offset;
195
4
            auto b_size = b_offsets[i] - prev_b_offset;
196
197
4
            c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
198
4
                                                               b_pos + prev_b_offset, b_size);
199
200
4
            prev_a_offset = a_offsets[i];
201
4
            prev_b_offset = b_offsets[i];
202
4
        }
203
1
    }
204
205
    static void NO_INLINE string_vector_constant(const ColumnString::Chars& a_data,
206
                                                 const ColumnString::Offsets& a_offsets,
207
                                                 const ColumnString::Chars& b_data,
208
                                                 ColumnString::Offset b_size,
209
10.5k
                                                 PaddedPODArray<UInt8>& c) {
210
10.5k
        size_t size = a_offsets.size();
211
10.5k
        if (b_size == 0) {
212
1
            auto* __restrict data = c.data();
213
1
            auto* __restrict offsets = a_offsets.data();
214
215
1
            ColumnString::Offset prev_a_offset = 0;
216
4
            for (size_t i = 0; i < size; ++i) {
217
3
                data[i] = positive ? (offsets[i] == prev_a_offset) : (offsets[i] != prev_a_offset);
218
3
                prev_a_offset = offsets[i];
219
3
            }
220
10.5k
        } else {
221
10.5k
            ColumnString::Offset prev_a_offset = 0;
222
10.5k
            const auto* a_pos = a_data.data();
223
10.5k
            const auto* b_pos = b_data.data();
224
1.49M
            for (size_t i = 0; i < size; ++i) {
225
1.48M
                auto a_size = a_offsets[i] - prev_a_offset;
226
1.48M
                c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
227
1.48M
                                                                   b_pos, b_size);
228
1.48M
                prev_a_offset = a_offsets[i];
229
1.48M
            }
230
10.5k
        }
231
10.5k
    }
_ZN5doris16StringEqualsImplILb1EE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS2_IjLm4096ES5_Lm16ELm15EEES8_jRS6_
Line
Count
Source
209
10.4k
                                                 PaddedPODArray<UInt8>& c) {
210
10.4k
        size_t size = a_offsets.size();
211
10.4k
        if (b_size == 0) {
212
0
            auto* __restrict data = c.data();
213
0
            auto* __restrict offsets = a_offsets.data();
214
215
0
            ColumnString::Offset prev_a_offset = 0;
216
0
            for (size_t i = 0; i < size; ++i) {
217
0
                data[i] = positive ? (offsets[i] == prev_a_offset) : (offsets[i] != prev_a_offset);
218
0
                prev_a_offset = offsets[i];
219
0
            }
220
10.4k
        } else {
221
10.4k
            ColumnString::Offset prev_a_offset = 0;
222
10.4k
            const auto* a_pos = a_data.data();
223
10.4k
            const auto* b_pos = b_data.data();
224
1.44M
            for (size_t i = 0; i < size; ++i) {
225
1.43M
                auto a_size = a_offsets[i] - prev_a_offset;
226
1.43M
                c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
227
1.43M
                                                                   b_pos, b_size);
228
1.43M
                prev_a_offset = a_offsets[i];
229
1.43M
            }
230
10.4k
        }
231
10.4k
    }
_ZN5doris16StringEqualsImplILb0EE22string_vector_constantERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS2_IjLm4096ES5_Lm16ELm15EEES8_jRS6_
Line
Count
Source
209
99
                                                 PaddedPODArray<UInt8>& c) {
210
99
        size_t size = a_offsets.size();
211
99
        if (b_size == 0) {
212
1
            auto* __restrict data = c.data();
213
1
            auto* __restrict offsets = a_offsets.data();
214
215
1
            ColumnString::Offset prev_a_offset = 0;
216
4
            for (size_t i = 0; i < size; ++i) {
217
3
                data[i] = positive ? (offsets[i] == prev_a_offset) : (offsets[i] != prev_a_offset);
218
3
                prev_a_offset = offsets[i];
219
3
            }
220
98
        } else {
221
98
            ColumnString::Offset prev_a_offset = 0;
222
98
            const auto* a_pos = a_data.data();
223
98
            const auto* b_pos = b_data.data();
224
44.9k
            for (size_t i = 0; i < size; ++i) {
225
44.8k
                auto a_size = a_offsets[i] - prev_a_offset;
226
44.8k
                c[i] = positive == memequal_small_allow_overflow15(a_pos + prev_a_offset, a_size,
227
44.8k
                                                                   b_pos, b_size);
228
44.8k
                prev_a_offset = a_offsets[i];
229
44.8k
            }
230
98
        }
231
99
    }
232
233
    static void NO_INLINE constant_string_vector(const ColumnString::Chars& a_data,
234
                                                 ColumnString::Offset a_size,
235
                                                 const ColumnString::Chars& b_data,
236
                                                 const ColumnString::Offsets& b_offsets,
237
0
                                                 PaddedPODArray<UInt8>& c) {
238
0
        string_vector_constant(b_data, b_offsets, a_data, a_size, c);
239
0
    }
Unexecuted instantiation: _ZN5doris16StringEqualsImplILb1EE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjS8_RKNS2_IjLm4096ES5_Lm16ELm15EEERS6_
Unexecuted instantiation: _ZN5doris16StringEqualsImplILb0EE22constant_string_vectorERKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEjS8_RKNS2_IjLm4096ES5_Lm16ELm15EEERS6_
240
};
241
242
template <PrimitiveType PT>
243
struct StringComparisonImpl<EqualsOp<PT>> : StringEqualsImpl<true> {};
244
245
template <PrimitiveType PT>
246
struct StringComparisonImpl<NotEqualsOp<PT>> : StringEqualsImpl<false> {};
247
248
struct NameEquals {
249
    static constexpr auto name = "eq";
250
};
251
struct NameNotEquals {
252
    static constexpr auto name = "ne";
253
};
254
struct NameLess {
255
    static constexpr auto name = "lt";
256
};
257
struct NameGreater {
258
    static constexpr auto name = "gt";
259
};
260
struct NameLessOrEquals {
261
    static constexpr auto name = "le";
262
};
263
struct NameGreaterOrEquals {
264
    static constexpr auto name = "ge";
265
};
266
267
namespace comparison_zonemap_detail {
268
enum class Op {
269
    EQ,
270
    NE,
271
    LT,
272
    LE,
273
    GT,
274
    GE,
275
};
276
277
4
inline Op symmetric_op(Op op) {
278
4
    switch (op) {
279
0
    case Op::EQ:
280
0
    case Op::NE:
281
0
        return op;
282
2
    case Op::LT:
283
2
        return Op::GT;
284
0
    case Op::LE:
285
0
        return Op::GE;
286
0
    case Op::GT:
287
0
        return Op::LT;
288
2
    case Op::GE:
289
2
        return Op::LE;
290
4
    }
291
0
    __builtin_unreachable();
292
4
}
293
294
inline ZoneMapFilterResult evaluate(const ZoneMapEvalContext& ctx, const VExprSPtrs& arguments,
295
2.60k
                                    Op op) {
296
2.60k
    auto slot_literal = expr_zonemap::extract_slot_and_literal(arguments);
297
298
2.60k
    auto slot_type = expr_zonemap::fetch_compatible_slot_type(ctx, slot_literal->slot_index,
299
2.60k
                                                              slot_literal->slot_type);
300
2.60k
    if (slot_type == nullptr) {
301
1
        return unsupported_zonemap_filter(ctx);
302
1
    }
303
2.59k
    auto zone_map_ptr = ctx.zone_map(slot_literal->slot_index);
304
2.59k
    if (zone_map_ptr == nullptr) {
305
29
        return unsupported_zonemap_filter(ctx);
306
29
    }
307
2.57k
    const auto& zone_map = *zone_map_ptr;
308
2.57k
    if (!zone_map.has_not_null) {
309
60
        return ZoneMapFilterResult::kNoMatch;
310
60
    }
311
2.51k
    if (!expr_zonemap::range_stats_usable_for_zonemap(zone_map, slot_type)) {
312
98
        return unsupported_zonemap_filter(ctx);
313
98
    }
314
315
2.41k
    const auto effective_op = slot_literal->literal_on_left ? symmetric_op(op) : op;
316
2.41k
    const auto& literal = slot_literal->literal;
317
2.41k
    switch (effective_op) {
318
1.51k
    case Op::EQ:
319
1.51k
        return literal < zone_map.min_value || zone_map.max_value < literal
320
1.51k
                       ? ZoneMapFilterResult::kNoMatch
321
1.51k
                       : ZoneMapFilterResult::kMayMatch;
322
96
    case Op::NE:
323
96
        return zone_map.min_value == literal && zone_map.max_value == literal
324
96
                       ? ZoneMapFilterResult::kNoMatch
325
96
                       : ZoneMapFilterResult::kMayMatch;
326
195
    case Op::LT:
327
195
        return zone_map.min_value >= literal ? ZoneMapFilterResult::kNoMatch
328
195
                                             : ZoneMapFilterResult::kMayMatch;
329
211
    case Op::LE:
330
211
        return zone_map.min_value > literal ? ZoneMapFilterResult::kNoMatch
331
211
                                            : ZoneMapFilterResult::kMayMatch;
332
191
    case Op::GT:
333
191
        return zone_map.max_value <= literal ? ZoneMapFilterResult::kNoMatch
334
191
                                             : ZoneMapFilterResult::kMayMatch;
335
206
    case Op::GE:
336
206
        return zone_map.max_value < literal ? ZoneMapFilterResult::kNoMatch
337
206
                                            : ZoneMapFilterResult::kMayMatch;
338
2.41k
    }
339
340
    // keep this to avoid compile failure with g++.
341
0
    __builtin_unreachable();
342
2.41k
}
343
344
29.7k
inline bool can_evaluate(const VExprSPtrs& arguments) {
345
29.7k
    auto slot_literal = expr_zonemap::extract_slot_and_literal(arguments);
346
29.7k
    if (!slot_literal.has_value()) {
347
19.3k
        return false;
348
19.3k
    }
349
350
    // A NULL literal makes the comparison evaluate to NULL instead of a byte range predicate on
351
    // the slot. This zonemap evaluator only derives bounds from non-NULL literals, so reject this
352
    // shape here before evaluate_zonemap_filter is called.
353
10.3k
    if (slot_literal->literal.is_null()) {
354
4
        return false;
355
4
    }
356
357
10.3k
    DORIS_CHECK(slot_literal->slot_type != nullptr);
358
10.3k
    DORIS_CHECK(slot_literal->literal_type != nullptr);
359
10.3k
    if (!expr_zonemap::data_types_compatible(slot_literal->slot_type, slot_literal->literal_type)) {
360
        // The optimizer may generate a bare slot/literal comparison whose logical types differ
361
        // only by attributes such as DATETIMEV2 scale. Expr zonemap evaluates stored Field
362
        // values without running expression casts, so conservatively skip this optimization.
363
1
        return false;
364
1
    }
365
366
10.3k
    return true;
367
10.3k
}
368
369
32.4k
inline std::optional<Op> op_from_name(std::string_view name) {
370
32.4k
    if (name == NameEquals::name) {
371
15.4k
        return Op::EQ;
372
15.4k
    }
373
16.9k
    if (name == NameNotEquals::name) {
374
1.44k
        return Op::NE;
375
1.44k
    }
376
15.4k
    if (name == NameLess::name) {
377
3.65k
        return Op::LT;
378
3.65k
    }
379
11.8k
    if (name == NameLessOrEquals::name) {
380
2.47k
        return Op::LE;
381
2.47k
    }
382
9.37k
    if (name == NameGreater::name) {
383
4.77k
        return Op::GT;
384
4.77k
    }
385
4.67k
    if (name == NameGreaterOrEquals::name) {
386
4.67k
        return Op::GE;
387
4.67k
    }
388
18.4E
    return std::nullopt;
389
4.60k
}
390
} // namespace comparison_zonemap_detail
391
392
template <template <PrimitiveType> class Op, typename Name>
393
class FunctionComparison : public IFunction {
394
public:
395
    static constexpr auto name = Name::name;
396
267k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE6createEv
Line
Count
Source
396
242k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE6createEv
Line
Count
Source
396
1.18k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE6createEv
Line
Count
Source
396
4.93k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE6createEv
Line
Count
Source
396
6.85k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE6createEv
Line
Count
Source
396
3.02k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
_ZN5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE6createEv
Line
Count
Source
396
9.56k
    static FunctionPtr create() { return std::make_shared<FunctionComparison>(); }
397
398
267k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEEC2Ev
Line
Count
Source
398
242k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEEC2Ev
Line
Count
Source
398
1.18k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEEC2Ev
Line
Count
Source
398
4.94k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEEC2Ev
Line
Count
Source
398
6.85k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_6LessOpENS_8NameLessEEC2Ev
Line
Count
Source
398
3.02k
    FunctionComparison() = default;
_ZN5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEEC2Ev
Line
Count
Source
398
9.53k
    FunctionComparison() = default;
399
400
650k
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE12execute_costEv
Line
Count
Source
400
644k
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE12execute_costEv
Line
Count
Source
400
603
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE12execute_costEv
Line
Count
Source
400
1.89k
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE12execute_costEv
Line
Count
Source
400
1.84k
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE12execute_costEv
Line
Count
Source
400
1.14k
    double execute_cost() const override { return 0.5; }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE12execute_costEv
Line
Count
Source
400
985
    double execute_cost() const override { return 0.5; }
401
402
private:
403
    template <PrimitiveType PT>
404
    Status execute_num_type(Block& block, uint32_t result, const ColumnPtr& col_left_ptr,
405
130k
                            const ColumnPtr& col_right_ptr) const {
406
130k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
130k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
130k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
130k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
130k
        DCHECK(!(left_is_const && right_is_const));
413
414
130k
        if (!left_is_const && !right_is_const) {
415
8.45k
            auto col_res = ColumnUInt8::create();
416
417
8.45k
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
8.45k
            vec_res.resize(col_left->get_data().size());
419
8.45k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
8.45k
                              typename PrimitiveTypeTraits<PT>::CppType,
421
8.45k
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
8.45k
                                                     vec_res);
423
424
8.45k
            block.replace_by_position(result, std::move(col_res));
425
122k
        } else if (!left_is_const && right_is_const) {
426
43.6k
            auto col_res = ColumnUInt8::create();
427
428
43.6k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
43.6k
            vec_res.resize(col_left->size());
430
43.6k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
43.6k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
43.6k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
43.6k
                                                       col_right->get_element(0), vec_res);
434
435
43.6k
            block.replace_by_position(result, std::move(col_res));
436
78.8k
        } else if (left_is_const && !right_is_const) {
437
78.8k
            auto col_res = ColumnUInt8::create();
438
439
78.8k
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
78.8k
            vec_res.resize(col_right->size());
441
78.8k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
78.8k
                              typename PrimitiveTypeTraits<PT>::CppType,
443
78.8k
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
78.8k
                                                       col_right->get_data(), vec_res);
445
446
78.8k
            block.replace_by_position(result, std::move(col_res));
447
78.8k
        }
448
130k
        return Status::OK();
449
130k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
100
                            const ColumnPtr& col_right_ptr) const {
406
100
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
100
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
100
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
100
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
100
        DCHECK(!(left_is_const && right_is_const));
413
414
100
        if (!left_is_const && !right_is_const) {
415
76
            auto col_res = ColumnUInt8::create();
416
417
76
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
76
            vec_res.resize(col_left->get_data().size());
419
76
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
76
                              typename PrimitiveTypeTraits<PT>::CppType,
421
76
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
76
                                                     vec_res);
423
424
76
            block.replace_by_position(result, std::move(col_res));
425
76
        } else if (!left_is_const && right_is_const) {
426
24
            auto col_res = ColumnUInt8::create();
427
428
24
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
24
            vec_res.resize(col_left->size());
430
24
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
24
                              typename PrimitiveTypeTraits<PT>::CppType,
432
24
                              Op<PT>>::vector_constant(col_left->get_data(),
433
24
                                                       col_right->get_element(0), vec_res);
434
435
24
            block.replace_by_position(result, std::move(col_res));
436
24
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
100
        return Status::OK();
449
100
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.03k
                            const ColumnPtr& col_right_ptr) const {
406
1.03k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.03k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.03k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.03k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.03k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.03k
        if (!left_is_const && !right_is_const) {
415
369
            auto col_res = ColumnUInt8::create();
416
417
369
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
369
            vec_res.resize(col_left->get_data().size());
419
369
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
369
                              typename PrimitiveTypeTraits<PT>::CppType,
421
369
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
369
                                                     vec_res);
423
424
369
            block.replace_by_position(result, std::move(col_res));
425
664
        } else if (!left_is_const && right_is_const) {
426
664
            auto col_res = ColumnUInt8::create();
427
428
664
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
664
            vec_res.resize(col_left->size());
430
664
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
664
                              typename PrimitiveTypeTraits<PT>::CppType,
432
664
                              Op<PT>>::vector_constant(col_left->get_data(),
433
664
                                                       col_right->get_element(0), vec_res);
434
435
664
            block.replace_by_position(result, std::move(col_res));
436
18.4E
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
1.03k
        return Status::OK();
449
1.03k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
443
                            const ColumnPtr& col_right_ptr) const {
406
443
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
443
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
443
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
443
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
443
        DCHECK(!(left_is_const && right_is_const));
413
414
443
        if (!left_is_const && !right_is_const) {
415
278
            auto col_res = ColumnUInt8::create();
416
417
278
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
278
            vec_res.resize(col_left->get_data().size());
419
278
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
278
                              typename PrimitiveTypeTraits<PT>::CppType,
421
278
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
278
                                                     vec_res);
423
424
278
            block.replace_by_position(result, std::move(col_res));
425
278
        } else if (!left_is_const && right_is_const) {
426
166
            auto col_res = ColumnUInt8::create();
427
428
166
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
166
            vec_res.resize(col_left->size());
430
166
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
166
                              typename PrimitiveTypeTraits<PT>::CppType,
432
166
                              Op<PT>>::vector_constant(col_left->get_data(),
433
166
                                                       col_right->get_element(0), vec_res);
434
435
166
            block.replace_by_position(result, std::move(col_res));
436
18.4E
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
443
        return Status::OK();
449
443
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
3
                            const ColumnPtr& col_right_ptr) const {
406
3
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
3
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
3
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
3
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
3
        DCHECK(!(left_is_const && right_is_const));
413
414
3
        if (!left_is_const && !right_is_const) {
415
3
            auto col_res = ColumnUInt8::create();
416
417
3
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
3
            vec_res.resize(col_left->get_data().size());
419
3
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
3
                              typename PrimitiveTypeTraits<PT>::CppType,
421
3
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
3
                                                     vec_res);
423
424
3
            block.replace_by_position(result, std::move(col_res));
425
3
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
3
        return Status::OK();
449
3
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
4.94k
                            const ColumnPtr& col_right_ptr) const {
406
4.94k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
4.94k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
4.94k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
4.94k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
4.94k
        DCHECK(!(left_is_const && right_is_const));
413
414
4.94k
        if (!left_is_const && !right_is_const) {
415
175
            auto col_res = ColumnUInt8::create();
416
417
175
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
175
            vec_res.resize(col_left->get_data().size());
419
175
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
175
                              typename PrimitiveTypeTraits<PT>::CppType,
421
175
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
175
                                                     vec_res);
423
424
175
            block.replace_by_position(result, std::move(col_res));
425
4.76k
        } else if (!left_is_const && right_is_const) {
426
4.49k
            auto col_res = ColumnUInt8::create();
427
428
4.49k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
4.49k
            vec_res.resize(col_left->size());
430
4.49k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
4.49k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
4.49k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
4.49k
                                                       col_right->get_element(0), vec_res);
434
435
4.49k
            block.replace_by_position(result, std::move(col_res));
436
4.49k
        } else if (left_is_const && !right_is_const) {
437
276
            auto col_res = ColumnUInt8::create();
438
439
276
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
276
            vec_res.resize(col_right->size());
441
276
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
276
                              typename PrimitiveTypeTraits<PT>::CppType,
443
276
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
276
                                                       col_right->get_data(), vec_res);
445
446
276
            block.replace_by_position(result, std::move(col_res));
447
276
        }
448
4.94k
        return Status::OK();
449
4.94k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
401
                            const ColumnPtr& col_right_ptr) const {
406
401
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
401
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
401
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
401
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
401
        DCHECK(!(left_is_const && right_is_const));
413
414
401
        if (!left_is_const && !right_is_const) {
415
96
            auto col_res = ColumnUInt8::create();
416
417
96
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
96
            vec_res.resize(col_left->get_data().size());
419
96
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
96
                              typename PrimitiveTypeTraits<PT>::CppType,
421
96
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
96
                                                     vec_res);
423
424
96
            block.replace_by_position(result, std::move(col_res));
425
305
        } else if (!left_is_const && right_is_const) {
426
268
            auto col_res = ColumnUInt8::create();
427
428
268
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
268
            vec_res.resize(col_left->size());
430
268
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
268
                              typename PrimitiveTypeTraits<PT>::CppType,
432
268
                              Op<PT>>::vector_constant(col_left->get_data(),
433
268
                                                       col_right->get_element(0), vec_res);
434
435
268
            block.replace_by_position(result, std::move(col_res));
436
268
        } else if (left_is_const && !right_is_const) {
437
36
            auto col_res = ColumnUInt8::create();
438
439
36
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
36
            vec_res.resize(col_right->size());
441
36
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
36
                              typename PrimitiveTypeTraits<PT>::CppType,
443
36
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
36
                                                       col_right->get_data(), vec_res);
445
446
36
            block.replace_by_position(result, std::move(col_res));
447
36
        }
448
401
        return Status::OK();
449
401
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
26.0k
                            const ColumnPtr& col_right_ptr) const {
406
26.0k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
26.0k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
26.0k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
26.0k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
26.0k
        DCHECK(!(left_is_const && right_is_const));
413
414
26.0k
        if (!left_is_const && !right_is_const) {
415
259
            auto col_res = ColumnUInt8::create();
416
417
259
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
259
            vec_res.resize(col_left->get_data().size());
419
259
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
259
                              typename PrimitiveTypeTraits<PT>::CppType,
421
259
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
259
                                                     vec_res);
423
424
259
            block.replace_by_position(result, std::move(col_res));
425
25.7k
        } else if (!left_is_const && right_is_const) {
426
13.3k
            auto col_res = ColumnUInt8::create();
427
428
13.3k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
13.3k
            vec_res.resize(col_left->size());
430
13.3k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
13.3k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
13.3k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
13.3k
                                                       col_right->get_element(0), vec_res);
434
435
13.3k
            block.replace_by_position(result, std::move(col_res));
436
13.3k
        } else if (left_is_const && !right_is_const) {
437
12.4k
            auto col_res = ColumnUInt8::create();
438
439
12.4k
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
12.4k
            vec_res.resize(col_right->size());
441
12.4k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
12.4k
                              typename PrimitiveTypeTraits<PT>::CppType,
443
12.4k
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
12.4k
                                                       col_right->get_data(), vec_res);
445
446
12.4k
            block.replace_by_position(result, std::move(col_res));
447
12.4k
        }
448
26.0k
        return Status::OK();
449
26.0k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2.97k
                            const ColumnPtr& col_right_ptr) const {
406
2.97k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2.97k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2.97k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2.97k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2.97k
        DCHECK(!(left_is_const && right_is_const));
413
414
2.97k
        if (!left_is_const && !right_is_const) {
415
149
            auto col_res = ColumnUInt8::create();
416
417
149
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
149
            vec_res.resize(col_left->get_data().size());
419
149
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
149
                              typename PrimitiveTypeTraits<PT>::CppType,
421
149
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
149
                                                     vec_res);
423
424
149
            block.replace_by_position(result, std::move(col_res));
425
2.82k
        } else if (!left_is_const && right_is_const) {
426
1.63k
            auto col_res = ColumnUInt8::create();
427
428
1.63k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1.63k
            vec_res.resize(col_left->size());
430
1.63k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1.63k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1.63k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1.63k
                                                       col_right->get_element(0), vec_res);
434
435
1.63k
            block.replace_by_position(result, std::move(col_res));
436
1.63k
        } else if (left_is_const && !right_is_const) {
437
1.19k
            auto col_res = ColumnUInt8::create();
438
439
1.19k
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
1.19k
            vec_res.resize(col_right->size());
441
1.19k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
1.19k
                              typename PrimitiveTypeTraits<PT>::CppType,
443
1.19k
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
1.19k
                                                       col_right->get_data(), vec_res);
445
446
1.19k
            block.replace_by_position(result, std::move(col_res));
447
1.19k
        }
448
2.97k
        return Status::OK();
449
2.97k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
117
                            const ColumnPtr& col_right_ptr) const {
406
117
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
117
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
117
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
117
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
117
        DCHECK(!(left_is_const && right_is_const));
413
414
117
        if (!left_is_const && !right_is_const) {
415
86
            auto col_res = ColumnUInt8::create();
416
417
86
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
86
            vec_res.resize(col_left->get_data().size());
419
86
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
86
                              typename PrimitiveTypeTraits<PT>::CppType,
421
86
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
86
                                                     vec_res);
423
424
86
            block.replace_by_position(result, std::move(col_res));
425
86
        } else if (!left_is_const && right_is_const) {
426
27
            auto col_res = ColumnUInt8::create();
427
428
27
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
27
            vec_res.resize(col_left->size());
430
27
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
27
                              typename PrimitiveTypeTraits<PT>::CppType,
432
27
                              Op<PT>>::vector_constant(col_left->get_data(),
433
27
                                                       col_right->get_element(0), vec_res);
434
435
27
            block.replace_by_position(result, std::move(col_res));
436
27
        } else if (left_is_const && !right_is_const) {
437
4
            auto col_res = ColumnUInt8::create();
438
439
4
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
4
            vec_res.resize(col_right->size());
441
4
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
4
                              typename PrimitiveTypeTraits<PT>::CppType,
443
4
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
4
                                                       col_right->get_data(), vec_res);
445
446
4
            block.replace_by_position(result, std::move(col_res));
447
4
        }
448
117
        return Status::OK();
449
117
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
31
                            const ColumnPtr& col_right_ptr) const {
406
31
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
31
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
31
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
31
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
31
        DCHECK(!(left_is_const && right_is_const));
413
414
31
        if (!left_is_const && !right_is_const) {
415
16
            auto col_res = ColumnUInt8::create();
416
417
16
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
16
            vec_res.resize(col_left->get_data().size());
419
16
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
16
                              typename PrimitiveTypeTraits<PT>::CppType,
421
16
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
16
                                                     vec_res);
423
424
16
            block.replace_by_position(result, std::move(col_res));
425
16
        } else if (!left_is_const && right_is_const) {
426
15
            auto col_res = ColumnUInt8::create();
427
428
15
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
15
            vec_res.resize(col_left->size());
430
15
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
15
                              typename PrimitiveTypeTraits<PT>::CppType,
432
15
                              Op<PT>>::vector_constant(col_left->get_data(),
433
15
                                                       col_right->get_element(0), vec_res);
434
435
15
            block.replace_by_position(result, std::move(col_res));
436
15
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
31
        return Status::OK();
449
31
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
30
                            const ColumnPtr& col_right_ptr) const {
406
30
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
30
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
30
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
30
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
30
        DCHECK(!(left_is_const && right_is_const));
413
414
30
        if (!left_is_const && !right_is_const) {
415
24
            auto col_res = ColumnUInt8::create();
416
417
24
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
24
            vec_res.resize(col_left->get_data().size());
419
24
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
24
                              typename PrimitiveTypeTraits<PT>::CppType,
421
24
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
24
                                                     vec_res);
423
424
24
            block.replace_by_position(result, std::move(col_res));
425
24
        } else if (!left_is_const && right_is_const) {
426
6
            auto col_res = ColumnUInt8::create();
427
428
6
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
6
            vec_res.resize(col_left->size());
430
6
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
6
                              typename PrimitiveTypeTraits<PT>::CppType,
432
6
                              Op<PT>>::vector_constant(col_left->get_data(),
433
6
                                                       col_right->get_element(0), vec_res);
434
435
6
            block.replace_by_position(result, std::move(col_res));
436
6
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
30
        return Status::OK();
449
30
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
118
                            const ColumnPtr& col_right_ptr) const {
406
118
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
118
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
118
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
118
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
118
        DCHECK(!(left_is_const && right_is_const));
413
414
118
        if (!left_is_const && !right_is_const) {
415
118
            auto col_res = ColumnUInt8::create();
416
417
118
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
118
            vec_res.resize(col_left->get_data().size());
419
118
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
118
                              typename PrimitiveTypeTraits<PT>::CppType,
421
118
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
118
                                                     vec_res);
423
424
118
            block.replace_by_position(result, std::move(col_res));
425
118
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
118
        return Status::OK();
449
118
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
728
                            const ColumnPtr& col_right_ptr) const {
406
728
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
728
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
728
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
728
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
728
        DCHECK(!(left_is_const && right_is_const));
413
414
728
        if (!left_is_const && !right_is_const) {
415
107
            auto col_res = ColumnUInt8::create();
416
417
107
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
107
            vec_res.resize(col_left->get_data().size());
419
107
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
107
                              typename PrimitiveTypeTraits<PT>::CppType,
421
107
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
107
                                                     vec_res);
423
424
107
            block.replace_by_position(result, std::move(col_res));
425
621
        } else if (!left_is_const && right_is_const) {
426
621
            auto col_res = ColumnUInt8::create();
427
428
621
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
621
            vec_res.resize(col_left->size());
430
621
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
621
                              typename PrimitiveTypeTraits<PT>::CppType,
432
621
                              Op<PT>>::vector_constant(col_left->get_data(),
433
621
                                                       col_right->get_element(0), vec_res);
434
435
621
            block.replace_by_position(result, std::move(col_res));
436
621
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
728
        return Status::OK();
449
728
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
4
                            const ColumnPtr& col_right_ptr) const {
406
4
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
4
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
4
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
4
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
4
        DCHECK(!(left_is_const && right_is_const));
413
414
4
        if (!left_is_const && !right_is_const) {
415
4
            auto col_res = ColumnUInt8::create();
416
417
4
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
4
            vec_res.resize(col_left->get_data().size());
419
4
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
4
                              typename PrimitiveTypeTraits<PT>::CppType,
421
4
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
4
                                                     vec_res);
423
424
4
            block.replace_by_position(result, std::move(col_res));
425
4
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
4
        return Status::OK();
449
4
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
67
                            const ColumnPtr& col_right_ptr) const {
406
67
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
67
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
67
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
67
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
67
        DCHECK(!(left_is_const && right_is_const));
413
414
68
        if (!left_is_const && !right_is_const) {
415
37
            auto col_res = ColumnUInt8::create();
416
417
37
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
37
            vec_res.resize(col_left->get_data().size());
419
37
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
37
                              typename PrimitiveTypeTraits<PT>::CppType,
421
37
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
37
                                                     vec_res);
423
424
37
            block.replace_by_position(result, std::move(col_res));
425
37
        } else if (!left_is_const && right_is_const) {
426
31
            auto col_res = ColumnUInt8::create();
427
428
31
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
31
            vec_res.resize(col_left->size());
430
31
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
31
                              typename PrimitiveTypeTraits<PT>::CppType,
432
31
                              Op<PT>>::vector_constant(col_left->get_data(),
433
31
                                                       col_right->get_element(0), vec_res);
434
435
31
            block.replace_by_position(result, std::move(col_res));
436
18.4E
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
67
        return Status::OK();
449
67
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
84
                            const ColumnPtr& col_right_ptr) const {
406
84
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
84
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
84
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
84
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
84
        DCHECK(!(left_is_const && right_is_const));
413
414
84
        if (!left_is_const && !right_is_const) {
415
56
            auto col_res = ColumnUInt8::create();
416
417
56
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
56
            vec_res.resize(col_left->get_data().size());
419
56
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
56
                              typename PrimitiveTypeTraits<PT>::CppType,
421
56
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
56
                                                     vec_res);
423
424
56
            block.replace_by_position(result, std::move(col_res));
425
56
        } else if (!left_is_const && right_is_const) {
426
28
            auto col_res = ColumnUInt8::create();
427
428
28
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
28
            vec_res.resize(col_left->size());
430
28
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
28
                              typename PrimitiveTypeTraits<PT>::CppType,
432
28
                              Op<PT>>::vector_constant(col_left->get_data(),
433
28
                                                       col_right->get_element(0), vec_res);
434
435
28
            block.replace_by_position(result, std::move(col_res));
436
28
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
84
        return Status::OK();
449
84
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.11k
                            const ColumnPtr& col_right_ptr) const {
406
1.11k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.11k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.11k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.11k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.11k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.11k
        if (!left_is_const && !right_is_const) {
415
864
            auto col_res = ColumnUInt8::create();
416
417
864
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
864
            vec_res.resize(col_left->get_data().size());
419
864
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
864
                              typename PrimitiveTypeTraits<PT>::CppType,
421
864
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
864
                                                     vec_res);
423
424
864
            block.replace_by_position(result, std::move(col_res));
425
864
        } else if (!left_is_const && right_is_const) {
426
249
            auto col_res = ColumnUInt8::create();
427
428
249
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
249
            vec_res.resize(col_left->size());
430
249
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
249
                              typename PrimitiveTypeTraits<PT>::CppType,
432
249
                              Op<PT>>::vector_constant(col_left->get_data(),
433
249
                                                       col_right->get_element(0), vec_res);
434
435
249
            block.replace_by_position(result, std::move(col_res));
436
249
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
1.11k
        return Status::OK();
449
1.11k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
874
                            const ColumnPtr& col_right_ptr) const {
406
874
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
874
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
874
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
874
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
874
        DCHECK(!(left_is_const && right_is_const));
413
414
874
        if (!left_is_const && !right_is_const) {
415
377
            auto col_res = ColumnUInt8::create();
416
417
377
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
377
            vec_res.resize(col_left->get_data().size());
419
377
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
377
                              typename PrimitiveTypeTraits<PT>::CppType,
421
377
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
377
                                                     vec_res);
423
424
377
            block.replace_by_position(result, std::move(col_res));
425
497
        } else if (!left_is_const && right_is_const) {
426
21
            auto col_res = ColumnUInt8::create();
427
428
21
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
21
            vec_res.resize(col_left->size());
430
21
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
21
                              typename PrimitiveTypeTraits<PT>::CppType,
432
21
                              Op<PT>>::vector_constant(col_left->get_data(),
433
21
                                                       col_right->get_element(0), vec_res);
434
435
21
            block.replace_by_position(result, std::move(col_res));
436
476
        } else if (left_is_const && !right_is_const) {
437
476
            auto col_res = ColumnUInt8::create();
438
439
476
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
476
            vec_res.resize(col_right->size());
441
476
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
476
                              typename PrimitiveTypeTraits<PT>::CppType,
443
476
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
476
                                                       col_right->get_data(), vec_res);
445
446
476
            block.replace_by_position(result, std::move(col_res));
447
476
        }
448
874
        return Status::OK();
449
874
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
48
                            const ColumnPtr& col_right_ptr) const {
406
48
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
48
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
48
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
48
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
48
        DCHECK(!(left_is_const && right_is_const));
413
414
48
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
28
        } else if (!left_is_const && right_is_const) {
426
28
            auto col_res = ColumnUInt8::create();
427
428
28
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
28
            vec_res.resize(col_left->size());
430
28
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
28
                              typename PrimitiveTypeTraits<PT>::CppType,
432
28
                              Op<PT>>::vector_constant(col_left->get_data(),
433
28
                                                       col_right->get_element(0), vec_res);
434
435
28
            block.replace_by_position(result, std::move(col_res));
436
28
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
48
        return Status::OK();
449
48
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
60
                            const ColumnPtr& col_right_ptr) const {
406
60
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
60
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
60
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
60
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
60
        DCHECK(!(left_is_const && right_is_const));
413
414
60
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
40
        } else if (!left_is_const && right_is_const) {
426
40
            auto col_res = ColumnUInt8::create();
427
428
40
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
40
            vec_res.resize(col_left->size());
430
40
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
40
                              typename PrimitiveTypeTraits<PT>::CppType,
432
40
                              Op<PT>>::vector_constant(col_left->get_data(),
433
40
                                                       col_right->get_element(0), vec_res);
434
435
40
            block.replace_by_position(result, std::move(col_res));
436
40
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
60
        return Status::OK();
449
60
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.16k
                            const ColumnPtr& col_right_ptr) const {
406
1.16k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.16k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.16k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.16k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.16k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.16k
        if (!left_is_const && !right_is_const) {
415
1.11k
            auto col_res = ColumnUInt8::create();
416
417
1.11k
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1.11k
            vec_res.resize(col_left->get_data().size());
419
1.11k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1.11k
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1.11k
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1.11k
                                                     vec_res);
423
424
1.11k
            block.replace_by_position(result, std::move(col_res));
425
1.11k
        } else if (!left_is_const && right_is_const) {
426
41
            auto col_res = ColumnUInt8::create();
427
428
41
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
41
            vec_res.resize(col_left->size());
430
41
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
41
                              typename PrimitiveTypeTraits<PT>::CppType,
432
41
                              Op<PT>>::vector_constant(col_left->get_data(),
433
41
                                                       col_right->get_element(0), vec_res);
434
435
41
            block.replace_by_position(result, std::move(col_res));
436
41
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
1.16k
        return Status::OK();
449
1.16k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2
                            const ColumnPtr& col_right_ptr) const {
406
2
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2
        DCHECK(!(left_is_const && right_is_const));
413
414
2
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
2
        } else if (!left_is_const && right_is_const) {
426
2
            auto col_res = ColumnUInt8::create();
427
428
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
2
            vec_res.resize(col_left->size());
430
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
2
                              typename PrimitiveTypeTraits<PT>::CppType,
432
2
                              Op<PT>>::vector_constant(col_left->get_data(),
433
2
                                                       col_right->get_element(0), vec_res);
434
435
2
            block.replace_by_position(result, std::move(col_res));
436
2
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
2
        return Status::OK();
449
2
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2
                            const ColumnPtr& col_right_ptr) const {
406
2
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2
        DCHECK(!(left_is_const && right_is_const));
413
414
2
        if (!left_is_const && !right_is_const) {
415
2
            auto col_res = ColumnUInt8::create();
416
417
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
2
            vec_res.resize(col_left->get_data().size());
419
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
2
                              typename PrimitiveTypeTraits<PT>::CppType,
421
2
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
2
                                                     vec_res);
423
424
2
            block.replace_by_position(result, std::move(col_res));
425
2
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
2
        return Status::OK();
449
2
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.36k
                            const ColumnPtr& col_right_ptr) const {
406
1.36k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.36k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.36k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.36k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.36k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.36k
        if (!left_is_const && !right_is_const) {
415
40
            auto col_res = ColumnUInt8::create();
416
417
40
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
40
            vec_res.resize(col_left->get_data().size());
419
40
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
40
                              typename PrimitiveTypeTraits<PT>::CppType,
421
40
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
40
                                                     vec_res);
423
424
40
            block.replace_by_position(result, std::move(col_res));
425
1.32k
        } else if (!left_is_const && right_is_const) {
426
1.09k
            auto col_res = ColumnUInt8::create();
427
428
1.09k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1.09k
            vec_res.resize(col_left->size());
430
1.09k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1.09k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1.09k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1.09k
                                                       col_right->get_element(0), vec_res);
434
435
1.09k
            block.replace_by_position(result, std::move(col_res));
436
1.09k
        } else if (left_is_const && !right_is_const) {
437
228
            auto col_res = ColumnUInt8::create();
438
439
228
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
228
            vec_res.resize(col_right->size());
441
228
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
228
                              typename PrimitiveTypeTraits<PT>::CppType,
443
228
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
228
                                                       col_right->get_data(), vec_res);
445
446
228
            block.replace_by_position(result, std::move(col_res));
447
228
        }
448
1.36k
        return Status::OK();
449
1.36k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.78k
                            const ColumnPtr& col_right_ptr) const {
406
1.78k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.78k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.78k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.78k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.78k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.78k
        if (!left_is_const && !right_is_const) {
415
112
            auto col_res = ColumnUInt8::create();
416
417
112
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
112
            vec_res.resize(col_left->get_data().size());
419
112
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
112
                              typename PrimitiveTypeTraits<PT>::CppType,
421
112
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
112
                                                     vec_res);
423
424
112
            block.replace_by_position(result, std::move(col_res));
425
1.67k
        } else if (!left_is_const && right_is_const) {
426
1.45k
            auto col_res = ColumnUInt8::create();
427
428
1.45k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1.45k
            vec_res.resize(col_left->size());
430
1.45k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1.45k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1.45k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1.45k
                                                       col_right->get_element(0), vec_res);
434
435
1.45k
            block.replace_by_position(result, std::move(col_res));
436
1.45k
        } else if (left_is_const && !right_is_const) {
437
227
            auto col_res = ColumnUInt8::create();
438
439
227
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
227
            vec_res.resize(col_right->size());
441
227
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
227
                              typename PrimitiveTypeTraits<PT>::CppType,
443
227
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
227
                                                       col_right->get_data(), vec_res);
445
446
227
            block.replace_by_position(result, std::move(col_res));
447
227
        }
448
1.78k
        return Status::OK();
449
1.78k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
67.1k
                            const ColumnPtr& col_right_ptr) const {
406
67.1k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
67.1k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
67.1k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
67.1k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
67.1k
        DCHECK(!(left_is_const && right_is_const));
413
414
67.1k
        if (!left_is_const && !right_is_const) {
415
49
            auto col_res = ColumnUInt8::create();
416
417
49
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
49
            vec_res.resize(col_left->get_data().size());
419
49
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
49
                              typename PrimitiveTypeTraits<PT>::CppType,
421
49
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
49
                                                     vec_res);
423
424
49
            block.replace_by_position(result, std::move(col_res));
425
67.1k
        } else if (!left_is_const && right_is_const) {
426
4.59k
            auto col_res = ColumnUInt8::create();
427
428
4.59k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
4.59k
            vec_res.resize(col_left->size());
430
4.59k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
4.59k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
4.59k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
4.59k
                                                       col_right->get_element(0), vec_res);
434
435
4.59k
            block.replace_by_position(result, std::move(col_res));
436
62.5k
        } else if (left_is_const && !right_is_const) {
437
62.5k
            auto col_res = ColumnUInt8::create();
438
439
62.5k
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
62.5k
            vec_res.resize(col_right->size());
441
62.5k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
62.5k
                              typename PrimitiveTypeTraits<PT>::CppType,
443
62.5k
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
62.5k
                                                       col_right->get_data(), vec_res);
445
446
62.5k
            block.replace_by_position(result, std::move(col_res));
447
62.5k
        }
448
67.1k
        return Status::OK();
449
67.1k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.70k
                            const ColumnPtr& col_right_ptr) const {
406
1.70k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.70k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.70k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.70k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.70k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.70k
        if (!left_is_const && !right_is_const) {
415
65
            auto col_res = ColumnUInt8::create();
416
417
65
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
65
            vec_res.resize(col_left->get_data().size());
419
65
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
65
                              typename PrimitiveTypeTraits<PT>::CppType,
421
65
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
65
                                                     vec_res);
423
424
65
            block.replace_by_position(result, std::move(col_res));
425
1.63k
        } else if (!left_is_const && right_is_const) {
426
1.12k
            auto col_res = ColumnUInt8::create();
427
428
1.12k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1.12k
            vec_res.resize(col_left->size());
430
1.12k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1.12k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1.12k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1.12k
                                                       col_right->get_element(0), vec_res);
434
435
1.12k
            block.replace_by_position(result, std::move(col_res));
436
1.12k
        } else if (left_is_const && !right_is_const) {
437
518
            auto col_res = ColumnUInt8::create();
438
439
518
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
518
            vec_res.resize(col_right->size());
441
518
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
518
                              typename PrimitiveTypeTraits<PT>::CppType,
443
518
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
518
                                                       col_right->get_data(), vec_res);
445
446
518
            block.replace_by_position(result, std::move(col_res));
447
518
        }
448
1.70k
        return Status::OK();
449
1.70k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
223
                            const ColumnPtr& col_right_ptr) const {
406
223
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
223
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
223
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
223
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
223
        DCHECK(!(left_is_const && right_is_const));
413
414
223
        if (!left_is_const && !right_is_const) {
415
3
            auto col_res = ColumnUInt8::create();
416
417
3
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
3
            vec_res.resize(col_left->get_data().size());
419
3
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
3
                              typename PrimitiveTypeTraits<PT>::CppType,
421
3
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
3
                                                     vec_res);
423
424
3
            block.replace_by_position(result, std::move(col_res));
425
220
        } else if (!left_is_const && right_is_const) {
426
202
            auto col_res = ColumnUInt8::create();
427
428
202
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
202
            vec_res.resize(col_left->size());
430
202
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
202
                              typename PrimitiveTypeTraits<PT>::CppType,
432
202
                              Op<PT>>::vector_constant(col_left->get_data(),
433
202
                                                       col_right->get_element(0), vec_res);
434
435
202
            block.replace_by_position(result, std::move(col_res));
436
202
        } else if (left_is_const && !right_is_const) {
437
18
            auto col_res = ColumnUInt8::create();
438
439
18
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
18
            vec_res.resize(col_right->size());
441
18
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
18
                              typename PrimitiveTypeTraits<PT>::CppType,
443
18
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
18
                                                       col_right->get_data(), vec_res);
445
446
18
            block.replace_by_position(result, std::move(col_res));
447
18
        }
448
223
        return Status::OK();
449
223
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
4
                            const ColumnPtr& col_right_ptr) const {
406
4
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
4
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
4
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
4
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
4
        DCHECK(!(left_is_const && right_is_const));
413
414
4
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
3
        } else if (!left_is_const && right_is_const) {
426
3
            auto col_res = ColumnUInt8::create();
427
428
3
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
3
            vec_res.resize(col_left->size());
430
3
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
3
                              typename PrimitiveTypeTraits<PT>::CppType,
432
3
                              Op<PT>>::vector_constant(col_left->get_data(),
433
3
                                                       col_right->get_element(0), vec_res);
434
435
3
            block.replace_by_position(result, std::move(col_res));
436
3
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
4
        return Status::OK();
449
4
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1
                            const ColumnPtr& col_right_ptr) const {
406
1
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1
        DCHECK(!(left_is_const && right_is_const));
413
414
1
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
1
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
1
        return Status::OK();
449
1
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
220
                            const ColumnPtr& col_right_ptr) const {
406
220
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
220
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
220
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
220
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
220
        DCHECK(!(left_is_const && right_is_const));
413
414
220
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
200
        } else if (!left_is_const && right_is_const) {
426
200
            auto col_res = ColumnUInt8::create();
427
428
200
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
200
            vec_res.resize(col_left->size());
430
200
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
200
                              typename PrimitiveTypeTraits<PT>::CppType,
432
200
                              Op<PT>>::vector_constant(col_left->get_data(),
433
200
                                                       col_right->get_element(0), vec_res);
434
435
200
            block.replace_by_position(result, std::move(col_res));
436
200
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
220
        return Status::OK();
449
220
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
530
                            const ColumnPtr& col_right_ptr) const {
406
530
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
530
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
530
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
530
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
530
        DCHECK(!(left_is_const && right_is_const));
413
414
530
        if (!left_is_const && !right_is_const) {
415
26
            auto col_res = ColumnUInt8::create();
416
417
26
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
26
            vec_res.resize(col_left->get_data().size());
419
26
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
26
                              typename PrimitiveTypeTraits<PT>::CppType,
421
26
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
26
                                                     vec_res);
423
424
26
            block.replace_by_position(result, std::move(col_res));
425
504
        } else if (!left_is_const && right_is_const) {
426
504
            auto col_res = ColumnUInt8::create();
427
428
504
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
504
            vec_res.resize(col_left->size());
430
504
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
504
                              typename PrimitiveTypeTraits<PT>::CppType,
432
504
                              Op<PT>>::vector_constant(col_left->get_data(),
433
504
                                                       col_right->get_element(0), vec_res);
434
435
504
            block.replace_by_position(result, std::move(col_res));
436
504
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
530
        return Status::OK();
449
530
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
24
                            const ColumnPtr& col_right_ptr) const {
406
24
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
24
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
24
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
24
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
24
        DCHECK(!(left_is_const && right_is_const));
413
414
24
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
24
        } else if (!left_is_const && right_is_const) {
426
24
            auto col_res = ColumnUInt8::create();
427
428
24
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
24
            vec_res.resize(col_left->size());
430
24
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
24
                              typename PrimitiveTypeTraits<PT>::CppType,
432
24
                              Op<PT>>::vector_constant(col_left->get_data(),
433
24
                                                       col_right->get_element(0), vec_res);
434
435
24
            block.replace_by_position(result, std::move(col_res));
436
24
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
24
        return Status::OK();
449
24
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
512
                            const ColumnPtr& col_right_ptr) const {
406
512
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
512
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
512
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
512
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
512
        DCHECK(!(left_is_const && right_is_const));
413
414
512
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
511
        } else if (!left_is_const && right_is_const) {
426
505
            auto col_res = ColumnUInt8::create();
427
428
505
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
505
            vec_res.resize(col_left->size());
430
505
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
505
                              typename PrimitiveTypeTraits<PT>::CppType,
432
505
                              Op<PT>>::vector_constant(col_left->get_data(),
433
505
                                                       col_right->get_element(0), vec_res);
434
435
505
            block.replace_by_position(result, std::move(col_res));
436
505
        } else if (left_is_const && !right_is_const) {
437
6
            auto col_res = ColumnUInt8::create();
438
439
6
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
6
            vec_res.resize(col_right->size());
441
6
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
6
                              typename PrimitiveTypeTraits<PT>::CppType,
443
6
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
6
                                                       col_right->get_data(), vec_res);
445
446
6
            block.replace_by_position(result, std::move(col_res));
447
6
        }
448
512
        return Status::OK();
449
512
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
142
                            const ColumnPtr& col_right_ptr) const {
406
142
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
142
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
142
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
142
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
142
        DCHECK(!(left_is_const && right_is_const));
413
414
142
        if (!left_is_const && !right_is_const) {
415
6
            auto col_res = ColumnUInt8::create();
416
417
6
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
6
            vec_res.resize(col_left->get_data().size());
419
6
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
6
                              typename PrimitiveTypeTraits<PT>::CppType,
421
6
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
6
                                                     vec_res);
423
424
6
            block.replace_by_position(result, std::move(col_res));
425
136
        } else if (!left_is_const && right_is_const) {
426
136
            auto col_res = ColumnUInt8::create();
427
428
136
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
136
            vec_res.resize(col_left->size());
430
136
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
136
                              typename PrimitiveTypeTraits<PT>::CppType,
432
136
                              Op<PT>>::vector_constant(col_left->get_data(),
433
136
                                                       col_right->get_element(0), vec_res);
434
435
136
            block.replace_by_position(result, std::move(col_res));
436
136
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
142
        return Status::OK();
449
142
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2
                            const ColumnPtr& col_right_ptr) const {
406
2
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2
        DCHECK(!(left_is_const && right_is_const));
413
414
2
        if (!left_is_const && !right_is_const) {
415
2
            auto col_res = ColumnUInt8::create();
416
417
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
2
            vec_res.resize(col_left->get_data().size());
419
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
2
                              typename PrimitiveTypeTraits<PT>::CppType,
421
2
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
2
                                                     vec_res);
423
424
2
            block.replace_by_position(result, std::move(col_res));
425
2
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
2
        return Status::OK();
449
2
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
45
                            const ColumnPtr& col_right_ptr) const {
406
45
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
45
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
45
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
45
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
45
        DCHECK(!(left_is_const && right_is_const));
413
414
45
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
45
        } else if (!left_is_const && right_is_const) {
426
45
            auto col_res = ColumnUInt8::create();
427
428
45
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
45
            vec_res.resize(col_left->size());
430
45
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
45
                              typename PrimitiveTypeTraits<PT>::CppType,
432
45
                              Op<PT>>::vector_constant(col_left->get_data(),
433
45
                                                       col_right->get_element(0), vec_res);
434
435
45
            block.replace_by_position(result, std::move(col_res));
436
45
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
45
        return Status::OK();
449
45
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
60
                            const ColumnPtr& col_right_ptr) const {
406
60
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
60
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
60
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
60
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
60
        DCHECK(!(left_is_const && right_is_const));
413
414
60
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
60
        } else if (!left_is_const && right_is_const) {
426
60
            auto col_res = ColumnUInt8::create();
427
428
60
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
60
            vec_res.resize(col_left->size());
430
60
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
60
                              typename PrimitiveTypeTraits<PT>::CppType,
432
60
                              Op<PT>>::vector_constant(col_left->get_data(),
433
60
                                                       col_right->get_element(0), vec_res);
434
435
60
            block.replace_by_position(result, std::move(col_res));
436
60
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
60
        return Status::OK();
449
60
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
881
                            const ColumnPtr& col_right_ptr) const {
406
881
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
881
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
881
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
881
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
881
        DCHECK(!(left_is_const && right_is_const));
413
414
881
        if (!left_is_const && !right_is_const) {
415
5
            auto col_res = ColumnUInt8::create();
416
417
5
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
5
            vec_res.resize(col_left->get_data().size());
419
5
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
5
                              typename PrimitiveTypeTraits<PT>::CppType,
421
5
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
5
                                                     vec_res);
423
424
5
            block.replace_by_position(result, std::move(col_res));
425
876
        } else if (!left_is_const && right_is_const) {
426
876
            auto col_res = ColumnUInt8::create();
427
428
876
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
876
            vec_res.resize(col_left->size());
430
876
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
876
                              typename PrimitiveTypeTraits<PT>::CppType,
432
876
                              Op<PT>>::vector_constant(col_left->get_data(),
433
876
                                                       col_right->get_element(0), vec_res);
434
435
876
            block.replace_by_position(result, std::move(col_res));
436
876
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
881
        return Status::OK();
449
881
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
171
                            const ColumnPtr& col_right_ptr) const {
406
171
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
171
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
171
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
171
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
171
        DCHECK(!(left_is_const && right_is_const));
413
414
171
        if (!left_is_const && !right_is_const) {
415
9
            auto col_res = ColumnUInt8::create();
416
417
9
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
9
            vec_res.resize(col_left->get_data().size());
419
9
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
9
                              typename PrimitiveTypeTraits<PT>::CppType,
421
9
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
9
                                                     vec_res);
423
424
9
            block.replace_by_position(result, std::move(col_res));
425
162
        } else if (!left_is_const && right_is_const) {
426
162
            auto col_res = ColumnUInt8::create();
427
428
162
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
162
            vec_res.resize(col_left->size());
430
162
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
162
                              typename PrimitiveTypeTraits<PT>::CppType,
432
162
                              Op<PT>>::vector_constant(col_left->get_data(),
433
162
                                                       col_right->get_element(0), vec_res);
434
435
162
            block.replace_by_position(result, std::move(col_res));
436
162
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
171
        return Status::OK();
449
171
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
18
                            const ColumnPtr& col_right_ptr) const {
406
18
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
18
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
18
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
18
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
18
        DCHECK(!(left_is_const && right_is_const));
413
414
18
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
18
        } else if (!left_is_const && right_is_const) {
426
18
            auto col_res = ColumnUInt8::create();
427
428
18
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
18
            vec_res.resize(col_left->size());
430
18
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
18
                              typename PrimitiveTypeTraits<PT>::CppType,
432
18
                              Op<PT>>::vector_constant(col_left->get_data(),
433
18
                                                       col_right->get_element(0), vec_res);
434
435
18
            block.replace_by_position(result, std::move(col_res));
436
18
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
18
        return Status::OK();
449
18
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
11
                            const ColumnPtr& col_right_ptr) const {
406
11
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
11
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
11
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
11
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
11
        DCHECK(!(left_is_const && right_is_const));
413
414
11
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
10
        } else if (!left_is_const && right_is_const) {
426
10
            auto col_res = ColumnUInt8::create();
427
428
10
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
10
            vec_res.resize(col_left->size());
430
10
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
10
                              typename PrimitiveTypeTraits<PT>::CppType,
432
10
                              Op<PT>>::vector_constant(col_left->get_data(),
433
10
                                                       col_right->get_element(0), vec_res);
434
435
10
            block.replace_by_position(result, std::move(col_res));
436
10
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
11
        return Status::OK();
449
11
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1
                            const ColumnPtr& col_right_ptr) const {
406
1
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1
        DCHECK(!(left_is_const && right_is_const));
413
414
1
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
1
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
1
        return Status::OK();
449
1
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
24
                            const ColumnPtr& col_right_ptr) const {
406
24
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
24
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
24
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
24
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
24
        DCHECK(!(left_is_const && right_is_const));
413
414
24
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
20
        } else if (!left_is_const && right_is_const) {
426
4
            auto col_res = ColumnUInt8::create();
427
428
4
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
4
            vec_res.resize(col_left->size());
430
4
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
4
                              typename PrimitiveTypeTraits<PT>::CppType,
432
4
                              Op<PT>>::vector_constant(col_left->get_data(),
433
4
                                                       col_right->get_element(0), vec_res);
434
435
4
            block.replace_by_position(result, std::move(col_res));
436
4
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
24
        return Status::OK();
449
24
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
218
                            const ColumnPtr& col_right_ptr) const {
406
218
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
218
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
218
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
218
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
218
        DCHECK(!(left_is_const && right_is_const));
413
414
218
        if (!left_is_const && !right_is_const) {
415
23
            auto col_res = ColumnUInt8::create();
416
417
23
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
23
            vec_res.resize(col_left->get_data().size());
419
23
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
23
                              typename PrimitiveTypeTraits<PT>::CppType,
421
23
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
23
                                                     vec_res);
423
424
23
            block.replace_by_position(result, std::move(col_res));
425
195
        } else if (!left_is_const && right_is_const) {
426
195
            auto col_res = ColumnUInt8::create();
427
428
195
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
195
            vec_res.resize(col_left->size());
430
195
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
195
                              typename PrimitiveTypeTraits<PT>::CppType,
432
195
                              Op<PT>>::vector_constant(col_left->get_data(),
433
195
                                                       col_right->get_element(0), vec_res);
434
435
195
            block.replace_by_position(result, std::move(col_res));
436
195
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
218
        return Status::OK();
449
218
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
101
                            const ColumnPtr& col_right_ptr) const {
406
101
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
101
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
101
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
101
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
101
        DCHECK(!(left_is_const && right_is_const));
413
414
101
        if (!left_is_const && !right_is_const) {
415
101
            auto col_res = ColumnUInt8::create();
416
417
101
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
101
            vec_res.resize(col_left->get_data().size());
419
101
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
101
                              typename PrimitiveTypeTraits<PT>::CppType,
421
101
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
101
                                                     vec_res);
423
424
101
            block.replace_by_position(result, std::move(col_res));
425
101
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
101
        return Status::OK();
449
101
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2.19k
                            const ColumnPtr& col_right_ptr) const {
406
2.19k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2.19k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2.19k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2.19k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2.19k
        DCHECK(!(left_is_const && right_is_const));
413
414
2.19k
        if (!left_is_const && !right_is_const) {
415
1.80k
            auto col_res = ColumnUInt8::create();
416
417
1.80k
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1.80k
            vec_res.resize(col_left->get_data().size());
419
1.80k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1.80k
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1.80k
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1.80k
                                                     vec_res);
423
424
1.80k
            block.replace_by_position(result, std::move(col_res));
425
1.80k
        } else if (!left_is_const && right_is_const) {
426
391
            auto col_res = ColumnUInt8::create();
427
428
391
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
391
            vec_res.resize(col_left->size());
430
391
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
391
                              typename PrimitiveTypeTraits<PT>::CppType,
432
391
                              Op<PT>>::vector_constant(col_left->get_data(),
433
391
                                                       col_right->get_element(0), vec_res);
434
435
391
            block.replace_by_position(result, std::move(col_res));
436
391
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
2.19k
        return Status::OK();
449
2.19k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
317
                            const ColumnPtr& col_right_ptr) const {
406
317
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
317
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
317
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
317
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
317
        DCHECK(!(left_is_const && right_is_const));
413
414
317
        if (!left_is_const && !right_is_const) {
415
258
            auto col_res = ColumnUInt8::create();
416
417
258
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
258
            vec_res.resize(col_left->get_data().size());
419
258
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
258
                              typename PrimitiveTypeTraits<PT>::CppType,
421
258
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
258
                                                     vec_res);
423
424
258
            block.replace_by_position(result, std::move(col_res));
425
258
        } else if (!left_is_const && right_is_const) {
426
59
            auto col_res = ColumnUInt8::create();
427
428
59
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
59
            vec_res.resize(col_left->size());
430
59
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
59
                              typename PrimitiveTypeTraits<PT>::CppType,
432
59
                              Op<PT>>::vector_constant(col_left->get_data(),
433
59
                                                       col_right->get_element(0), vec_res);
434
435
59
            block.replace_by_position(result, std::move(col_res));
436
59
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
317
        return Status::OK();
449
317
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
3
                            const ColumnPtr& col_right_ptr) const {
406
3
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
3
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
3
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
3
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
3
        DCHECK(!(left_is_const && right_is_const));
413
414
3
        if (!left_is_const && !right_is_const) {
415
2
            auto col_res = ColumnUInt8::create();
416
417
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
2
            vec_res.resize(col_left->get_data().size());
419
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
2
                              typename PrimitiveTypeTraits<PT>::CppType,
421
2
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
2
                                                     vec_res);
423
424
2
            block.replace_by_position(result, std::move(col_res));
425
2
        } else if (!left_is_const && right_is_const) {
426
1
            auto col_res = ColumnUInt8::create();
427
428
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1
            vec_res.resize(col_left->size());
430
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1
                                                       col_right->get_element(0), vec_res);
434
435
1
            block.replace_by_position(result, std::move(col_res));
436
1
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
3
        return Status::OK();
449
3
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2.15k
                            const ColumnPtr& col_right_ptr) const {
406
2.15k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2.15k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2.15k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2.15k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2.15k
        DCHECK(!(left_is_const && right_is_const));
413
414
2.15k
        if (!left_is_const && !right_is_const) {
415
156
            auto col_res = ColumnUInt8::create();
416
417
156
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
156
            vec_res.resize(col_left->get_data().size());
419
156
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
156
                              typename PrimitiveTypeTraits<PT>::CppType,
421
156
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
156
                                                     vec_res);
423
424
156
            block.replace_by_position(result, std::move(col_res));
425
1.99k
        } else if (!left_is_const && right_is_const) {
426
1.75k
            auto col_res = ColumnUInt8::create();
427
428
1.75k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
1.75k
            vec_res.resize(col_left->size());
430
1.75k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
1.75k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
1.75k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
1.75k
                                                       col_right->get_element(0), vec_res);
434
435
1.75k
            block.replace_by_position(result, std::move(col_res));
436
1.75k
        } else if (left_is_const && !right_is_const) {
437
240
            auto col_res = ColumnUInt8::create();
438
439
240
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
240
            vec_res.resize(col_right->size());
441
240
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
240
                              typename PrimitiveTypeTraits<PT>::CppType,
443
240
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
240
                                                       col_right->get_data(), vec_res);
445
446
240
            block.replace_by_position(result, std::move(col_res));
447
240
        }
448
2.15k
        return Status::OK();
449
2.15k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
150
                            const ColumnPtr& col_right_ptr) const {
406
150
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
150
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
150
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
150
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
150
        DCHECK(!(left_is_const && right_is_const));
413
414
150
        if (!left_is_const && !right_is_const) {
415
136
            auto col_res = ColumnUInt8::create();
416
417
136
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
136
            vec_res.resize(col_left->get_data().size());
419
136
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
136
                              typename PrimitiveTypeTraits<PT>::CppType,
421
136
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
136
                                                     vec_res);
423
424
136
            block.replace_by_position(result, std::move(col_res));
425
136
        } else if (!left_is_const && right_is_const) {
426
14
            auto col_res = ColumnUInt8::create();
427
428
14
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
14
            vec_res.resize(col_left->size());
430
14
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
14
                              typename PrimitiveTypeTraits<PT>::CppType,
432
14
                              Op<PT>>::vector_constant(col_left->get_data(),
433
14
                                                       col_right->get_element(0), vec_res);
434
435
14
            block.replace_by_position(result, std::move(col_res));
436
14
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
150
        return Status::OK();
449
150
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
1.23k
                            const ColumnPtr& col_right_ptr) const {
406
1.23k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
1.23k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
1.23k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
1.23k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
1.23k
        DCHECK(!(left_is_const && right_is_const));
413
414
1.23k
        if (!left_is_const && !right_is_const) {
415
173
            auto col_res = ColumnUInt8::create();
416
417
173
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
173
            vec_res.resize(col_left->get_data().size());
419
173
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
173
                              typename PrimitiveTypeTraits<PT>::CppType,
421
173
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
173
                                                     vec_res);
423
424
173
            block.replace_by_position(result, std::move(col_res));
425
1.06k
        } else if (!left_is_const && right_is_const) {
426
869
            auto col_res = ColumnUInt8::create();
427
428
869
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
869
            vec_res.resize(col_left->size());
430
869
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
869
                              typename PrimitiveTypeTraits<PT>::CppType,
432
869
                              Op<PT>>::vector_constant(col_left->get_data(),
433
869
                                                       col_right->get_element(0), vec_res);
434
435
869
            block.replace_by_position(result, std::move(col_res));
436
869
        } else if (left_is_const && !right_is_const) {
437
193
            auto col_res = ColumnUInt8::create();
438
439
193
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
193
            vec_res.resize(col_right->size());
441
193
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
193
                              typename PrimitiveTypeTraits<PT>::CppType,
443
193
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
193
                                                       col_right->get_data(), vec_res);
445
446
193
            block.replace_by_position(result, std::move(col_res));
447
193
        }
448
1.23k
        return Status::OK();
449
1.23k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
815
                            const ColumnPtr& col_right_ptr) const {
406
815
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
815
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
815
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
815
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
815
        DCHECK(!(left_is_const && right_is_const));
413
414
815
        if (!left_is_const && !right_is_const) {
415
214
            auto col_res = ColumnUInt8::create();
416
417
214
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
214
            vec_res.resize(col_left->get_data().size());
419
214
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
214
                              typename PrimitiveTypeTraits<PT>::CppType,
421
214
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
214
                                                     vec_res);
423
424
214
            block.replace_by_position(result, std::move(col_res));
425
601
        } else if (!left_is_const && right_is_const) {
426
521
            auto col_res = ColumnUInt8::create();
427
428
521
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
521
            vec_res.resize(col_left->size());
430
521
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
521
                              typename PrimitiveTypeTraits<PT>::CppType,
432
521
                              Op<PT>>::vector_constant(col_left->get_data(),
433
521
                                                       col_right->get_element(0), vec_res);
434
435
521
            block.replace_by_position(result, std::move(col_res));
436
521
        } else if (left_is_const && !right_is_const) {
437
80
            auto col_res = ColumnUInt8::create();
438
439
80
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
80
            vec_res.resize(col_right->size());
441
80
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
80
                              typename PrimitiveTypeTraits<PT>::CppType,
443
80
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
80
                                                       col_right->get_data(), vec_res);
445
446
80
            block.replace_by_position(result, std::move(col_res));
447
80
        }
448
815
        return Status::OK();
449
815
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
252
                            const ColumnPtr& col_right_ptr) const {
406
252
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
252
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
252
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
252
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
252
        DCHECK(!(left_is_const && right_is_const));
413
414
252
        if (!left_is_const && !right_is_const) {
415
144
            auto col_res = ColumnUInt8::create();
416
417
144
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
144
            vec_res.resize(col_left->get_data().size());
419
144
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
144
                              typename PrimitiveTypeTraits<PT>::CppType,
421
144
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
144
                                                     vec_res);
423
424
144
            block.replace_by_position(result, std::move(col_res));
425
144
        } else if (!left_is_const && right_is_const) {
426
42
            auto col_res = ColumnUInt8::create();
427
428
42
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
42
            vec_res.resize(col_left->size());
430
42
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
42
                              typename PrimitiveTypeTraits<PT>::CppType,
432
42
                              Op<PT>>::vector_constant(col_left->get_data(),
433
42
                                                       col_right->get_element(0), vec_res);
434
435
42
            block.replace_by_position(result, std::move(col_res));
436
66
        } else if (left_is_const && !right_is_const) {
437
66
            auto col_res = ColumnUInt8::create();
438
439
66
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
66
            vec_res.resize(col_right->size());
441
66
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
66
                              typename PrimitiveTypeTraits<PT>::CppType,
443
66
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
66
                                                       col_right->get_data(), vec_res);
445
446
66
            block.replace_by_position(result, std::move(col_res));
447
66
        }
448
252
        return Status::OK();
449
252
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
18
                            const ColumnPtr& col_right_ptr) const {
406
18
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
18
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
18
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
18
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
18
        DCHECK(!(left_is_const && right_is_const));
413
414
18
        if (!left_is_const && !right_is_const) {
415
16
            auto col_res = ColumnUInt8::create();
416
417
16
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
16
            vec_res.resize(col_left->get_data().size());
419
16
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
16
                              typename PrimitiveTypeTraits<PT>::CppType,
421
16
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
16
                                                     vec_res);
423
424
16
            block.replace_by_position(result, std::move(col_res));
425
16
        } else if (!left_is_const && right_is_const) {
426
2
            auto col_res = ColumnUInt8::create();
427
428
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
2
            vec_res.resize(col_left->size());
430
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
2
                              typename PrimitiveTypeTraits<PT>::CppType,
432
2
                              Op<PT>>::vector_constant(col_left->get_data(),
433
2
                                                       col_right->get_element(0), vec_res);
434
435
2
            block.replace_by_position(result, std::move(col_res));
436
2
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
18
        return Status::OK();
449
18
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
16
                            const ColumnPtr& col_right_ptr) const {
406
16
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
16
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
16
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
16
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
16
        DCHECK(!(left_is_const && right_is_const));
413
414
16
        if (!left_is_const && !right_is_const) {
415
16
            auto col_res = ColumnUInt8::create();
416
417
16
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
16
            vec_res.resize(col_left->get_data().size());
419
16
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
16
                              typename PrimitiveTypeTraits<PT>::CppType,
421
16
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
16
                                                     vec_res);
423
424
16
            block.replace_by_position(result, std::move(col_res));
425
16
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
16
        return Status::OK();
449
16
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
154
                            const ColumnPtr& col_right_ptr) const {
406
154
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
154
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
154
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
154
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
154
        DCHECK(!(left_is_const && right_is_const));
413
414
154
        if (!left_is_const && !right_is_const) {
415
154
            auto col_res = ColumnUInt8::create();
416
417
154
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
154
            vec_res.resize(col_left->get_data().size());
419
154
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
154
                              typename PrimitiveTypeTraits<PT>::CppType,
421
154
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
154
                                                     vec_res);
423
424
154
            block.replace_by_position(result, std::move(col_res));
425
154
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
154
        return Status::OK();
449
154
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
379
                            const ColumnPtr& col_right_ptr) const {
406
379
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
379
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
379
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
379
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
379
        DCHECK(!(left_is_const && right_is_const));
413
414
379
        if (!left_is_const && !right_is_const) {
415
143
            auto col_res = ColumnUInt8::create();
416
417
143
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
143
            vec_res.resize(col_left->get_data().size());
419
143
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
143
                              typename PrimitiveTypeTraits<PT>::CppType,
421
143
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
143
                                                     vec_res);
423
424
143
            block.replace_by_position(result, std::move(col_res));
425
236
        } else if (!left_is_const && right_is_const) {
426
236
            auto col_res = ColumnUInt8::create();
427
428
236
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
236
            vec_res.resize(col_left->size());
430
236
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
236
                              typename PrimitiveTypeTraits<PT>::CppType,
432
236
                              Op<PT>>::vector_constant(col_left->get_data(),
433
236
                                                       col_right->get_element(0), vec_res);
434
435
236
            block.replace_by_position(result, std::move(col_res));
436
236
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
379
        return Status::OK();
449
379
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE2EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
18
                            const ColumnPtr& col_right_ptr) const {
406
18
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
18
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
18
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
18
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
18
        DCHECK(!(left_is_const && right_is_const));
413
414
18
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
18
        } else if (!left_is_const && right_is_const) {
426
18
            auto col_res = ColumnUInt8::create();
427
428
18
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
18
            vec_res.resize(col_left->size());
430
18
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
18
                              typename PrimitiveTypeTraits<PT>::CppType,
432
18
                              Op<PT>>::vector_constant(col_left->get_data(),
433
18
                                                       col_right->get_element(0), vec_res);
434
435
18
            block.replace_by_position(result, std::move(col_res));
436
18
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
18
        return Status::OK();
449
18
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE25EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
573
                            const ColumnPtr& col_right_ptr) const {
406
573
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
573
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
573
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
573
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
573
        DCHECK(!(left_is_const && right_is_const));
413
414
573
        if (!left_is_const && !right_is_const) {
415
418
            auto col_res = ColumnUInt8::create();
416
417
418
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
418
            vec_res.resize(col_left->get_data().size());
419
418
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
418
                              typename PrimitiveTypeTraits<PT>::CppType,
421
418
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
418
                                                     vec_res);
423
424
418
            block.replace_by_position(result, std::move(col_res));
425
418
        } else if (!left_is_const && right_is_const) {
426
150
            auto col_res = ColumnUInt8::create();
427
428
150
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
150
            vec_res.resize(col_left->size());
430
150
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
150
                              typename PrimitiveTypeTraits<PT>::CppType,
432
150
                              Op<PT>>::vector_constant(col_left->get_data(),
433
150
                                                       col_right->get_element(0), vec_res);
434
435
150
            block.replace_by_position(result, std::move(col_res));
436
150
        } else if (left_is_const && !right_is_const) {
437
5
            auto col_res = ColumnUInt8::create();
438
439
5
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
5
            vec_res.resize(col_right->size());
441
5
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
5
                              typename PrimitiveTypeTraits<PT>::CppType,
443
5
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
5
                                                       col_right->get_data(), vec_res);
445
446
5
            block.replace_by_position(result, std::move(col_res));
447
5
        }
448
573
        return Status::OK();
449
573
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE26EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
57
                            const ColumnPtr& col_right_ptr) const {
406
57
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
57
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
57
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
57
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
57
        DCHECK(!(left_is_const && right_is_const));
413
414
57
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
57
        } else if (!left_is_const && right_is_const) {
426
57
            auto col_res = ColumnUInt8::create();
427
428
57
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
57
            vec_res.resize(col_left->size());
430
57
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
57
                              typename PrimitiveTypeTraits<PT>::CppType,
432
57
                              Op<PT>>::vector_constant(col_left->get_data(),
433
57
                                                       col_right->get_element(0), vec_res);
434
435
57
            block.replace_by_position(result, std::move(col_res));
436
57
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
57
        return Status::OK();
449
57
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE42EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
2
                            const ColumnPtr& col_right_ptr) const {
406
2
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
2
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
2
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
2
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
2
        DCHECK(!(left_is_const && right_is_const));
413
414
2
        if (!left_is_const && !right_is_const) {
415
2
            auto col_res = ColumnUInt8::create();
416
417
2
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
2
            vec_res.resize(col_left->get_data().size());
419
2
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
2
                              typename PrimitiveTypeTraits<PT>::CppType,
421
2
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
2
                                                     vec_res);
423
424
2
            block.replace_by_position(result, std::move(col_res));
425
2
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
2
        return Status::OK();
449
2
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE3EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
48
                            const ColumnPtr& col_right_ptr) const {
406
48
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
48
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
48
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
48
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
48
        DCHECK(!(left_is_const && right_is_const));
413
414
48
        if (!left_is_const && !right_is_const) {
415
1
            auto col_res = ColumnUInt8::create();
416
417
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
1
            vec_res.resize(col_left->get_data().size());
419
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
1
                              typename PrimitiveTypeTraits<PT>::CppType,
421
1
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
1
                                                     vec_res);
423
424
1
            block.replace_by_position(result, std::move(col_res));
425
47
        } else if (!left_is_const && right_is_const) {
426
47
            auto col_res = ColumnUInt8::create();
427
428
47
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
47
            vec_res.resize(col_left->size());
430
47
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
47
                              typename PrimitiveTypeTraits<PT>::CppType,
432
47
                              Op<PT>>::vector_constant(col_left->get_data(),
433
47
                                                       col_right->get_element(0), vec_res);
434
435
47
            block.replace_by_position(result, std::move(col_res));
436
47
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
48
        return Status::OK();
449
48
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE4EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
64
                            const ColumnPtr& col_right_ptr) const {
406
64
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
64
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
64
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
64
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
64
        DCHECK(!(left_is_const && right_is_const));
413
414
65
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
65
        } else if (!left_is_const && right_is_const) {
426
65
            auto col_res = ColumnUInt8::create();
427
428
65
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
65
            vec_res.resize(col_left->size());
430
65
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
65
                              typename PrimitiveTypeTraits<PT>::CppType,
432
65
                              Op<PT>>::vector_constant(col_left->get_data(),
433
65
                                                       col_right->get_element(0), vec_res);
434
435
65
            block.replace_by_position(result, std::move(col_res));
436
18.4E
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
64
        return Status::OK();
449
64
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE5EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
6.35k
                            const ColumnPtr& col_right_ptr) const {
406
6.35k
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
6.35k
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
6.35k
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
6.35k
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
6.35k
        DCHECK(!(left_is_const && right_is_const));
413
414
6.35k
        if (!left_is_const && !right_is_const) {
415
10
            auto col_res = ColumnUInt8::create();
416
417
10
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
10
            vec_res.resize(col_left->get_data().size());
419
10
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
10
                              typename PrimitiveTypeTraits<PT>::CppType,
421
10
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
10
                                                     vec_res);
423
424
10
            block.replace_by_position(result, std::move(col_res));
425
6.34k
        } else if (!left_is_const && right_is_const) {
426
6.11k
            auto col_res = ColumnUInt8::create();
427
428
6.11k
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
6.11k
            vec_res.resize(col_left->size());
430
6.11k
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
6.11k
                              typename PrimitiveTypeTraits<PT>::CppType,
432
6.11k
                              Op<PT>>::vector_constant(col_left->get_data(),
433
6.11k
                                                       col_right->get_element(0), vec_res);
434
435
6.11k
            block.replace_by_position(result, std::move(col_res));
436
6.11k
        } else if (left_is_const && !right_is_const) {
437
231
            auto col_res = ColumnUInt8::create();
438
439
231
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
231
            vec_res.resize(col_right->size());
441
231
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
231
                              typename PrimitiveTypeTraits<PT>::CppType,
443
231
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
231
                                                       col_right->get_data(), vec_res);
445
446
231
            block.replace_by_position(result, std::move(col_res));
447
231
        }
448
6.35k
        return Status::OK();
449
6.35k
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE6EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
292
                            const ColumnPtr& col_right_ptr) const {
406
292
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
292
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
292
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
292
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
292
        DCHECK(!(left_is_const && right_is_const));
413
414
292
        if (!left_is_const && !right_is_const) {
415
31
            auto col_res = ColumnUInt8::create();
416
417
31
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
31
            vec_res.resize(col_left->get_data().size());
419
31
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
31
                              typename PrimitiveTypeTraits<PT>::CppType,
421
31
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
31
                                                     vec_res);
423
424
31
            block.replace_by_position(result, std::move(col_res));
425
261
        } else if (!left_is_const && right_is_const) {
426
213
            auto col_res = ColumnUInt8::create();
427
428
213
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
213
            vec_res.resize(col_left->size());
430
213
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
213
                              typename PrimitiveTypeTraits<PT>::CppType,
432
213
                              Op<PT>>::vector_constant(col_left->get_data(),
433
213
                                                       col_right->get_element(0), vec_res);
434
435
213
            block.replace_by_position(result, std::move(col_res));
436
213
        } else if (left_is_const && !right_is_const) {
437
48
            auto col_res = ColumnUInt8::create();
438
439
48
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
48
            vec_res.resize(col_right->size());
441
48
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
48
                              typename PrimitiveTypeTraits<PT>::CppType,
443
48
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
48
                                                       col_right->get_data(), vec_res);
445
446
48
            block.replace_by_position(result, std::move(col_res));
447
48
        }
448
292
        return Status::OK();
449
292
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE7EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
43
                            const ColumnPtr& col_right_ptr) const {
406
43
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
43
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
43
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
43
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
43
        DCHECK(!(left_is_const && right_is_const));
413
414
43
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
43
        } else if (!left_is_const && right_is_const) {
426
43
            auto col_res = ColumnUInt8::create();
427
428
43
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
43
            vec_res.resize(col_left->size());
430
43
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
43
                              typename PrimitiveTypeTraits<PT>::CppType,
432
43
                              Op<PT>>::vector_constant(col_left->get_data(),
433
43
                                                       col_right->get_element(0), vec_res);
434
435
43
            block.replace_by_position(result, std::move(col_res));
436
43
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
43
        return Status::OK();
449
43
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE36EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
10
                            const ColumnPtr& col_right_ptr) const {
406
10
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
10
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
10
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
10
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
10
        DCHECK(!(left_is_const && right_is_const));
413
414
10
        if (!left_is_const && !right_is_const) {
415
0
            auto col_res = ColumnUInt8::create();
416
417
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
0
            vec_res.resize(col_left->get_data().size());
419
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
0
                              typename PrimitiveTypeTraits<PT>::CppType,
421
0
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
0
                                                     vec_res);
423
424
0
            block.replace_by_position(result, std::move(col_res));
425
10
        } else if (!left_is_const && right_is_const) {
426
10
            auto col_res = ColumnUInt8::create();
427
428
10
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
10
            vec_res.resize(col_left->size());
430
10
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
10
                              typename PrimitiveTypeTraits<PT>::CppType,
432
10
                              Op<PT>>::vector_constant(col_left->get_data(),
433
10
                                                       col_right->get_element(0), vec_res);
434
435
10
            block.replace_by_position(result, std::move(col_res));
436
10
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
10
        return Status::OK();
449
10
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE37EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE8EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
20
                            const ColumnPtr& col_right_ptr) const {
406
20
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
20
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
20
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
20
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
20
        DCHECK(!(left_is_const && right_is_const));
413
414
20
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
20
        } else if (!left_is_const && right_is_const) {
426
0
            auto col_res = ColumnUInt8::create();
427
428
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
0
            vec_res.resize(col_left->size());
430
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
0
                              typename PrimitiveTypeTraits<PT>::CppType,
432
0
                              Op<PT>>::vector_constant(col_left->get_data(),
433
0
                                                       col_right->get_element(0), vec_res);
434
435
0
            block.replace_by_position(result, std::move(col_res));
436
0
        } else if (left_is_const && !right_is_const) {
437
0
            auto col_res = ColumnUInt8::create();
438
439
0
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
0
            vec_res.resize(col_right->size());
441
0
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
0
                              typename PrimitiveTypeTraits<PT>::CppType,
443
0
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
0
                                                       col_right->get_data(), vec_res);
445
446
0
            block.replace_by_position(result, std::move(col_res));
447
0
        }
448
20
        return Status::OK();
449
20
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE9EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
Line
Count
Source
405
149
                            const ColumnPtr& col_right_ptr) const {
406
149
        auto [col_left_untype, left_is_const] = unpack_if_const(col_left_ptr);
407
149
        auto [col_right_untyped, right_is_const] = unpack_if_const(col_right_ptr);
408
409
149
        const auto* col_left = assert_cast<const ColumnVector<PT>*>(col_left_untype.get());
410
149
        const auto* col_right = assert_cast<const ColumnVector<PT>*>(col_right_untyped.get());
411
412
149
        DCHECK(!(left_is_const && right_is_const));
413
414
149
        if (!left_is_const && !right_is_const) {
415
20
            auto col_res = ColumnUInt8::create();
416
417
20
            ColumnUInt8::Container& vec_res = col_res->get_data();
418
20
            vec_res.resize(col_left->get_data().size());
419
20
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
420
20
                              typename PrimitiveTypeTraits<PT>::CppType,
421
20
                              Op<PT>>::vector_vector(col_left->get_data(), col_right->get_data(),
422
20
                                                     vec_res);
423
424
20
            block.replace_by_position(result, std::move(col_res));
425
129
        } else if (!left_is_const && right_is_const) {
426
128
            auto col_res = ColumnUInt8::create();
427
428
128
            ColumnUInt8::Container& vec_res = col_res->get_data();
429
128
            vec_res.resize(col_left->size());
430
128
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
431
128
                              typename PrimitiveTypeTraits<PT>::CppType,
432
128
                              Op<PT>>::vector_constant(col_left->get_data(),
433
128
                                                       col_right->get_element(0), vec_res);
434
435
128
            block.replace_by_position(result, std::move(col_res));
436
128
        } else if (left_is_const && !right_is_const) {
437
1
            auto col_res = ColumnUInt8::create();
438
439
1
            ColumnUInt8::Container& vec_res = col_res->get_data();
440
1
            vec_res.resize(col_right->size());
441
1
            NumComparisonImpl<typename PrimitiveTypeTraits<PT>::CppType,
442
1
                              typename PrimitiveTypeTraits<PT>::CppType,
443
1
                              Op<PT>>::constant_vector(col_left->get_element(0),
444
1
                                                       col_right->get_data(), vec_res);
445
446
1
            block.replace_by_position(result, std::move(col_res));
447
1
        }
448
149
        return Status::OK();
449
149
    }
Unexecuted instantiation: _ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE16execute_num_typeILNS_13PrimitiveTypeE27EEENS_6StatusERNS_5BlockEjRKNS_3COWINS_7IColumnEE13immutable_ptrISA_EESF_
450
451
    Status execute_decimal(Block& block, uint32_t result, const ColumnWithTypeAndName& col_left,
452
3.32k
                           const ColumnWithTypeAndName& col_right) const {
453
3.32k
        auto call = [&](const auto& type) -> bool {
454
3.32k
            using DispatchType = std::decay_t<decltype(type)>;
455
3.32k
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
3.32k
                    block, result, col_left, col_right);
457
3.32k
            return true;
458
3.32k
        };
_ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
Line
Count
Source
453
165
        auto call = [&](const auto& type) -> bool {
454
165
            using DispatchType = std::decay_t<decltype(type)>;
455
165
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
165
                    block, result, col_left, col_right);
457
165
            return true;
458
165
        };
_ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
203
        auto call = [&](const auto& type) -> bool {
454
203
            using DispatchType = std::decay_t<decltype(type)>;
455
203
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
203
                    block, result, col_left, col_right);
457
203
            return true;
458
203
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
899
        auto call = [&](const auto& type) -> bool {
454
899
            using DispatchType = std::decay_t<decltype(type)>;
455
899
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
899
                    block, result, col_left, col_right);
457
899
            return true;
458
899
        };
_ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
30
        auto call = [&](const auto& type) -> bool {
454
30
            using DispatchType = std::decay_t<decltype(type)>;
455
30
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
30
                    block, result, col_left, col_right);
457
30
            return true;
458
30
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
67
        auto call = [&](const auto& type) -> bool {
454
67
            using DispatchType = std::decay_t<decltype(type)>;
455
67
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
67
                    block, result, col_left, col_right);
457
67
            return true;
458
67
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
28
        auto call = [&](const auto& type) -> bool {
454
28
            using DispatchType = std::decay_t<decltype(type)>;
455
28
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
28
                    block, result, col_left, col_right);
457
28
            return true;
458
28
        };
_ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
30
        auto call = [&](const auto& type) -> bool {
454
30
            using DispatchType = std::decay_t<decltype(type)>;
455
30
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
30
                    block, result, col_left, col_right);
457
30
            return true;
458
30
        };
_ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
Line
Count
Source
453
8
        auto call = [&](const auto& type) -> bool {
454
8
            using DispatchType = std::decay_t<decltype(type)>;
455
8
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
8
                    block, result, col_left, col_right);
457
8
            return true;
458
8
        };
_ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
66
        auto call = [&](const auto& type) -> bool {
454
66
            using DispatchType = std::decay_t<decltype(type)>;
455
66
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
66
                    block, result, col_left, col_right);
457
66
            return true;
458
66
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
729
        auto call = [&](const auto& type) -> bool {
454
729
            using DispatchType = std::decay_t<decltype(type)>;
455
729
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
729
                    block, result, col_left, col_right);
457
729
            return true;
458
729
        };
_ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
2
        auto call = [&](const auto& type) -> bool {
454
2
            using DispatchType = std::decay_t<decltype(type)>;
455
2
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
2
                    block, result, col_left, col_right);
457
2
            return true;
458
2
        };
_ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
Line
Count
Source
453
1
        auto call = [&](const auto& type) -> bool {
454
1
            using DispatchType = std::decay_t<decltype(type)>;
455
1
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
1
                    block, result, col_left, col_right);
457
1
            return true;
458
1
        };
_ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
73
        auto call = [&](const auto& type) -> bool {
454
73
            using DispatchType = std::decay_t<decltype(type)>;
455
73
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
73
                    block, result, col_left, col_right);
457
73
            return true;
458
73
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
80
        auto call = [&](const auto& type) -> bool {
454
80
            using DispatchType = std::decay_t<decltype(type)>;
455
80
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
80
                    block, result, col_left, col_right);
457
80
            return true;
458
80
        };
_ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
27
        auto call = [&](const auto& type) -> bool {
454
27
            using DispatchType = std::decay_t<decltype(type)>;
455
27
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
27
                    block, result, col_left, col_right);
457
27
            return true;
458
27
        };
_ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
Line
Count
Source
453
198
        auto call = [&](const auto& type) -> bool {
454
198
            using DispatchType = std::decay_t<decltype(type)>;
455
198
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
198
                    block, result, col_left, col_right);
457
198
            return true;
458
198
        };
_ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
233
        auto call = [&](const auto& type) -> bool {
454
233
            using DispatchType = std::decay_t<decltype(type)>;
455
233
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
233
                    block, result, col_left, col_right);
457
233
            return true;
458
233
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
312
        auto call = [&](const auto& type) -> bool {
454
312
            using DispatchType = std::decay_t<decltype(type)>;
455
312
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
312
                    block, result, col_left, col_right);
457
312
            return true;
458
312
        };
_ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
1
        auto call = [&](const auto& type) -> bool {
454
1
            using DispatchType = std::decay_t<decltype(type)>;
455
1
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
1
                    block, result, col_left, col_right);
457
1
            return true;
458
1
        };
_ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE28EEEEEbSB_
Line
Count
Source
453
5
        auto call = [&](const auto& type) -> bool {
454
5
            using DispatchType = std::decay_t<decltype(type)>;
455
5
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
5
                    block, result, col_left, col_right);
457
5
            return true;
458
5
        };
_ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE29EEEEEbSB_
Line
Count
Source
453
76
        auto call = [&](const auto& type) -> bool {
454
76
            using DispatchType = std::decay_t<decltype(type)>;
455
76
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
76
                    block, result, col_left, col_right);
457
76
            return true;
458
76
        };
Unexecuted instantiation: _ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE20EEEEEbSB_
_ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE30EEEEEbSB_
Line
Count
Source
453
66
        auto call = [&](const auto& type) -> bool {
454
66
            using DispatchType = std::decay_t<decltype(type)>;
455
66
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
66
                    block, result, col_left, col_right);
457
66
            return true;
458
66
        };
_ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_ENKUlRKT_E_clINS_16DispatchDataTypeILNS_13PrimitiveTypeE35EEEEEbSB_
Line
Count
Source
453
22
        auto call = [&](const auto& type) -> bool {
454
22
            using DispatchType = std::decay_t<decltype(type)>;
455
22
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
22
                    block, result, col_left, col_right);
457
22
            return true;
458
22
        };
459
460
3.32k
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
3.32k
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
3.32k
        return Status::OK();
471
3.32k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
1.29k
                           const ColumnWithTypeAndName& col_right) const {
453
1.29k
        auto call = [&](const auto& type) -> bool {
454
1.29k
            using DispatchType = std::decay_t<decltype(type)>;
455
1.29k
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
1.29k
                    block, result, col_left, col_right);
457
1.29k
            return true;
458
1.29k
        };
459
460
1.29k
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
1.29k
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
1.29k
        return Status::OK();
471
1.29k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
125
                           const ColumnWithTypeAndName& col_right) const {
453
125
        auto call = [&](const auto& type) -> bool {
454
125
            using DispatchType = std::decay_t<decltype(type)>;
455
125
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
125
                    block, result, col_left, col_right);
457
125
            return true;
458
125
        };
459
460
125
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
125
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
125
        return Status::OK();
471
125
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
806
                           const ColumnWithTypeAndName& col_right) const {
453
806
        auto call = [&](const auto& type) -> bool {
454
806
            using DispatchType = std::decay_t<decltype(type)>;
455
806
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
806
                    block, result, col_left, col_right);
457
806
            return true;
458
806
        };
459
460
806
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
806
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
806
        return Status::OK();
471
806
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
181
                           const ColumnWithTypeAndName& col_right) const {
453
181
        auto call = [&](const auto& type) -> bool {
454
181
            using DispatchType = std::decay_t<decltype(type)>;
455
181
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
181
                    block, result, col_left, col_right);
457
181
            return true;
458
181
        };
459
460
181
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
181
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
181
        return Status::OK();
471
181
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
744
                           const ColumnWithTypeAndName& col_right) const {
453
744
        auto call = [&](const auto& type) -> bool {
454
744
            using DispatchType = std::decay_t<decltype(type)>;
455
744
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
744
                    block, result, col_left, col_right);
457
744
            return true;
458
744
        };
459
460
744
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
744
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
744
        return Status::OK();
471
744
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_decimalERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
452
169
                           const ColumnWithTypeAndName& col_right) const {
453
169
        auto call = [&](const auto& type) -> bool {
454
169
            using DispatchType = std::decay_t<decltype(type)>;
455
169
            DecimalComparison<DispatchType::PType, DispatchType::PType, Op, false>(
456
169
                    block, result, col_left, col_right);
457
169
            return true;
458
169
        };
459
460
169
        if (col_left.type->get_primitive_type() != col_right.type->get_primitive_type()) {
461
0
            return Status::RuntimeError(
462
0
                    "type of left column {} is not equal to type of right column {}",
463
0
                    col_left.type->get_name(), col_right.type->get_name());
464
0
        }
465
466
169
        if (!dispatch_switch_decimal(col_right.type->get_primitive_type(), call)) {
467
0
            return Status::RuntimeError("Wrong call for {} with {} and {}", get_name(),
468
0
                                        col_left.type->get_name(), col_right.type->get_name());
469
0
        }
470
169
        return Status::OK();
471
169
    }
472
473
    Status execute_string(Block& block, uint32_t result, const IColumn* c0,
474
12.3k
                          const IColumn* c1) const {
475
12.3k
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
12.3k
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
12.3k
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
12.3k
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
12.3k
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
12.3k
        DCHECK(!(c0_const && c1_const));
484
12.3k
        const ColumnString::Chars* c0_const_chars = nullptr;
485
12.3k
        const ColumnString::Chars* c1_const_chars = nullptr;
486
12.3k
        ColumnString::Offset c0_const_size = 0;
487
12.3k
        ColumnString::Offset c1_const_size = 0;
488
489
12.3k
        if (c0_const) {
490
4
            const ColumnString* c0_const_string =
491
4
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
4
            if (c0_const_string) {
494
4
                c0_const_chars = &c0_const_string->get_chars();
495
4
                c0_const_size = c0_const_string->get_offsets()[0];
496
4
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
4
        }
501
502
12.3k
        if (c1_const) {
503
11.2k
            const ColumnString* c1_const_string =
504
11.2k
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
11.2k
            if (c1_const_string) {
507
11.2k
                c1_const_chars = &c1_const_string->get_chars();
508
11.2k
                c1_const_size = c1_const_string->get_offsets()[0];
509
18.4E
            } else {
510
18.4E
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
18.4E
                                            c1->get_name(), name);
512
18.4E
            }
513
11.2k
        }
514
515
12.3k
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
12.3k
        auto c_res = ColumnUInt8::create();
518
12.3k
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
12.3k
        vec_res.resize(c0->size());
520
521
12.3k
        if (c0_string && c1_string) {
522
1.08k
            StringImpl::string_vector_string_vector(
523
1.08k
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
1.08k
                    c1_string->get_offsets(), vec_res);
525
11.2k
        } else if (c0_string && c1_const) {
526
11.2k
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
11.2k
                                               *c1_const_chars, c1_const_size, vec_res);
528
11.2k
        } else if (c0_const && c1_string) {
529
4
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
4
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
4
                                               vec_res);
532
18.4E
        } else {
533
18.4E
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
18.4E
                                        c0->get_name(), c1->get_name(), name);
535
18.4E
        }
536
12.3k
        block.replace_by_position(result, std::move(c_res));
537
12.3k
        return Status::OK();
538
12.3k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
11.0k
                          const IColumn* c1) const {
475
11.0k
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
11.0k
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
11.0k
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
11.0k
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
11.0k
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
11.0k
        DCHECK(!(c0_const && c1_const));
484
11.0k
        const ColumnString::Chars* c0_const_chars = nullptr;
485
11.0k
        const ColumnString::Chars* c1_const_chars = nullptr;
486
11.0k
        ColumnString::Offset c0_const_size = 0;
487
11.0k
        ColumnString::Offset c1_const_size = 0;
488
489
11.0k
        if (c0_const) {
490
0
            const ColumnString* c0_const_string =
491
0
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
0
            if (c0_const_string) {
494
0
                c0_const_chars = &c0_const_string->get_chars();
495
0
                c0_const_size = c0_const_string->get_offsets()[0];
496
0
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
0
        }
501
502
11.0k
        if (c1_const) {
503
10.4k
            const ColumnString* c1_const_string =
504
10.4k
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
10.4k
            if (c1_const_string) {
507
10.4k
                c1_const_chars = &c1_const_string->get_chars();
508
10.4k
                c1_const_size = c1_const_string->get_offsets()[0];
509
18.4E
            } else {
510
18.4E
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
18.4E
                                            c1->get_name(), name);
512
18.4E
            }
513
10.4k
        }
514
515
11.0k
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
11.0k
        auto c_res = ColumnUInt8::create();
518
11.0k
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
11.0k
        vec_res.resize(c0->size());
520
521
11.0k
        if (c0_string && c1_string) {
522
553
            StringImpl::string_vector_string_vector(
523
553
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
553
                    c1_string->get_offsets(), vec_res);
525
10.4k
        } else if (c0_string && c1_const) {
526
10.4k
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
10.4k
                                               *c1_const_chars, c1_const_size, vec_res);
528
18.4E
        } else if (c0_const && c1_string) {
529
0
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
0
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
0
                                               vec_res);
532
18.4E
        } else {
533
18.4E
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
18.4E
                                        c0->get_name(), c1->get_name(), name);
535
18.4E
        }
536
11.0k
        block.replace_by_position(result, std::move(c_res));
537
11.0k
        return Status::OK();
538
11.0k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
100
                          const IColumn* c1) const {
475
100
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
100
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
100
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
100
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
100
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
100
        DCHECK(!(c0_const && c1_const));
484
100
        const ColumnString::Chars* c0_const_chars = nullptr;
485
100
        const ColumnString::Chars* c1_const_chars = nullptr;
486
100
        ColumnString::Offset c0_const_size = 0;
487
100
        ColumnString::Offset c1_const_size = 0;
488
489
100
        if (c0_const) {
490
0
            const ColumnString* c0_const_string =
491
0
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
0
            if (c0_const_string) {
494
0
                c0_const_chars = &c0_const_string->get_chars();
495
0
                c0_const_size = c0_const_string->get_offsets()[0];
496
0
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
0
        }
501
502
100
        if (c1_const) {
503
99
            const ColumnString* c1_const_string =
504
99
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
99
            if (c1_const_string) {
507
99
                c1_const_chars = &c1_const_string->get_chars();
508
99
                c1_const_size = c1_const_string->get_offsets()[0];
509
99
            } else {
510
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
0
                                            c1->get_name(), name);
512
0
            }
513
99
        }
514
515
100
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
100
        auto c_res = ColumnUInt8::create();
518
100
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
100
        vec_res.resize(c0->size());
520
521
100
        if (c0_string && c1_string) {
522
1
            StringImpl::string_vector_string_vector(
523
1
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
1
                    c1_string->get_offsets(), vec_res);
525
99
        } else if (c0_string && c1_const) {
526
99
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
99
                                               *c1_const_chars, c1_const_size, vec_res);
528
99
        } else if (c0_const && c1_string) {
529
0
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
0
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
0
                                               vec_res);
532
0
        } else {
533
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
0
                                        c0->get_name(), c1->get_name(), name);
535
0
        }
536
100
        block.replace_by_position(result, std::move(c_res));
537
100
        return Status::OK();
538
100
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
178
                          const IColumn* c1) const {
475
178
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
178
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
178
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
178
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
178
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
178
        DCHECK(!(c0_const && c1_const));
484
178
        const ColumnString::Chars* c0_const_chars = nullptr;
485
178
        const ColumnString::Chars* c1_const_chars = nullptr;
486
178
        ColumnString::Offset c0_const_size = 0;
487
178
        ColumnString::Offset c1_const_size = 0;
488
489
178
        if (c0_const) {
490
0
            const ColumnString* c0_const_string =
491
0
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
0
            if (c0_const_string) {
494
0
                c0_const_chars = &c0_const_string->get_chars();
495
0
                c0_const_size = c0_const_string->get_offsets()[0];
496
0
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
0
        }
501
502
178
        if (c1_const) {
503
176
            const ColumnString* c1_const_string =
504
176
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
176
            if (c1_const_string) {
507
176
                c1_const_chars = &c1_const_string->get_chars();
508
176
                c1_const_size = c1_const_string->get_offsets()[0];
509
176
            } else {
510
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
0
                                            c1->get_name(), name);
512
0
            }
513
176
        }
514
515
178
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
178
        auto c_res = ColumnUInt8::create();
518
178
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
178
        vec_res.resize(c0->size());
520
521
178
        if (c0_string && c1_string) {
522
2
            StringImpl::string_vector_string_vector(
523
2
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
2
                    c1_string->get_offsets(), vec_res);
525
176
        } else if (c0_string && c1_const) {
526
176
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
176
                                               *c1_const_chars, c1_const_size, vec_res);
528
176
        } else if (c0_const && c1_string) {
529
0
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
0
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
0
                                               vec_res);
532
0
        } else {
533
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
0
                                        c0->get_name(), c1->get_name(), name);
535
0
        }
536
178
        block.replace_by_position(result, std::move(c_res));
537
178
        return Status::OK();
538
178
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
256
                          const IColumn* c1) const {
475
256
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
256
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
256
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
256
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
256
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
256
        DCHECK(!(c0_const && c1_const));
484
256
        const ColumnString::Chars* c0_const_chars = nullptr;
485
256
        const ColumnString::Chars* c1_const_chars = nullptr;
486
256
        ColumnString::Offset c0_const_size = 0;
487
256
        ColumnString::Offset c1_const_size = 0;
488
489
256
        if (c0_const) {
490
0
            const ColumnString* c0_const_string =
491
0
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
0
            if (c0_const_string) {
494
0
                c0_const_chars = &c0_const_string->get_chars();
495
0
                c0_const_size = c0_const_string->get_offsets()[0];
496
0
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
0
        }
501
502
256
        if (c1_const) {
503
220
            const ColumnString* c1_const_string =
504
220
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
220
            if (c1_const_string) {
507
220
                c1_const_chars = &c1_const_string->get_chars();
508
220
                c1_const_size = c1_const_string->get_offsets()[0];
509
220
            } else {
510
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
0
                                            c1->get_name(), name);
512
0
            }
513
220
        }
514
515
256
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
256
        auto c_res = ColumnUInt8::create();
518
256
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
256
        vec_res.resize(c0->size());
520
521
256
        if (c0_string && c1_string) {
522
36
            StringImpl::string_vector_string_vector(
523
36
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
36
                    c1_string->get_offsets(), vec_res);
525
220
        } else if (c0_string && c1_const) {
526
220
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
220
                                               *c1_const_chars, c1_const_size, vec_res);
528
220
        } else if (c0_const && c1_string) {
529
0
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
0
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
0
                                               vec_res);
532
0
        } else {
533
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
0
                                        c0->get_name(), c1->get_name(), name);
535
0
        }
536
256
        block.replace_by_position(result, std::move(c_res));
537
256
        return Status::OK();
538
256
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
593
                          const IColumn* c1) const {
475
593
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
593
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
593
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
593
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
593
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
593
        DCHECK(!(c0_const && c1_const));
484
593
        const ColumnString::Chars* c0_const_chars = nullptr;
485
593
        const ColumnString::Chars* c1_const_chars = nullptr;
486
593
        ColumnString::Offset c0_const_size = 0;
487
593
        ColumnString::Offset c1_const_size = 0;
488
489
593
        if (c0_const) {
490
4
            const ColumnString* c0_const_string =
491
4
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
4
            if (c0_const_string) {
494
4
                c0_const_chars = &c0_const_string->get_chars();
495
4
                c0_const_size = c0_const_string->get_offsets()[0];
496
4
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
4
        }
501
502
593
        if (c1_const) {
503
96
            const ColumnString* c1_const_string =
504
96
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
96
            if (c1_const_string) {
507
96
                c1_const_chars = &c1_const_string->get_chars();
508
96
                c1_const_size = c1_const_string->get_offsets()[0];
509
96
            } else {
510
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
0
                                            c1->get_name(), name);
512
0
            }
513
96
        }
514
515
593
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
593
        auto c_res = ColumnUInt8::create();
518
593
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
593
        vec_res.resize(c0->size());
520
521
593
        if (c0_string && c1_string) {
522
493
            StringImpl::string_vector_string_vector(
523
493
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
493
                    c1_string->get_offsets(), vec_res);
525
493
        } else if (c0_string && c1_const) {
526
96
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
96
                                               *c1_const_chars, c1_const_size, vec_res);
528
96
        } else if (c0_const && c1_string) {
529
4
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
4
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
4
                                               vec_res);
532
4
        } else {
533
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
0
                                        c0->get_name(), c1->get_name(), name);
535
0
        }
536
593
        block.replace_by_position(result, std::move(c_res));
537
593
        return Status::OK();
538
593
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE14execute_stringERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
474
210
                          const IColumn* c1) const {
475
210
        const ColumnString* c0_string = check_and_get_column<ColumnString>(c0);
476
210
        const ColumnString* c1_string = check_and_get_column<ColumnString>(c1);
477
210
        const ColumnConst* c0_const = check_and_get_column_const_string_or_fixedstring(c0);
478
210
        const ColumnConst* c1_const = check_and_get_column_const_string_or_fixedstring(c1);
479
210
        if (!((c0_string || c0_const) && (c1_string || c1_const))) {
480
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
481
0
                                        c0->get_name(), c1->get_name(), name);
482
0
        }
483
210
        DCHECK(!(c0_const && c1_const));
484
210
        const ColumnString::Chars* c0_const_chars = nullptr;
485
210
        const ColumnString::Chars* c1_const_chars = nullptr;
486
210
        ColumnString::Offset c0_const_size = 0;
487
210
        ColumnString::Offset c1_const_size = 0;
488
489
210
        if (c0_const) {
490
0
            const ColumnString* c0_const_string =
491
0
                    check_and_get_column<ColumnString>(&c0_const->get_data_column());
492
493
0
            if (c0_const_string) {
494
0
                c0_const_chars = &c0_const_string->get_chars();
495
0
                c0_const_size = c0_const_string->get_offsets()[0];
496
0
            } else {
497
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
498
0
                                            c0->get_name(), name);
499
0
            }
500
0
        }
501
502
210
        if (c1_const) {
503
210
            const ColumnString* c1_const_string =
504
210
                    check_and_get_column<ColumnString>(&c1_const->get_data_column());
505
506
210
            if (c1_const_string) {
507
210
                c1_const_chars = &c1_const_string->get_chars();
508
210
                c1_const_size = c1_const_string->get_offsets()[0];
509
210
            } else {
510
0
                return Status::NotSupported("Illegal columns {}, of argument of function {}",
511
0
                                            c1->get_name(), name);
512
0
            }
513
210
        }
514
515
210
        using StringImpl = StringComparisonImpl<Op<TYPE_INT>>;
516
517
210
        auto c_res = ColumnUInt8::create();
518
210
        ColumnUInt8::Container& vec_res = c_res->get_data();
519
210
        vec_res.resize(c0->size());
520
521
210
        if (c0_string && c1_string) {
522
0
            StringImpl::string_vector_string_vector(
523
0
                    c0_string->get_chars(), c0_string->get_offsets(), c1_string->get_chars(),
524
0
                    c1_string->get_offsets(), vec_res);
525
210
        } else if (c0_string && c1_const) {
526
210
            StringImpl::string_vector_constant(c0_string->get_chars(), c0_string->get_offsets(),
527
210
                                               *c1_const_chars, c1_const_size, vec_res);
528
210
        } else if (c0_const && c1_string) {
529
0
            StringImpl::constant_string_vector(*c0_const_chars, c0_const_size,
530
0
                                               c1_string->get_chars(), c1_string->get_offsets(),
531
0
                                               vec_res);
532
0
        } else {
533
0
            return Status::NotSupported("Illegal columns {}, {} of argument of function {}",
534
0
                                        c0->get_name(), c1->get_name(), name);
535
0
        }
536
210
        block.replace_by_position(result, std::move(c_res));
537
210
        return Status::OK();
538
210
    }
539
540
    void execute_generic_identical_types(Block& block, uint32_t result, const IColumn* c0,
541
151
                                         const IColumn* c1) const {
542
151
        bool c0_const = is_column_const(*c0);
543
151
        bool c1_const = is_column_const(*c1);
544
545
151
        DCHECK(!(c0_const && c1_const));
546
547
151
        auto c_res = ColumnUInt8::create();
548
151
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
151
        vec_res.resize(c0->size());
550
551
151
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
151
        } else if (c1_const) {
554
142
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
142
        } else {
556
9
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
9
        }
558
559
151
        block.replace_by_position(result, std::move(c_res));
560
151
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
17
                                         const IColumn* c1) const {
542
17
        bool c0_const = is_column_const(*c0);
543
17
        bool c1_const = is_column_const(*c1);
544
545
17
        DCHECK(!(c0_const && c1_const));
546
547
17
        auto c_res = ColumnUInt8::create();
548
17
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
17
        vec_res.resize(c0->size());
550
551
17
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
17
        } else if (c1_const) {
554
13
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
13
        } else {
556
4
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
4
        }
558
559
17
        block.replace_by_position(result, std::move(c_res));
560
17
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
8
                                         const IColumn* c1) const {
542
8
        bool c0_const = is_column_const(*c0);
543
8
        bool c1_const = is_column_const(*c1);
544
545
8
        DCHECK(!(c0_const && c1_const));
546
547
8
        auto c_res = ColumnUInt8::create();
548
8
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
8
        vec_res.resize(c0->size());
550
551
8
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
8
        } else if (c1_const) {
554
8
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
8
        } else {
556
0
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
0
        }
558
559
8
        block.replace_by_position(result, std::move(c_res));
560
8
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
9
                                         const IColumn* c1) const {
542
9
        bool c0_const = is_column_const(*c0);
543
9
        bool c1_const = is_column_const(*c1);
544
545
9
        DCHECK(!(c0_const && c1_const));
546
547
9
        auto c_res = ColumnUInt8::create();
548
9
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
9
        vec_res.resize(c0->size());
550
551
9
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
9
        } else if (c1_const) {
554
8
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
8
        } else {
556
1
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
1
        }
558
559
9
        block.replace_by_position(result, std::move(c_res));
560
9
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
60
                                         const IColumn* c1) const {
542
60
        bool c0_const = is_column_const(*c0);
543
60
        bool c1_const = is_column_const(*c1);
544
545
60
        DCHECK(!(c0_const && c1_const));
546
547
60
        auto c_res = ColumnUInt8::create();
548
60
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
60
        vec_res.resize(c0->size());
550
551
60
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
60
        } else if (c1_const) {
554
59
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
59
        } else {
556
1
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
1
        }
558
559
60
        block.replace_by_position(result, std::move(c_res));
560
60
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
11
                                         const IColumn* c1) const {
542
11
        bool c0_const = is_column_const(*c0);
543
11
        bool c1_const = is_column_const(*c1);
544
545
11
        DCHECK(!(c0_const && c1_const));
546
547
11
        auto c_res = ColumnUInt8::create();
548
11
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
11
        vec_res.resize(c0->size());
550
551
11
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
11
        } else if (c1_const) {
554
8
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
8
        } else {
556
3
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
3
        }
558
559
11
        block.replace_by_position(result, std::move(c_res));
560
11
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE31execute_generic_identical_typesERNS_5BlockEjPKNS_7IColumnES8_
Line
Count
Source
541
46
                                         const IColumn* c1) const {
542
46
        bool c0_const = is_column_const(*c0);
543
46
        bool c1_const = is_column_const(*c1);
544
545
46
        DCHECK(!(c0_const && c1_const));
546
547
46
        auto c_res = ColumnUInt8::create();
548
46
        ColumnUInt8::Container& vec_res = c_res->get_data();
549
46
        vec_res.resize(c0->size());
550
551
46
        if (c0_const) {
552
0
            GenericComparisonImpl<Op<TYPE_INT>>::constant_vector(*c0, *c1, vec_res);
553
46
        } else if (c1_const) {
554
46
            GenericComparisonImpl<Op<TYPE_INT>>::vector_constant(*c0, *c1, vec_res);
555
46
        } else {
556
0
            GenericComparisonImpl<Op<TYPE_INT>>::vector_vector(*c0, *c1, vec_res);
557
0
        }
558
559
46
        block.replace_by_position(result, std::move(c_res));
560
46
    }
561
562
    Status execute_generic(Block& block, uint32_t result, const ColumnWithTypeAndName& c0,
563
151
                           const ColumnWithTypeAndName& c1) const {
564
151
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
151
        return Status::OK();
566
151
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
17
                           const ColumnWithTypeAndName& c1) const {
564
17
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
17
        return Status::OK();
566
17
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
8
                           const ColumnWithTypeAndName& c1) const {
564
8
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
8
        return Status::OK();
566
8
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
9
                           const ColumnWithTypeAndName& c1) const {
564
9
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
9
        return Status::OK();
566
9
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
60
                           const ColumnWithTypeAndName& c1) const {
564
60
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
60
        return Status::OK();
566
60
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
11
                           const ColumnWithTypeAndName& c1) const {
564
11
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
11
        return Status::OK();
566
11
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE15execute_genericERNS_5BlockEjRKNS_21ColumnWithTypeAndNameES8_
Line
Count
Source
563
46
                           const ColumnWithTypeAndName& c1) const {
564
46
        execute_generic_identical_types(block, result, c0.column.get(), c1.column.get());
565
46
        return Status::OK();
566
46
    }
567
568
public:
569
221
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE8get_nameB5cxx11Ev
Line
Count
Source
569
63
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE8get_nameB5cxx11Ev
Line
Count
Source
569
37
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE8get_nameB5cxx11Ev
Line
Count
Source
569
38
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE8get_nameB5cxx11Ev
Line
Count
Source
569
81
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE8get_nameB5cxx11Ev
Line
Count
Source
569
1
    String get_name() const override { return name; }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE8get_nameB5cxx11Ev
Line
Count
Source
569
1
    String get_name() const override { return name; }
570
571
267k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE23get_number_of_argumentsEv
Line
Count
Source
571
242k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE23get_number_of_argumentsEv
Line
Count
Source
571
1.17k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE23get_number_of_argumentsEv
Line
Count
Source
571
4.93k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE23get_number_of_argumentsEv
Line
Count
Source
571
6.84k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE23get_number_of_argumentsEv
Line
Count
Source
571
3.01k
    size_t get_number_of_arguments() const override { return 2; }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE23get_number_of_argumentsEv
Line
Count
Source
571
9.46k
    size_t get_number_of_arguments() const override { return 2; }
572
573
    ZoneMapFilterResult evaluate_zonemap_filter(const ZoneMapEvalContext& ctx,
574
2.59k
                                                const VExprSPtrs& arguments) const override {
575
2.59k
        auto op = comparison_zonemap_detail::op_from_name(name);
576
2.59k
        DORIS_CHECK(op.has_value());
577
2.59k
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
2.59k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
1.56k
                                                const VExprSPtrs& arguments) const override {
575
1.56k
        auto op = comparison_zonemap_detail::op_from_name(name);
576
1.56k
        DORIS_CHECK(op.has_value());
577
1.56k
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
1.56k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
141
                                                const VExprSPtrs& arguments) const override {
575
141
        auto op = comparison_zonemap_detail::op_from_name(name);
576
141
        DORIS_CHECK(op.has_value());
577
141
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
141
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
193
                                                const VExprSPtrs& arguments) const override {
575
193
        auto op = comparison_zonemap_detail::op_from_name(name);
576
193
        DORIS_CHECK(op.has_value());
577
193
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
193
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
225
                                                const VExprSPtrs& arguments) const override {
575
225
        auto op = comparison_zonemap_detail::op_from_name(name);
576
225
        DORIS_CHECK(op.has_value());
577
225
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
225
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
265
                                                const VExprSPtrs& arguments) const override {
575
265
        auto op = comparison_zonemap_detail::op_from_name(name);
576
265
        DORIS_CHECK(op.has_value());
577
265
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
265
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE23evaluate_zonemap_filterERKNS_18ZoneMapEvalContextERKSt6vectorISt10shared_ptrINS_5VExprEESaISA_EE
Line
Count
Source
574
210
                                                const VExprSPtrs& arguments) const override {
575
210
        auto op = comparison_zonemap_detail::op_from_name(name);
576
210
        DORIS_CHECK(op.has_value());
577
210
        return comparison_zonemap_detail::evaluate(ctx, arguments, *op);
578
210
    }
579
580
29.8k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
29.8k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
29.8k
               comparison_zonemap_detail::can_evaluate(arguments);
583
29.8k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
13.9k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
13.9k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
13.9k
               comparison_zonemap_detail::can_evaluate(arguments);
583
13.9k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
1.29k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
1.29k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
1.29k
               comparison_zonemap_detail::can_evaluate(arguments);
583
1.29k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
4.54k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
4.54k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
4.57k
               comparison_zonemap_detail::can_evaluate(arguments);
583
4.54k
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
4.45k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
4.45k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
4.45k
               comparison_zonemap_detail::can_evaluate(arguments);
583
4.45k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
3.37k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
3.37k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
3.38k
               comparison_zonemap_detail::can_evaluate(arguments);
583
3.37k
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE27can_evaluate_zonemap_filterERKSt6vectorISt10shared_ptrINS_5VExprEESaIS7_EE
Line
Count
Source
580
2.26k
    bool can_evaluate_zonemap_filter(const VExprSPtrs& arguments) const override {
581
2.26k
        return comparison_zonemap_detail::op_from_name(name).has_value() &&
582
2.26k
               comparison_zonemap_detail::can_evaluate(arguments);
583
2.26k
    }
584
585
    /// Get result types by argument types. If the function does not apply to these arguments, throw an exception.
586
267k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
267k
        return std::make_shared<DataTypeUInt8>();
588
267k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
241k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
241k
        return std::make_shared<DataTypeUInt8>();
588
241k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
1.17k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
1.17k
        return std::make_shared<DataTypeUInt8>();
588
1.17k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
4.93k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
4.93k
        return std::make_shared<DataTypeUInt8>();
588
4.93k
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
6.84k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
6.84k
        return std::make_shared<DataTypeUInt8>();
588
6.84k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
3.01k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
3.01k
        return std::make_shared<DataTypeUInt8>();
588
3.01k
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS8_EE
Line
Count
Source
586
9.47k
    DataTypePtr get_return_type_impl(const DataTypes& arguments) const override {
587
9.47k
        return std::make_shared<DataTypeUInt8>();
588
9.47k
    }
589
590
    Status evaluate_inverted_index(
591
            const ColumnsWithTypeAndName& arguments,
592
            const std::vector<IndexFieldNameAndTypePair>& data_type_with_names,
593
            std::vector<segment_v2::IndexIterator*> iterators, uint32_t num_rows,
594
            const InvertedIndexAnalyzerCtx* analyzer_ctx,
595
1.34k
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
1.34k
        DCHECK(arguments.size() == 1);
597
1.34k
        DCHECK(data_type_with_names.size() == 1);
598
1.34k
        DCHECK(iterators.size() == 1);
599
1.34k
        auto* iter = iterators[0];
600
1.34k
        auto data_type_with_name = data_type_with_names[0];
601
1.34k
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
1.34k
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
308
            return Status::OK();
606
308
        }
607
1.03k
        segment_v2::InvertedIndexQueryType query_type;
608
1.03k
        std::string_view name_view(name);
609
1.03k
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
715
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
715
        } else if (name_view == NameLess::name) {
612
77
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
246
        } else if (name_view == NameLessOrEquals::name) {
614
81
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
165
        } else if (name_view == NameGreater::name) {
616
73
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
93
        } else if (name_view == NameGreaterOrEquals::name) {
618
93
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
18.4E
        } else {
620
18.4E
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
18.4E
        }
622
623
1.03k
        if (segment_v2::is_range_query(query_type) &&
624
1.03k
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
133
            return Status::OK();
627
133
        }
628
906
        Field param_value;
629
906
        arguments[0].column->get(0, param_value);
630
906
        if (param_value.is_null()) {
631
2
            return Status::OK();
632
2
        }
633
904
        segment_v2::InvertedIndexParam param;
634
904
        param.column_name = data_type_with_name.first;
635
904
        param.column_type = data_type_with_name.second;
636
904
        param.query_value = param_value;
637
904
        param.query_type = query_type;
638
904
        param.num_rows = num_rows;
639
904
        param.roaring = std::make_shared<roaring::Roaring>();
640
904
        param.analyzer_ctx = analyzer_ctx;
641
904
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
751
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
751
        if (iter->has_null()) {
644
751
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
751
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
751
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
751
        }
648
751
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
751
        bitmap_result = result;
650
751
        bitmap_result.mask_out_null();
651
652
751
        if (name_view == NameNotEquals::name) {
653
58
            roaring::Roaring full_result;
654
58
            full_result.addRange(0, num_rows);
655
58
            bitmap_result.op_not(&full_result);
656
58
        }
657
658
751
        return Status::OK();
659
751
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
689
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
689
        DCHECK(arguments.size() == 1);
597
689
        DCHECK(data_type_with_names.size() == 1);
598
689
        DCHECK(iterators.size() == 1);
599
689
        auto* iter = iterators[0];
600
689
        auto data_type_with_name = data_type_with_names[0];
601
689
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
689
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
42
            return Status::OK();
606
42
        }
607
647
        segment_v2::InvertedIndexQueryType query_type;
608
647
        std::string_view name_view(name);
609
649
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
649
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
18.4E
        } else if (name_view == NameLess::name) {
612
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
18.4E
        } else if (name_view == NameLessOrEquals::name) {
614
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
18.4E
        } else if (name_view == NameGreater::name) {
616
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
18.4E
        } else if (name_view == NameGreaterOrEquals::name) {
618
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
18.4E
        } else {
620
18.4E
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
18.4E
        }
622
623
649
        if (segment_v2::is_range_query(query_type) &&
624
649
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
0
            return Status::OK();
627
0
        }
628
649
        Field param_value;
629
649
        arguments[0].column->get(0, param_value);
630
649
        if (param_value.is_null()) {
631
2
            return Status::OK();
632
2
        }
633
647
        segment_v2::InvertedIndexParam param;
634
647
        param.column_name = data_type_with_name.first;
635
647
        param.column_type = data_type_with_name.second;
636
647
        param.query_value = param_value;
637
647
        param.query_type = query_type;
638
647
        param.num_rows = num_rows;
639
647
        param.roaring = std::make_shared<roaring::Roaring>();
640
647
        param.analyzer_ctx = analyzer_ctx;
641
647
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
602
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
602
        if (iter->has_null()) {
644
602
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
602
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
602
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
602
        }
648
602
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
602
        bitmap_result = result;
650
602
        bitmap_result.mask_out_null();
651
652
602
        if (name_view == NameNotEquals::name) {
653
0
            roaring::Roaring full_result;
654
0
            full_result.addRange(0, num_rows);
655
0
            bitmap_result.op_not(&full_result);
656
0
        }
657
658
602
        return Status::OK();
659
602
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
72
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
72
        DCHECK(arguments.size() == 1);
597
72
        DCHECK(data_type_with_names.size() == 1);
598
72
        DCHECK(iterators.size() == 1);
599
72
        auto* iter = iterators[0];
600
72
        auto data_type_with_name = data_type_with_names[0];
601
72
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
72
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
6
            return Status::OK();
606
6
        }
607
66
        segment_v2::InvertedIndexQueryType query_type;
608
66
        std::string_view name_view(name);
609
66
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
66
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
66
        } else if (name_view == NameLess::name) {
612
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
0
        } else if (name_view == NameLessOrEquals::name) {
614
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
0
        } else if (name_view == NameGreater::name) {
616
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
0
        } else if (name_view == NameGreaterOrEquals::name) {
618
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
0
        } else {
620
0
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
0
        }
622
623
66
        if (segment_v2::is_range_query(query_type) &&
624
66
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
0
            return Status::OK();
627
0
        }
628
66
        Field param_value;
629
66
        arguments[0].column->get(0, param_value);
630
66
        if (param_value.is_null()) {
631
0
            return Status::OK();
632
0
        }
633
66
        segment_v2::InvertedIndexParam param;
634
66
        param.column_name = data_type_with_name.first;
635
66
        param.column_type = data_type_with_name.second;
636
66
        param.query_value = param_value;
637
66
        param.query_type = query_type;
638
66
        param.num_rows = num_rows;
639
66
        param.roaring = std::make_shared<roaring::Roaring>();
640
66
        param.analyzer_ctx = analyzer_ctx;
641
66
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
59
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
59
        if (iter->has_null()) {
644
58
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
58
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
58
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
58
        }
648
59
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
59
        bitmap_result = result;
650
59
        bitmap_result.mask_out_null();
651
652
59
        if (name_view == NameNotEquals::name) {
653
58
            roaring::Roaring full_result;
654
58
            full_result.addRange(0, num_rows);
655
58
            bitmap_result.op_not(&full_result);
656
58
        }
657
658
59
        return Status::OK();
659
59
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
112
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
112
        DCHECK(arguments.size() == 1);
597
112
        DCHECK(data_type_with_names.size() == 1);
598
112
        DCHECK(iterators.size() == 1);
599
112
        auto* iter = iterators[0];
600
112
        auto data_type_with_name = data_type_with_names[0];
601
112
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
112
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
39
            return Status::OK();
606
39
        }
607
73
        segment_v2::InvertedIndexQueryType query_type;
608
73
        std::string_view name_view(name);
609
73
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
0
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
73
        } else if (name_view == NameLess::name) {
612
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
73
        } else if (name_view == NameLessOrEquals::name) {
614
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
73
        } else if (name_view == NameGreater::name) {
616
73
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
73
        } else if (name_view == NameGreaterOrEquals::name) {
618
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
0
        } else {
620
0
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
0
        }
622
623
73
        if (segment_v2::is_range_query(query_type) &&
624
73
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
17
            return Status::OK();
627
17
        }
628
56
        Field param_value;
629
56
        arguments[0].column->get(0, param_value);
630
56
        if (param_value.is_null()) {
631
0
            return Status::OK();
632
0
        }
633
56
        segment_v2::InvertedIndexParam param;
634
56
        param.column_name = data_type_with_name.first;
635
56
        param.column_type = data_type_with_name.second;
636
56
        param.query_value = param_value;
637
56
        param.query_type = query_type;
638
56
        param.num_rows = num_rows;
639
56
        param.roaring = std::make_shared<roaring::Roaring>();
640
56
        param.analyzer_ctx = analyzer_ctx;
641
56
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
37
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
37
        if (iter->has_null()) {
644
37
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
37
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
37
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
37
        }
648
37
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
37
        bitmap_result = result;
650
37
        bitmap_result.mask_out_null();
651
652
37
        if (name_view == NameNotEquals::name) {
653
0
            roaring::Roaring full_result;
654
0
            full_result.addRange(0, num_rows);
655
0
            bitmap_result.op_not(&full_result);
656
0
        }
657
658
37
        return Status::OK();
659
37
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
179
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
179
        DCHECK(arguments.size() == 1);
597
179
        DCHECK(data_type_with_names.size() == 1);
598
179
        DCHECK(iterators.size() == 1);
599
179
        auto* iter = iterators[0];
600
179
        auto data_type_with_name = data_type_with_names[0];
601
179
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
179
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
85
            return Status::OK();
606
85
        }
607
94
        segment_v2::InvertedIndexQueryType query_type;
608
94
        std::string_view name_view(name);
609
94
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
0
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
94
        } else if (name_view == NameLess::name) {
612
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
94
        } else if (name_view == NameLessOrEquals::name) {
614
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
94
        } else if (name_view == NameGreater::name) {
616
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
94
        } else if (name_view == NameGreaterOrEquals::name) {
618
93
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
93
        } else {
620
1
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
1
        }
622
623
93
        if (segment_v2::is_range_query(query_type) &&
624
93
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
47
            return Status::OK();
627
47
        }
628
46
        Field param_value;
629
46
        arguments[0].column->get(0, param_value);
630
46
        if (param_value.is_null()) {
631
0
            return Status::OK();
632
0
        }
633
46
        segment_v2::InvertedIndexParam param;
634
46
        param.column_name = data_type_with_name.first;
635
46
        param.column_type = data_type_with_name.second;
636
46
        param.query_value = param_value;
637
46
        param.query_type = query_type;
638
46
        param.num_rows = num_rows;
639
46
        param.roaring = std::make_shared<roaring::Roaring>();
640
46
        param.analyzer_ctx = analyzer_ctx;
641
46
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
5
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
5
        if (iter->has_null()) {
644
5
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
5
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
5
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
5
        }
648
5
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
5
        bitmap_result = result;
650
5
        bitmap_result.mask_out_null();
651
652
5
        if (name_view == NameNotEquals::name) {
653
0
            roaring::Roaring full_result;
654
0
            full_result.addRange(0, num_rows);
655
0
            bitmap_result.op_not(&full_result);
656
0
        }
657
658
5
        return Status::OK();
659
5
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
119
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
119
        DCHECK(arguments.size() == 1);
597
119
        DCHECK(data_type_with_names.size() == 1);
598
119
        DCHECK(iterators.size() == 1);
599
119
        auto* iter = iterators[0];
600
119
        auto data_type_with_name = data_type_with_names[0];
601
119
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
119
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
43
            return Status::OK();
606
43
        }
607
76
        segment_v2::InvertedIndexQueryType query_type;
608
76
        std::string_view name_view(name);
609
77
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
0
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
77
        } else if (name_view == NameLess::name) {
612
77
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
18.4E
        } else if (name_view == NameLessOrEquals::name) {
614
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
18.4E
        } else if (name_view == NameGreater::name) {
616
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
18.4E
        } else if (name_view == NameGreaterOrEquals::name) {
618
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
18.4E
        } else {
620
18.4E
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
18.4E
        }
622
623
77
        if (segment_v2::is_range_query(query_type) &&
624
77
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
18
            return Status::OK();
627
18
        }
628
59
        Field param_value;
629
59
        arguments[0].column->get(0, param_value);
630
59
        if (param_value.is_null()) {
631
0
            return Status::OK();
632
0
        }
633
59
        segment_v2::InvertedIndexParam param;
634
59
        param.column_name = data_type_with_name.first;
635
59
        param.column_type = data_type_with_name.second;
636
59
        param.query_value = param_value;
637
59
        param.query_type = query_type;
638
59
        param.num_rows = num_rows;
639
59
        param.roaring = std::make_shared<roaring::Roaring>();
640
59
        param.analyzer_ctx = analyzer_ctx;
641
59
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
39
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
40
        if (iter->has_null()) {
644
40
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
40
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
40
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
40
        }
648
39
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
39
        bitmap_result = result;
650
39
        bitmap_result.mask_out_null();
651
652
39
        if (name_view == NameNotEquals::name) {
653
0
            roaring::Roaring full_result;
654
0
            full_result.addRange(0, num_rows);
655
0
            bitmap_result.op_not(&full_result);
656
0
        }
657
658
39
        return Status::OK();
659
39
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE23evaluate_inverted_indexERKSt6vectorINS_21ColumnWithTypeAndNameESaIS5_EERKS4_ISt4pairINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt10shared_ptrIKNS_9IDataTypeEEESaISL_EES4_IPNS_10segment_v213IndexIteratorESaISS_EEjPKNS_24InvertedIndexAnalyzerCtxERNSQ_25InvertedIndexResultBitmapE
Line
Count
Source
595
175
            segment_v2::InvertedIndexResultBitmap& bitmap_result) const override {
596
175
        DCHECK(arguments.size() == 1);
597
175
        DCHECK(data_type_with_names.size() == 1);
598
175
        DCHECK(iterators.size() == 1);
599
175
        auto* iter = iterators[0];
600
175
        auto data_type_with_name = data_type_with_names[0];
601
175
        if (iter == nullptr) {
602
0
            return Status::OK();
603
0
        }
604
175
        if (!segment_v2::IndexReaderHelper::has_string_or_bkd_index(iter)) {
605
93
            return Status::OK();
606
93
        }
607
82
        segment_v2::InvertedIndexQueryType query_type;
608
82
        std::string_view name_view(name);
609
82
        if (name_view == NameEquals::name || name_view == NameNotEquals::name) {
610
0
            query_type = segment_v2::InvertedIndexQueryType::EQUAL_QUERY;
611
82
        } else if (name_view == NameLess::name) {
612
0
            query_type = segment_v2::InvertedIndexQueryType::LESS_THAN_QUERY;
613
82
        } else if (name_view == NameLessOrEquals::name) {
614
81
            query_type = segment_v2::InvertedIndexQueryType::LESS_EQUAL_QUERY;
615
81
        } else if (name_view == NameGreater::name) {
616
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_THAN_QUERY;
617
1
        } else if (name_view == NameGreaterOrEquals::name) {
618
0
            query_type = segment_v2::InvertedIndexQueryType::GREATER_EQUAL_QUERY;
619
1
        } else {
620
1
            return Status::InvalidArgument("invalid comparison op type {}", Name::name);
621
1
        }
622
623
81
        if (segment_v2::is_range_query(query_type) &&
624
81
            iter->get_reader(segment_v2::InvertedIndexReaderType::STRING_TYPE)) {
625
            // untokenized strings exceed ignore_above, they are written as null, causing range query errors
626
51
            return Status::OK();
627
51
        }
628
30
        Field param_value;
629
30
        arguments[0].column->get(0, param_value);
630
30
        if (param_value.is_null()) {
631
0
            return Status::OK();
632
0
        }
633
30
        segment_v2::InvertedIndexParam param;
634
30
        param.column_name = data_type_with_name.first;
635
30
        param.column_type = data_type_with_name.second;
636
30
        param.query_value = param_value;
637
30
        param.query_type = query_type;
638
30
        param.num_rows = num_rows;
639
30
        param.roaring = std::make_shared<roaring::Roaring>();
640
30
        param.analyzer_ctx = analyzer_ctx;
641
30
        RETURN_IF_ERROR(iter->read_from_index(segment_v2::IndexParam {&param}));
642
9
        std::shared_ptr<roaring::Roaring> null_bitmap = std::make_shared<roaring::Roaring>();
643
9
        if (iter->has_null()) {
644
9
            segment_v2::InvertedIndexQueryCacheHandle null_bitmap_cache_handle;
645
9
            RETURN_IF_ERROR(iter->read_null_bitmap(&null_bitmap_cache_handle));
646
9
            null_bitmap = null_bitmap_cache_handle.get_bitmap();
647
9
        }
648
9
        segment_v2::InvertedIndexResultBitmap result(param.roaring, null_bitmap);
649
9
        bitmap_result = result;
650
9
        bitmap_result.mask_out_null();
651
652
9
        if (name_view == NameNotEquals::name) {
653
0
            roaring::Roaring full_result;
654
0
            full_result.addRange(0, num_rows);
655
0
            bitmap_result.op_not(&full_result);
656
0
        }
657
658
9
        return Status::OK();
659
9
    }
660
661
    Status execute_impl(FunctionContext* context, Block& block, const ColumnNumbers& arguments,
662
146k
                        uint32_t result, size_t input_rows_count) const override {
663
146k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
146k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
146k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
146k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
146k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
146k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
146k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
146k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
146k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
146k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
0
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
0
                block.get_by_position(result).column =
685
0
                        DataTypeUInt8()
686
0
                                .create_column_const(input_rows_count,
687
0
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
0
                                ->convert_to_full_column_if_const();
689
0
                return Status::OK();
690
0
            } else {
691
0
                block.get_by_position(result).column =
692
0
                        DataTypeUInt8()
693
0
                                .create_column_const(input_rows_count,
694
0
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
0
                                ->convert_to_full_column_if_const();
696
0
                return Status::OK();
697
0
            }
698
0
        }
699
700
277k
        auto can_compare = [](PrimitiveType t) -> bool {
701
277k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
277k
        };
_ZZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
86.2k
        auto can_compare = [](PrimitiveType t) -> bool {
701
86.2k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
86.2k
        };
_ZZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
4.72k
        auto can_compare = [](PrimitiveType t) -> bool {
701
4.72k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
4.72k
        };
_ZZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
149k
        auto can_compare = [](PrimitiveType t) -> bool {
701
149k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
149k
        };
_ZZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
4.77k
        auto can_compare = [](PrimitiveType t) -> bool {
701
4.77k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
4.77k
        };
_ZZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
16.9k
        auto can_compare = [](PrimitiveType t) -> bool {
701
16.9k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
16.9k
        };
_ZZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlNS_13PrimitiveTypeEE_clESD_
Line
Count
Source
700
15.7k
        auto can_compare = [](PrimitiveType t) -> bool {
701
15.7k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
15.7k
        };
703
704
146k
        if (can_compare(left_type->get_primitive_type()) &&
705
146k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
131k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
131k
        }
713
714
146k
        auto compare_type = left_type->get_primitive_type();
715
146k
        switch (compare_type) {
716
243
        case TYPE_BOOLEAN:
717
243
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
5.53k
        case TYPE_DATEV2:
719
5.53k
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
961
        case TYPE_DATETIMEV2:
721
961
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
12
        case TYPE_TIMESTAMPTZ:
723
12
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
8.63k
        case TYPE_TINYINT:
725
8.63k
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
2.46k
        case TYPE_SMALLINT:
727
2.46k
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
102k
        case TYPE_INT:
729
102k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
6.83k
        case TYPE_BIGINT:
731
6.83k
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
653
        case TYPE_LARGEINT:
733
653
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
74
        case TYPE_IPV4:
735
74
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
48
        case TYPE_IPV6:
737
48
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
584
        case TYPE_FLOAT:
739
584
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
2.06k
        case TYPE_DOUBLE:
741
2.06k
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
4
        case TYPE_TIMEV2:
743
4
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
377
        case TYPE_DECIMAL32:
746
1.09k
        case TYPE_DECIMAL64:
747
3.20k
        case TYPE_DECIMAL128I:
748
3.32k
        case TYPE_DECIMAL256:
749
3.32k
            return execute_decimal(block, result, col_with_type_and_name_left,
750
3.32k
                                   col_with_type_and_name_right);
751
965
        case TYPE_CHAR:
752
6.76k
        case TYPE_VARCHAR:
753
12.3k
        case TYPE_STRING:
754
12.3k
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
151
        default:
756
151
            return execute_generic(block, result, col_with_type_and_name_left,
757
151
                                   col_with_type_and_name_right);
758
146k
        }
759
0
        return Status::OK();
760
146k
    }
_ZNK5doris18FunctionComparisonINS_8EqualsOpENS_10NameEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
49.2k
                        uint32_t result, size_t input_rows_count) const override {
663
49.2k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
49.2k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
49.2k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
49.2k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
49.2k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
49.2k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
49.2k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
49.2k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
49.2k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
49.2k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
0
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
0
                block.get_by_position(result).column =
685
0
                        DataTypeUInt8()
686
0
                                .create_column_const(input_rows_count,
687
0
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
0
                                ->convert_to_full_column_if_const();
689
0
                return Status::OK();
690
            } else {
691
                block.get_by_position(result).column =
692
                        DataTypeUInt8()
693
                                .create_column_const(input_rows_count,
694
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
                                ->convert_to_full_column_if_const();
696
                return Status::OK();
697
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
49.2k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
49.2k
        };
703
704
49.2k
        if (can_compare(left_type->get_primitive_type()) &&
705
49.2k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
36.9k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
36.9k
        }
713
714
49.2k
        auto compare_type = left_type->get_primitive_type();
715
49.2k
        switch (compare_type) {
716
100
        case TYPE_BOOLEAN:
717
100
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
1.03k
        case TYPE_DATEV2:
719
1.03k
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
443
        case TYPE_DATETIMEV2:
721
443
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
3
        case TYPE_TIMESTAMPTZ:
723
3
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
4.94k
        case TYPE_TINYINT:
725
4.94k
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
401
        case TYPE_SMALLINT:
727
401
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
26.0k
        case TYPE_INT:
729
26.0k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
2.97k
        case TYPE_BIGINT:
731
2.97k
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
117
        case TYPE_LARGEINT:
733
117
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
31
        case TYPE_IPV4:
735
31
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
30
        case TYPE_IPV6:
737
30
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
118
        case TYPE_FLOAT:
739
118
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
728
        case TYPE_DOUBLE:
741
728
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
4
        case TYPE_TIMEV2:
743
4
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
165
        case TYPE_DECIMAL32:
746
368
        case TYPE_DECIMAL64:
747
1.26k
        case TYPE_DECIMAL128I:
748
1.29k
        case TYPE_DECIMAL256:
749
1.29k
            return execute_decimal(block, result, col_with_type_and_name_left,
750
1.29k
                                   col_with_type_and_name_right);
751
707
        case TYPE_CHAR:
752
5.91k
        case TYPE_VARCHAR:
753
11.0k
        case TYPE_STRING:
754
11.0k
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
17
        default:
756
17
            return execute_generic(block, result, col_with_type_and_name_left,
757
17
                                   col_with_type_and_name_right);
758
49.2k
        }
759
0
        return Status::OK();
760
49.2k
    }
_ZNK5doris18FunctionComparisonINS_11NotEqualsOpENS_13NameNotEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
2.48k
                        uint32_t result, size_t input_rows_count) const override {
663
2.48k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
2.48k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
2.48k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
2.48k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
2.48k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
2.48k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
2.48k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
2.48k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
2.48k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
2.48k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
                block.get_by_position(result).column =
685
                        DataTypeUInt8()
686
                                .create_column_const(input_rows_count,
687
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
                                ->convert_to_full_column_if_const();
689
                return Status::OK();
690
0
            } else {
691
0
                block.get_by_position(result).column =
692
0
                        DataTypeUInt8()
693
0
                                .create_column_const(input_rows_count,
694
0
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
0
                                ->convert_to_full_column_if_const();
696
0
                return Status::OK();
697
0
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
2.48k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
2.48k
        };
703
704
2.48k
        if (can_compare(left_type->get_primitive_type()) &&
705
2.48k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
2.24k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
2.24k
        }
713
714
2.48k
        auto compare_type = left_type->get_primitive_type();
715
2.48k
        switch (compare_type) {
716
0
        case TYPE_BOOLEAN:
717
0
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
68
        case TYPE_DATEV2:
719
68
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
0
        case TYPE_DATETIMEV2:
721
0
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
0
        case TYPE_TIMESTAMPTZ:
723
0
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
84
        case TYPE_TINYINT:
725
84
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
0
        case TYPE_SMALLINT:
727
0
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
1.11k
        case TYPE_INT:
729
1.11k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
874
        case TYPE_BIGINT:
731
874
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
0
        case TYPE_LARGEINT:
733
0
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
0
        case TYPE_IPV4:
735
0
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
0
        case TYPE_IPV6:
737
0
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
48
        case TYPE_FLOAT:
739
48
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
60
        case TYPE_DOUBLE:
741
60
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
0
        case TYPE_TIMEV2:
743
0
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
0
        case TYPE_DECIMAL32:
746
67
        case TYPE_DECIMAL64:
747
95
        case TYPE_DECIMAL128I:
748
125
        case TYPE_DECIMAL256:
749
125
            return execute_decimal(block, result, col_with_type_and_name_left,
750
125
                                   col_with_type_and_name_right);
751
1
        case TYPE_CHAR:
752
26
        case TYPE_VARCHAR:
753
100
        case TYPE_STRING:
754
100
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
8
        default:
756
8
            return execute_generic(block, result, col_with_type_and_name_left,
757
8
                                   col_with_type_and_name_right);
758
2.48k
        }
759
0
        return Status::OK();
760
2.48k
    }
_ZNK5doris18FunctionComparisonINS_9GreaterOpENS_11NameGreaterEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
75.1k
                        uint32_t result, size_t input_rows_count) const override {
663
75.1k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
75.1k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
75.1k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
75.1k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
75.1k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
75.1k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
75.1k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
75.1k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
75.1k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
75.1k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
                block.get_by_position(result).column =
685
                        DataTypeUInt8()
686
                                .create_column_const(input_rows_count,
687
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
                                ->convert_to_full_column_if_const();
689
                return Status::OK();
690
0
            } else {
691
0
                block.get_by_position(result).column =
692
0
                        DataTypeUInt8()
693
0
                                .create_column_const(input_rows_count,
694
0
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
0
                                ->convert_to_full_column_if_const();
696
0
                return Status::OK();
697
0
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
75.1k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
75.1k
        };
703
704
75.1k
        if (can_compare(left_type->get_primitive_type()) &&
705
75.1k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
74.1k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
74.1k
        }
713
714
75.1k
        auto compare_type = left_type->get_primitive_type();
715
75.1k
        switch (compare_type) {
716
0
        case TYPE_BOOLEAN:
717
0
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
1.16k
        case TYPE_DATEV2:
719
1.16k
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
2
        case TYPE_DATETIMEV2:
721
2
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
2
        case TYPE_TIMESTAMPTZ:
723
2
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
1.36k
        case TYPE_TINYINT:
725
1.36k
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
1.78k
        case TYPE_SMALLINT:
727
1.78k
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
67.1k
        case TYPE_INT:
729
67.1k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
1.70k
        case TYPE_BIGINT:
731
1.70k
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
223
        case TYPE_LARGEINT:
733
223
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
4
        case TYPE_IPV4:
735
4
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
1
        case TYPE_IPV6:
737
1
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
220
        case TYPE_FLOAT:
739
220
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
530
        case TYPE_DOUBLE:
741
530
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
0
        case TYPE_TIMEV2:
743
0
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
8
        case TYPE_DECIMAL32:
746
73
        case TYPE_DECIMAL64:
747
802
        case TYPE_DECIMAL128I:
748
804
        case TYPE_DECIMAL256:
749
804
            return execute_decimal(block, result, col_with_type_and_name_left,
750
804
                                   col_with_type_and_name_right);
751
14
        case TYPE_CHAR:
752
76
        case TYPE_VARCHAR:
753
178
        case TYPE_STRING:
754
178
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
9
        default:
756
9
            return execute_generic(block, result, col_with_type_and_name_left,
757
9
                                   col_with_type_and_name_right);
758
75.1k
        }
759
0
        return Status::OK();
760
75.1k
    }
_ZNK5doris18FunctionComparisonINS_17GreaterOrEqualsOpENS_19NameGreaterOrEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
2.60k
                        uint32_t result, size_t input_rows_count) const override {
663
2.60k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
2.60k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
2.60k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
2.60k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
2.60k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
2.60k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
2.60k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
2.60k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
2.60k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
2.60k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
0
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
0
                block.get_by_position(result).column =
685
0
                        DataTypeUInt8()
686
0
                                .create_column_const(input_rows_count,
687
0
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
0
                                ->convert_to_full_column_if_const();
689
0
                return Status::OK();
690
            } else {
691
                block.get_by_position(result).column =
692
                        DataTypeUInt8()
693
                                .create_column_const(input_rows_count,
694
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
                                ->convert_to_full_column_if_const();
696
                return Status::OK();
697
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
2.60k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
2.60k
        };
703
704
2.60k
        if (can_compare(left_type->get_primitive_type()) &&
705
2.60k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
2.16k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
2.16k
        }
713
714
2.60k
        auto compare_type = left_type->get_primitive_type();
715
2.60k
        switch (compare_type) {
716
24
        case TYPE_BOOLEAN:
717
24
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
512
        case TYPE_DATEV2:
719
512
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
142
        case TYPE_DATETIMEV2:
721
142
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
2
        case TYPE_TIMESTAMPTZ:
723
2
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
45
        case TYPE_TINYINT:
725
45
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
60
        case TYPE_SMALLINT:
727
60
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
881
        case TYPE_INT:
729
881
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
171
        case TYPE_BIGINT:
731
171
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
18
        case TYPE_LARGEINT:
733
18
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
11
        case TYPE_IPV4:
735
11
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
1
        case TYPE_IPV6:
737
1
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
24
        case TYPE_FLOAT:
739
24
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
218
        case TYPE_DOUBLE:
741
218
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
0
        case TYPE_TIMEV2:
743
0
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
1
        case TYPE_DECIMAL32:
746
74
        case TYPE_DECIMAL64:
747
154
        case TYPE_DECIMAL128I:
748
181
        case TYPE_DECIMAL256:
749
181
            return execute_decimal(block, result, col_with_type_and_name_left,
750
181
                                   col_with_type_and_name_right);
751
22
        case TYPE_CHAR:
752
200
        case TYPE_VARCHAR:
753
256
        case TYPE_STRING:
754
256
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
60
        default:
756
60
            return execute_generic(block, result, col_with_type_and_name_left,
757
60
                                   col_with_type_and_name_right);
758
2.60k
        }
759
0
        return Status::OK();
760
2.60k
    }
_ZNK5doris18FunctionComparisonINS_6LessOpENS_8NameLessEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
9.13k
                        uint32_t result, size_t input_rows_count) const override {
663
9.13k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
9.13k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
9.13k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
9.13k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
9.13k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
9.13k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
9.13k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
9.13k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
9.13k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
9.13k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
                block.get_by_position(result).column =
685
                        DataTypeUInt8()
686
                                .create_column_const(input_rows_count,
687
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
                                ->convert_to_full_column_if_const();
689
                return Status::OK();
690
0
            } else {
691
0
                block.get_by_position(result).column =
692
0
                        DataTypeUInt8()
693
0
                                .create_column_const(input_rows_count,
694
0
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
0
                                ->convert_to_full_column_if_const();
696
0
                return Status::OK();
697
0
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
9.13k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
9.13k
        };
703
704
9.13k
        if (can_compare(left_type->get_primitive_type()) &&
705
9.13k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
7.78k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
7.78k
        }
713
714
9.13k
        auto compare_type = left_type->get_primitive_type();
715
9.13k
        switch (compare_type) {
716
101
        case TYPE_BOOLEAN:
717
101
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
2.19k
        case TYPE_DATEV2:
719
2.19k
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
317
        case TYPE_DATETIMEV2:
721
317
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
3
        case TYPE_TIMESTAMPTZ:
723
3
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
2.15k
        case TYPE_TINYINT:
725
2.15k
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
150
        case TYPE_SMALLINT:
727
150
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
1.23k
        case TYPE_INT:
729
1.23k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
815
        case TYPE_BIGINT:
731
815
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
252
        case TYPE_LARGEINT:
733
252
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
18
        case TYPE_IPV4:
735
18
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
16
        case TYPE_IPV6:
737
16
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
154
        case TYPE_FLOAT:
739
154
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
379
        case TYPE_DOUBLE:
741
379
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
0
        case TYPE_TIMEV2:
743
0
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
198
        case TYPE_DECIMAL32:
746
431
        case TYPE_DECIMAL64:
747
743
        case TYPE_DECIMAL128I:
748
744
        case TYPE_DECIMAL256:
749
744
            return execute_decimal(block, result, col_with_type_and_name_left,
750
744
                                   col_with_type_and_name_right);
751
184
        case TYPE_CHAR:
752
397
        case TYPE_VARCHAR:
753
593
        case TYPE_STRING:
754
593
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
11
        default:
756
11
            return execute_generic(block, result, col_with_type_and_name_left,
757
11
                                   col_with_type_and_name_right);
758
9.13k
        }
759
0
        return Status::OK();
760
9.13k
    }
_ZNK5doris18FunctionComparisonINS_14LessOrEqualsOpENS_16NameLessOrEqualsEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm
Line
Count
Source
662
8.05k
                        uint32_t result, size_t input_rows_count) const override {
663
8.05k
        const auto& col_with_type_and_name_left = block.get_by_position(arguments[0]);
664
8.05k
        const auto& col_with_type_and_name_right = block.get_by_position(arguments[1]);
665
666
8.05k
        const auto& col_left_ptr = col_with_type_and_name_left.column;
667
8.05k
        const auto& col_right_ptr = col_with_type_and_name_right.column;
668
8.05k
        const IColumn* col_left_untyped = col_with_type_and_name_left.column.get();
669
8.05k
        const IColumn* col_right_untyped = col_with_type_and_name_right.column.get();
670
671
8.05k
        const DataTypePtr& left_type = col_with_type_and_name_left.type;
672
8.05k
        const DataTypePtr& right_type = col_with_type_and_name_right.type;
673
674
        /// The case when arguments are the same (tautological comparison). Return constant.
675
        /// NOTE: Nullable types are special case. (BTW, this function use default implementation for Nullable, so Nullable types cannot be here. Check just in case.)
676
        /// NOTE: We consider NaN comparison to be implementation specific (and in our implementation NaNs are sometimes equal sometimes not).
677
8.05k
        if (left_type->equals(*right_type) && !left_type->is_nullable() &&
678
8.05k
            col_left_untyped == col_right_untyped) {
679
            /// Always true: =, <=, >=
680
            // TODO: Return const column in the future. But seems so far to do. We need a unified approach for passing const column.
681
            if constexpr (std::is_same_v<Op<TYPE_INT>, EqualsOp<TYPE_INT>> ||
682
                          std::is_same_v<Op<TYPE_INT>, LessOrEqualsOp<TYPE_INT>> ||
683
0
                          std::is_same_v<Op<TYPE_INT>, GreaterOrEqualsOp<TYPE_INT>>) {
684
0
                block.get_by_position(result).column =
685
0
                        DataTypeUInt8()
686
0
                                .create_column_const(input_rows_count,
687
0
                                                     Field::create_field<TYPE_BOOLEAN>(1))
688
0
                                ->convert_to_full_column_if_const();
689
0
                return Status::OK();
690
            } else {
691
                block.get_by_position(result).column =
692
                        DataTypeUInt8()
693
                                .create_column_const(input_rows_count,
694
                                                     Field::create_field<TYPE_BOOLEAN>(0))
695
                                ->convert_to_full_column_if_const();
696
                return Status::OK();
697
            }
698
0
        }
699
700
0
        auto can_compare = [](PrimitiveType t) -> bool {
701
8.05k
            return is_int_or_bool(t) || is_float_or_double(t) || is_ip(t) || is_date_type(t);
702
8.05k
        };
703
704
8.05k
        if (can_compare(left_type->get_primitive_type()) &&
705
8.05k
            can_compare(right_type->get_primitive_type())) {
706
            // check left type equals right type TODO: remove this after FE is aware of scales difference
707
7.67k
            if (!left_type->equals_ignore_precision(*right_type)) {
708
0
                return Status::RuntimeError("not same type in function {} , left : {} , right : {}",
709
0
                                            get_name(), left_type->get_name(),
710
0
                                            right_type->get_name());
711
0
            }
712
7.67k
        }
713
714
8.05k
        auto compare_type = left_type->get_primitive_type();
715
8.05k
        switch (compare_type) {
716
18
        case TYPE_BOOLEAN:
717
18
            return execute_num_type<TYPE_BOOLEAN>(block, result, col_left_ptr, col_right_ptr);
718
573
        case TYPE_DATEV2:
719
573
            return execute_num_type<TYPE_DATEV2>(block, result, col_left_ptr, col_right_ptr);
720
57
        case TYPE_DATETIMEV2:
721
57
            return execute_num_type<TYPE_DATETIMEV2>(block, result, col_left_ptr, col_right_ptr);
722
2
        case TYPE_TIMESTAMPTZ:
723
2
            return execute_num_type<TYPE_TIMESTAMPTZ>(block, result, col_left_ptr, col_right_ptr);
724
48
        case TYPE_TINYINT:
725
48
            return execute_num_type<TYPE_TINYINT>(block, result, col_left_ptr, col_right_ptr);
726
64
        case TYPE_SMALLINT:
727
64
            return execute_num_type<TYPE_SMALLINT>(block, result, col_left_ptr, col_right_ptr);
728
6.35k
        case TYPE_INT:
729
6.35k
            return execute_num_type<TYPE_INT>(block, result, col_left_ptr, col_right_ptr);
730
292
        case TYPE_BIGINT:
731
292
            return execute_num_type<TYPE_BIGINT>(block, result, col_left_ptr, col_right_ptr);
732
43
        case TYPE_LARGEINT:
733
43
            return execute_num_type<TYPE_LARGEINT>(block, result, col_left_ptr, col_right_ptr);
734
10
        case TYPE_IPV4:
735
10
            return execute_num_type<TYPE_IPV4>(block, result, col_left_ptr, col_right_ptr);
736
0
        case TYPE_IPV6:
737
0
            return execute_num_type<TYPE_IPV6>(block, result, col_left_ptr, col_right_ptr);
738
20
        case TYPE_FLOAT:
739
20
            return execute_num_type<TYPE_FLOAT>(block, result, col_left_ptr, col_right_ptr);
740
149
        case TYPE_DOUBLE:
741
149
            return execute_num_type<TYPE_DOUBLE>(block, result, col_left_ptr, col_right_ptr);
742
0
        case TYPE_TIMEV2:
743
0
            return execute_num_type<TYPE_TIMEV2>(block, result, col_left_ptr, col_right_ptr);
744
0
        case TYPE_DECIMALV2:
745
5
        case TYPE_DECIMAL32:
746
81
        case TYPE_DECIMAL64:
747
147
        case TYPE_DECIMAL128I:
748
169
        case TYPE_DECIMAL256:
749
169
            return execute_decimal(block, result, col_with_type_and_name_left,
750
169
                                   col_with_type_and_name_right);
751
37
        case TYPE_CHAR:
752
151
        case TYPE_VARCHAR:
753
210
        case TYPE_STRING:
754
210
            return execute_string(block, result, col_left_untyped, col_right_untyped);
755
46
        default:
756
46
            return execute_generic(block, result, col_with_type_and_name_left,
757
46
                                   col_with_type_and_name_right);
758
8.05k
        }
759
0
        return Status::OK();
760
8.05k
    }
761
};
762
763
} // namespace doris