be/src/exprs/aggregate/aggregate_function_percentile.h
Line | Count | Source |
1 | | // Licensed to the Apache Software Foundation (ASF) under one |
2 | | // or more contributor license agreements. See the NOTICE file |
3 | | // distributed with this work for additional information |
4 | | // regarding copyright ownership. The ASF licenses this file |
5 | | // to you under the Apache License, Version 2.0 (the |
6 | | // "License"); you may not use this file except in compliance |
7 | | // with the License. You may obtain a copy of the License at |
8 | | // |
9 | | // http://www.apache.org/licenses/LICENSE-2.0 |
10 | | // |
11 | | // Unless required by applicable law or agreed to in writing, |
12 | | // software distributed under the License is distributed on an |
13 | | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
14 | | // KIND, either express or implied. See the License for the |
15 | | // specific language governing permissions and limitations |
16 | | // under the License. |
17 | | |
18 | | #pragma once |
19 | | |
20 | | #include <glog/logging.h> |
21 | | #include <stddef.h> |
22 | | #include <stdint.h> |
23 | | |
24 | | #include <boost/iterator/iterator_facade.hpp> |
25 | | #include <cmath> |
26 | | #include <cstdint> |
27 | | #include <memory> |
28 | | #include <string> |
29 | | #include <vector> |
30 | | |
31 | | #include "core/assert_cast.h" |
32 | | #include "core/column/column.h" |
33 | | #include "core/column/column_array.h" |
34 | | #include "core/column/column_nullable.h" |
35 | | #include "core/column/column_vector.h" |
36 | | #include "core/data_type/data_type_array.h" |
37 | | #include "core/data_type/data_type_nullable.h" |
38 | | #include "core/data_type/data_type_number.h" |
39 | | #include "core/pod_array_fwd.h" |
40 | | #include "core/types.h" |
41 | | #include "exprs/aggregate/aggregate_function.h" |
42 | | #include "util/counts.h" |
43 | | #include "util/tdigest.h" |
44 | | |
45 | | namespace doris { |
46 | | #include "common/compile_check_begin.h" |
47 | | |
48 | | class Arena; |
49 | | class BufferReadable; |
50 | | |
51 | 0 | inline void check_quantile(double quantile) { |
52 | 0 | if (quantile < 0 || quantile > 1) { |
53 | 0 | throw Exception(ErrorCode::INVALID_ARGUMENT, |
54 | 0 | "quantile in func percentile should in [0, 1], but real data is:" + |
55 | 0 | std::to_string(quantile)); |
56 | 0 | } |
57 | 0 | } |
58 | | |
59 | | struct PercentileApproxState { |
60 | | static constexpr double INIT_QUANTILE = -1.0; |
61 | 0 | PercentileApproxState() = default; |
62 | 0 | ~PercentileApproxState() = default; |
63 | | |
64 | 0 | void init(double quantile, float compression = 10000) { |
65 | 0 | if (!init_flag) { |
66 | | //https://doris.apache.org/zh-CN/sql-reference/sql-functions/aggregate-functions/percentile_approx.html#description |
67 | | //The compression parameter setting range is [2048, 10000]. |
68 | | //If the value of compression parameter is not specified set, or is outside the range of [2048, 10000], |
69 | | //will use the default value of 10000 |
70 | 0 | if (compression < 2048 || compression > 10000) { |
71 | 0 | compression = 10000; |
72 | 0 | } |
73 | 0 | digest = TDigest::create_unique(compression); |
74 | 0 | check_quantile(quantile); |
75 | 0 | target_quantile = quantile; |
76 | 0 | compressions = compression; |
77 | 0 | init_flag = true; |
78 | 0 | } |
79 | 0 | } |
80 | | |
81 | 0 | void write(BufferWritable& buf) const { |
82 | 0 | buf.write_binary(init_flag); |
83 | 0 | if (!init_flag) { |
84 | 0 | return; |
85 | 0 | } |
86 | | |
87 | 0 | buf.write_binary(target_quantile); |
88 | 0 | buf.write_binary(compressions); |
89 | 0 | uint32_t serialize_size = digest->serialized_size(); |
90 | 0 | std::string result(serialize_size, '0'); |
91 | 0 | DCHECK(digest.get() != nullptr); |
92 | 0 | digest->serialize((uint8_t*)result.c_str()); |
93 | |
|
94 | 0 | buf.write_binary(result); |
95 | 0 | } |
96 | | |
97 | 0 | void read(BufferReadable& buf) { |
98 | 0 | buf.read_binary(init_flag); |
99 | 0 | if (!init_flag) { |
100 | 0 | return; |
101 | 0 | } |
102 | | |
103 | 0 | buf.read_binary(target_quantile); |
104 | 0 | buf.read_binary(compressions); |
105 | 0 | std::string str; |
106 | 0 | buf.read_binary(str); |
107 | 0 | digest = TDigest::create_unique(compressions); |
108 | 0 | digest->unserialize((uint8_t*)str.c_str()); |
109 | 0 | } |
110 | | |
111 | 0 | double get() const { |
112 | 0 | if (init_flag) { |
113 | 0 | return digest->quantile(static_cast<float>(target_quantile)); |
114 | 0 | } else { |
115 | 0 | return std::nan(""); |
116 | 0 | } |
117 | 0 | } |
118 | | |
119 | 0 | void merge(const PercentileApproxState& rhs) { |
120 | 0 | if (!rhs.init_flag) { |
121 | 0 | return; |
122 | 0 | } |
123 | 0 | if (init_flag) { |
124 | 0 | DCHECK(digest.get() != nullptr); |
125 | 0 | digest->merge(rhs.digest.get()); |
126 | 0 | } else { |
127 | 0 | digest = TDigest::create_unique(compressions); |
128 | 0 | digest->merge(rhs.digest.get()); |
129 | 0 | init_flag = true; |
130 | 0 | } |
131 | 0 | if (target_quantile == PercentileApproxState::INIT_QUANTILE) { |
132 | 0 | target_quantile = rhs.target_quantile; |
133 | 0 | } |
134 | 0 | } |
135 | | |
136 | 0 | void add(double source) { digest->add(static_cast<float>(source)); } |
137 | | |
138 | 0 | void add_with_weight(double source, double weight) { |
139 | | // the weight should be positive num, as have check the value valid use DCHECK_GT(c._weight, 0); |
140 | 0 | if (weight <= 0) { |
141 | 0 | return; |
142 | 0 | } |
143 | 0 | digest->add(static_cast<float>(source), static_cast<float>(weight)); |
144 | 0 | } |
145 | | |
146 | 0 | void reset() { |
147 | 0 | target_quantile = INIT_QUANTILE; |
148 | 0 | init_flag = false; |
149 | 0 | digest = TDigest::create_unique(compressions); |
150 | 0 | } |
151 | | |
152 | | bool init_flag = false; |
153 | | std::unique_ptr<TDigest> digest; |
154 | | double target_quantile = INIT_QUANTILE; |
155 | | float compressions = 10000; |
156 | | }; |
157 | | |
158 | | class AggregateFunctionPercentileApprox |
159 | | : public IAggregateFunctionDataHelper<PercentileApproxState, |
160 | | AggregateFunctionPercentileApprox> { |
161 | | public: |
162 | | AggregateFunctionPercentileApprox(const DataTypes& argument_types_) |
163 | 0 | : IAggregateFunctionDataHelper<PercentileApproxState, |
164 | 0 | AggregateFunctionPercentileApprox>(argument_types_) {} |
165 | | |
166 | 0 | String get_name() const override { return "percentile_approx"; } |
167 | | |
168 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
169 | 0 | AggregateFunctionPercentileApprox::data(place).reset(); |
170 | 0 | } |
171 | | |
172 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
173 | 0 | Arena&) const override { |
174 | 0 | AggregateFunctionPercentileApprox::data(place).merge( |
175 | 0 | AggregateFunctionPercentileApprox::data(rhs)); |
176 | 0 | } |
177 | | |
178 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
179 | 0 | AggregateFunctionPercentileApprox::data(place).write(buf); |
180 | 0 | } |
181 | | |
182 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
183 | 0 | Arena&) const override { |
184 | 0 | AggregateFunctionPercentileApprox::data(place).read(buf); |
185 | 0 | } |
186 | | }; |
187 | | |
188 | | class AggregateFunctionPercentileApproxTwoParams final : public AggregateFunctionPercentileApprox, |
189 | | public MultiExpression, |
190 | | public NullableAggregateFunction { |
191 | | public: |
192 | | AggregateFunctionPercentileApproxTwoParams(const DataTypes& argument_types_) |
193 | 0 | : AggregateFunctionPercentileApprox(argument_types_) {} |
194 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
195 | 0 | Arena&) const override { |
196 | 0 | const auto& sources = |
197 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
198 | 0 | const auto& quantile = |
199 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
200 | 0 | this->data(place).init(quantile.get_element(0)); |
201 | 0 | this->data(place).add(sources.get_element(row_num)); |
202 | 0 | } |
203 | | |
204 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
205 | | |
206 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
207 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
208 | 0 | double result = AggregateFunctionPercentileApprox::data(place).get(); |
209 | |
|
210 | 0 | if (std::isnan(result)) { |
211 | 0 | col.insert_default(); |
212 | 0 | } else { |
213 | 0 | col.get_data().push_back(result); |
214 | 0 | } |
215 | 0 | } |
216 | | }; |
217 | | |
218 | | class AggregateFunctionPercentileApproxThreeParams final : public AggregateFunctionPercentileApprox, |
219 | | public MultiExpression, |
220 | | public NullableAggregateFunction { |
221 | | public: |
222 | | AggregateFunctionPercentileApproxThreeParams(const DataTypes& argument_types_) |
223 | 0 | : AggregateFunctionPercentileApprox(argument_types_) {} |
224 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
225 | 0 | Arena&) const override { |
226 | 0 | const auto& sources = |
227 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
228 | 0 | const auto& quantile = |
229 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
230 | 0 | const auto& compression = |
231 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
232 | |
|
233 | 0 | this->data(place).init(quantile.get_element(0), |
234 | 0 | static_cast<float>(compression.get_element(0))); |
235 | 0 | this->data(place).add(sources.get_element(row_num)); |
236 | 0 | } |
237 | | |
238 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
239 | | |
240 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
241 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
242 | 0 | double result = AggregateFunctionPercentileApprox::data(place).get(); |
243 | |
|
244 | 0 | if (std::isnan(result)) { |
245 | 0 | col.insert_default(); |
246 | 0 | } else { |
247 | 0 | col.get_data().push_back(result); |
248 | 0 | } |
249 | 0 | } |
250 | | }; |
251 | | |
252 | | class AggregateFunctionPercentileApproxWeightedThreeParams final |
253 | | : public AggregateFunctionPercentileApprox, |
254 | | MultiExpression, |
255 | | NullableAggregateFunction { |
256 | | public: |
257 | | AggregateFunctionPercentileApproxWeightedThreeParams(const DataTypes& argument_types_) |
258 | 0 | : AggregateFunctionPercentileApprox(argument_types_) {} |
259 | | |
260 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
261 | 0 | Arena&) const override { |
262 | 0 | const auto& sources = |
263 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
264 | 0 | const auto& weight = |
265 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
266 | 0 | const auto& quantile = |
267 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
268 | |
|
269 | 0 | this->data(place).init(quantile.get_element(0)); |
270 | 0 | this->data(place).add_with_weight(sources.get_element(row_num), |
271 | 0 | weight.get_element(row_num)); |
272 | 0 | } |
273 | | |
274 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
275 | | |
276 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
277 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
278 | 0 | double result = AggregateFunctionPercentileApprox::data(place).get(); |
279 | |
|
280 | 0 | if (std::isnan(result)) { |
281 | 0 | col.insert_default(); |
282 | 0 | } else { |
283 | 0 | col.get_data().push_back(result); |
284 | 0 | } |
285 | 0 | } |
286 | | }; |
287 | | |
288 | | class AggregateFunctionPercentileApproxWeightedFourParams final |
289 | | : public AggregateFunctionPercentileApprox, |
290 | | MultiExpression, |
291 | | NullableAggregateFunction { |
292 | | public: |
293 | | AggregateFunctionPercentileApproxWeightedFourParams(const DataTypes& argument_types_) |
294 | 0 | : AggregateFunctionPercentileApprox(argument_types_) {} |
295 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
296 | 0 | Arena&) const override { |
297 | 0 | const auto& sources = |
298 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
299 | 0 | const auto& weight = |
300 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
301 | 0 | const auto& quantile = |
302 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
303 | 0 | const auto& compression = |
304 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[3]); |
305 | |
|
306 | 0 | this->data(place).init(quantile.get_element(0), |
307 | 0 | static_cast<float>(compression.get_element(0))); |
308 | 0 | this->data(place).add_with_weight(sources.get_element(row_num), |
309 | 0 | weight.get_element(row_num)); |
310 | 0 | } |
311 | | |
312 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
313 | | |
314 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
315 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
316 | 0 | double result = AggregateFunctionPercentileApprox::data(place).get(); |
317 | |
|
318 | 0 | if (std::isnan(result)) { |
319 | 0 | col.insert_default(); |
320 | 0 | } else { |
321 | 0 | col.get_data().push_back(result); |
322 | 0 | } |
323 | 0 | } |
324 | | }; |
325 | | |
326 | | template <PrimitiveType T> |
327 | | struct PercentileState { |
328 | | mutable std::vector<Counts<typename PrimitiveTypeTraits<T>::CppType>> vec_counts; |
329 | | std::vector<double> vec_quantile {-1}; |
330 | | bool inited_flag = false; |
331 | | |
332 | 0 | void write(BufferWritable& buf) const { |
333 | 0 | buf.write_binary(inited_flag); |
334 | 0 | if (!inited_flag) { |
335 | 0 | return; |
336 | 0 | } |
337 | 0 | int size_num = cast_set<int>(vec_quantile.size()); |
338 | 0 | buf.write_binary(size_num); |
339 | 0 | for (const auto& quantile : vec_quantile) { |
340 | 0 | buf.write_binary(quantile); |
341 | 0 | } |
342 | 0 | for (auto& counts : vec_counts) { |
343 | 0 | counts.serialize(buf); |
344 | 0 | } |
345 | 0 | } Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE3EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE4EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE5EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE6EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE7EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE8EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE9EE5writeERNS_14BufferWritableE |
346 | | |
347 | 0 | void read(BufferReadable& buf) { |
348 | 0 | buf.read_binary(inited_flag); |
349 | 0 | if (!inited_flag) { |
350 | 0 | return; |
351 | 0 | } |
352 | 0 | int size_num = 0; |
353 | 0 | buf.read_binary(size_num); |
354 | 0 | double data = 0.0; |
355 | 0 | vec_quantile.clear(); |
356 | 0 | for (int i = 0; i < size_num; ++i) { |
357 | 0 | buf.read_binary(data); |
358 | 0 | vec_quantile.emplace_back(data); |
359 | 0 | } |
360 | 0 | vec_counts.clear(); |
361 | 0 | vec_counts.resize(size_num); |
362 | 0 | for (int i = 0; i < size_num; ++i) { |
363 | 0 | vec_counts[i].unserialize(buf); |
364 | 0 | } |
365 | 0 | } Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE4readERNS_14BufferReadableE |
366 | | |
367 | | void add(typename PrimitiveTypeTraits<T>::CppType source, |
368 | 0 | const PaddedPODArray<Float64>& quantiles, const NullMap& null_maps, int64_t arg_size) { |
369 | 0 | if (!inited_flag) { |
370 | 0 | vec_counts.resize(arg_size); |
371 | 0 | vec_quantile.resize(arg_size, -1); |
372 | 0 | inited_flag = true; |
373 | 0 | for (int i = 0; i < arg_size; ++i) { |
374 | | // throw Exception func call percentile_array(id, [1,0,null]) |
375 | 0 | if (null_maps[i]) { |
376 | 0 | throw Exception(ErrorCode::INVALID_ARGUMENT, |
377 | 0 | "quantiles in func percentile_array should not have null"); |
378 | 0 | } |
379 | 0 | check_quantile(quantiles[i]); |
380 | 0 | vec_quantile[i] = quantiles[i]; |
381 | 0 | } |
382 | 0 | } |
383 | 0 | for (int i = 0; i < arg_size; ++i) { |
384 | 0 | vec_counts[i].increment(source); |
385 | 0 | } |
386 | 0 | } Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE3addEaRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE3addEsRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE3addEiRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE3addElRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE3addEnRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE3addEfRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE3addEdRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl |
387 | | |
388 | | void add_batch(const PaddedPODArray<typename PrimitiveTypeTraits<T>::CppType>& source, |
389 | 0 | const Float64& q) { |
390 | 0 | if (!inited_flag) { |
391 | 0 | inited_flag = true; |
392 | 0 | vec_counts.resize(1); |
393 | 0 | vec_quantile.resize(1); |
394 | 0 | check_quantile(q); |
395 | 0 | vec_quantile[0] = q; |
396 | 0 | } |
397 | 0 | vec_counts[0].increment_batch(source); |
398 | 0 | } Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE9add_batchERKNS_8PODArrayIaLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE9add_batchERKNS_8PODArrayIsLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE9add_batchERKNS_8PODArrayIiLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE9add_batchERKNS_8PODArrayIlLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE9add_batchERKNS_8PODArrayInLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE9add_batchERKNS_8PODArrayIfLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE9add_batchERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKd |
399 | | |
400 | 0 | void merge(const PercentileState& rhs) { |
401 | 0 | if (!rhs.inited_flag) { |
402 | 0 | return; |
403 | 0 | } |
404 | 0 | int size_num = cast_set<int>(rhs.vec_quantile.size()); |
405 | 0 | if (!inited_flag) { |
406 | 0 | vec_counts.resize(size_num); |
407 | 0 | vec_quantile.resize(size_num, -1); |
408 | 0 | inited_flag = true; |
409 | 0 | } |
410 | |
|
411 | 0 | for (int i = 0; i < size_num; ++i) { |
412 | 0 | if (vec_quantile[i] == -1.0) { |
413 | 0 | vec_quantile[i] = rhs.vec_quantile[i]; |
414 | 0 | } |
415 | 0 | vec_counts[i].merge(&(rhs.vec_counts[i])); |
416 | 0 | } |
417 | 0 | } Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE5mergeERKS2_ |
418 | | |
419 | 0 | void reset() { |
420 | 0 | vec_counts.clear(); |
421 | 0 | vec_quantile.clear(); |
422 | 0 | inited_flag = false; |
423 | 0 | } Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE5resetEv Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE5resetEv |
424 | | |
425 | 0 | double get() const { return vec_counts.empty() ? 0 : vec_counts[0].terminate(vec_quantile[0]); }Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE3EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE4EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE5EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE6EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE7EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE8EE3getEv Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE9EE3getEv |
426 | | |
427 | 0 | void insert_result_into(IColumn& to) const { |
428 | 0 | auto& column_data = assert_cast<ColumnFloat64&>(to).get_data(); |
429 | 0 | for (int i = 0; i < vec_counts.size(); ++i) { |
430 | 0 | column_data.push_back(vec_counts[i].terminate(vec_quantile[i])); |
431 | 0 | } |
432 | 0 | } Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE3EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE4EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE5EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE6EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE7EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE8EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE9EE18insert_result_intoERNS_7IColumnE |
433 | | }; |
434 | | |
435 | | template <PrimitiveType T> |
436 | | class AggregateFunctionPercentile final |
437 | | : public IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentile<T>>, |
438 | | MultiExpression, |
439 | | NullableAggregateFunction { |
440 | | public: |
441 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
442 | | using Base = IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentile<T>>; |
443 | 0 | AggregateFunctionPercentile(const DataTypes& argument_types_) : Base(argument_types_) {}Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
444 | | |
445 | 0 | String get_name() const override { return "percentile"; }Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
446 | | |
447 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE15get_return_typeEv |
448 | | |
449 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
450 | 0 | Arena&) const override { |
451 | 0 | const auto& sources = |
452 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
453 | 0 | const auto& quantile = |
454 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
455 | 0 | AggregateFunctionPercentile::data(place).add(sources.get_data()[row_num], |
456 | 0 | quantile.get_data(), NullMap(1, 0), 1); |
457 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE |
458 | | |
459 | | void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns, |
460 | 0 | Arena&) const override { |
461 | 0 | const auto& sources = |
462 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
463 | 0 | const auto& quantile = |
464 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
465 | 0 | DCHECK_EQ(sources.get_data().size(), batch_size); |
466 | 0 | AggregateFunctionPercentile::data(place).add_batch(sources.get_data(), |
467 | 0 | quantile.get_data()[0]); |
468 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE |
469 | | |
470 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
471 | 0 | AggregateFunctionPercentile::data(place).reset(); |
472 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE5resetEPc Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE5resetEPc |
473 | | |
474 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
475 | 0 | Arena&) const override { |
476 | 0 | AggregateFunctionPercentile::data(place).merge(AggregateFunctionPercentile::data(rhs)); |
477 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE |
478 | | |
479 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
480 | 0 | AggregateFunctionPercentile::data(place).write(buf); |
481 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE |
482 | | |
483 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
484 | 0 | Arena&) const override { |
485 | 0 | AggregateFunctionPercentile::data(place).read(buf); |
486 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE |
487 | | |
488 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
489 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
490 | 0 | col.insert_value(AggregateFunctionPercentile::data(place).get()); |
491 | 0 | } Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE |
492 | | }; |
493 | | |
494 | | template <PrimitiveType T> |
495 | | class AggregateFunctionPercentileArray final |
496 | | : public IAggregateFunctionDataHelper<PercentileState<T>, |
497 | | AggregateFunctionPercentileArray<T>>, |
498 | | MultiExpression, |
499 | | NotNullableAggregateFunction { |
500 | | public: |
501 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
502 | | using Base = |
503 | | IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentileArray<T>>; |
504 | 0 | AggregateFunctionPercentileArray(const DataTypes& argument_types_) : Base(argument_types_) {}Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
505 | | |
506 | 0 | String get_name() const override { return "percentile_array"; }Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
507 | | |
508 | 0 | DataTypePtr get_return_type() const override { |
509 | 0 | return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>())); |
510 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE15get_return_typeEv |
511 | | |
512 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
513 | 0 | Arena&) const override { |
514 | 0 | const auto& sources = |
515 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
516 | 0 | const auto& quantile_array = |
517 | 0 | assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
518 | 0 | const auto& offset_column_data = quantile_array.get_offsets(); |
519 | 0 | const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
520 | 0 | quantile_array.get_data()) |
521 | 0 | .get_null_map_data(); |
522 | 0 | const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
523 | 0 | quantile_array.get_data()) |
524 | 0 | .get_nested_column(); |
525 | 0 | const auto& nested_column_data = |
526 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column); |
527 | |
|
528 | 0 | AggregateFunctionPercentileArray::data(place).add( |
529 | 0 | sources.get_element(row_num), nested_column_data.get_data(), null_maps, |
530 | 0 | offset_column_data.data()[row_num] - offset_column_data[(ssize_t)row_num - 1]); |
531 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE |
532 | | |
533 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
534 | 0 | AggregateFunctionPercentileArray::data(place).reset(); |
535 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE5resetEPc Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE5resetEPc |
536 | | |
537 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
538 | 0 | Arena&) const override { |
539 | 0 | AggregateFunctionPercentileArray::data(place).merge( |
540 | 0 | AggregateFunctionPercentileArray::data(rhs)); |
541 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE |
542 | | |
543 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
544 | 0 | AggregateFunctionPercentileArray::data(place).write(buf); |
545 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE |
546 | | |
547 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
548 | 0 | Arena&) const override { |
549 | 0 | AggregateFunctionPercentileArray::data(place).read(buf); |
550 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE |
551 | | |
552 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
553 | 0 | auto& to_arr = assert_cast<ColumnArray&>(to); |
554 | 0 | auto& to_nested_col = to_arr.get_data(); |
555 | 0 | if (to_nested_col.is_nullable()) { |
556 | 0 | auto col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col); |
557 | 0 | AggregateFunctionPercentileArray::data(place).insert_result_into( |
558 | 0 | col_null->get_nested_column()); |
559 | 0 | col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0); |
560 | 0 | } else { |
561 | 0 | AggregateFunctionPercentileArray::data(place).insert_result_into(to_nested_col); |
562 | 0 | } |
563 | 0 | to_arr.get_offsets().push_back(to_nested_col.size()); |
564 | 0 | } Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE |
565 | | }; |
566 | | |
567 | | #include "common/compile_check_end.h" |
568 | | } // namespace doris |