be/src/exprs/function/function_bitmap_variadic.cpp
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 | | #include <stddef.h> |
19 | | |
20 | | #include <algorithm> |
21 | | #include <functional> |
22 | | #include <memory> |
23 | | #include <type_traits> |
24 | | #include <utility> |
25 | | #include <vector> |
26 | | |
27 | | #include "common/status.h" |
28 | | #include "core/assert_cast.h" |
29 | | #include "core/block/block.h" |
30 | | #include "core/block/column_numbers.h" |
31 | | #include "core/block/column_with_type_and_name.h" |
32 | | #include "core/column/column.h" |
33 | | #include "core/column/column_complex.h" |
34 | | #include "core/column/column_nullable.h" |
35 | | #include "core/column/column_vector.h" |
36 | | #include "core/data_type/data_type.h" |
37 | | #include "core/data_type/data_type_bitmap.h" |
38 | | #include "core/data_type/data_type_nullable.h" |
39 | | #include "core/data_type/data_type_number.h" |
40 | | #include "core/types.h" |
41 | | #include "core/value/bitmap_value.h" |
42 | | #include "exprs/aggregate/aggregate_function.h" |
43 | | #include "exprs/function/function.h" |
44 | | #include "exprs/function/simple_function_factory.h" |
45 | | |
46 | | namespace doris { |
47 | | class FunctionContext; |
48 | | } // namespace doris |
49 | | |
50 | | namespace doris { |
51 | | |
52 | | // currently only bitmap_or and bitmap_or_count will call this function, |
53 | | // other bitmap functions will use default implementation for nulls |
54 | | #define BITMAP_OR_NULLABLE(nullable, input_rows_count, res, op) \ |
55 | 119 | const auto& nested_col_ptr = nullable->get_nested_column_ptr(); \ |
56 | 119 | const auto* __restrict null_map_data = nullable->get_null_map_data().data(); \ |
57 | 119 | const auto& mid_data = assert_cast<const ColumnBitmap*>(nested_col_ptr.get())->get_data(); \ |
58 | 277 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
59 | 158 | if (!null_map_data[row]) { \ |
60 | 77 | res[row] op mid_data[row]; \ |
61 | 77 | } \ |
62 | 158 | } |
63 | | |
64 | | #define BITMAP_FUNCTION_VARIADIC(CLASS, FUNCTION_NAME, OP) \ |
65 | | struct CLASS { \ |
66 | | static constexpr auto name = #FUNCTION_NAME; \ |
67 | | using ResultDataType = DataTypeBitMap; \ |
68 | | static Status vector_vector(ColumnPtr argument_columns[], size_t col_size, \ |
69 | | size_t input_rows_count, std::vector<BitmapValue>& res, \ |
70 | 438 | IColumn* res_nulls) { \ |
71 | 438 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ |
72 | 438 | int nullable_cols_count = 0; \ |
73 | 438 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ |
74 | 438 | if (res_nulls) { \ |
75 | 49 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ |
76 | 49 | } \ |
77 | 438 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ |
78 | 26 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ |
79 | 26 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ |
80 | 412 | } else { \ |
81 | 412 | const auto& mid_data = \ |
82 | 412 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ |
83 | 3.32k | for (size_t row = 0; row < input_rows_count; ++row) { \ |
84 | 2.91k | res[row] = mid_data[row]; \ |
85 | 2.91k | } \ |
86 | 412 | } \ |
87 | 911 | for (size_t col = 1; col < col_size; ++col) { \ |
88 | 473 | if (auto* nullable = \ |
89 | 473 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ |
90 | 48 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ |
91 | 48 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ |
92 | 425 | } else { \ |
93 | 425 | const auto& col_data = \ |
94 | 425 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ |
95 | 425 | ->get_data(); \ |
96 | 3.33k | for (size_t row = 0; row < input_rows_count; ++row) { \ |
97 | 2.90k | res[row] OP col_data[row]; \ |
98 | 2.90k | } \ |
99 | 425 | } \ |
100 | 473 | } \ |
101 | 438 | if (res_nulls_data && nullable_cols_count == col_size) { \ |
102 | 23 | const auto* null_map_data = null_map_datas[0]; \ |
103 | 46 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
104 | 23 | res_nulls_data[row] = null_map_data[row]; \ |
105 | 23 | } \ |
106 | 46 | for (int i = 1; i < nullable_cols_count; ++i) { \ |
107 | 23 | null_map_data = null_map_datas[i]; \ |
108 | 46 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
109 | 23 | res_nulls_data[row] &= null_map_data[row]; \ |
110 | 23 | } \ |
111 | 23 | } \ |
112 | 23 | } \ |
113 | 438 | return Status::OK(); \ |
114 | 438 | } \ _ZN5doris8BitmapOr13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRSt6vectorINS_11BitmapValueESaIS8_EEPS2_ Line | Count | Source | 70 | 89 | IColumn* res_nulls) { \ | 71 | 89 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ | 72 | 89 | int nullable_cols_count = 0; \ | 73 | 89 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ | 74 | 89 | if (res_nulls) { \ | 75 | 49 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ | 76 | 49 | } \ | 77 | 89 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 78 | 26 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 79 | 26 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ | 80 | 63 | } else { \ | 81 | 63 | const auto& mid_data = \ | 82 | 63 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 83 | 171 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 84 | 108 | res[row] = mid_data[row]; \ | 85 | 108 | } \ | 86 | 63 | } \ | 87 | 195 | for (size_t col = 1; col < col_size; ++col) { \ | 88 | 106 | if (auto* nullable = \ | 89 | 106 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 90 | 48 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 91 | 48 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ | 92 | 58 | } else { \ | 93 | 58 | const auto& col_data = \ | 94 | 58 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 95 | 58 | ->get_data(); \ | 96 | 143 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 85 | res[row] OP col_data[row]; \ | 98 | 85 | } \ | 99 | 58 | } \ | 100 | 106 | } \ | 101 | 89 | if (res_nulls_data && nullable_cols_count == col_size) { \ | 102 | 23 | const auto* null_map_data = null_map_datas[0]; \ | 103 | 46 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 104 | 23 | res_nulls_data[row] = null_map_data[row]; \ | 105 | 23 | } \ | 106 | 46 | for (int i = 1; i < nullable_cols_count; ++i) { \ | 107 | 23 | null_map_data = null_map_datas[i]; \ | 108 | 46 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 109 | 23 | res_nulls_data[row] &= null_map_data[row]; \ | 110 | 23 | } \ | 111 | 23 | } \ | 112 | 23 | } \ | 113 | 89 | return Status::OK(); \ | 114 | 89 | } \ |
_ZN5doris9BitmapXor13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRSt6vectorINS_11BitmapValueESaIS8_EEPS2_ Line | Count | Source | 70 | 324 | IColumn* res_nulls) { \ | 71 | 324 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ | 72 | 324 | int nullable_cols_count = 0; \ | 73 | 324 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ | 74 | 324 | if (res_nulls) { \ | 75 | 0 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ | 76 | 0 | } \ | 77 | 324 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 78 | 0 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 79 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ | 80 | 324 | } else { \ | 81 | 324 | const auto& mid_data = \ | 82 | 324 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 83 | 3.08k | for (size_t row = 0; row < input_rows_count; ++row) { \ | 84 | 2.75k | res[row] = mid_data[row]; \ | 85 | 2.75k | } \ | 86 | 324 | } \ | 87 | 660 | for (size_t col = 1; col < col_size; ++col) { \ | 88 | 336 | if (auto* nullable = \ | 89 | 336 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 90 | 0 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 91 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ | 92 | 336 | } else { \ | 93 | 336 | const auto& col_data = \ | 94 | 336 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 95 | 336 | ->get_data(); \ | 96 | 3.10k | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 2.76k | res[row] OP col_data[row]; \ | 98 | 2.76k | } \ | 99 | 336 | } \ | 100 | 336 | } \ | 101 | 324 | if (res_nulls_data && nullable_cols_count == col_size) { \ | 102 | 0 | const auto* null_map_data = null_map_datas[0]; \ | 103 | 0 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 104 | 0 | res_nulls_data[row] = null_map_data[row]; \ | 105 | 0 | } \ | 106 | 0 | for (int i = 1; i < nullable_cols_count; ++i) { \ | 107 | 0 | null_map_data = null_map_datas[i]; \ | 108 | 0 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 109 | 0 | res_nulls_data[row] &= null_map_data[row]; \ | 110 | 0 | } \ | 111 | 0 | } \ | 112 | 0 | } \ | 113 | 324 | return Status::OK(); \ | 114 | 324 | } \ |
_ZN5doris9BitmapAnd13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRSt6vectorINS_11BitmapValueESaIS8_EEPS2_ Line | Count | Source | 70 | 25 | IColumn* res_nulls) { \ | 71 | 25 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ | 72 | 25 | int nullable_cols_count = 0; \ | 73 | 25 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ | 74 | 25 | if (res_nulls) { \ | 75 | 0 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ | 76 | 0 | } \ | 77 | 25 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 78 | 0 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 79 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ | 80 | 25 | } else { \ | 81 | 25 | const auto& mid_data = \ | 82 | 25 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 83 | 74 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 84 | 49 | res[row] = mid_data[row]; \ | 85 | 49 | } \ | 86 | 25 | } \ | 87 | 56 | for (size_t col = 1; col < col_size; ++col) { \ | 88 | 31 | if (auto* nullable = \ | 89 | 31 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 90 | 0 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 91 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ | 92 | 31 | } else { \ | 93 | 31 | const auto& col_data = \ | 94 | 31 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 95 | 31 | ->get_data(); \ | 96 | 85 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 54 | res[row] OP col_data[row]; \ | 98 | 54 | } \ | 99 | 31 | } \ | 100 | 31 | } \ | 101 | 25 | if (res_nulls_data && nullable_cols_count == col_size) { \ | 102 | 0 | const auto* null_map_data = null_map_datas[0]; \ | 103 | 0 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 104 | 0 | res_nulls_data[row] = null_map_data[row]; \ | 105 | 0 | } \ | 106 | 0 | for (int i = 1; i < nullable_cols_count; ++i) { \ | 107 | 0 | null_map_data = null_map_datas[i]; \ | 108 | 0 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 109 | 0 | res_nulls_data[row] &= null_map_data[row]; \ | 110 | 0 | } \ | 111 | 0 | } \ | 112 | 0 | } \ | 113 | 25 | return Status::OK(); \ | 114 | 25 | } \ |
|
115 | | } |
116 | | |
117 | | #define BITMAP_FUNCTION_COUNT_VARIADIC(CLASS, FUNCTION_NAME, OP) \ |
118 | | struct CLASS { \ |
119 | | static constexpr auto name = #FUNCTION_NAME; \ |
120 | | using ResultDataType = DataTypeInt64; \ |
121 | | using TData = std::vector<BitmapValue>; \ |
122 | | using ResTData = typename ColumnInt64::Container; \ |
123 | | static Status vector_vector(ColumnPtr argument_columns[], size_t col_size, \ |
124 | 110 | size_t input_rows_count, ResTData& res, IColumn* res_nulls) { \ |
125 | 110 | TData vals; \ |
126 | 110 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ |
127 | 18 | vals.resize(input_rows_count); \ |
128 | 18 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, =); \ |
129 | 92 | } else { \ |
130 | 92 | vals = assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ |
131 | 92 | } \ |
132 | 251 | for (size_t col = 1; col < col_size; ++col) { \ |
133 | 141 | if (auto* nullable = \ |
134 | 141 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ |
135 | 27 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, OP); \ |
136 | 114 | } else { \ |
137 | 114 | const auto& col_data = \ |
138 | 114 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ |
139 | 114 | ->get_data(); \ |
140 | 327 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
141 | 213 | vals[row] OP col_data[row]; \ |
142 | 213 | } \ |
143 | 114 | } \ |
144 | 141 | } \ |
145 | 326 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
146 | 216 | res[row] = vals[row].cardinality(); \ |
147 | 216 | } \ |
148 | 110 | return Status::OK(); \ |
149 | 110 | } \ _ZN5doris13BitmapOrCount13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEPS2_ Line | Count | Source | 124 | 38 | size_t input_rows_count, ResTData& res, IColumn* res_nulls) { \ | 125 | 38 | TData vals; \ | 126 | 38 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 127 | 18 | vals.resize(input_rows_count); \ | 128 | 18 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, =); \ | 129 | 20 | } else { \ | 130 | 20 | vals = assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 131 | 20 | } \ | 132 | 85 | for (size_t col = 1; col < col_size; ++col) { \ | 133 | 47 | if (auto* nullable = \ | 134 | 47 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 135 | 27 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, OP); \ | 136 | 27 | } else { \ | 137 | 20 | const auto& col_data = \ | 138 | 20 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 139 | 20 | ->get_data(); \ | 140 | 61 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 141 | 41 | vals[row] OP col_data[row]; \ | 142 | 41 | } \ | 143 | 20 | } \ | 144 | 47 | } \ | 145 | 110 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 146 | 72 | res[row] = vals[row].cardinality(); \ | 147 | 72 | } \ | 148 | 38 | return Status::OK(); \ | 149 | 38 | } \ |
_ZN5doris14BitmapAndCount13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEPS2_ Line | Count | Source | 124 | 36 | size_t input_rows_count, ResTData& res, IColumn* res_nulls) { \ | 125 | 36 | TData vals; \ | 126 | 36 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 127 | 0 | vals.resize(input_rows_count); \ | 128 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, =); \ | 129 | 36 | } else { \ | 130 | 36 | vals = assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 131 | 36 | } \ | 132 | 83 | for (size_t col = 1; col < col_size; ++col) { \ | 133 | 47 | if (auto* nullable = \ | 134 | 47 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 135 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, OP); \ | 136 | 47 | } else { \ | 137 | 47 | const auto& col_data = \ | 138 | 47 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 139 | 47 | ->get_data(); \ | 140 | 133 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 141 | 86 | vals[row] OP col_data[row]; \ | 142 | 86 | } \ | 143 | 47 | } \ | 144 | 47 | } \ | 145 | 108 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 146 | 72 | res[row] = vals[row].cardinality(); \ | 147 | 72 | } \ | 148 | 36 | return Status::OK(); \ | 149 | 36 | } \ |
_ZN5doris14BitmapXorCount13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEEPS2_ Line | Count | Source | 124 | 36 | size_t input_rows_count, ResTData& res, IColumn* res_nulls) { \ | 125 | 36 | TData vals; \ | 126 | 36 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 127 | 0 | vals.resize(input_rows_count); \ | 128 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, =); \ | 129 | 36 | } else { \ | 130 | 36 | vals = assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 131 | 36 | } \ | 132 | 83 | for (size_t col = 1; col < col_size; ++col) { \ | 133 | 47 | if (auto* nullable = \ | 134 | 47 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 135 | 0 | BITMAP_OR_NULLABLE(nullable, input_rows_count, vals, OP); \ | 136 | 47 | } else { \ | 137 | 47 | const auto& col_data = \ | 138 | 47 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 139 | 47 | ->get_data(); \ | 140 | 133 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 141 | 86 | vals[row] OP col_data[row]; \ | 142 | 86 | } \ | 143 | 47 | } \ | 144 | 47 | } \ | 145 | 108 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 146 | 72 | res[row] = vals[row].cardinality(); \ | 147 | 72 | } \ | 148 | 36 | return Status::OK(); \ | 149 | 36 | } \ |
|
150 | | } |
151 | | |
152 | | BITMAP_FUNCTION_VARIADIC(BitmapOr, bitmap_or, |=); |
153 | | BITMAP_FUNCTION_VARIADIC(BitmapAnd, bitmap_and, &=); |
154 | | BITMAP_FUNCTION_VARIADIC(BitmapXor, bitmap_xor, ^=); |
155 | | BITMAP_FUNCTION_COUNT_VARIADIC(BitmapOrCount, bitmap_or_count, |=); |
156 | | BITMAP_FUNCTION_COUNT_VARIADIC(BitmapAndCount, bitmap_and_count, &=); |
157 | | BITMAP_FUNCTION_COUNT_VARIADIC(BitmapXorCount, bitmap_xor_count, ^=); |
158 | | |
159 | | Status execute_bitmap_op_count_null_to_zero( |
160 | | FunctionContext* context, Block& block, const ColumnNumbers& arguments, uint32_t result, |
161 | | size_t input_rows_count, |
162 | | const std::function<Status(FunctionContext*, Block&, const ColumnNumbers&, size_t, size_t)>& |
163 | | exec_impl_func); |
164 | | |
165 | | template <typename Impl> |
166 | | class FunctionBitMapVariadic : public IFunction { |
167 | | public: |
168 | | static constexpr auto name = Impl::name; |
169 | | |
170 | 240 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); }_ZN5doris22FunctionBitMapVariadicINS_8BitmapOrEE6createEv Line | Count | Source | 170 | 72 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
_ZN5doris22FunctionBitMapVariadicINS_9BitmapXorEE6createEv Line | Count | Source | 170 | 37 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
_ZN5doris22FunctionBitMapVariadicINS_9BitmapAndEE6createEv Line | Count | Source | 170 | 26 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
_ZN5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE6createEv Line | Count | Source | 170 | 35 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
_ZN5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE6createEv Line | Count | Source | 170 | 35 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
_ZN5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE6createEv Line | Count | Source | 170 | 35 | static FunctionPtr create() { return std::make_shared<FunctionBitMapVariadic>(); } |
|
171 | | |
172 | 0 | String get_name() const override { return name; }Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE8get_nameB5cxx11Ev |
173 | | |
174 | 0 | size_t get_number_of_arguments() const override { return 0; }Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE23get_number_of_argumentsEv Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE23get_number_of_argumentsEv Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE23get_number_of_argumentsEv Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE23get_number_of_argumentsEv Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE23get_number_of_argumentsEv Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE23get_number_of_argumentsEv |
175 | | |
176 | 192 | bool is_variadic() const override { return true; }_ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE11is_variadicEv Line | Count | Source | 176 | 64 | bool is_variadic() const override { return true; } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE11is_variadicEv Line | Count | Source | 176 | 29 | bool is_variadic() const override { return true; } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE11is_variadicEv Line | Count | Source | 176 | 18 | bool is_variadic() const override { return true; } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE11is_variadicEv Line | Count | Source | 176 | 27 | bool is_variadic() const override { return true; } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE11is_variadicEv Line | Count | Source | 176 | 27 | bool is_variadic() const override { return true; } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE11is_variadicEv Line | Count | Source | 176 | 27 | bool is_variadic() const override { return true; } |
|
177 | | |
178 | 186 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { |
179 | 186 | using ResultDataType = typename Impl::ResultDataType; |
180 | 186 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { |
181 | 141 | bool return_nullable = false; |
182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count |
183 | 287 | for (size_t i = 0; i < arguments.size(); ++i) { |
184 | 235 | if (arguments[i]->is_nullable()) { |
185 | 89 | return_nullable = true; |
186 | 89 | break; |
187 | 89 | } |
188 | 235 | } |
189 | 141 | auto result_type = std::make_shared<ResultDataType>(); |
190 | 141 | return return_nullable ? make_nullable(result_type) : result_type; |
191 | 141 | } else { |
192 | 45 | return std::make_shared<ResultDataType>(); |
193 | 45 | } |
194 | 186 | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 63 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 63 | using ResultDataType = typename Impl::ResultDataType; | 180 | 63 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 63 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 153 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 123 | if (arguments[i]->is_nullable()) { | 185 | 33 | return_nullable = true; | 186 | 33 | break; | 187 | 33 | } | 188 | 123 | } | 189 | 63 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 63 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 63 | } else { | 192 | 0 | return std::make_shared<ResultDataType>(); | 193 | 0 | } | 194 | 63 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 28 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 28 | using ResultDataType = typename Impl::ResultDataType; | 180 | 28 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 0 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 0 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 0 | if (arguments[i]->is_nullable()) { | 185 | 0 | return_nullable = true; | 186 | 0 | break; | 187 | 0 | } | 188 | 0 | } | 189 | 0 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 0 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 28 | } else { | 192 | 28 | return std::make_shared<ResultDataType>(); | 193 | 28 | } | 194 | 28 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 17 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 17 | using ResultDataType = typename Impl::ResultDataType; | 180 | 17 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 0 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 0 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 0 | if (arguments[i]->is_nullable()) { | 185 | 0 | return_nullable = true; | 186 | 0 | break; | 187 | 0 | } | 188 | 0 | } | 189 | 0 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 0 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 17 | } else { | 192 | 17 | return std::make_shared<ResultDataType>(); | 193 | 17 | } | 194 | 17 | } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 26 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 26 | using ResultDataType = typename Impl::ResultDataType; | 180 | 26 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 26 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 42 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 36 | if (arguments[i]->is_nullable()) { | 185 | 20 | return_nullable = true; | 186 | 20 | break; | 187 | 20 | } | 188 | 36 | } | 189 | 26 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 26 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 26 | } else { | 192 | 0 | return std::make_shared<ResultDataType>(); | 193 | 0 | } | 194 | 26 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 26 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 26 | using ResultDataType = typename Impl::ResultDataType; | 180 | 26 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 26 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 46 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 38 | if (arguments[i]->is_nullable()) { | 185 | 18 | return_nullable = true; | 186 | 18 | break; | 187 | 18 | } | 188 | 38 | } | 189 | 26 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 26 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 26 | } else { | 192 | 0 | return std::make_shared<ResultDataType>(); | 193 | 0 | } | 194 | 26 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE20get_return_type_implERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 178 | 26 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 26 | using ResultDataType = typename Impl::ResultDataType; | 180 | 26 | if (std::is_same_v<Impl, BitmapOr> || is_count()) { | 181 | 26 | bool return_nullable = false; | 182 | | // result is nullable only when any columns is nullable for bitmap_or and bitmap_or_count | 183 | 46 | for (size_t i = 0; i < arguments.size(); ++i) { | 184 | 38 | if (arguments[i]->is_nullable()) { | 185 | 18 | return_nullable = true; | 186 | 18 | break; | 187 | 18 | } | 188 | 38 | } | 189 | 26 | auto result_type = std::make_shared<ResultDataType>(); | 190 | 26 | return return_nullable ? make_nullable(result_type) : result_type; | 191 | 26 | } else { | 192 | 0 | return std::make_shared<ResultDataType>(); | 193 | 0 | } | 194 | 26 | } |
|
195 | | |
196 | 1.85k | bool use_default_implementation_for_nulls() const override { |
197 | | // result is null only when all columns is null for bitmap_or. |
198 | | // for count functions, result is always not null, and if the bitmap op result is null, |
199 | | // the count is 0 |
200 | 1.85k | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); |
201 | 1.85k | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 330 | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 330 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 330 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 1.01k | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 1.01k | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 1.01k | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 101 | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 101 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 101 | } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 140 | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 140 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 140 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 134 | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 134 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 134 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 134 | bool use_default_implementation_for_nulls() const override { | 197 | | // result is null only when all columns is null for bitmap_or. | 198 | | // for count functions, result is always not null, and if the bitmap op result is null, | 199 | | // the count is 0 | 200 | 134 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 134 | } |
|
202 | | |
203 | | Status execute_impl(FunctionContext* context, Block& block, const ColumnNumbers& arguments, |
204 | 548 | uint32_t result, size_t input_rows_count) const override { |
205 | 548 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { |
206 | 72 | auto impl_func = [&](FunctionContext* context, Block& block, |
207 | 72 | const ColumnNumbers& arguments, uint32_t result, |
208 | 72 | size_t input_rows_count) { |
209 | 71 | return execute_impl_internal(context, block, arguments, result, input_rows_count); |
210 | 71 | }; _ZZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlS4_S6_SB_jmE_clES4_S6_SB_jm Line | Count | Source | 208 | 36 | size_t input_rows_count) { | 209 | 36 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 36 | }; |
_ZZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlS4_S6_SB_jmE_clES4_S6_SB_jm Line | Count | Source | 208 | 35 | size_t input_rows_count) { | 209 | 35 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 35 | }; |
|
211 | 72 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, |
212 | 72 | input_rows_count, impl_func); |
213 | 476 | } else { |
214 | 476 | return execute_impl_internal(context, block, arguments, result, input_rows_count); |
215 | 476 | } |
216 | 548 | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 89 | uint32_t result, size_t input_rows_count) const override { | 205 | 89 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 0 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 0 | const ColumnNumbers& arguments, uint32_t result, | 208 | 0 | size_t input_rows_count) { | 209 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 0 | }; | 211 | 0 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 0 | input_rows_count, impl_func); | 213 | 89 | } else { | 214 | 89 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 89 | } | 216 | 89 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 324 | uint32_t result, size_t input_rows_count) const override { | 205 | 324 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 0 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 0 | const ColumnNumbers& arguments, uint32_t result, | 208 | 0 | size_t input_rows_count) { | 209 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 0 | }; | 211 | 0 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 0 | input_rows_count, impl_func); | 213 | 324 | } else { | 214 | 324 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 324 | } | 216 | 324 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 25 | uint32_t result, size_t input_rows_count) const override { | 205 | 25 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 0 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 0 | const ColumnNumbers& arguments, uint32_t result, | 208 | 0 | size_t input_rows_count) { | 209 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 0 | }; | 211 | 0 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 0 | input_rows_count, impl_func); | 213 | 25 | } else { | 214 | 25 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 25 | } | 216 | 25 | } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 38 | uint32_t result, size_t input_rows_count) const override { | 205 | 38 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 0 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 0 | const ColumnNumbers& arguments, uint32_t result, | 208 | 0 | size_t input_rows_count) { | 209 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 0 | }; | 211 | 0 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 0 | input_rows_count, impl_func); | 213 | 38 | } else { | 214 | 38 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 38 | } | 216 | 38 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 36 | uint32_t result, size_t input_rows_count) const override { | 205 | 36 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 36 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 36 | const ColumnNumbers& arguments, uint32_t result, | 208 | 36 | size_t input_rows_count) { | 209 | 36 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 36 | }; | 211 | 36 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 36 | input_rows_count, impl_func); | 213 | 36 | } else { | 214 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 0 | } | 216 | 36 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 36 | uint32_t result, size_t input_rows_count) const override { | 205 | 36 | if (std::is_same_v<Impl, BitmapAndCount> || std::is_same_v<Impl, BitmapXorCount>) { | 206 | 36 | auto impl_func = [&](FunctionContext* context, Block& block, | 207 | 36 | const ColumnNumbers& arguments, uint32_t result, | 208 | 36 | size_t input_rows_count) { | 209 | 36 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 36 | }; | 211 | 36 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, | 212 | 36 | input_rows_count, impl_func); | 213 | 36 | } else { | 214 | 0 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 0 | } | 216 | 36 | } |
|
217 | | |
218 | | Status execute_impl_internal(FunctionContext* context, Block& block, |
219 | | const ColumnNumbers& arguments, uint32_t result, |
220 | 547 | size_t input_rows_count) const { |
221 | 547 | size_t argument_size = arguments.size(); |
222 | 547 | std::vector<ColumnPtr> argument_columns(argument_size); |
223 | | |
224 | 1.70k | for (size_t i = 0; i < argument_size; ++i) { |
225 | 1.15k | argument_columns[i] = |
226 | 1.15k | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); |
227 | 1.15k | } |
228 | | |
229 | 547 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 |
230 | 547 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, |
231 | 547 | ColumnComplexType<ResultDataType::PType>, |
232 | 547 | ColumnVector<ResultDataType::PType>>; |
233 | 547 | typename ColVecResult::MutablePtr col_res = nullptr; |
234 | | |
235 | 547 | typename ColumnUInt8::MutablePtr col_res_nulls; |
236 | 547 | auto& result_info = block.get_by_position(result); |
237 | | // special case for bitmap_or and bitmap_or_count |
238 | 547 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { |
239 | 119 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); |
240 | 119 | } |
241 | | |
242 | 547 | col_res = ColVecResult::create(); |
243 | | |
244 | 547 | auto& vec_res = col_res->get_data(); |
245 | 547 | vec_res.resize(input_rows_count); |
246 | | |
247 | 547 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, |
248 | 547 | input_rows_count, vec_res, col_res_nulls.get())); |
249 | 547 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { |
250 | 119 | block.replace_by_position( |
251 | 119 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); |
252 | 428 | } else { |
253 | 428 | block.replace_by_position(result, std::move(col_res)); |
254 | 428 | } |
255 | 547 | return Status::OK(); |
256 | 547 | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 89 | size_t input_rows_count) const { | 221 | 89 | size_t argument_size = arguments.size(); | 222 | 89 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 284 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 195 | argument_columns[i] = | 226 | 195 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 195 | } | 228 | | | 229 | 89 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 89 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 89 | ColumnComplexType<ResultDataType::PType>, | 232 | 89 | ColumnVector<ResultDataType::PType>>; | 233 | 89 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 89 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 89 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 89 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 49 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 49 | } | 241 | | | 242 | 89 | col_res = ColVecResult::create(); | 243 | | | 244 | 89 | auto& vec_res = col_res->get_data(); | 245 | 89 | vec_res.resize(input_rows_count); | 246 | | | 247 | 89 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 89 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 89 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 49 | block.replace_by_position( | 251 | 49 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 49 | } else { | 253 | 40 | block.replace_by_position(result, std::move(col_res)); | 254 | 40 | } | 255 | 89 | return Status::OK(); | 256 | 89 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 324 | size_t input_rows_count) const { | 221 | 324 | size_t argument_size = arguments.size(); | 222 | 324 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 984 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 660 | argument_columns[i] = | 226 | 660 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 660 | } | 228 | | | 229 | 324 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 324 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 324 | ColumnComplexType<ResultDataType::PType>, | 232 | 324 | ColumnVector<ResultDataType::PType>>; | 233 | 324 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 324 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 324 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 324 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 0 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 0 | } | 241 | | | 242 | 324 | col_res = ColVecResult::create(); | 243 | | | 244 | 324 | auto& vec_res = col_res->get_data(); | 245 | 324 | vec_res.resize(input_rows_count); | 246 | | | 247 | 324 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 324 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 324 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 0 | block.replace_by_position( | 251 | 0 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 324 | } else { | 253 | 324 | block.replace_by_position(result, std::move(col_res)); | 254 | 324 | } | 255 | 324 | return Status::OK(); | 256 | 324 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 25 | size_t input_rows_count) const { | 221 | 25 | size_t argument_size = arguments.size(); | 222 | 25 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 81 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 56 | argument_columns[i] = | 226 | 56 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 56 | } | 228 | | | 229 | 25 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 25 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 25 | ColumnComplexType<ResultDataType::PType>, | 232 | 25 | ColumnVector<ResultDataType::PType>>; | 233 | 25 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 25 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 25 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 25 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 0 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 0 | } | 241 | | | 242 | 25 | col_res = ColVecResult::create(); | 243 | | | 244 | 25 | auto& vec_res = col_res->get_data(); | 245 | 25 | vec_res.resize(input_rows_count); | 246 | | | 247 | 25 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 25 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 25 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 0 | block.replace_by_position( | 251 | 0 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 25 | } else { | 253 | 25 | block.replace_by_position(result, std::move(col_res)); | 254 | 25 | } | 255 | 25 | return Status::OK(); | 256 | 25 | } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 38 | size_t input_rows_count) const { | 221 | 38 | size_t argument_size = arguments.size(); | 222 | 38 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 123 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 85 | argument_columns[i] = | 226 | 85 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 85 | } | 228 | | | 229 | 38 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 38 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 38 | ColumnComplexType<ResultDataType::PType>, | 232 | 38 | ColumnVector<ResultDataType::PType>>; | 233 | 38 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 38 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 38 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 38 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 26 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 26 | } | 241 | | | 242 | 38 | col_res = ColVecResult::create(); | 243 | | | 244 | 38 | auto& vec_res = col_res->get_data(); | 245 | 38 | vec_res.resize(input_rows_count); | 246 | | | 247 | 38 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 38 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 38 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 26 | block.replace_by_position( | 251 | 26 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 26 | } else { | 253 | 12 | block.replace_by_position(result, std::move(col_res)); | 254 | 12 | } | 255 | 38 | return Status::OK(); | 256 | 38 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 36 | size_t input_rows_count) const { | 221 | 36 | size_t argument_size = arguments.size(); | 222 | 36 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 116 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 80 | argument_columns[i] = | 226 | 80 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 80 | } | 228 | | | 229 | 36 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 36 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 36 | ColumnComplexType<ResultDataType::PType>, | 232 | 36 | ColumnVector<ResultDataType::PType>>; | 233 | 36 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 36 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 36 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 36 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 22 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 22 | } | 241 | | | 242 | 36 | col_res = ColVecResult::create(); | 243 | | | 244 | 36 | auto& vec_res = col_res->get_data(); | 245 | 36 | vec_res.resize(input_rows_count); | 246 | | | 247 | 36 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 36 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 36 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 22 | block.replace_by_position( | 251 | 22 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 22 | } else { | 253 | 14 | block.replace_by_position(result, std::move(col_res)); | 254 | 14 | } | 255 | 36 | return Status::OK(); | 256 | 36 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 35 | size_t input_rows_count) const { | 221 | 35 | size_t argument_size = arguments.size(); | 222 | 35 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 118 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 83 | argument_columns[i] = | 226 | 83 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 83 | } | 228 | | | 229 | 35 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 35 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 35 | ColumnComplexType<ResultDataType::PType>, | 232 | 35 | ColumnVector<ResultDataType::PType>>; | 233 | 35 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 35 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 35 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 36 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 22 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 22 | } | 241 | | | 242 | 35 | col_res = ColVecResult::create(); | 243 | | | 244 | 35 | auto& vec_res = col_res->get_data(); | 245 | 35 | vec_res.resize(input_rows_count); | 246 | | | 247 | 35 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 35 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 36 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 22 | block.replace_by_position( | 251 | 22 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 22 | } else { | 253 | 13 | block.replace_by_position(result, std::move(col_res)); | 254 | 13 | } | 255 | 35 | return Status::OK(); | 256 | 35 | } |
|
257 | | |
258 | | private: |
259 | 1.64k | bool is_count() const { |
260 | 1.64k | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || |
261 | 1.64k | std::is_same_v<Impl, BitmapXorCount>); |
262 | 1.64k | } _ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE8is_countEv Line | Count | Source | 259 | 1.04k | bool is_count() const { | 260 | 1.04k | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 1.04k | std::is_same_v<Impl, BitmapXorCount>); | 262 | 1.04k | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE8is_countEv Line | Count | Source | 259 | 117 | bool is_count() const { | 260 | 117 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 117 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 117 | } |
_ZNK5doris22FunctionBitMapVariadicINS_13BitmapOrCountEE8is_countEv Line | Count | Source | 259 | 166 | bool is_count() const { | 260 | 166 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 166 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 166 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapAndCountEE8is_countEv Line | Count | Source | 259 | 160 | bool is_count() const { | 260 | 160 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 160 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 160 | } |
_ZNK5doris22FunctionBitMapVariadicINS_14BitmapXorCountEE8is_countEv Line | Count | Source | 259 | 160 | bool is_count() const { | 260 | 160 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 160 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 160 | } |
Unexecuted instantiation: _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE8is_countEv |
263 | | }; |
264 | | |
265 | | using FunctionBitmapOr = FunctionBitMapVariadic<BitmapOr>; |
266 | | using FunctionBitmapXor = FunctionBitMapVariadic<BitmapXor>; |
267 | | using FunctionBitmapAnd = FunctionBitMapVariadic<BitmapAnd>; |
268 | | using FunctionBitmapOrCount = FunctionBitMapVariadic<BitmapOrCount>; |
269 | | using FunctionBitmapAndCount = FunctionBitMapVariadic<BitmapAndCount>; |
270 | | using FunctionBitmapXorCount = FunctionBitMapVariadic<BitmapXorCount>; |
271 | | |
272 | 8 | void register_function_bitmap_variadic(SimpleFunctionFactory& factory) { |
273 | 8 | factory.register_function<FunctionBitmapOr>(); |
274 | 8 | factory.register_function<FunctionBitmapXor>(); |
275 | 8 | factory.register_function<FunctionBitmapAnd>(); |
276 | 8 | factory.register_function<FunctionBitmapOrCount>(); |
277 | 8 | factory.register_function<FunctionBitmapAndCount>(); |
278 | 8 | factory.register_function<FunctionBitmapXorCount>(); |
279 | 8 | } |
280 | | } // namespace doris |