Coverage Report

Created: 2026-06-03 04:12

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/aggregate/aggregate_function_bitmap.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
18
#pragma once
19
20
#include <stddef.h>
21
22
#include <algorithm>
23
#include <boost/iterator/iterator_facade.hpp>
24
#include <memory>
25
#include <string>
26
#include <vector>
27
28
#include "agent/be_exec_version_manager.h"
29
#include "common/compiler_util.h" // IWYU pragma: keep
30
#include "core/assert_cast.h"
31
#include "core/column/column_complex.h"
32
#include "core/column/column_nullable.h"
33
#include "core/column/column_vector.h"
34
#include "core/data_type/data_type_bitmap.h"
35
#include "core/data_type/data_type_number.h"
36
#include "core/types.h"
37
#include "core/value/bitmap_value.h"
38
#include "exprs/aggregate/aggregate_function.h"
39
40
namespace doris {
41
42
class Arena;
43
class BufferReadable;
44
class BufferWritable;
45
class IColumn;
46
struct AggregateFunctionBitmapUnionOp {
47
    static constexpr auto name = "bitmap_union";
48
49
    template <typename T>
50
510
    static void add(BitmapValue& res, const T& data, bool& is_first) {
51
510
        res.add(data);
52
510
        is_first = false;
53
510
    }
_ZN5doris30AggregateFunctionBitmapUnionOp3addIaEEvRNS_11BitmapValueERKT_Rb
Line
Count
Source
50
114
    static void add(BitmapValue& res, const T& data, bool& is_first) {
51
114
        res.add(data);
52
114
        is_first = false;
53
114
    }
_ZN5doris30AggregateFunctionBitmapUnionOp3addIsEEvRNS_11BitmapValueERKT_Rb
Line
Count
Source
50
142
    static void add(BitmapValue& res, const T& data, bool& is_first) {
51
142
        res.add(data);
52
142
        is_first = false;
53
142
    }
_ZN5doris30AggregateFunctionBitmapUnionOp3addIiEEvRNS_11BitmapValueERKT_Rb
Line
Count
Source
50
245
    static void add(BitmapValue& res, const T& data, bool& is_first) {
51
245
        res.add(data);
52
245
        is_first = false;
53
245
    }
_ZN5doris30AggregateFunctionBitmapUnionOp3addIlEEvRNS_11BitmapValueERKT_Rb
Line
Count
Source
50
9
    static void add(BitmapValue& res, const T& data, bool& is_first) {
51
9
        res.add(data);
52
9
        is_first = false;
53
9
    }
54
55
118k
    static void add(BitmapValue& res, const BitmapValue& data, bool& is_first) {
56
118k
        if (UNLIKELY(is_first)) {
57
1.15k
            res = data;
58
1.15k
            is_first = false;
59
117k
        } else {
60
117k
            res |= data;
61
117k
        }
62
118k
    }
63
64
57.8k
    static void add_batch(BitmapValue& res, std::vector<const BitmapValue*>& data, bool& is_first) {
65
57.8k
        res.fastunion(data);
66
        // after fastunion, res myabe have many datas, so is_first should be false
67
        // then call add function will not reset res
68
57.8k
        is_first = false;
69
57.8k
    }
70
71
41.6k
    static void merge(BitmapValue& res, const BitmapValue& data, bool& is_first) {
72
41.6k
        if (UNLIKELY(is_first)) {
73
41.2k
            res = data;
74
41.2k
            is_first = false;
75
41.2k
        } else {
76
386
            res |= data;
77
386
        }
78
41.6k
    }
79
};
80
81
struct AggregateFunctionBitmapIntersectOp {
82
    static constexpr auto name = "bitmap_intersect";
83
84
5.70k
    static void add(BitmapValue& res, const BitmapValue& data, bool& is_first) {
85
5.70k
        if (UNLIKELY(is_first)) {
86
1.68k
            res = data;
87
1.68k
            is_first = false;
88
4.02k
        } else {
89
4.02k
            res &= data;
90
4.02k
        }
91
5.70k
    }
92
93
247
    static void merge(BitmapValue& res, const BitmapValue& data, bool& is_first) {
94
247
        if (UNLIKELY(is_first)) {
95
132
            res = data;
96
132
            is_first = false;
97
132
        } else {
98
115
            res &= data;
99
115
        }
100
247
    }
101
};
102
103
struct AggregateFunctionGroupBitmapXorOp {
104
    static constexpr auto name = "group_bitmap_xor";
105
106
286
    static void add(BitmapValue& res, const BitmapValue& data, bool& is_first) {
107
286
        if (UNLIKELY(is_first)) {
108
216
            res = data;
109
216
            is_first = false;
110
216
        } else {
111
70
            res ^= data;
112
70
        }
113
286
    }
114
115
191
    static void merge(BitmapValue& res, const BitmapValue& data, bool& is_first) {
116
191
        if (UNLIKELY(is_first)) {
117
83
            res = data;
118
83
            is_first = false;
119
108
        } else {
120
108
            res ^= data;
121
108
        }
122
191
    }
123
};
124
125
template <typename Op>
126
struct AggregateFunctionBitmapData {
127
    BitmapValue value;
128
    bool is_first = true;
129
130
    template <typename T>
131
124k
    void add(const T& data) {
132
124k
        Op::add(value, data, is_first);
133
124k
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3addINS_11BitmapValueEEEvRKT_
Line
Count
Source
131
118k
    void add(const T& data) {
132
118k
        Op::add(value, data, is_first);
133
118k
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3addIaEEvRKT_
Line
Count
Source
131
114
    void add(const T& data) {
132
114
        Op::add(value, data, is_first);
133
114
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3addIsEEvRKT_
Line
Count
Source
131
142
    void add(const T& data) {
132
142
        Op::add(value, data, is_first);
133
142
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3addIiEEvRKT_
Line
Count
Source
131
245
    void add(const T& data) {
132
245
        Op::add(value, data, is_first);
133
245
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3addIlEEvRKT_
Line
Count
Source
131
9
    void add(const T& data) {
132
9
        Op::add(value, data, is_first);
133
9
    }
_ZN5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE3addINS_11BitmapValueEEEvRKT_
Line
Count
Source
131
5.70k
    void add(const T& data) {
132
5.70k
        Op::add(value, data, is_first);
133
5.70k
    }
_ZN5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE3addINS_11BitmapValueEEEvRKT_
Line
Count
Source
131
286
    void add(const T& data) {
132
286
        Op::add(value, data, is_first);
133
286
    }
134
135
57.8k
    void add_batch(std::vector<const BitmapValue*>& data) { Op::add_batch(value, data, is_first); }
136
137
42.1k
    void merge(const BitmapValue& data) { Op::merge(value, data, is_first); }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE5mergeERKNS_11BitmapValueE
Line
Count
Source
137
41.6k
    void merge(const BitmapValue& data) { Op::merge(value, data, is_first); }
_ZN5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE5mergeERKNS_11BitmapValueE
Line
Count
Source
137
247
    void merge(const BitmapValue& data) { Op::merge(value, data, is_first); }
_ZN5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE5mergeERKNS_11BitmapValueE
Line
Count
Source
137
191
    void merge(const BitmapValue& data) { Op::merge(value, data, is_first); }
138
139
0
    void write(BufferWritable& buf) const { DataTypeBitMap::serialize_as_stream(value, buf); }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE5writeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE5writeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE5writeERNS_14BufferWritableE
140
141
0
    void read(BufferReadable& buf) { DataTypeBitMap::deserialize_as_stream(value, buf); }
Unexecuted instantiation: _ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE4readERNS_14BufferReadableE
Unexecuted instantiation: _ZN5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE4readERNS_14BufferReadableE
Unexecuted instantiation: _ZN5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE4readERNS_14BufferReadableE
142
143
16.9k
    void reset() {
144
16.9k
        is_first = true;
145
16.9k
        value.reset(); // it's better to call reset function by self firstly.
146
16.9k
    }
_ZN5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE5resetEv
Line
Count
Source
143
16.8k
    void reset() {
144
16.8k
        is_first = true;
145
16.8k
        value.reset(); // it's better to call reset function by self firstly.
146
16.8k
    }
_ZN5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE5resetEv
Line
Count
Source
143
58
    void reset() {
144
58
        is_first = true;
145
58
        value.reset(); // it's better to call reset function by self firstly.
146
58
    }
_ZN5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE5resetEv
Line
Count
Source
143
38
    void reset() {
144
38
        is_first = true;
145
38
        value.reset(); // it's better to call reset function by self firstly.
146
38
    }
147
148
    BitmapValue& get() { return value; }
149
150
59.7k
    const BitmapValue& get() const { return value; }
_ZNK5doris27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEE3getEv
Line
Count
Source
150
58.1k
    const BitmapValue& get() const { return value; }
_ZNK5doris27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEE3getEv
Line
Count
Source
150
1.53k
    const BitmapValue& get() const { return value; }
_ZNK5doris27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEE3getEv
Line
Count
Source
150
79
    const BitmapValue& get() const { return value; }
151
};
152
153
template <typename Data, typename Derived>
154
class AggregateFunctionBitmapSerializationHelper
155
        : public IAggregateFunctionDataHelper<Data, Derived> {
156
public:
157
    using BaseHelper = IAggregateFunctionHelper<Derived>;
158
159
    AggregateFunctionBitmapSerializationHelper(const DataTypes& argument_types_)
160
5.49k
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
3
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
633
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
11
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
14
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
427
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
Unexecuted instantiation: _ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
9
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
9
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
15
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISE_EE
Line
Count
Source
160
1
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISB_EE
Line
Count
Source
160
2.60k
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISB_EE
Line
Count
Source
160
1.31k
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
_ZN5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISB_EE
Line
Count
Source
160
447
            : IAggregateFunctionDataHelper<Data, Derived>(argument_types_) {}
161
162
    void streaming_agg_serialize_to_column(const IColumn** columns, MutableColumnPtr& dst,
163
59
                                           const size_t num_rows, Arena& arena) const override {
164
59
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
59
        char place[sizeof(Data)];
166
59
        col.resize(num_rows);
167
59
        auto* data = col.get_data().data();
168
523
        for (size_t i = 0; i != num_rows; ++i) {
169
464
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
464
            DEFER({
171
464
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
464
            });
173
464
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
464
                                                                                arena);
175
464
            data[i] = std::move(this->data(place).value);
176
464
        }
177
59
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Line
Count
Source
163
9
                                           const size_t num_rows, Arena& arena) const override {
164
9
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
9
        char place[sizeof(Data)];
166
9
        col.resize(num_rows);
167
9
        auto* data = col.get_data().data();
168
117
        for (size_t i = 0; i != num_rows; ++i) {
169
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
108
            DEFER({
171
108
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
108
            });
173
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
108
                                                                                arena);
175
108
            data[i] = std::move(this->data(place).value);
176
108
        }
177
9
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Line
Count
Source
163
9
                                           const size_t num_rows, Arena& arena) const override {
164
9
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
9
        char place[sizeof(Data)];
166
9
        col.resize(num_rows);
167
9
        auto* data = col.get_data().data();
168
117
        for (size_t i = 0; i != num_rows; ++i) {
169
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
108
            DEFER({
171
108
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
108
            });
173
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
108
                                                                                arena);
175
108
            data[i] = std::move(this->data(place).value);
176
108
        }
177
9
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWISA_E11mutable_ptrISA_EEmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWIS7_E11mutable_ptrIS7_EEmRNS_5ArenaE
Line
Count
Source
163
7
                                           const size_t num_rows, Arena& arena) const override {
164
7
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
7
        char place[sizeof(Data)];
166
7
        col.resize(num_rows);
167
7
        auto* data = col.get_data().data();
168
23
        for (size_t i = 0; i != num_rows; ++i) {
169
16
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
16
            DEFER({
171
16
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
16
            });
173
16
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
16
                                                                                arena);
175
16
            data[i] = std::move(this->data(place).value);
176
16
        }
177
7
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWIS7_E11mutable_ptrIS7_EEmRNS_5ArenaE
Line
Count
Source
163
25
                                           const size_t num_rows, Arena& arena) const override {
164
25
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
25
        char place[sizeof(Data)];
166
25
        col.resize(num_rows);
167
25
        auto* data = col.get_data().data();
168
149
        for (size_t i = 0; i != num_rows; ++i) {
169
124
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
124
            DEFER({
171
124
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
124
            });
173
124
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
124
                                                                                arena);
175
124
            data[i] = std::move(this->data(place).value);
176
124
        }
177
25
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE33streaming_agg_serialize_to_columnEPPKNS_7IColumnERNS_3COWIS7_E11mutable_ptrIS7_EEmRNS_5ArenaE
Line
Count
Source
163
9
                                           const size_t num_rows, Arena& arena) const override {
164
9
        auto& col = assert_cast<ColumnBitmap&>(*dst);
165
9
        char place[sizeof(Data)];
166
9
        col.resize(num_rows);
167
9
        auto* data = col.get_data().data();
168
117
        for (size_t i = 0; i != num_rows; ++i) {
169
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->create(place);
170
108
            DEFER({
171
108
                assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->destroy(place);
172
108
            });
173
108
            assert_cast<const Derived*, TypeCheckOnRelease::DISABLE>(this)->add(place, columns, i,
174
108
                                                                                arena);
175
108
            data[i] = std::move(this->data(place).value);
176
108
        }
177
9
    }
178
179
    void serialize_to_column(const std::vector<AggregateDataPtr>& places, size_t offset,
180
1.31k
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
1.31k
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
1.31k
        col.resize(num_rows);
183
1.31k
        auto* data = col.get_data().data();
184
42.3k
        for (size_t i = 0; i != num_rows; ++i) {
185
41.0k
            data[i] = std::move(this->data(places[i] + offset).value);
186
41.0k
        }
187
1.31k
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
474
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
474
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
474
        col.resize(num_rows);
183
474
        auto* data = col.get_data().data();
184
770
        for (size_t i = 0; i != num_rows; ++i) {
185
296
            data[i] = std::move(this->data(places[i] + offset).value);
186
296
        }
187
474
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
14
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
14
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
14
        col.resize(num_rows);
183
14
        auto* data = col.get_data().data();
184
54
        for (size_t i = 0; i != num_rows; ++i) {
185
40
            data[i] = std::move(this->data(places[i] + offset).value);
186
40
        }
187
14
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
14
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
14
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
14
        col.resize(num_rows);
183
14
        auto* data = col.get_data().data();
184
54
        for (size_t i = 0; i != num_rows; ++i) {
185
40
            data[i] = std::move(this->data(places[i] + offset).value);
186
40
        }
187
14
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
14
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
14
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
14
        col.resize(num_rows);
183
14
        auto* data = col.get_data().data();
184
54
        for (size_t i = 0; i != num_rows; ++i) {
185
40
            data[i] = std::move(this->data(places[i] + offset).value);
186
40
        }
187
14
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
6
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
6
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
6
        col.resize(num_rows);
183
6
        auto* data = col.get_data().data();
184
22
        for (size_t i = 0; i != num_rows; ++i) {
185
16
            data[i] = std::move(this->data(places[i] + offset).value);
186
16
        }
187
6
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
6
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
6
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
6
        col.resize(num_rows);
183
6
        auto* data = col.get_data().data();
184
22
        for (size_t i = 0; i != num_rows; ++i) {
185
16
            data[i] = std::move(this->data(places[i] + offset).value);
186
16
        }
187
6
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
Line
Count
Source
180
6
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
6
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
6
        col.resize(num_rows);
183
6
        auto* data = col.get_data().data();
184
22
        for (size_t i = 0; i != num_rows; ++i) {
185
16
            data[i] = std::move(this->data(places[i] + offset).value);
186
16
        }
187
6
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE19serialize_to_columnERKSt6vectorIPcSaISB_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISH_EEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19serialize_to_columnERKSt6vectorIPcSaIS8_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISE_EEm
Line
Count
Source
180
729
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
729
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
729
        col.resize(num_rows);
183
729
        auto* data = col.get_data().data();
184
41.1k
        for (size_t i = 0; i != num_rows; ++i) {
185
40.4k
            data[i] = std::move(this->data(places[i] + offset).value);
186
40.4k
        }
187
729
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19serialize_to_columnERKSt6vectorIPcSaIS8_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISE_EEm
Line
Count
Source
180
36
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
36
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
36
        col.resize(num_rows);
183
36
        auto* data = col.get_data().data();
184
96
        for (size_t i = 0; i != num_rows; ++i) {
185
60
            data[i] = std::move(this->data(places[i] + offset).value);
186
60
        }
187
36
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19serialize_to_columnERKSt6vectorIPcSaIS8_EEmRNS_3COWINS_7IColumnEE11mutable_ptrISE_EEm
Line
Count
Source
180
20
                             MutableColumnPtr& dst, const size_t num_rows) const override {
181
20
        auto& col = assert_cast<ColumnBitmap&>(*dst);
182
20
        col.resize(num_rows);
183
20
        auto* data = col.get_data().data();
184
76
        for (size_t i = 0; i != num_rows; ++i) {
185
56
            data[i] = std::move(this->data(places[i] + offset).value);
186
56
        }
187
20
    }
188
189
    void deserialize_and_merge_from_column_range(AggregateDataPtr __restrict place,
190
                                                 const IColumn& column, size_t begin, size_t end,
191
801
                                                 Arena&) const override {
192
18.4E
        DCHECK(end <= column.size() && begin <= end)
193
18.4E
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
801
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
801
        const auto* data = col.get_data().data();
196
1.71k
        for (size_t i = begin; i <= end; ++i) {
197
918
            this->data(place).merge(data[i]);
198
918
        }
199
801
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
171
                                                 Arena&) const override {
192
171
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
171
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
171
        const auto* data = col.get_data().data();
196
359
        for (size_t i = begin; i <= end; ++i) {
197
188
            this->data(place).merge(data[i]);
198
188
        }
199
171
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
10
                                                 Arena&) const override {
192
10
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
10
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
10
        const auto* data = col.get_data().data();
196
29
        for (size_t i = begin; i <= end; ++i) {
197
19
            this->data(place).merge(data[i]);
198
19
        }
199
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
10
                                                 Arena&) const override {
192
18.4E
        DCHECK(end <= column.size() && begin <= end)
193
18.4E
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
10
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
10
        const auto* data = col.get_data().data();
196
27
        for (size_t i = begin; i <= end; ++i) {
197
17
            this->data(place).merge(data[i]);
198
17
        }
199
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
132
                                                 Arena&) const override {
192
132
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
132
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
132
        const auto* data = col.get_data().data();
196
273
        for (size_t i = begin; i <= end; ++i) {
197
141
            this->data(place).merge(data[i]);
198
141
        }
199
132
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
10
                                                 Arena&) const override {
192
10
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
10
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
10
        const auto* data = col.get_data().data();
196
28
        for (size_t i = begin; i <= end; ++i) {
197
18
            this->data(place).merge(data[i]);
198
18
        }
199
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
10
                                                 Arena&) const override {
192
10
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
10
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
10
        const auto* data = col.get_data().data();
196
28
        for (size_t i = begin; i <= end; ++i) {
197
18
            this->data(place).merge(data[i]);
198
18
        }
199
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
11
                                                 Arena&) const override {
192
11
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
11
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
11
        const auto* data = col.get_data().data();
196
30
        for (size_t i = begin; i <= end; ++i) {
197
19
            this->data(place).merge(data[i]);
198
19
        }
199
11
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
109
                                                 Arena&) const override {
192
109
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
109
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
109
        const auto* data = col.get_data().data();
196
235
        for (size_t i = begin; i <= end; ++i) {
197
126
            this->data(place).merge(data[i]);
198
126
        }
199
109
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
195
                                                 Arena&) const override {
192
195
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
195
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
195
        const auto* data = col.get_data().data();
196
407
        for (size_t i = begin; i <= end; ++i) {
197
212
            this->data(place).merge(data[i]);
198
212
        }
199
195
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE39deserialize_and_merge_from_column_rangeEPcRKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
191
143
                                                 Arena&) const override {
192
143
        DCHECK(end <= column.size() && begin <= end)
193
0
                << ", begin:" << begin << ", end:" << end << ", column.size():" << column.size();
194
143
        const auto& col = assert_cast<const ColumnBitmap&>(column);
195
143
        const auto* data = col.get_data().data();
196
303
        for (size_t i = begin; i <= end; ++i) {
197
160
            this->data(place).merge(data[i]);
198
160
        }
199
143
    }
200
201
    void deserialize_and_merge_vec(const AggregateDataPtr* places, size_t offset,
202
                                   AggregateDataPtr rhs, const IColumn* column, Arena&,
203
717
                                   const size_t num_rows) const override {
204
717
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
717
        const auto* data = col.get_data().data();
206
42.1k
        for (size_t i = 0; i != num_rows; ++i) {
207
41.4k
            this->data(places[i] + offset).merge(data[i]);
208
41.4k
        }
209
717
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
195
                                   const size_t num_rows) const override {
204
195
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
195
        const auto* data = col.get_data().data();
206
466
        for (size_t i = 0; i != num_rows; ++i) {
207
271
            this->data(places[i] + offset).merge(data[i]);
208
271
        }
209
195
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
10
                                   const size_t num_rows) const override {
204
10
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
10
        const auto* data = col.get_data().data();
206
37
        for (size_t i = 0; i != num_rows; ++i) {
207
27
            this->data(places[i] + offset).merge(data[i]);
208
27
        }
209
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
10
                                   const size_t num_rows) const override {
204
10
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
10
        const auto* data = col.get_data().data();
206
37
        for (size_t i = 0; i != num_rows; ++i) {
207
27
            this->data(places[i] + offset).merge(data[i]);
208
27
        }
209
10
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
10
                                   const size_t num_rows) const override {
204
10
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
10
        const auto* data = col.get_data().data();
206
37
        for (size_t i = 0; i != num_rows; ++i) {
207
27
            this->data(places[i] + offset).merge(data[i]);
208
27
        }
209
10
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
2
                                   const size_t num_rows) const override {
204
2
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
2
        const auto* data = col.get_data().data();
206
6
        for (size_t i = 0; i != num_rows; ++i) {
207
4
            this->data(places[i] + offset).merge(data[i]);
208
4
        }
209
2
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
2
                                   const size_t num_rows) const override {
204
2
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
2
        const auto* data = col.get_data().data();
206
6
        for (size_t i = 0; i != num_rows; ++i) {
207
4
            this->data(places[i] + offset).merge(data[i]);
208
4
        }
209
2
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
2
                                   const size_t num_rows) const override {
204
2
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
2
        const auto* data = col.get_data().data();
206
6
        for (size_t i = 0; i != num_rows; ++i) {
207
4
            this->data(places[i] + offset).merge(data[i]);
208
4
        }
209
2
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE25deserialize_and_merge_vecEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE25deserialize_and_merge_vecEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
458
                                   const size_t num_rows) const override {
204
458
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
458
        const auto* data = col.get_data().data();
206
41.4k
        for (size_t i = 0; i != num_rows; ++i) {
207
40.9k
            this->data(places[i] + offset).merge(data[i]);
208
40.9k
        }
209
458
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE25deserialize_and_merge_vecEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
16
                                   const size_t num_rows) const override {
204
16
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
16
        const auto* data = col.get_data().data();
206
51
        for (size_t i = 0; i != num_rows; ++i) {
207
35
            this->data(places[i] + offset).merge(data[i]);
208
35
        }
209
16
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE25deserialize_and_merge_vecEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
Line
Count
Source
203
12
                                   const size_t num_rows) const override {
204
12
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
205
12
        const auto* data = col.get_data().data();
206
43
        for (size_t i = 0; i != num_rows; ++i) {
207
31
            this->data(places[i] + offset).merge(data[i]);
208
31
        }
209
12
    }
210
211
    void deserialize_and_merge_vec_selected(const AggregateDataPtr* places, size_t offset,
212
                                            AggregateDataPtr rhs, const IColumn* column, Arena&,
213
0
                                            const size_t num_rows) const override {
214
0
        const auto& col = assert_cast<const ColumnBitmap&>(*column);
215
0
        const auto* data = col.get_data().data();
216
0
        for (size_t i = 0; i != num_rows; ++i) {
217
0
            if (places[i]) {
218
0
                this->data(places[i] + offset).merge(data[i]);
219
0
            }
220
0
        }
221
0
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE34deserialize_and_merge_vec_selectedEPKPcmSA_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE34deserialize_and_merge_vec_selectedEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE34deserialize_and_merge_vec_selectedEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE34deserialize_and_merge_vec_selectedEPKPcmS7_PKNS_7IColumnERNS_5ArenaEm
222
223
    void serialize_without_key_to_column(ConstAggregateDataPtr __restrict place,
224
445
                                         IColumn& to) const override {
225
445
        auto& col = assert_cast<ColumnBitmap&>(to);
226
445
        size_t old_size = col.size();
227
445
        col.resize(old_size + 1);
228
445
        col.get_data()[old_size] = std::move(this->data(place).value);
229
445
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
93
                                         IColumn& to) const override {
225
93
        auto& col = assert_cast<ColumnBitmap&>(to);
226
93
        size_t old_size = col.size();
227
93
        col.resize(old_size + 1);
228
93
        col.get_data()[old_size] = std::move(this->data(place).value);
229
93
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
6
                                         IColumn& to) const override {
225
6
        auto& col = assert_cast<ColumnBitmap&>(to);
226
6
        size_t old_size = col.size();
227
6
        col.resize(old_size + 1);
228
6
        col.get_data()[old_size] = std::move(this->data(place).value);
229
6
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
7
                                         IColumn& to) const override {
225
7
        auto& col = assert_cast<ColumnBitmap&>(to);
226
7
        size_t old_size = col.size();
227
7
        col.resize(old_size + 1);
228
7
        col.get_data()[old_size] = std::move(this->data(place).value);
229
7
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
59
                                         IColumn& to) const override {
225
59
        auto& col = assert_cast<ColumnBitmap&>(to);
226
59
        size_t old_size = col.size();
227
59
        col.resize(old_size + 1);
228
59
        col.get_data()[old_size] = std::move(this->data(place).value);
229
59
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
6
                                         IColumn& to) const override {
225
6
        auto& col = assert_cast<ColumnBitmap&>(to);
226
6
        size_t old_size = col.size();
227
6
        col.resize(old_size + 1);
228
6
        col.get_data()[old_size] = std::move(this->data(place).value);
229
6
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
6
                                         IColumn& to) const override {
225
6
        auto& col = assert_cast<ColumnBitmap&>(to);
226
6
        size_t old_size = col.size();
227
6
        col.resize(old_size + 1);
228
6
        col.get_data()[old_size] = std::move(this->data(place).value);
229
6
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
7
                                         IColumn& to) const override {
225
7
        auto& col = assert_cast<ColumnBitmap&>(to);
226
7
        size_t old_size = col.size();
227
7
        col.resize(old_size + 1);
228
7
        col.get_data()[old_size] = std::move(this->data(place).value);
229
7
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
91
                                         IColumn& to) const override {
225
91
        auto& col = assert_cast<ColumnBitmap&>(to);
226
91
        size_t old_size = col.size();
227
91
        col.resize(old_size + 1);
228
91
        col.get_data()[old_size] = std::move(this->data(place).value);
229
91
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
104
                                         IColumn& to) const override {
225
104
        auto& col = assert_cast<ColumnBitmap&>(to);
226
104
        size_t old_size = col.size();
227
104
        col.resize(old_size + 1);
228
104
        col.get_data()[old_size] = std::move(this->data(place).value);
229
104
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE31serialize_without_key_to_columnEPKcRNS_7IColumnE
Line
Count
Source
224
66
                                         IColumn& to) const override {
225
66
        auto& col = assert_cast<ColumnBitmap&>(to);
226
66
        size_t old_size = col.size();
227
66
        col.resize(old_size + 1);
228
66
        col.get_data()[old_size] = std::move(this->data(place).value);
229
66
    }
230
231
3.30k
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
3.30k
        return ColumnBitmap::create();
233
3.30k
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE23create_serialize_columnEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE23create_serialize_columnEv
Line
Count
Source
231
863
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
863
        return ColumnBitmap::create();
233
863
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE23create_serialize_columnEv
Line
Count
Source
231
20
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
20
        return ColumnBitmap::create();
233
20
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE23create_serialize_columnEv
Line
Count
Source
231
21
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
21
        return ColumnBitmap::create();
233
21
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE23create_serialize_columnEv
Line
Count
Source
231
368
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
368
        return ColumnBitmap::create();
233
368
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE23create_serialize_columnEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE23create_serialize_columnEv
Line
Count
Source
231
12
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
12
        return ColumnBitmap::create();
233
12
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE23create_serialize_columnEv
Line
Count
Source
231
12
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
12
        return ColumnBitmap::create();
233
12
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE23create_serialize_columnEv
Line
Count
Source
231
13
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
13
        return ColumnBitmap::create();
233
13
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE23create_serialize_columnEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE23create_serialize_columnEv
Line
Count
Source
231
940
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
940
        return ColumnBitmap::create();
233
940
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE23create_serialize_columnEv
Line
Count
Source
231
672
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
672
        return ColumnBitmap::create();
233
672
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE23create_serialize_columnEv
Line
Count
Source
231
383
    [[nodiscard]] MutableColumnPtr create_serialize_column() const override {
232
383
        return ColumnBitmap::create();
233
383
    }
234
235
4.01k
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
4.01k
        return std::make_shared<DataTypeBitMap>();
237
4.01k
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE19get_serialized_typeEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEEE19get_serialized_typeEv
Line
Count
Source
235
928
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
928
        return std::make_shared<DataTypeBitMap>();
237
928
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE19get_serialized_typeEv
Line
Count
Source
235
20
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
20
        return std::make_shared<DataTypeBitMap>();
237
20
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE19get_serialized_typeEv
Line
Count
Source
235
21
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
21
        return std::make_shared<DataTypeBitMap>();
237
21
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE19get_serialized_typeEv
Line
Count
Source
235
430
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
430
        return std::make_shared<DataTypeBitMap>();
237
430
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE19get_serialized_typeEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEE19get_serialized_typeEv
Line
Count
Source
235
12
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
12
        return std::make_shared<DataTypeBitMap>();
237
12
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEE19get_serialized_typeEv
Line
Count
Source
235
12
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
12
        return std::make_shared<DataTypeBitMap>();
237
12
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEE19get_serialized_typeEv
Line
Count
Source
235
13
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
13
        return std::make_shared<DataTypeBitMap>();
237
13
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEE19get_serialized_typeEv
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_30AggregateFunctionBitmapUnionOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19get_serialized_typeEv
Line
Count
Source
235
1.07k
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
1.07k
        return std::make_shared<DataTypeBitMap>();
237
1.07k
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_34AggregateFunctionBitmapIntersectOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19get_serialized_typeEv
Line
Count
Source
235
1.06k
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
1.06k
        return std::make_shared<DataTypeBitMap>();
237
1.06k
    }
_ZNK5doris42AggregateFunctionBitmapSerializationHelperINS_27AggregateFunctionBitmapDataINS_33AggregateFunctionGroupBitmapXorOpEEENS_25AggregateFunctionBitmapOpIS2_EEE19get_serialized_typeEv
Line
Count
Source
235
445
    [[nodiscard]] DataTypePtr get_serialized_type() const override {
236
445
        return std::make_shared<DataTypeBitMap>();
237
445
    }
238
239
protected:
240
    using IAggregateFunction::version;
241
};
242
243
template <typename Op>
244
class AggregateFunctionBitmapOp final
245
        : public AggregateFunctionBitmapSerializationHelper<AggregateFunctionBitmapData<Op>,
246
                                                            AggregateFunctionBitmapOp<Op>>,
247
          UnaryExpression,
248
          NullableAggregateFunction {
249
public:
250
    using ResultDataType = BitmapValue;
251
    using ColVecType = ColumnBitmap;
252
    using ColVecResult = ColumnBitmap;
253
254
174
    String get_name() const override { return Op::name; }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE8get_nameB5cxx11Ev
Line
Count
Source
254
44
    String get_name() const override { return Op::name; }
_ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE8get_nameB5cxx11Ev
Line
Count
Source
254
93
    String get_name() const override { return Op::name; }
_ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE8get_nameB5cxx11Ev
Line
Count
Source
254
37
    String get_name() const override { return Op::name; }
255
256
    AggregateFunctionBitmapOp(const DataTypes& argument_types_)
257
4.37k
            : AggregateFunctionBitmapSerializationHelper<AggregateFunctionBitmapData<Op>,
258
4.37k
                                                         AggregateFunctionBitmapOp<Op>>(
259
4.37k
                      argument_types_) {}
_ZN5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
257
2.60k
            : AggregateFunctionBitmapSerializationHelper<AggregateFunctionBitmapData<Op>,
258
2.60k
                                                         AggregateFunctionBitmapOp<Op>>(
259
2.60k
                      argument_types_) {}
_ZN5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
257
1.31k
            : AggregateFunctionBitmapSerializationHelper<AggregateFunctionBitmapData<Op>,
258
1.31k
                                                         AggregateFunctionBitmapOp<Op>>(
259
1.31k
                      argument_types_) {}
_ZN5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
257
447
            : AggregateFunctionBitmapSerializationHelper<AggregateFunctionBitmapData<Op>,
258
447
                                                         AggregateFunctionBitmapOp<Op>>(
259
447
                      argument_types_) {}
260
261
919
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeBitMap>(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE15get_return_typeEv
Line
Count
Source
261
725
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeBitMap>(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE15get_return_typeEv
Line
Count
Source
261
117
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeBitMap>(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE15get_return_typeEv
Line
Count
Source
261
77
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeBitMap>(); }
262
263
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
264
109k
             Arena&) const override {
265
109k
        const auto& column =
266
109k
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
267
109k
        this->data(place).add(column.get_data()[row_num]);
268
109k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
264
103k
             Arena&) const override {
265
103k
        const auto& column =
266
103k
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
267
103k
        this->data(place).add(column.get_data()[row_num]);
268
103k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
264
5.70k
             Arena&) const override {
265
5.70k
        const auto& column =
266
5.70k
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
267
5.70k
        this->data(place).add(column.get_data()[row_num]);
268
5.70k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
264
286
             Arena&) const override {
265
286
        const auto& column =
266
286
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
267
286
        this->data(place).add(column.get_data()[row_num]);
268
286
    }
269
270
    void add_many(AggregateDataPtr __restrict place, const IColumn** columns,
271
40.8k
                  std::vector<int>& rows, Arena&) const override {
272
        // now this only for bitmap_union function
273
40.8k
        if constexpr (std::is_same_v<Op, AggregateFunctionBitmapUnionOp>) {
274
40.8k
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
275
40.8k
            std::vector<const BitmapValue*> values;
276
40.9k
            for (auto row : rows) {
277
40.9k
                values.push_back(&(column.get_data()[row]));
278
40.9k
            }
279
40.8k
            this->data(place).add_batch(values);
280
40.8k
        }
281
40.8k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Line
Count
Source
271
40.8k
                  std::vector<int>& rows, Arena&) const override {
272
        // now this only for bitmap_union function
273
40.8k
        if constexpr (std::is_same_v<Op, AggregateFunctionBitmapUnionOp>) {
274
40.8k
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
275
40.8k
            std::vector<const BitmapValue*> values;
276
40.9k
            for (auto row : rows) {
277
40.9k
                values.push_back(&(column.get_data()[row]));
278
40.9k
            }
279
40.8k
            this->data(place).add_batch(values);
280
40.8k
        }
281
40.8k
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
282
283
    void add_batch_range(size_t batch_begin, size_t batch_end, AggregateDataPtr place,
284
16.8k
                         const IColumn** columns, Arena& arena, bool has_null) override {
285
        // now this only for bitmap_union function
286
16.8k
        if constexpr (std::is_same_v<Op, AggregateFunctionBitmapUnionOp>) {
287
16.8k
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
288
16.8k
            std::vector<const BitmapValue*> values;
289
33.5k
            for (size_t i = batch_begin; i <= batch_end; ++i) {
290
16.7k
                values.push_back(&(column.get_data()[i]));
291
16.7k
            }
292
16.8k
            this->data(place).add_batch(values);
293
16.8k
        } else {
294
0
            for (size_t i = batch_begin; i <= batch_end; ++i) {
295
0
                this->add(place, columns, i, arena);
296
0
            }
297
0
        }
298
16.8k
    }
_ZN5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
284
16.8k
                         const IColumn** columns, Arena& arena, bool has_null) override {
285
        // now this only for bitmap_union function
286
16.8k
        if constexpr (std::is_same_v<Op, AggregateFunctionBitmapUnionOp>) {
287
16.8k
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
288
16.8k
            std::vector<const BitmapValue*> values;
289
33.5k
            for (size_t i = batch_begin; i <= batch_end; ++i) {
290
16.7k
                values.push_back(&(column.get_data()[i]));
291
16.7k
            }
292
16.8k
            this->data(place).add_batch(values);
293
        } else {
294
            for (size_t i = batch_begin; i <= batch_end; ++i) {
295
                this->add(place, columns, i, arena);
296
            }
297
        }
298
16.8k
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZN5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb
299
300
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
301
4
               Arena&) const override {
302
4
        this->data(place).merge(this->data(rhs).get());
303
4
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
301
4
               Arena&) const override {
302
4
        this->data(place).merge(this->data(rhs).get());
303
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE5mergeEPcPKcRNS_5ArenaE
304
305
0
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
306
0
        this->data(place).write(buf);
307
0
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE9serializeEPKcRNS_14BufferWritableE
308
309
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
310
0
                     Arena&) const override {
311
0
        this->data(place).read(buf);
312
0
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
313
314
59.1k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
315
59.1k
        auto& column = assert_cast<ColVecResult&>(to);
316
59.1k
        column.get_data().push_back(this->data(place).get());
317
59.1k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
314
57.5k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
315
57.5k
        auto& column = assert_cast<ColVecResult&>(to);
316
57.5k
        column.get_data().push_back(this->data(place).get());
317
57.5k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
314
1.52k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
315
1.52k
        auto& column = assert_cast<ColVecResult&>(to);
316
1.52k
        column.get_data().push_back(this->data(place).get());
317
1.52k
    }
_ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
314
79
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
315
79
        auto& column = assert_cast<ColVecResult&>(to);
316
79
        column.get_data().push_back(this->data(place).get());
317
79
    }
318
319
16.8k
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_30AggregateFunctionBitmapUnionOpEE5resetEPc
Line
Count
Source
319
16.7k
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_34AggregateFunctionBitmapIntersectOpEE5resetEPc
Line
Count
Source
319
58
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris25AggregateFunctionBitmapOpINS_33AggregateFunctionGroupBitmapXorOpEE5resetEPc
Line
Count
Source
319
38
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
320
};
321
322
template <bool arg_is_nullable, typename ColVecType>
323
class AggregateFunctionBitmapCount final
324
        : public AggregateFunctionBitmapSerializationHelper<
325
                  AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
326
                  AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>,
327
          UnaryExpression,
328
          NotNullableAggregateFunction {
329
public:
330
    // using ColVecType = ColumnBitmap;
331
    using ColVecResult = ColumnInt64;
332
    using AggFunctionData = AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>;
333
    static int constexpr BATCH_HALF_ROWS = 4064 / 2;
334
335
    AggregateFunctionBitmapCount(const DataTypes& argument_types_)
336
1.12k
            : AggregateFunctionBitmapSerializationHelper<
337
1.12k
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
1.12k
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
3
            : AggregateFunctionBitmapSerializationHelper<
337
3
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
3
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
633
            : AggregateFunctionBitmapSerializationHelper<
337
633
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
633
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
11
            : AggregateFunctionBitmapSerializationHelper<
337
11
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
11
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
14
            : AggregateFunctionBitmapSerializationHelper<
337
14
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
14
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
427
            : AggregateFunctionBitmapSerializationHelper<
337
427
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
427
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
9
            : AggregateFunctionBitmapSerializationHelper<
337
9
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
9
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
9
            : AggregateFunctionBitmapSerializationHelper<
337
9
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
9
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
15
            : AggregateFunctionBitmapSerializationHelper<
337
15
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
15
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
_ZN5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
336
1
            : AggregateFunctionBitmapSerializationHelper<
337
1
                      AggregateFunctionBitmapData<AggregateFunctionBitmapUnionOp>,
338
1
                      AggregateFunctionBitmapCount<arg_is_nullable, ColVecType>>(argument_types_) {}
339
340
117
    String get_name() const override {
341
117
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
342
81
            return "bitmap_union_count";
343
81
        } else {
344
36
            return "bitmap_union_int";
345
36
        }
346
117
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE8get_nameB5cxx11Ev
Line
Count
Source
340
16
    String get_name() const override {
341
16
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
342
16
            return "bitmap_union_count";
343
        } else {
344
            return "bitmap_union_int";
345
        }
346
16
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE8get_nameB5cxx11Ev
Line
Count
Source
340
65
    String get_name() const override {
341
65
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
342
65
            return "bitmap_union_count";
343
        } else {
344
            return "bitmap_union_int";
345
        }
346
65
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE8get_nameB5cxx11Ev
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE8get_nameB5cxx11Ev
Line
Count
Source
340
16
    String get_name() const override {
341
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
342
            return "bitmap_union_count";
343
16
        } else {
344
16
            return "bitmap_union_int";
345
16
        }
346
16
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE8get_nameB5cxx11Ev
Line
Count
Source
340
20
    String get_name() const override {
341
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
342
            return "bitmap_union_count";
343
20
        } else {
344
20
            return "bitmap_union_int";
345
20
        }
346
20
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE8get_nameB5cxx11Ev
347
348
555
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE15get_return_typeEv
Line
Count
Source
348
21
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE15get_return_typeEv
Line
Count
Source
348
395
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE15get_return_typeEv
Line
Count
Source
348
18
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE15get_return_typeEv
Line
Count
Source
348
39
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE15get_return_typeEv
Line
Count
Source
348
28
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE15get_return_typeEv
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE15get_return_typeEv
Line
Count
Source
348
14
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE15get_return_typeEv
Line
Count
Source
348
14
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE15get_return_typeEv
Line
Count
Source
348
26
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE15get_return_typeEv
349
350
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
351
15.8k
             Arena&) const override {
352
15.8k
        if constexpr (arg_is_nullable) {
353
375
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
375
            if (!nullable_column.is_null_at(row_num)) {
355
347
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
347
                        nullable_column.get_nested_column());
357
347
                this->data(place).add(column.get_data()[row_num]);
358
347
            }
359
15.5k
        } else {
360
15.5k
            const auto& column =
361
15.5k
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
15.5k
            this->data(place).add(column.get_data()[row_num]);
363
15.5k
        }
364
15.8k
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
19
             Arena&) const override {
352
19
        if constexpr (arg_is_nullable) {
353
19
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
19
            if (!nullable_column.is_null_at(row_num)) {
355
18
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
18
                        nullable_column.get_nested_column());
357
18
                this->data(place).add(column.get_data()[row_num]);
358
18
            }
359
        } else {
360
            const auto& column =
361
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
            this->data(place).add(column.get_data()[row_num]);
363
        }
364
19
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
15.3k
             Arena&) const override {
352
        if constexpr (arg_is_nullable) {
353
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
            if (!nullable_column.is_null_at(row_num)) {
355
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
                        nullable_column.get_nested_column());
357
                this->data(place).add(column.get_data()[row_num]);
358
            }
359
15.3k
        } else {
360
15.3k
            const auto& column =
361
15.3k
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
15.3k
            this->data(place).add(column.get_data()[row_num]);
363
15.3k
        }
364
15.3k
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
63
             Arena&) const override {
352
63
        if constexpr (arg_is_nullable) {
353
63
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
63
            if (!nullable_column.is_null_at(row_num)) {
355
58
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
58
                        nullable_column.get_nested_column());
357
58
                this->data(place).add(column.get_data()[row_num]);
358
58
            }
359
        } else {
360
            const auto& column =
361
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
            this->data(place).add(column.get_data()[row_num]);
363
        }
364
63
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
92
             Arena&) const override {
352
92
        if constexpr (arg_is_nullable) {
353
92
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
92
            if (!nullable_column.is_null_at(row_num)) {
355
85
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
85
                        nullable_column.get_nested_column());
357
85
                this->data(place).add(column.get_data()[row_num]);
358
85
            }
359
        } else {
360
            const auto& column =
361
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
            this->data(place).add(column.get_data()[row_num]);
363
        }
364
92
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
201
             Arena&) const override {
352
201
        if constexpr (arg_is_nullable) {
353
201
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
201
            if (!nullable_column.is_null_at(row_num)) {
355
186
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
186
                        nullable_column.get_nested_column());
357
186
                this->data(place).add(column.get_data()[row_num]);
358
186
            }
359
        } else {
360
            const auto& column =
361
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
            this->data(place).add(column.get_data()[row_num]);
363
        }
364
201
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
57
             Arena&) const override {
352
        if constexpr (arg_is_nullable) {
353
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
            if (!nullable_column.is_null_at(row_num)) {
355
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
                        nullable_column.get_nested_column());
357
                this->data(place).add(column.get_data()[row_num]);
358
            }
359
57
        } else {
360
57
            const auto& column =
361
57
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
57
            this->data(place).add(column.get_data()[row_num]);
363
57
        }
364
57
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
57
             Arena&) const override {
352
        if constexpr (arg_is_nullable) {
353
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
            if (!nullable_column.is_null_at(row_num)) {
355
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
                        nullable_column.get_nested_column());
357
                this->data(place).add(column.get_data()[row_num]);
358
            }
359
57
        } else {
360
57
            const auto& column =
361
57
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
57
            this->data(place).add(column.get_data()[row_num]);
363
57
        }
364
57
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
59
             Arena&) const override {
352
        if constexpr (arg_is_nullable) {
353
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
            if (!nullable_column.is_null_at(row_num)) {
355
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
                        nullable_column.get_nested_column());
357
                this->data(place).add(column.get_data()[row_num]);
358
            }
359
59
        } else {
360
59
            const auto& column =
361
59
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
59
            this->data(place).add(column.get_data()[row_num]);
363
59
        }
364
59
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
351
9
             Arena&) const override {
352
        if constexpr (arg_is_nullable) {
353
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
354
            if (!nullable_column.is_null_at(row_num)) {
355
                const auto& column = assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(
356
                        nullable_column.get_nested_column());
357
                this->data(place).add(column.get_data()[row_num]);
358
            }
359
9
        } else {
360
9
            const auto& column =
361
9
                    assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
362
9
            this->data(place).add(column.get_data()[row_num]);
363
9
        }
364
9
    }
365
366
    void add_many(AggregateDataPtr __restrict place, const IColumn** columns,
367
167
                  std::vector<int>& rows, Arena&) const override {
368
        // now this only for bitmap_union_count function
369
167
        if constexpr (arg_is_nullable && std::is_same_v<ColVecType, ColumnBitmap>) {
370
0
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
371
0
            const auto& column =
372
0
                    assert_cast<const ColVecType&>(nullable_column.get_nested_column());
373
0
            std::vector<const BitmapValue*> values;
374
0
            for (auto row : rows) {
375
0
                if (!nullable_column.is_null_at(row)) {
376
0
                    values.push_back(&(column.get_data()[row]));
377
0
                }
378
0
            }
379
0
            this->data(place).add_batch(values);
380
167
        } else if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
381
167
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
382
167
            std::vector<const BitmapValue*> values;
383
271
            for (auto row : rows) {
384
271
                values.push_back(&(column.get_data()[row]));
385
271
            }
386
167
            this->data(place).add_batch(values);
387
167
        }
388
167
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Line
Count
Source
367
167
                  std::vector<int>& rows, Arena&) const override {
368
        // now this only for bitmap_union_count function
369
        if constexpr (arg_is_nullable && std::is_same_v<ColVecType, ColumnBitmap>) {
370
            const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
371
            const auto& column =
372
                    assert_cast<const ColVecType&>(nullable_column.get_nested_column());
373
            std::vector<const BitmapValue*> values;
374
            for (auto row : rows) {
375
                if (!nullable_column.is_null_at(row)) {
376
                    values.push_back(&(column.get_data()[row]));
377
                }
378
            }
379
            this->data(place).add_batch(values);
380
167
        } else if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
381
167
            const auto& column = assert_cast<const ColVecType&>(*columns[0]);
382
167
            std::vector<const BitmapValue*> values;
383
271
            for (auto row : rows) {
384
271
                values.push_back(&(column.get_data()[row]));
385
271
            }
386
167
            this->data(place).add_batch(values);
387
167
        }
388
167
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE8add_manyEPcPPKNS_7IColumnERSt6vectorIiSaIiEERNS_5ArenaE
389
390
    void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns,
391
68
                                Arena& arena) const override {
392
68
        auto normal_add_lambda = [&]() {
393
15.1k
            for (size_t i = 0; i < batch_size; ++i) {
394
15.1k
                this->add(place, columns, i, arena);
395
15.1k
            }
396
58
        };
Unexecuted instantiation: _ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
_ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
32
        auto normal_add_lambda = [&]() {
393
15.0k
            for (size_t i = 0; i < batch_size; ++i) {
394
15.0k
                this->add(place, columns, i, arena);
395
15.0k
            }
396
32
        };
_ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
3
        auto normal_add_lambda = [&]() {
393
14
            for (size_t i = 0; i < batch_size; ++i) {
394
11
                this->add(place, columns, i, arena);
395
11
            }
396
3
        };
_ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
5
        auto normal_add_lambda = [&]() {
393
28
            for (size_t i = 0; i < batch_size; ++i) {
394
23
                this->add(place, columns, i, arena);
395
23
            }
396
5
        };
_ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
5
        auto normal_add_lambda = [&]() {
393
19
            for (size_t i = 0; i < batch_size; ++i) {
394
14
                this->add(place, columns, i, arena);
395
14
            }
396
5
        };
Unexecuted instantiation: _ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
_ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
4
        auto normal_add_lambda = [&]() {
393
16
            for (size_t i = 0; i < batch_size; ++i) {
394
12
                this->add(place, columns, i, arena);
395
12
            }
396
4
        };
_ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
4
        auto normal_add_lambda = [&]() {
393
16
            for (size_t i = 0; i < batch_size; ++i) {
394
12
                this->add(place, columns, i, arena);
395
12
            }
396
4
        };
_ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
Line
Count
Source
392
5
        auto normal_add_lambda = [&]() {
393
18
            for (size_t i = 0; i < batch_size; ++i) {
394
13
                this->add(place, columns, i, arena);
395
13
            }
396
5
        };
Unexecuted instantiation: _ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlvE_clEv
397
398
        // now this only for bitmap_union_count function
399
68
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
42
            if (batch_size < BATCH_HALF_ROWS) {
402
32
                normal_add_lambda();
403
32
                return;
404
32
            }
405
10
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
10
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
10
                std::vector<const BitmapValue*> values;
408
25.6k
                for (size_t i = 0; i < batch_size; ++i) {
409
25.6k
                    if constexpr (arg_is_nullable) {
410
0
                        if ((*null_map)[i]) {
411
0
                            continue; // skip null value
412
0
                        }
413
0
                    }
414
0
                    values.push_back(&(column.get_data()[i]));
415
25.6k
                }
416
0
                this->data(place).add_batch(values);
417
0
            };
Unexecuted instantiation: _ZZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlRS7_PKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEE_clESC_SJ_
_ZZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaEENKUlRS7_PKNS_8PODArrayIhLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEE_clESC_SJ_
Line
Count
Source
405
10
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
10
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
10
                std::vector<const BitmapValue*> values;
408
25.6k
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
25.6k
                    values.push_back(&(column.get_data()[i]));
415
25.6k
                }
416
10
                this->data(place).add_batch(values);
417
10
            };
418
419
10
            if constexpr (arg_is_nullable) {
420
0
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
0
                add_batch_lambda(nullable_column.get_nested_column(),
422
0
                                 &(nullable_column.get_null_map_data()));
423
10
            } else {
424
10
                add_batch_lambda(*columns[0], nullptr);
425
10
            }
426
26
        } else {
427
26
            normal_add_lambda();
428
26
        }
429
68
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
42
                                Arena& arena) const override {
392
42
        auto normal_add_lambda = [&]() {
393
42
            for (size_t i = 0; i < batch_size; ++i) {
394
42
                this->add(place, columns, i, arena);
395
42
            }
396
42
        };
397
398
        // now this only for bitmap_union_count function
399
42
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
42
            if (batch_size < BATCH_HALF_ROWS) {
402
32
                normal_add_lambda();
403
32
                return;
404
32
            }
405
10
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
10
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
10
                std::vector<const BitmapValue*> values;
408
10
                for (size_t i = 0; i < batch_size; ++i) {
409
10
                    if constexpr (arg_is_nullable) {
410
10
                        if ((*null_map)[i]) {
411
10
                            continue; // skip null value
412
10
                        }
413
10
                    }
414
10
                    values.push_back(&(column.get_data()[i]));
415
10
                }
416
10
                this->data(place).add_batch(values);
417
10
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
10
            } else {
424
10
                add_batch_lambda(*columns[0], nullptr);
425
10
            }
426
        } else {
427
            normal_add_lambda();
428
        }
429
42
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
3
                                Arena& arena) const override {
392
3
        auto normal_add_lambda = [&]() {
393
3
            for (size_t i = 0; i < batch_size; ++i) {
394
3
                this->add(place, columns, i, arena);
395
3
            }
396
3
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
3
        } else {
427
3
            normal_add_lambda();
428
3
        }
429
3
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
5
                                Arena& arena) const override {
392
5
        auto normal_add_lambda = [&]() {
393
5
            for (size_t i = 0; i < batch_size; ++i) {
394
5
                this->add(place, columns, i, arena);
395
5
            }
396
5
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
5
        } else {
427
5
            normal_add_lambda();
428
5
        }
429
5
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
5
                                Arena& arena) const override {
392
5
        auto normal_add_lambda = [&]() {
393
5
            for (size_t i = 0; i < batch_size; ++i) {
394
5
                this->add(place, columns, i, arena);
395
5
            }
396
5
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
5
        } else {
427
5
            normal_add_lambda();
428
5
        }
429
5
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
4
                                Arena& arena) const override {
392
4
        auto normal_add_lambda = [&]() {
393
4
            for (size_t i = 0; i < batch_size; ++i) {
394
4
                this->add(place, columns, i, arena);
395
4
            }
396
4
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
4
        } else {
427
4
            normal_add_lambda();
428
4
        }
429
4
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
4
                                Arena& arena) const override {
392
4
        auto normal_add_lambda = [&]() {
393
4
            for (size_t i = 0; i < batch_size; ++i) {
394
4
                this->add(place, columns, i, arena);
395
4
            }
396
4
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
4
        } else {
427
4
            normal_add_lambda();
428
4
        }
429
4
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
391
5
                                Arena& arena) const override {
392
5
        auto normal_add_lambda = [&]() {
393
5
            for (size_t i = 0; i < batch_size; ++i) {
394
5
                this->add(place, columns, i, arena);
395
5
            }
396
5
        };
397
398
        // now this only for bitmap_union_count function
399
        if constexpr (std::is_same_v<ColVecType, ColumnBitmap>) {
400
            // if batch_size is small, the add_batch of fast union seems to be slower than normal add
401
            if (batch_size < BATCH_HALF_ROWS) {
402
                normal_add_lambda();
403
                return;
404
            }
405
            auto add_batch_lambda = [&](const IColumn& data_column, const NullMap* null_map) {
406
                const auto& column = assert_cast<const ColVecType&>(data_column);
407
                std::vector<const BitmapValue*> values;
408
                for (size_t i = 0; i < batch_size; ++i) {
409
                    if constexpr (arg_is_nullable) {
410
                        if ((*null_map)[i]) {
411
                            continue; // skip null value
412
                        }
413
                    }
414
                    values.push_back(&(column.get_data()[i]));
415
                }
416
                this->data(place).add_batch(values);
417
            };
418
419
            if constexpr (arg_is_nullable) {
420
                const auto& nullable_column = assert_cast<const ColumnNullable&>(*columns[0]);
421
                add_batch_lambda(nullable_column.get_nested_column(),
422
                                 &(nullable_column.get_null_map_data()));
423
            } else {
424
                add_batch_lambda(*columns[0], nullptr);
425
            }
426
5
        } else {
427
5
            normal_add_lambda();
428
5
        }
429
5
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
430
431
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
432
0
               Arena&) const override {
433
0
        this->data(place).merge(this->data(rhs).get());
434
0
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE5mergeEPcPKcRNS_5ArenaE
435
436
0
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
437
0
        this->data(place).write(buf);
438
0
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE9serializeEPKcRNS_14BufferWritableE
439
440
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
441
0
                     Arena&) const override {
442
0
        this->data(place).read(buf);
443
0
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
444
445
543
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
543
        auto& value_data = this->data(place).get();
447
543
        auto& column = assert_cast<ColVecResult&>(to);
448
543
        column.get_data().push_back(value_data.cardinality());
449
543
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
15
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
15
        auto& value_data = this->data(place).get();
447
15
        auto& column = assert_cast<ColVecResult&>(to);
448
15
        column.get_data().push_back(value_data.cardinality());
449
15
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
377
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
377
        auto& value_data = this->data(place).get();
447
377
        auto& column = assert_cast<ColVecResult&>(to);
448
377
        column.get_data().push_back(value_data.cardinality());
449
377
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
21
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
21
        auto& value_data = this->data(place).get();
447
21
        auto& column = assert_cast<ColVecResult&>(to);
448
21
        column.get_data().push_back(value_data.cardinality());
449
21
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
39
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
39
        auto& value_data = this->data(place).get();
447
39
        auto& column = assert_cast<ColVecResult&>(to);
448
39
        column.get_data().push_back(value_data.cardinality());
449
39
    }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
36
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
36
        auto& value_data = this->data(place).get();
447
36
        auto& column = assert_cast<ColVecResult&>(to);
448
36
        column.get_data().push_back(value_data.cardinality());
449
36
    }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
17
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
17
        auto& value_data = this->data(place).get();
447
17
        auto& column = assert_cast<ColVecResult&>(to);
448
17
        column.get_data().push_back(value_data.cardinality());
449
17
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
17
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
17
        auto& value_data = this->data(place).get();
447
17
        auto& column = assert_cast<ColVecResult&>(to);
448
17
        column.get_data().push_back(value_data.cardinality());
449
17
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
20
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
20
        auto& value_data = this->data(place).get();
447
20
        auto& column = assert_cast<ColVecResult&>(to);
448
20
        column.get_data().push_back(value_data.cardinality());
449
20
    }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
445
1
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
446
1
        auto& value_data = this->data(place).get();
447
1
        auto& column = assert_cast<ColVecResult&>(to);
448
1
        column.get_data().push_back(value_data.cardinality());
449
1
    }
450
451
71
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE5resetEPc
Line
Count
Source
451
3
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris28AggregateFunctionBitmapCountILb0ENS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEE5resetEPc
Line
Count
Source
451
39
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE5resetEPc
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE5resetEPc
Line
Count
Source
451
3
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE5resetEPc
Line
Count
Source
451
26
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb1ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE3EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE4EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE5EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris28AggregateFunctionBitmapCountILb0ENS_12ColumnVectorILNS_13PrimitiveTypeE6EEEE5resetEPc
452
};
453
454
AggregateFunctionPtr create_aggregate_function_bitmap_union(const std::string& name,
455
                                                            const DataTypes& argument_types,
456
                                                            const bool result_is_nullable);
457
458
} // namespace doris