Coverage Report

Created: 2026-04-01 20:50

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/util/bitmap_intersect.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
#pragma once
18
#include <parallel_hashmap/phmap.h>
19
20
#include "common/cast_set.h"
21
#include "core/string_ref.h"
22
#include "core/value/bitmap_value.h"
23
24
namespace doris {
25
#include "common/compile_check_begin.h"
26
27
namespace detail {
28
class Helper {
29
public:
30
    static const int DATETIME_PACKED_TIME_BYTE_SIZE = 8;
31
    static const int DATETIME_TYPE_BYTE_SIZE = 4;
32
    static const int DECIMAL_BYTE_SIZE = 16;
33
34
    // serialize_size start
35
    template <typename T>
36
323
    static int32_t serialize_size(const T& v) {
37
323
        return sizeof(T);
38
323
    }
_ZN5doris6detail6Helper14serialize_sizeIaEEiRKT_
Line
Count
Source
36
4
    static int32_t serialize_size(const T& v) {
37
4
        return sizeof(T);
38
4
    }
_ZN5doris6detail6Helper14serialize_sizeIsEEiRKT_
Line
Count
Source
36
7
    static int32_t serialize_size(const T& v) {
37
7
        return sizeof(T);
38
7
    }
_ZN5doris6detail6Helper14serialize_sizeIiEEiRKT_
Line
Count
Source
36
312
    static int32_t serialize_size(const T& v) {
37
312
        return sizeof(T);
38
312
    }
Unexecuted instantiation: _ZN5doris6detail6Helper14serialize_sizeIlEEiRKT_
Unexecuted instantiation: _ZN5doris6detail6Helper14serialize_sizeInEEiRKT_
39
40
    // write_to start
41
    template <typename T>
42
323
    static char* write_to(const T& v, char* dest) {
43
323
        size_t type_size = sizeof(T);
44
323
        memcpy(dest, &v, type_size);
45
323
        dest += type_size;
46
323
        return dest;
47
323
    }
_ZN5doris6detail6Helper8write_toIaEEPcRKT_S3_
Line
Count
Source
42
4
    static char* write_to(const T& v, char* dest) {
43
4
        size_t type_size = sizeof(T);
44
4
        memcpy(dest, &v, type_size);
45
4
        dest += type_size;
46
4
        return dest;
47
4
    }
_ZN5doris6detail6Helper8write_toIsEEPcRKT_S3_
Line
Count
Source
42
7
    static char* write_to(const T& v, char* dest) {
43
7
        size_t type_size = sizeof(T);
44
7
        memcpy(dest, &v, type_size);
45
7
        dest += type_size;
46
7
        return dest;
47
7
    }
_ZN5doris6detail6Helper8write_toIiEEPcRKT_S3_
Line
Count
Source
42
312
    static char* write_to(const T& v, char* dest) {
43
312
        size_t type_size = sizeof(T);
44
312
        memcpy(dest, &v, type_size);
45
312
        dest += type_size;
46
312
        return dest;
47
312
    }
Unexecuted instantiation: _ZN5doris6detail6Helper8write_toIlEEPcRKT_S3_
Unexecuted instantiation: _ZN5doris6detail6Helper8write_toInEEPcRKT_S3_
48
49
    // read_from start
50
    template <typename T>
51
245
    static void read_from(const char** src, T* result) {
52
245
        size_t type_size = sizeof(T);
53
245
        memcpy(result, *src, type_size);
54
245
        *src += type_size;
55
245
    }
_ZN5doris6detail6Helper9read_fromIaEEvPPKcPT_
Line
Count
Source
51
4
    static void read_from(const char** src, T* result) {
52
4
        size_t type_size = sizeof(T);
53
4
        memcpy(result, *src, type_size);
54
4
        *src += type_size;
55
4
    }
_ZN5doris6detail6Helper9read_fromIsEEvPPKcPT_
Line
Count
Source
51
7
    static void read_from(const char** src, T* result) {
52
7
        size_t type_size = sizeof(T);
53
7
        memcpy(result, *src, type_size);
54
7
        *src += type_size;
55
7
    }
_ZN5doris6detail6Helper9read_fromIiEEvPPKcPT_
Line
Count
Source
51
234
    static void read_from(const char** src, T* result) {
52
234
        size_t type_size = sizeof(T);
53
234
        memcpy(result, *src, type_size);
54
234
        *src += type_size;
55
234
    }
Unexecuted instantiation: _ZN5doris6detail6Helper9read_fromIlEEvPPKcPT_
Unexecuted instantiation: _ZN5doris6detail6Helper9read_fromInEEvPPKcPT_
56
};
57
58
template <>
59
0
inline char* Helper::write_to<VecDateTimeValue>(const VecDateTimeValue& v, char* dest) {
60
0
    *(int64_t*)dest = v.to_int64_datetime_packed();
61
0
    dest += DATETIME_PACKED_TIME_BYTE_SIZE;
62
0
    *(int*)dest = v.type();
63
0
    dest += DATETIME_TYPE_BYTE_SIZE;
64
0
    return dest;
65
0
}
66
67
template <>
68
0
inline char* Helper::write_to<DecimalV2Value>(const DecimalV2Value& v, char* dest) {
69
0
    __int128 value = v.value();
70
0
    memcpy(dest, &value, DECIMAL_BYTE_SIZE);
71
0
    dest += DECIMAL_BYTE_SIZE;
72
0
    return dest;
73
0
}
74
75
template <>
76
0
inline char* Helper::write_to<StringRef>(const StringRef& v, char* dest) {
77
0
    *(int32_t*)dest = cast_set<int32_t>(v.size);
78
0
    dest += 4;
79
0
    memcpy(dest, v.data, v.size);
80
0
    dest += v.size;
81
0
    return dest;
82
0
}
83
84
template <>
85
4
inline char* Helper::write_to<std::string>(const std::string& v, char* dest) {
86
4
    *(uint32_t*)dest = cast_set<uint32_t>(v.size());
87
4
    dest += 4;
88
4
    memcpy(dest, v.c_str(), v.size());
89
4
    dest += v.size();
90
4
    return dest;
91
4
}
92
// write_to end
93
94
template <>
95
0
inline int32_t Helper::serialize_size<VecDateTimeValue>(const VecDateTimeValue& v) {
96
0
    return Helper::DATETIME_PACKED_TIME_BYTE_SIZE + Helper::DATETIME_TYPE_BYTE_SIZE;
97
0
}
98
99
template <>
100
0
inline int32_t Helper::serialize_size<DecimalV2Value>(const DecimalV2Value& v) {
101
0
    return Helper::DECIMAL_BYTE_SIZE;
102
0
}
103
104
template <>
105
0
inline int32_t Helper::serialize_size<StringRef>(const StringRef& v) {
106
0
    return cast_set<int32_t>(v.size + 4);
107
0
}
108
109
template <>
110
4
inline int32_t Helper::serialize_size<std::string>(const std::string& v) {
111
4
    return cast_set<int32_t>(v.size() + 4);
112
4
}
113
// serialize_size end
114
115
template <>
116
0
inline void Helper::read_from<VecDateTimeValue>(const char** src, VecDateTimeValue* result) {
117
0
    result->from_packed_time(*(int64_t*)(*src));
118
0
    *src += DATETIME_PACKED_TIME_BYTE_SIZE;
119
0
    if (*(int*)(*src) == TIME_DATE) {
120
0
        result->cast_to_date();
121
0
    }
122
0
    *src += DATETIME_TYPE_BYTE_SIZE;
123
0
}
124
125
template <>
126
0
inline void Helper::read_from<DecimalV2Value>(const char** src, DecimalV2Value* result) {
127
0
    __int128 v = 0;
128
0
    memcpy(&v, *src, DECIMAL_BYTE_SIZE);
129
0
    *src += DECIMAL_BYTE_SIZE;
130
0
    *result = DecimalV2Value(v);
131
0
}
132
133
template <>
134
0
inline void Helper::read_from<StringRef>(const char** src, StringRef* result) {
135
0
    int32_t length = *(int32_t*)(*src);
136
0
    *src += 4;
137
0
    *result = StringRef((char*)*src, length);
138
0
    *src += length;
139
0
}
140
141
template <>
142
4
inline void Helper::read_from<std::string>(const char** src, std::string* result) {
143
4
    int32_t length = *(int32_t*)(*src);
144
4
    *src += 4;
145
4
    *result = std::string((char*)*src, length);
146
4
    *src += length;
147
4
}
148
// read_from end
149
} // namespace detail
150
151
// Calculate the intersection of two or more bitmaps
152
// Usage: intersect_count(bitmap_column_to_count, filter_column, filter_values ...)
153
// Example: intersect_count(user_id, event, 'A', 'B', 'C'), meaning find the intersect count of user_id in all A/B/C 3 bitmaps
154
// Todo(kks) Use Array type instead of variable arguments
155
template <typename T>
156
struct BitmapIntersect {
157
public:
158
543
    BitmapIntersect() = default;
_ZN5doris15BitmapIntersectIaEC2Ev
Line
Count
Source
158
5
    BitmapIntersect() = default;
_ZN5doris15BitmapIntersectIsEC2Ev
Line
Count
Source
158
20
    BitmapIntersect() = default;
_ZN5doris15BitmapIntersectIiEC2Ev
Line
Count
Source
158
358
    BitmapIntersect() = default;
_ZN5doris15BitmapIntersectIlEC2Ev
Line
Count
Source
158
153
    BitmapIntersect() = default;
Unexecuted instantiation: _ZN5doris15BitmapIntersectInEC2Ev
_ZN5doris15BitmapIntersectINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEEC2Ev
Line
Count
Source
158
7
    BitmapIntersect() = default;
159
160
    explicit BitmapIntersect(const char* src) { deserialize(src); }
161
162
267
    void add_key(const T key) {
163
267
        BitmapValue empty_bitmap;
164
267
        _bitmaps[key] = empty_bitmap;
165
267
    }
_ZN5doris15BitmapIntersectIaE7add_keyEa
Line
Count
Source
162
4
    void add_key(const T key) {
163
4
        BitmapValue empty_bitmap;
164
4
        _bitmaps[key] = empty_bitmap;
165
4
    }
_ZN5doris15BitmapIntersectIsE7add_keyEs
Line
Count
Source
162
3
    void add_key(const T key) {
163
3
        BitmapValue empty_bitmap;
164
3
        _bitmaps[key] = empty_bitmap;
165
3
    }
_ZN5doris15BitmapIntersectIiE7add_keyEi
Line
Count
Source
162
236
    void add_key(const T key) {
163
236
        BitmapValue empty_bitmap;
164
236
        _bitmaps[key] = empty_bitmap;
165
236
    }
_ZN5doris15BitmapIntersectIlE7add_keyEl
Line
Count
Source
162
20
    void add_key(const T key) {
163
20
        BitmapValue empty_bitmap;
164
20
        _bitmaps[key] = empty_bitmap;
165
20
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE7add_keyEn
_ZN5doris15BitmapIntersectINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEE7add_keyES6_
Line
Count
Source
162
4
    void add_key(const T key) {
163
4
        BitmapValue empty_bitmap;
164
4
        _bitmaps[key] = empty_bitmap;
165
4
    }
166
167
180
    void update(const T& key, const BitmapValue& bitmap) {
168
180
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
51
            _bitmaps[key] |= bitmap;
170
51
        }
171
180
    }
_ZN5doris15BitmapIntersectIaE6updateERKaRKNS_11BitmapValueE
Line
Count
Source
167
15
    void update(const T& key, const BitmapValue& bitmap) {
168
15
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
2
            _bitmaps[key] |= bitmap;
170
2
        }
171
15
    }
_ZN5doris15BitmapIntersectIsE6updateERKsRKNS_11BitmapValueE
Line
Count
Source
167
3
    void update(const T& key, const BitmapValue& bitmap) {
168
3
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
3
            _bitmaps[key] |= bitmap;
170
3
        }
171
3
    }
_ZN5doris15BitmapIntersectIiE6updateERKiRKNS_11BitmapValueE
Line
Count
Source
167
130
    void update(const T& key, const BitmapValue& bitmap) {
168
130
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
22
            _bitmaps[key] |= bitmap;
170
22
        }
171
130
    }
_ZN5doris15BitmapIntersectIlE6updateERKlRKNS_11BitmapValueE
Line
Count
Source
167
28
    void update(const T& key, const BitmapValue& bitmap) {
168
28
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
20
            _bitmaps[key] |= bitmap;
170
20
        }
171
28
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE6updateERKnRKNS_11BitmapValueE
_ZN5doris15BitmapIntersectINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEE6updateERKS6_RKNS_11BitmapValueE
Line
Count
Source
167
4
    void update(const T& key, const BitmapValue& bitmap) {
168
4
        if (_bitmaps.find(key) != _bitmaps.end()) {
169
4
            _bitmaps[key] |= bitmap;
170
4
        }
171
4
    }
172
173
126
    void merge(const BitmapIntersect& other) {
174
245
        for (auto& kv : other._bitmaps) {
175
245
            if (_bitmaps.find(kv.first) != _bitmaps.end()) {
176
126
                _bitmaps[kv.first] |= kv.second;
177
126
            } else {
178
119
                _bitmaps[kv.first] = kv.second;
179
119
            }
180
245
        }
181
126
    }
_ZN5doris15BitmapIntersectIaE5mergeERKS1_
Line
Count
Source
173
2
    void merge(const BitmapIntersect& other) {
174
4
        for (auto& kv : other._bitmaps) {
175
4
            if (_bitmaps.find(kv.first) != _bitmaps.end()) {
176
2
                _bitmaps[kv.first] |= kv.second;
177
2
            } else {
178
2
                _bitmaps[kv.first] = kv.second;
179
2
            }
180
4
        }
181
2
    }
_ZN5doris15BitmapIntersectIsE5mergeERKS1_
Line
Count
Source
173
7
    void merge(const BitmapIntersect& other) {
174
7
        for (auto& kv : other._bitmaps) {
175
7
            if (_bitmaps.find(kv.first) != _bitmaps.end()) {
176
0
                _bitmaps[kv.first] |= kv.second;
177
7
            } else {
178
7
                _bitmaps[kv.first] = kv.second;
179
7
            }
180
7
        }
181
7
    }
_ZN5doris15BitmapIntersectIiE5mergeERKS1_
Line
Count
Source
173
117
    void merge(const BitmapIntersect& other) {
174
234
        for (auto& kv : other._bitmaps) {
175
234
            if (_bitmaps.find(kv.first) != _bitmaps.end()) {
176
124
                _bitmaps[kv.first] |= kv.second;
177
124
            } else {
178
110
                _bitmaps[kv.first] = kv.second;
179
110
            }
180
234
        }
181
117
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectIlE5mergeERKS1_
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE5mergeERKS1_
182
183
    // intersection
184
38
    BitmapValue intersect() const {
185
38
        BitmapValue result;
186
38
        if (_bitmaps.empty()) {
187
1
            return result;
188
1
        }
189
37
        auto it = _bitmaps.begin();
190
37
        result |= it->second;
191
37
        it++;
192
83
        for (; it != _bitmaps.end(); it++) {
193
46
            result &= it->second;
194
46
        }
195
37
        return result;
196
38
    }
_ZNK5doris15BitmapIntersectIaE9intersectEv
Line
Count
Source
184
1
    BitmapValue intersect() const {
185
1
        BitmapValue result;
186
1
        if (_bitmaps.empty()) {
187
0
            return result;
188
0
        }
189
1
        auto it = _bitmaps.begin();
190
1
        result |= it->second;
191
1
        it++;
192
2
        for (; it != _bitmaps.end(); it++) {
193
1
            result &= it->second;
194
1
        }
195
1
        return result;
196
1
    }
_ZNK5doris15BitmapIntersectIsE9intersectEv
Line
Count
Source
184
3
    BitmapValue intersect() const {
185
3
        BitmapValue result;
186
3
        if (_bitmaps.empty()) {
187
0
            return result;
188
0
        }
189
3
        auto it = _bitmaps.begin();
190
3
        result |= it->second;
191
3
        it++;
192
3
        for (; it != _bitmaps.end(); it++) {
193
0
            result &= it->second;
194
0
        }
195
3
        return result;
196
3
    }
_ZNK5doris15BitmapIntersectIiE9intersectEv
Line
Count
Source
184
17
    BitmapValue intersect() const {
185
17
        BitmapValue result;
186
17
        if (_bitmaps.empty()) {
187
0
            return result;
188
0
        }
189
17
        auto it = _bitmaps.begin();
190
17
        result |= it->second;
191
17
        it++;
192
34
        for (; it != _bitmaps.end(); it++) {
193
17
            result &= it->second;
194
17
        }
195
17
        return result;
196
17
    }
_ZNK5doris15BitmapIntersectIlE9intersectEv
Line
Count
Source
184
17
    BitmapValue intersect() const {
185
17
        BitmapValue result;
186
17
        if (_bitmaps.empty()) {
187
1
            return result;
188
1
        }
189
16
        auto it = _bitmaps.begin();
190
16
        result |= it->second;
191
16
        it++;
192
44
        for (; it != _bitmaps.end(); it++) {
193
28
            result &= it->second;
194
28
        }
195
16
        return result;
196
17
    }
Unexecuted instantiation: _ZNK5doris15BitmapIntersectInE9intersectEv
197
198
    // calculate the intersection for _bitmaps's bitmap values
199
35
    int64_t intersect_count() const {
200
35
        if (_bitmaps.empty()) {
201
4
            return 0;
202
4
        }
203
31
        return intersect().cardinality();
204
35
    }
_ZNK5doris15BitmapIntersectIaE15intersect_countEv
Line
Count
Source
199
1
    int64_t intersect_count() const {
200
1
        if (_bitmaps.empty()) {
201
0
            return 0;
202
0
        }
203
1
        return intersect().cardinality();
204
1
    }
_ZNK5doris15BitmapIntersectIsE15intersect_countEv
Line
Count
Source
199
3
    int64_t intersect_count() const {
200
3
        if (_bitmaps.empty()) {
201
0
            return 0;
202
0
        }
203
3
        return intersect().cardinality();
204
3
    }
_ZNK5doris15BitmapIntersectIiE15intersect_countEv
Line
Count
Source
199
19
    int64_t intersect_count() const {
200
19
        if (_bitmaps.empty()) {
201
2
            return 0;
202
2
        }
203
17
        return intersect().cardinality();
204
19
    }
_ZNK5doris15BitmapIntersectIlE15intersect_countEv
Line
Count
Source
199
12
    int64_t intersect_count() const {
200
12
        if (_bitmaps.empty()) {
201
2
            return 0;
202
2
        }
203
10
        return intersect().cardinality();
204
12
    }
Unexecuted instantiation: _ZNK5doris15BitmapIntersectInE15intersect_countEv
205
206
    // the serialize size
207
173
    size_t size() {
208
173
        size_t size = 4;
209
323
        for (auto& kv : _bitmaps) {
210
323
            size += detail::Helper::serialize_size(kv.first);
211
323
            size += kv.second.getSizeInBytes();
212
323
        }
213
173
        return size;
214
173
    }
_ZN5doris15BitmapIntersectIaE4sizeEv
Line
Count
Source
207
2
    size_t size() {
208
2
        size_t size = 4;
209
4
        for (auto& kv : _bitmaps) {
210
4
            size += detail::Helper::serialize_size(kv.first);
211
4
            size += kv.second.getSizeInBytes();
212
4
        }
213
2
        return size;
214
2
    }
_ZN5doris15BitmapIntersectIsE4sizeEv
Line
Count
Source
207
7
    size_t size() {
208
7
        size_t size = 4;
209
7
        for (auto& kv : _bitmaps) {
210
7
            size += detail::Helper::serialize_size(kv.first);
211
7
            size += kv.second.getSizeInBytes();
212
7
        }
213
7
        return size;
214
7
    }
_ZN5doris15BitmapIntersectIiE4sizeEv
Line
Count
Source
207
164
    size_t size() {
208
164
        size_t size = 4;
209
312
        for (auto& kv : _bitmaps) {
210
312
            size += detail::Helper::serialize_size(kv.first);
211
312
            size += kv.second.getSizeInBytes();
212
312
        }
213
164
        return size;
214
164
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectIlE4sizeEv
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE4sizeEv
215
216
    //must call size() first
217
173
    void serialize(char* dest) {
218
173
        char* writer = dest;
219
173
        *(int32_t*)writer = cast_set<int32_t>(_bitmaps.size());
220
173
        writer += 4;
221
323
        for (auto& kv : _bitmaps) {
222
323
            writer = detail::Helper::write_to(kv.first, writer);
223
323
            kv.second.write_to(writer);
224
323
            writer += kv.second.getSizeInBytes();
225
323
        }
226
173
    }
_ZN5doris15BitmapIntersectIaE9serializeEPc
Line
Count
Source
217
2
    void serialize(char* dest) {
218
2
        char* writer = dest;
219
2
        *(int32_t*)writer = cast_set<int32_t>(_bitmaps.size());
220
2
        writer += 4;
221
4
        for (auto& kv : _bitmaps) {
222
4
            writer = detail::Helper::write_to(kv.first, writer);
223
4
            kv.second.write_to(writer);
224
4
            writer += kv.second.getSizeInBytes();
225
4
        }
226
2
    }
_ZN5doris15BitmapIntersectIsE9serializeEPc
Line
Count
Source
217
7
    void serialize(char* dest) {
218
7
        char* writer = dest;
219
7
        *(int32_t*)writer = cast_set<int32_t>(_bitmaps.size());
220
7
        writer += 4;
221
7
        for (auto& kv : _bitmaps) {
222
7
            writer = detail::Helper::write_to(kv.first, writer);
223
7
            kv.second.write_to(writer);
224
7
            writer += kv.second.getSizeInBytes();
225
7
        }
226
7
    }
_ZN5doris15BitmapIntersectIiE9serializeEPc
Line
Count
Source
217
164
    void serialize(char* dest) {
218
164
        char* writer = dest;
219
164
        *(int32_t*)writer = cast_set<int32_t>(_bitmaps.size());
220
164
        writer += 4;
221
312
        for (auto& kv : _bitmaps) {
222
312
            writer = detail::Helper::write_to(kv.first, writer);
223
312
            kv.second.write_to(writer);
224
312
            writer += kv.second.getSizeInBytes();
225
312
        }
226
164
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectIlE9serializeEPc
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE9serializeEPc
227
228
134
    void deserialize(const char* src) {
229
134
        const char* reader = src;
230
134
        int32_t bitmaps_size = *(int32_t*)reader;
231
134
        reader += 4;
232
379
        for (int32_t i = 0; i < bitmaps_size; i++) {
233
245
            T key;
234
245
            detail::Helper::read_from(&reader, &key);
235
245
            BitmapValue bitmap(reader);
236
245
            reader += bitmap.getSizeInBytes();
237
245
            _bitmaps[key] = bitmap;
238
245
        }
239
134
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectINSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEE11deserializeEPKc
_ZN5doris15BitmapIntersectIaE11deserializeEPKc
Line
Count
Source
228
2
    void deserialize(const char* src) {
229
2
        const char* reader = src;
230
2
        int32_t bitmaps_size = *(int32_t*)reader;
231
2
        reader += 4;
232
6
        for (int32_t i = 0; i < bitmaps_size; i++) {
233
4
            T key;
234
4
            detail::Helper::read_from(&reader, &key);
235
4
            BitmapValue bitmap(reader);
236
4
            reader += bitmap.getSizeInBytes();
237
4
            _bitmaps[key] = bitmap;
238
4
        }
239
2
    }
_ZN5doris15BitmapIntersectIsE11deserializeEPKc
Line
Count
Source
228
7
    void deserialize(const char* src) {
229
7
        const char* reader = src;
230
7
        int32_t bitmaps_size = *(int32_t*)reader;
231
7
        reader += 4;
232
14
        for (int32_t i = 0; i < bitmaps_size; i++) {
233
7
            T key;
234
7
            detail::Helper::read_from(&reader, &key);
235
7
            BitmapValue bitmap(reader);
236
7
            reader += bitmap.getSizeInBytes();
237
7
            _bitmaps[key] = bitmap;
238
7
        }
239
7
    }
_ZN5doris15BitmapIntersectIiE11deserializeEPKc
Line
Count
Source
228
125
    void deserialize(const char* src) {
229
125
        const char* reader = src;
230
125
        int32_t bitmaps_size = *(int32_t*)reader;
231
125
        reader += 4;
232
359
        for (int32_t i = 0; i < bitmaps_size; i++) {
233
234
            T key;
234
234
            detail::Helper::read_from(&reader, &key);
235
234
            BitmapValue bitmap(reader);
236
234
            reader += bitmap.getSizeInBytes();
237
234
            _bitmaps[key] = bitmap;
238
234
        }
239
125
    }
Unexecuted instantiation: _ZN5doris15BitmapIntersectIlE11deserializeEPKc
Unexecuted instantiation: _ZN5doris15BitmapIntersectInE11deserializeEPKc
240
241
protected:
242
    std::map<T, BitmapValue> _bitmaps;
243
};
244
245
template <>
246
struct BitmapIntersect<std::string_view> {
247
public:
248
5
    BitmapIntersect() = default;
249
250
0
    explicit BitmapIntersect(const char* src) { deserialize(src); }
251
252
4
    void add_key(const std::string_view key) {
253
4
        BitmapValue empty_bitmap;
254
4
        _bitmaps[key] = empty_bitmap;
255
4
    }
256
257
15
    void update(const std::string_view& key, const BitmapValue& bitmap) {
258
15
        if (_bitmaps.find(key) != _bitmaps.end()) {
259
2
            _bitmaps[key] |= bitmap;
260
2
        }
261
15
    }
262
263
2
    void merge(const BitmapIntersect& other) {
264
4
        for (auto& kv : other._bitmaps) {
265
4
            if (_bitmaps.find(kv.first) != _bitmaps.end()) {
266
2
                _bitmaps[kv.first] |= kv.second;
267
2
            } else {
268
2
                _bitmaps[kv.first] = kv.second;
269
2
            }
270
4
        }
271
2
    }
272
273
    // intersection
274
1
    BitmapValue intersect() const {
275
1
        BitmapValue result;
276
1
        auto it = _bitmaps.begin();
277
1
        result |= it->second;
278
1
        it++;
279
2
        for (; it != _bitmaps.end(); it++) {
280
1
            result &= it->second;
281
1
        }
282
1
        return result;
283
1
    }
284
285
    // calculate the intersection for _bitmaps's bitmap values
286
1
    int64_t intersect_count() const {
287
1
        if (_bitmaps.empty()) {
288
0
            return 0;
289
0
        }
290
1
        return intersect().cardinality();
291
1
    }
292
293
    // the serialize size
294
2
    size_t size() {
295
2
        size_t size = 4;
296
4
        for (auto& kv : _bitmaps) {
297
4
            size += detail::Helper::serialize_size(kv.first);
298
4
            size += kv.second.getSizeInBytes();
299
4
        }
300
2
        return size;
301
2
    }
302
303
    //must call size() first
304
2
    void serialize(char* dest) {
305
2
        char* writer = dest;
306
2
        *(int32_t*)writer = cast_set<int32_t>(_bitmaps.size());
307
2
        writer += 4;
308
4
        for (auto& kv : _bitmaps) {
309
4
            writer = detail::Helper::write_to(kv.first, writer);
310
4
            kv.second.write_to(writer);
311
4
            writer += kv.second.getSizeInBytes();
312
4
        }
313
2
    }
314
315
2
    void deserialize(const char* src) {
316
2
        const char* reader = src;
317
2
        int32_t bitmaps_size = *(int32_t*)reader;
318
2
        reader += 4;
319
6
        for (int32_t i = 0; i < bitmaps_size; i++) {
320
4
            std::string key;
321
4
            detail::Helper::read_from(&reader, &key);
322
4
            BitmapValue bitmap(reader);
323
4
            reader += bitmap.getSizeInBytes();
324
4
            _bitmaps[key] = bitmap;
325
4
        }
326
2
    }
327
328
protected:
329
    phmap::flat_hash_map<std::string, BitmapValue> _bitmaps;
330
};
331
#include "common/compile_check_end.h"
332
} // namespace doris