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 | 115 | const auto& nested_col_ptr = nullable->get_nested_column_ptr(); \ |
56 | 115 | const auto* __restrict null_map_data = nullable->get_null_map_data().data(); \ |
57 | 115 | const auto& mid_data = assert_cast<const ColumnBitmap*>(nested_col_ptr.get())->get_data(); \ |
58 | 273 | 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 | 301 | IColumn* res_nulls) { \ |
71 | 301 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ |
72 | 301 | int nullable_cols_count = 0; \ |
73 | 301 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ |
74 | 301 | if (res_nulls) { \ |
75 | 47 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ |
76 | 47 | } \ |
77 | 301 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ |
78 | 24 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ |
79 | 24 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ |
80 | 277 | } else { \ |
81 | 277 | const auto& mid_data = \ |
82 | 277 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ |
83 | 6.98k | for (size_t row = 0; row < input_rows_count; ++row) { \ |
84 | 6.70k | res[row] = mid_data[row]; \ |
85 | 6.70k | } \ |
86 | 277 | } \ |
87 | 638 | for (size_t col = 1; col < col_size; ++col) { \ |
88 | 337 | if (auto* nullable = \ |
89 | 337 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ |
90 | 46 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ |
91 | 46 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ |
92 | 291 | } else { \ |
93 | 291 | const auto& col_data = \ |
94 | 291 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ |
95 | 291 | ->get_data(); \ |
96 | 6.99k | for (size_t row = 0; row < input_rows_count; ++row) { \ |
97 | 6.70k | res[row] OP col_data[row]; \ |
98 | 6.70k | } \ |
99 | 291 | } \ |
100 | 337 | } \ |
101 | 301 | if (res_nulls_data && nullable_cols_count == col_size) { \ |
102 | 21 | const auto* null_map_data = null_map_datas[0]; \ |
103 | 44 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
104 | 23 | res_nulls_data[row] = null_map_data[row]; \ |
105 | 23 | } \ |
106 | 42 | for (int i = 1; i < nullable_cols_count; ++i) { \ |
107 | 21 | null_map_data = null_map_datas[i]; \ |
108 | 44 | for (size_t row = 0; row < input_rows_count; ++row) { \ |
109 | 23 | res_nulls_data[row] &= null_map_data[row]; \ |
110 | 23 | } \ |
111 | 21 | } \ |
112 | 21 | } \ |
113 | 301 | return Status::OK(); \ |
114 | 301 | } \ _ZN5doris8BitmapOr13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRSt6vectorINS_11BitmapValueESaIS8_EEPS2_ Line | Count | Source | 70 | 84 | IColumn* res_nulls) { \ | 71 | 84 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ | 72 | 84 | int nullable_cols_count = 0; \ | 73 | 84 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ | 74 | 84 | if (res_nulls) { \ | 75 | 47 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ | 76 | 47 | } \ | 77 | 84 | if (auto* nullable = check_and_get_column<ColumnNullable>(*argument_columns[0])) { \ | 78 | 24 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 79 | 24 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, =); \ | 80 | 60 | } else { \ | 81 | 60 | const auto& mid_data = \ | 82 | 60 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 83 | 166 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 84 | 106 | res[row] = mid_data[row]; \ | 85 | 106 | } \ | 86 | 60 | } \ | 87 | 186 | for (size_t col = 1; col < col_size; ++col) { \ | 88 | 102 | if (auto* nullable = \ | 89 | 102 | check_and_get_column<ColumnNullable>(*argument_columns[col])) { \ | 90 | 46 | null_map_datas[nullable_cols_count++] = nullable->get_null_map_data().data(); \ | 91 | 46 | BITMAP_OR_NULLABLE(nullable, input_rows_count, res, OP); \ | 92 | 56 | } else { \ | 93 | 56 | const auto& col_data = \ | 94 | 56 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 95 | 56 | ->get_data(); \ | 96 | 140 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 84 | res[row] OP col_data[row]; \ | 98 | 84 | } \ | 99 | 56 | } \ | 100 | 102 | } \ | 101 | 84 | if (res_nulls_data && nullable_cols_count == col_size) { \ | 102 | 21 | const auto* null_map_data = null_map_datas[0]; \ | 103 | 44 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 104 | 23 | res_nulls_data[row] = null_map_data[row]; \ | 105 | 23 | } \ | 106 | 42 | for (int i = 1; i < nullable_cols_count; ++i) { \ | 107 | 21 | null_map_data = null_map_datas[i]; \ | 108 | 44 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 109 | 23 | res_nulls_data[row] &= null_map_data[row]; \ | 110 | 23 | } \ | 111 | 21 | } \ | 112 | 21 | } \ | 113 | 84 | return Status::OK(); \ | 114 | 84 | } \ |
_ZN5doris9BitmapXor13vector_vectorEPNS_3COWINS_7IColumnEE13immutable_ptrIS2_EEmmRSt6vectorINS_11BitmapValueESaIS8_EEPS2_ Line | Count | Source | 70 | 192 | IColumn* res_nulls) { \ | 71 | 192 | std::vector<const ColumnUInt8::value_type*> null_map_datas(col_size); \ | 72 | 192 | int nullable_cols_count = 0; \ | 73 | 192 | ColumnUInt8::value_type* __restrict res_nulls_data = nullptr; \ | 74 | 192 | if (res_nulls) { \ | 75 | 0 | res_nulls_data = assert_cast<ColumnUInt8*>(res_nulls)->get_data().data(); \ | 76 | 0 | } \ | 77 | 192 | 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 | 192 | } else { \ | 81 | 192 | const auto& mid_data = \ | 82 | 192 | assert_cast<const ColumnBitmap*>(argument_columns[0].get())->get_data(); \ | 83 | 6.74k | for (size_t row = 0; row < input_rows_count; ++row) { \ | 84 | 6.55k | res[row] = mid_data[row]; \ | 85 | 6.55k | } \ | 86 | 192 | } \ | 87 | 396 | for (size_t col = 1; col < col_size; ++col) { \ | 88 | 204 | if (auto* nullable = \ | 89 | 204 | 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 | 204 | } else { \ | 93 | 204 | const auto& col_data = \ | 94 | 204 | assert_cast<const ColumnBitmap*>(argument_columns[col].get()) \ | 95 | 204 | ->get_data(); \ | 96 | 6.77k | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 6.56k | res[row] OP col_data[row]; \ | 98 | 6.56k | } \ | 99 | 204 | } \ | 100 | 204 | } \ | 101 | 192 | 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 | 192 | return Status::OK(); \ | 114 | 192 | } \ |
_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 | 86 | for (size_t row = 0; row < input_rows_count; ++row) { \ | 97 | 55 | res[row] OP col_data[row]; \ | 98 | 55 | } \ | 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_22DefaultMemoryAllocatorELb0EEELm16ELm15EEEPS2_ 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_22DefaultMemoryAllocatorELb0EEELm16ELm15EEEPS2_ 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_22DefaultMemoryAllocatorELb0EEELm16ELm15EEEPS2_ 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 | 254 | 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 | 51 | 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 | 206 | 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 | 43 | 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 | 200 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { |
179 | 200 | using ResultDataType = typename Impl::ResultDataType; |
180 | 200 | 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 | 59 | return std::make_shared<ResultDataType>(); |
193 | 59 | } |
194 | 200 | } _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 | 42 | DataTypePtr get_return_type_impl(const DataTypes& arguments) const override { | 179 | 42 | using ResultDataType = typename Impl::ResultDataType; | 180 | 42 | 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 | 42 | } else { | 192 | 42 | return std::make_shared<ResultDataType>(); | 193 | 42 | } | 194 | 42 | } |
_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.45k | 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.45k | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); |
201 | 1.45k | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 315 | 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 | 315 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 315 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE36use_default_implementation_for_nullsEv Line | Count | Source | 196 | 634 | 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 | 634 | return !static_cast<bool>(std::is_same_v<Impl, BitmapOr> || is_count()); | 201 | 634 | } |
_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 | 411 | uint32_t result, size_t input_rows_count) const override { |
205 | 411 | 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 | 72 | return execute_impl_internal(context, block, arguments, result, input_rows_count); |
210 | 72 | }; _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 | 36 | size_t input_rows_count) { | 209 | 36 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 210 | 36 | }; |
|
211 | 72 | return execute_bitmap_op_count_null_to_zero(context, block, arguments, result, |
212 | 72 | input_rows_count, impl_func); |
213 | 339 | } else { |
214 | 339 | return execute_impl_internal(context, block, arguments, result, input_rows_count); |
215 | 339 | } |
216 | 411 | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 84 | uint32_t result, size_t input_rows_count) const override { | 205 | 84 | 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 | 84 | } else { | 214 | 84 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 84 | } | 216 | 84 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE12execute_implEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 204 | 192 | uint32_t result, size_t input_rows_count) const override { | 205 | 192 | 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 | 192 | } else { | 214 | 192 | return execute_impl_internal(context, block, arguments, result, input_rows_count); | 215 | 192 | } | 216 | 192 | } |
_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 | 411 | size_t input_rows_count) const { |
221 | 411 | size_t argument_size = arguments.size(); |
222 | 411 | std::vector<ColumnPtr> argument_columns(argument_size); |
223 | | |
224 | 1.30k | for (size_t i = 0; i < argument_size; ++i) { |
225 | 889 | argument_columns[i] = |
226 | 889 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); |
227 | 889 | } |
228 | | |
229 | 411 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 |
230 | 411 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, |
231 | 411 | ColumnComplexType<ResultDataType::PType>, |
232 | 411 | ColumnVector<ResultDataType::PType>>; |
233 | 411 | typename ColVecResult::MutablePtr col_res = nullptr; |
234 | | |
235 | 411 | typename ColumnUInt8::MutablePtr col_res_nulls; |
236 | 411 | auto& result_info = block.get_by_position(result); |
237 | | // special case for bitmap_or and bitmap_or_count |
238 | 411 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { |
239 | 117 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); |
240 | 117 | } |
241 | | |
242 | 411 | col_res = ColVecResult::create(); |
243 | | |
244 | 411 | auto& vec_res = col_res->get_data(); |
245 | 411 | vec_res.resize(input_rows_count); |
246 | | |
247 | 411 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, |
248 | 411 | input_rows_count, vec_res, col_res_nulls.get())); |
249 | 411 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { |
250 | 117 | block.replace_by_position( |
251 | 117 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); |
252 | 294 | } else { |
253 | 294 | block.replace_by_position(result, std::move(col_res)); |
254 | 294 | } |
255 | 411 | return Status::OK(); |
256 | 411 | } _ZNK5doris22FunctionBitMapVariadicINS_8BitmapOrEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 84 | size_t input_rows_count) const { | 221 | 84 | size_t argument_size = arguments.size(); | 222 | 84 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 270 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 186 | argument_columns[i] = | 226 | 186 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 186 | } | 228 | | | 229 | 84 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 84 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 84 | ColumnComplexType<ResultDataType::PType>, | 232 | 84 | ColumnVector<ResultDataType::PType>>; | 233 | 84 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 84 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 84 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 84 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 239 | 47 | col_res_nulls = ColumnUInt8::create(input_rows_count, 0); | 240 | 47 | } | 241 | | | 242 | 84 | col_res = ColVecResult::create(); | 243 | | | 244 | 84 | auto& vec_res = col_res->get_data(); | 245 | 84 | vec_res.resize(input_rows_count); | 246 | | | 247 | 84 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 84 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 84 | if (!use_default_implementation_for_nulls() && result_info.type->is_nullable()) { | 250 | 47 | block.replace_by_position( | 251 | 47 | result, ColumnNullable::create(std::move(col_res), std::move(col_res_nulls))); | 252 | 47 | } else { | 253 | 37 | block.replace_by_position(result, std::move(col_res)); | 254 | 37 | } | 255 | 84 | return Status::OK(); | 256 | 84 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE21execute_impl_internalEPNS_15FunctionContextERNS_5BlockERKSt6vectorIjSaIjEEjm Line | Count | Source | 220 | 192 | size_t input_rows_count) const { | 221 | 192 | size_t argument_size = arguments.size(); | 222 | 192 | std::vector<ColumnPtr> argument_columns(argument_size); | 223 | | | 224 | 588 | for (size_t i = 0; i < argument_size; ++i) { | 225 | 396 | argument_columns[i] = | 226 | 396 | block.get_by_position(arguments[i]).column->convert_to_full_column_if_const(); | 227 | 396 | } | 228 | | | 229 | 192 | using ResultDataType = typename Impl::ResultDataType; //DataTypeBitMap or DataTypeInt64 | 230 | 192 | using ColVecResult = std::conditional_t<is_complex_v<ResultDataType::PType>, | 231 | 192 | ColumnComplexType<ResultDataType::PType>, | 232 | 192 | ColumnVector<ResultDataType::PType>>; | 233 | 192 | typename ColVecResult::MutablePtr col_res = nullptr; | 234 | | | 235 | 192 | typename ColumnUInt8::MutablePtr col_res_nulls; | 236 | 192 | auto& result_info = block.get_by_position(result); | 237 | | // special case for bitmap_or and bitmap_or_count | 238 | 192 | 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 | 192 | col_res = ColVecResult::create(); | 243 | | | 244 | 192 | auto& vec_res = col_res->get_data(); | 245 | 192 | vec_res.resize(input_rows_count); | 246 | | | 247 | 192 | RETURN_IF_ERROR(Impl::vector_vector(argument_columns.data(), argument_size, | 248 | 192 | input_rows_count, vec_res, col_res_nulls.get())); | 249 | 192 | 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 | 192 | } else { | 253 | 192 | block.replace_by_position(result, std::move(col_res)); | 254 | 192 | } | 255 | 192 | return Status::OK(); | 256 | 192 | } |
_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 | 119 | 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 | 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 | 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 | 119 | 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 | 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 | } |
|
257 | | |
258 | | private: |
259 | 1.28k | bool is_count() const { |
260 | 1.28k | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || |
261 | 1.28k | std::is_same_v<Impl, BitmapXorCount>); |
262 | 1.28k | } _ZNK5doris22FunctionBitMapVariadicINS_9BitmapXorEE8is_countEv Line | Count | Source | 259 | 676 | bool is_count() const { | 260 | 676 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 676 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 676 | } |
_ZNK5doris22FunctionBitMapVariadicINS_9BitmapAndEE8is_countEv Line | Count | Source | 259 | 118 | bool is_count() const { | 260 | 118 | return (std::is_same_v<Impl, BitmapOrCount> || std::is_same_v<Impl, BitmapAndCount> || | 261 | 118 | std::is_same_v<Impl, BitmapXorCount>); | 262 | 118 | } |
_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 |