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.h" |
40 | | #include "core/pod_array_fwd.h" |
41 | | #include "core/types.h" |
42 | | #include "exprs/aggregate/aggregate_function.h" |
43 | | #include "util/percentile_util.h" |
44 | | #include "util/tdigest.h" |
45 | | |
46 | | namespace doris { |
47 | | |
48 | | class Arena; |
49 | | class BufferReadable; |
50 | | |
51 | | struct PercentileApproxState { |
52 | | static constexpr double INIT_QUANTILE = -1.0; |
53 | 0 | PercentileApproxState() = default; |
54 | 0 | ~PercentileApproxState() = default; |
55 | | |
56 | 0 | void init(double quantile, float compression = 10000) { |
57 | 0 | if (!init_flag) { |
58 | | //https://doris.apache.org/zh-CN/sql-reference/sql-functions/aggregate-functions/percentile_approx.html#description |
59 | | //The compression parameter setting range is [2048, 10000]. |
60 | | //If the value of compression parameter is not specified set, or is outside the range of [2048, 10000], |
61 | | //will use the default value of 10000 |
62 | 0 | if (compression < 2048 || compression > 10000) { |
63 | 0 | compression = 10000; |
64 | 0 | } |
65 | 0 | digest = TDigest::create_unique(compression); |
66 | 0 | check_quantile(quantile); |
67 | 0 | target_quantile = quantile; |
68 | 0 | compressions = compression; |
69 | 0 | init_flag = true; |
70 | 0 | } |
71 | 0 | } |
72 | | |
73 | 0 | void write(BufferWritable& buf) const { |
74 | 0 | buf.write_binary(init_flag); |
75 | 0 | if (!init_flag) { |
76 | 0 | return; |
77 | 0 | } |
78 | | |
79 | 0 | buf.write_binary(target_quantile); |
80 | 0 | buf.write_binary(compressions); |
81 | 0 | uint32_t serialize_size = digest->serialized_size(); |
82 | 0 | std::string result(serialize_size, '0'); |
83 | 0 | DCHECK(digest.get() != nullptr); |
84 | 0 | digest->serialize((uint8_t*)result.c_str()); |
85 | |
|
86 | 0 | buf.write_binary(result); |
87 | 0 | } |
88 | | |
89 | 0 | void read(BufferReadable& buf) { |
90 | 0 | buf.read_binary(init_flag); |
91 | 0 | if (!init_flag) { |
92 | 0 | return; |
93 | 0 | } |
94 | | |
95 | 0 | buf.read_binary(target_quantile); |
96 | 0 | buf.read_binary(compressions); |
97 | 0 | std::string str; |
98 | 0 | buf.read_binary(str); |
99 | 0 | digest = TDigest::create_unique(compressions); |
100 | 0 | digest->unserialize((uint8_t*)str.c_str()); |
101 | 0 | } |
102 | | |
103 | 0 | double get() const { |
104 | 0 | if (init_flag) { |
105 | 0 | return digest->quantile(static_cast<float>(target_quantile)); |
106 | 0 | } else { |
107 | 0 | return std::nan(""); |
108 | 0 | } |
109 | 0 | } |
110 | | |
111 | 0 | void merge(const PercentileApproxState& rhs) { |
112 | 0 | if (!rhs.init_flag) { |
113 | 0 | return; |
114 | 0 | } |
115 | 0 | if (init_flag) { |
116 | 0 | DCHECK(digest.get() != nullptr); |
117 | 0 | digest->merge(rhs.digest.get()); |
118 | 0 | } else { |
119 | 0 | digest = TDigest::create_unique(compressions); |
120 | 0 | digest->merge(rhs.digest.get()); |
121 | 0 | init_flag = true; |
122 | 0 | } |
123 | 0 | if (target_quantile == PercentileApproxState::INIT_QUANTILE) { |
124 | 0 | target_quantile = rhs.target_quantile; |
125 | 0 | } |
126 | 0 | } |
127 | | |
128 | 0 | void add(double source) { digest->add(static_cast<float>(source)); } |
129 | | |
130 | 0 | void add_with_weight(double source, double weight) { |
131 | | // the weight should be positive num, as have check the value valid use DCHECK_GT(c._weight, 0); |
132 | 0 | if (weight <= 0) { |
133 | 0 | return; |
134 | 0 | } |
135 | 0 | digest->add(static_cast<float>(source), static_cast<float>(weight)); |
136 | 0 | } |
137 | | |
138 | 0 | void reset() { |
139 | 0 | target_quantile = INIT_QUANTILE; |
140 | 0 | init_flag = false; |
141 | 0 | digest = TDigest::create_unique(compressions); |
142 | 0 | } |
143 | | |
144 | | bool init_flag = false; |
145 | | std::unique_ptr<TDigest> digest; |
146 | | double target_quantile = INIT_QUANTILE; |
147 | | float compressions = 10000; |
148 | | }; |
149 | | |
150 | | template <typename Derived> |
151 | | class AggregateFunctionPercentileApproxBase |
152 | | : public IAggregateFunctionDataHelper<PercentileApproxState, Derived> { |
153 | | public: |
154 | | AggregateFunctionPercentileApproxBase(const DataTypes& argument_types_) |
155 | 0 | : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}Unexecuted instantiation: _ZN5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
156 | | |
157 | 0 | String get_name() const override { return "percentile_approx"; }Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE8get_nameB5cxx11Ev |
158 | | |
159 | 0 | void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE5resetEPc Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE5resetEPc Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE5resetEPc Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE5resetEPc |
160 | | |
161 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
162 | 0 | Arena&) const override { |
163 | 0 | this->data(place).merge(this->data(rhs)); |
164 | 0 | } Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE5mergeEPcPKcRNS_5ArenaE |
165 | | |
166 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
167 | 0 | this->data(place).write(buf); |
168 | 0 | } Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE9serializeEPKcRNS_14BufferWritableE |
169 | | |
170 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
171 | 0 | Arena&) const override { |
172 | 0 | this->data(place).read(buf); |
173 | 0 | } Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE |
174 | | }; |
175 | | |
176 | | class AggregateFunctionPercentileApproxTwoParams final |
177 | | : public AggregateFunctionPercentileApproxBase<AggregateFunctionPercentileApproxTwoParams>, |
178 | | public MultiExpression, |
179 | | public NullableAggregateFunction { |
180 | | public: |
181 | | AggregateFunctionPercentileApproxTwoParams(const DataTypes& argument_types_) |
182 | 0 | : AggregateFunctionPercentileApproxBase<AggregateFunctionPercentileApproxTwoParams>( |
183 | 0 | argument_types_) {} |
184 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
185 | 0 | Arena&) const override { |
186 | 0 | const auto& sources = |
187 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
188 | 0 | const auto& quantile = |
189 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
190 | 0 | this->data(place).init(quantile.get_element(0)); |
191 | 0 | this->data(place).add(sources.get_element(row_num)); |
192 | 0 | } |
193 | | |
194 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
195 | | |
196 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
197 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
198 | 0 | double result = this->data(place).get(); |
199 | |
|
200 | 0 | if (std::isnan(result)) { |
201 | 0 | col.insert_default(); |
202 | 0 | } else { |
203 | 0 | col.get_data().push_back(result); |
204 | 0 | } |
205 | 0 | } |
206 | | }; |
207 | | |
208 | | class AggregateFunctionPercentileApproxThreeParams final |
209 | | : public AggregateFunctionPercentileApproxBase< |
210 | | AggregateFunctionPercentileApproxThreeParams>, |
211 | | public MultiExpression, |
212 | | public NullableAggregateFunction { |
213 | | public: |
214 | | AggregateFunctionPercentileApproxThreeParams(const DataTypes& argument_types_) |
215 | 0 | : AggregateFunctionPercentileApproxBase<AggregateFunctionPercentileApproxThreeParams>( |
216 | 0 | argument_types_) {} |
217 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
218 | 0 | Arena&) const override { |
219 | 0 | const auto& sources = |
220 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
221 | 0 | const auto& quantile = |
222 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
223 | 0 | const auto& compression = |
224 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
225 | |
|
226 | 0 | this->data(place).init(quantile.get_element(0), |
227 | 0 | static_cast<float>(compression.get_element(0))); |
228 | 0 | this->data(place).add(sources.get_element(row_num)); |
229 | 0 | } |
230 | | |
231 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
232 | | |
233 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
234 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
235 | 0 | double result = this->data(place).get(); |
236 | |
|
237 | 0 | if (std::isnan(result)) { |
238 | 0 | col.insert_default(); |
239 | 0 | } else { |
240 | 0 | col.get_data().push_back(result); |
241 | 0 | } |
242 | 0 | } |
243 | | }; |
244 | | |
245 | | class AggregateFunctionPercentileApproxWeightedThreeParams final |
246 | | : public AggregateFunctionPercentileApproxBase< |
247 | | AggregateFunctionPercentileApproxWeightedThreeParams>, |
248 | | MultiExpression, |
249 | | NullableAggregateFunction { |
250 | | public: |
251 | | AggregateFunctionPercentileApproxWeightedThreeParams(const DataTypes& argument_types_) |
252 | 0 | : AggregateFunctionPercentileApproxBase< |
253 | 0 | AggregateFunctionPercentileApproxWeightedThreeParams>(argument_types_) {} |
254 | | |
255 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
256 | 0 | Arena&) const override { |
257 | 0 | const auto& sources = |
258 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
259 | 0 | const auto& weight = |
260 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
261 | 0 | const auto& quantile = |
262 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
263 | |
|
264 | 0 | this->data(place).init(quantile.get_element(0)); |
265 | 0 | this->data(place).add_with_weight(sources.get_element(row_num), |
266 | 0 | weight.get_element(row_num)); |
267 | 0 | } |
268 | | |
269 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
270 | | |
271 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
272 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
273 | 0 | double result = this->data(place).get(); |
274 | |
|
275 | 0 | if (std::isnan(result)) { |
276 | 0 | col.insert_default(); |
277 | 0 | } else { |
278 | 0 | col.get_data().push_back(result); |
279 | 0 | } |
280 | 0 | } |
281 | | }; |
282 | | |
283 | | class AggregateFunctionPercentileApproxWeightedFourParams final |
284 | | : public AggregateFunctionPercentileApproxBase< |
285 | | AggregateFunctionPercentileApproxWeightedFourParams>, |
286 | | MultiExpression, |
287 | | NullableAggregateFunction { |
288 | | public: |
289 | | AggregateFunctionPercentileApproxWeightedFourParams(const DataTypes& argument_types_) |
290 | 0 | : AggregateFunctionPercentileApproxBase< |
291 | 0 | AggregateFunctionPercentileApproxWeightedFourParams>(argument_types_) {} |
292 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
293 | 0 | Arena&) const override { |
294 | 0 | const auto& sources = |
295 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
296 | 0 | const auto& weight = |
297 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
298 | 0 | const auto& quantile = |
299 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]); |
300 | 0 | const auto& compression = |
301 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[3]); |
302 | |
|
303 | 0 | this->data(place).init(quantile.get_element(0), |
304 | 0 | static_cast<float>(compression.get_element(0))); |
305 | 0 | this->data(place).add_with_weight(sources.get_element(row_num), |
306 | 0 | weight.get_element(row_num)); |
307 | 0 | } |
308 | | |
309 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); } |
310 | | |
311 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
312 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
313 | 0 | double result = this->data(place).get(); |
314 | |
|
315 | 0 | if (std::isnan(result)) { |
316 | 0 | col.insert_default(); |
317 | 0 | } else { |
318 | 0 | col.get_data().push_back(result); |
319 | 0 | } |
320 | 0 | } |
321 | | }; |
322 | | |
323 | | template <PrimitiveType T> |
324 | | struct PercentileState { |
325 | | mutable std::vector<Counts<typename PrimitiveTypeTraits<T>::CppType>> vec_counts; |
326 | | std::vector<double> vec_quantile {-1}; |
327 | | bool inited_flag = false; |
328 | | |
329 | 0 | void write(BufferWritable& buf) const { |
330 | 0 | buf.write_binary(inited_flag); |
331 | 0 | if (!inited_flag) { |
332 | 0 | return; |
333 | 0 | } |
334 | 0 | int size_num = cast_set<int>(vec_quantile.size()); |
335 | 0 | buf.write_binary(size_num); |
336 | 0 | for (const auto& quantile : vec_quantile) { |
337 | 0 | buf.write_binary(quantile); |
338 | 0 | } |
339 | 0 | for (auto& counts : vec_counts) { |
340 | 0 | counts.serialize(buf); |
341 | 0 | } |
342 | 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 |
343 | | |
344 | 0 | void read(BufferReadable& buf) { |
345 | 0 | buf.read_binary(inited_flag); |
346 | 0 | if (!inited_flag) { |
347 | 0 | return; |
348 | 0 | } |
349 | 0 | int size_num = 0; |
350 | 0 | buf.read_binary(size_num); |
351 | 0 | double data = 0.0; |
352 | 0 | vec_quantile.clear(); |
353 | 0 | for (int i = 0; i < size_num; ++i) { |
354 | 0 | buf.read_binary(data); |
355 | 0 | vec_quantile.emplace_back(data); |
356 | 0 | } |
357 | 0 | vec_counts.clear(); |
358 | 0 | vec_counts.resize(size_num); |
359 | 0 | for (int i = 0; i < size_num; ++i) { |
360 | 0 | vec_counts[i].unserialize(buf); |
361 | 0 | } |
362 | 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 |
363 | | |
364 | | void add(typename PrimitiveTypeTraits<T>::CppType source, |
365 | 0 | const PaddedPODArray<Float64>& quantiles, const NullMap& null_maps, int64_t arg_size) { |
366 | 0 | if (!inited_flag) { |
367 | 0 | vec_counts.resize(arg_size); |
368 | 0 | vec_quantile.resize(arg_size, -1); |
369 | 0 | inited_flag = true; |
370 | 0 | for (int i = 0; i < arg_size; ++i) { |
371 | | // throw Exception func call percentile_array(id, [1,0,null]) |
372 | 0 | if (null_maps[i]) { |
373 | 0 | throw Exception(ErrorCode::INVALID_ARGUMENT, |
374 | 0 | "quantiles in func percentile_array should not have null"); |
375 | 0 | } |
376 | 0 | check_quantile(quantiles[i]); |
377 | 0 | vec_quantile[i] = quantiles[i]; |
378 | 0 | } |
379 | 0 | } |
380 | 0 | for (int i = 0; i < arg_size; ++i) { |
381 | 0 | vec_counts[i].increment(source); |
382 | 0 | } |
383 | 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 |
384 | | |
385 | | void add_batch(const PaddedPODArray<typename PrimitiveTypeTraits<T>::CppType>& source, |
386 | 0 | const Float64& q) { |
387 | 0 | if (!inited_flag) { |
388 | 0 | inited_flag = true; |
389 | 0 | vec_counts.resize(1); |
390 | 0 | vec_quantile.resize(1); |
391 | 0 | check_quantile(q); |
392 | 0 | vec_quantile[0] = q; |
393 | 0 | } |
394 | 0 | vec_counts[0].increment_batch(source); |
395 | 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 |
396 | | |
397 | 0 | void merge(const PercentileState& rhs) { |
398 | 0 | if (!rhs.inited_flag) { |
399 | 0 | return; |
400 | 0 | } |
401 | 0 | int size_num = cast_set<int>(rhs.vec_quantile.size()); |
402 | 0 | if (!inited_flag) { |
403 | 0 | vec_counts.resize(size_num); |
404 | 0 | vec_quantile.resize(size_num, -1); |
405 | 0 | inited_flag = true; |
406 | 0 | } |
407 | |
|
408 | 0 | for (int i = 0; i < size_num; ++i) { |
409 | 0 | if (vec_quantile[i] == -1.0) { |
410 | 0 | vec_quantile[i] = rhs.vec_quantile[i]; |
411 | 0 | } |
412 | 0 | vec_counts[i].merge(&(rhs.vec_counts[i])); |
413 | 0 | } |
414 | 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_ |
415 | | |
416 | 0 | void reset() { |
417 | 0 | vec_counts.clear(); |
418 | 0 | vec_quantile.clear(); |
419 | 0 | inited_flag = false; |
420 | 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 |
421 | | |
422 | 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 |
423 | | |
424 | 0 | void insert_result_into(IColumn& to) const { |
425 | 0 | auto& column_data = assert_cast<ColumnFloat64&>(to).get_data(); |
426 | 0 | for (int i = 0; i < vec_counts.size(); ++i) { |
427 | 0 | column_data.push_back(vec_counts[i].terminate(vec_quantile[i])); |
428 | 0 | } |
429 | 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 |
430 | | }; |
431 | | |
432 | | template <PrimitiveType T> |
433 | | struct PercentileExactState { |
434 | | using ValueType = typename PrimitiveTypeTraits<T>::CppType; |
435 | | static constexpr size_t bytes_in_arena = 64 - sizeof(PODArray<ValueType>); |
436 | | using Array = PODArrayWithStackMemory<ValueType, bytes_in_arena>; |
437 | | |
438 | 0 | void add_single_range(const ValueType* data, size_t count, double quantile) { |
439 | 0 | if (!inited_flag) { |
440 | 0 | _set_single_level(quantile); |
441 | 0 | inited_flag = true; |
442 | 0 | } |
443 | 0 | _append(data, count); |
444 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE16add_single_rangeEPKamd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE16add_single_rangeEPKsmd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE16add_single_rangeEPKimd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE16add_single_rangeEPKlmd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE16add_single_rangeEPKnmd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE16add_single_rangeEPKfmd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE16add_single_rangeEPKdmd |
445 | | |
446 | | void add_many_range(const ValueType* data, size_t count, |
447 | | const PaddedPODArray<Float64>& quantiles_data, const NullMap& null_maps, |
448 | 0 | size_t start, int64_t arg_size) { |
449 | 0 | if (!inited_flag) { |
450 | 0 | _set_many_levels(quantiles_data, null_maps, start, arg_size); |
451 | 0 | inited_flag = true; |
452 | 0 | } |
453 | 0 | if (levels.empty()) { |
454 | 0 | return; |
455 | 0 | } |
456 | 0 | _append(data, count); |
457 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE14add_many_rangeEPKamRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE14add_many_rangeEPKsmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE14add_many_rangeEPKimRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE14add_many_rangeEPKlmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE14add_many_rangeEPKnmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE14add_many_rangeEPKfmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE14add_many_rangeEPKdmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml |
458 | | |
459 | 0 | void write(BufferWritable& buf) const { |
460 | 0 | buf.write_binary(inited_flag); |
461 | 0 | if (!inited_flag) { |
462 | 0 | return; |
463 | 0 | } |
464 | | |
465 | 0 | levels.write(buf); |
466 | 0 | size_t size = values.size(); |
467 | 0 | buf.write_binary(size); |
468 | 0 | if (size > 0) { |
469 | 0 | buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size); |
470 | 0 | } |
471 | 0 | } Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5writeERNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5writeERNS_14BufferWritableE |
472 | | |
473 | 0 | void read(BufferReadable& buf) { |
474 | 0 | reset(); |
475 | 0 | buf.read_binary(inited_flag); |
476 | 0 | if (!inited_flag) { |
477 | 0 | return; |
478 | 0 | } |
479 | | |
480 | 0 | levels.read(buf); |
481 | 0 | size_t size = 0; |
482 | 0 | buf.read_binary(size); |
483 | 0 | values.resize(size); |
484 | 0 | if (size > 0) { |
485 | 0 | auto raw = buf.read(sizeof(ValueType) * size); |
486 | 0 | memcpy(values.data(), raw.data, raw.size); |
487 | 0 | } |
488 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE4readERNS_14BufferReadableE Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE4readERNS_14BufferReadableE |
489 | | |
490 | 0 | void merge(const PercentileExactState& rhs) { |
491 | 0 | if (!rhs.inited_flag) { |
492 | 0 | return; |
493 | 0 | } |
494 | | |
495 | 0 | if (!inited_flag) { |
496 | 0 | levels = rhs.levels; |
497 | 0 | inited_flag = true; |
498 | 0 | } else { |
499 | 0 | levels.merge(rhs.levels); |
500 | 0 | } |
501 | 0 | _append(rhs.values.data(), rhs.values.size()); |
502 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5mergeERKS2_ Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5mergeERKS2_ |
503 | | |
504 | 0 | void reset() { |
505 | 0 | values.clear(); |
506 | 0 | levels.clear(); |
507 | 0 | inited_flag = false; |
508 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5resetEv Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5resetEv |
509 | | |
510 | 0 | double get() const { |
511 | 0 | if (!inited_flag || levels.empty() || values.empty()) { |
512 | 0 | return 0.0; |
513 | 0 | } |
514 | | |
515 | 0 | DCHECK_EQ(levels.quantiles.size(), 1); |
516 | 0 | return _get_result(levels.quantiles[0]); |
517 | 0 | } Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE3getEv Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE3getEv |
518 | | |
519 | 0 | void insert_result_into(IColumn& to) const { |
520 | 0 | auto& column_data = assert_cast<ColumnFloat64&>(to).get_data(); |
521 | 0 | if (!inited_flag || levels.empty() || values.empty()) { |
522 | 0 | return; |
523 | 0 | } |
524 | | |
525 | 0 | size_t old_size = column_data.size(); |
526 | 0 | size_t size = levels.quantiles.size(); |
527 | 0 | column_data.resize(old_size + size); |
528 | 0 | auto* result = column_data.data() + old_size; |
529 | |
|
530 | 0 | if (values.size() == 1) { |
531 | 0 | for (size_t i = 0; i < size; ++i) { |
532 | 0 | result[i] = static_cast<double>(values.front()); |
533 | 0 | } |
534 | 0 | return; |
535 | 0 | } |
536 | | |
537 | 0 | size_t prev_index = 0; |
538 | 0 | const auto& quantiles = levels.quantiles; |
539 | 0 | const auto& permutation = levels.get_permutation(); |
540 | 0 | for (size_t i = 0; i < size; ++i) { |
541 | 0 | auto level_index = permutation[i]; |
542 | 0 | auto level = quantiles[level_index]; |
543 | 0 | double u = static_cast<double>(values.size() - 1) * level; |
544 | 0 | auto index = static_cast<size_t>(u); |
545 | |
|
546 | 0 | if (index + 1 >= values.size()) { |
547 | 0 | result[level_index] = |
548 | 0 | static_cast<double>(*std::max_element(values.begin(), values.end())); |
549 | 0 | } else { |
550 | 0 | std::nth_element(values.begin() + prev_index, values.begin() + index, values.end()); |
551 | 0 | auto* nth_elem = std::min_element(values.begin() + index + 1, values.end()); |
552 | 0 | result[level_index] = |
553 | 0 | static_cast<double>(values[index]) + |
554 | 0 | (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) - |
555 | 0 | static_cast<double>(values[index])); |
556 | 0 | prev_index = index; |
557 | 0 | } |
558 | 0 | } |
559 | 0 | } Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE18insert_result_intoERNS_7IColumnE Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE18insert_result_intoERNS_7IColumnE |
560 | | |
561 | | private: |
562 | 0 | void _set_single_level(double quantile) { |
563 | 0 | DCHECK(levels.empty()); |
564 | 0 | check_quantile(quantile); |
565 | 0 | levels.quantiles.push_back(quantile); |
566 | 0 | levels.permutation.push_back(0); |
567 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE17_set_single_levelEd Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE17_set_single_levelEd |
568 | | |
569 | | void _set_many_levels(const PaddedPODArray<Float64>& quantiles_data, const NullMap& null_maps, |
570 | 0 | size_t start, int64_t arg_size) { |
571 | 0 | DCHECK(levels.empty()); |
572 | 0 | size_t size = cast_set<size_t>(arg_size); |
573 | 0 | levels.quantiles.resize(size); |
574 | 0 | levels.permutation.resize(size); |
575 | 0 | for (size_t i = 0; i < size; ++i) { |
576 | 0 | if (null_maps[start + i]) { |
577 | 0 | throw Exception(ErrorCode::INVALID_ARGUMENT, |
578 | 0 | "quantiles in func percentile_array should not have null"); |
579 | 0 | } |
580 | 0 | check_quantile(quantiles_data[start + i]); |
581 | 0 | levels.quantiles[i] = quantiles_data[start + i]; |
582 | 0 | levels.permutation[i] = i; |
583 | 0 | } |
584 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml |
585 | | |
586 | 0 | void _append(const ValueType* data, size_t count) { |
587 | 0 | if (count == 0) { |
588 | 0 | return; |
589 | 0 | } |
590 | 0 | values.reserve(values.size() + count); |
591 | 0 | values.insert_assume_reserved(data, data + count); |
592 | 0 | } Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE7_appendEPKam Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE7_appendEPKsm Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE7_appendEPKim Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE7_appendEPKlm Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE7_appendEPKnm Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE7_appendEPKfm Unexecuted instantiation: _ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE7_appendEPKdm |
593 | | |
594 | 0 | double _get_result(double quantile) const { |
595 | 0 | if (values.size() == 1) { |
596 | 0 | return static_cast<double>(values.front()); |
597 | 0 | } |
598 | | |
599 | 0 | double u = static_cast<double>(values.size() - 1) * quantile; |
600 | 0 | auto index = static_cast<size_t>(u); |
601 | |
|
602 | 0 | if (index + 1 >= values.size()) { |
603 | 0 | return static_cast<double>(*std::max_element(values.begin(), values.end())); |
604 | 0 | } |
605 | | |
606 | 0 | std::nth_element(values.begin(), values.begin() + index, values.end()); |
607 | 0 | auto* nth_elem = std::min_element(values.begin() + index + 1, values.end()); |
608 | |
|
609 | 0 | return static_cast<double>(values[index]) + |
610 | 0 | (u - static_cast<double>(index)) * |
611 | 0 | (static_cast<double>(*nth_elem) - static_cast<double>(values[index])); |
612 | 0 | } Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE11_get_resultEd Unexecuted instantiation: _ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE11_get_resultEd |
613 | | |
614 | | mutable Array values; |
615 | | mutable PercentileLevels levels; |
616 | | bool inited_flag = false; |
617 | | }; |
618 | | |
619 | | template <PrimitiveType T> |
620 | | class AggregateFunctionPercentile final |
621 | | : public IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentile<T>>, |
622 | | MultiExpression, |
623 | | NullableAggregateFunction { |
624 | | public: |
625 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
626 | | using Base = IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentile<T>>; |
627 | 2 | 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 _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 627 | 2 | AggregateFunctionPercentile(const DataTypes& argument_types_) : Base(argument_types_) {} |
Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
628 | | |
629 | 2 | String get_name() const override { return "percentile"; }Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Line | Count | Source | 629 | 2 | String get_name() const override { return "percentile"; } |
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
630 | | |
631 | 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 |
632 | | |
633 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
634 | 0 | Arena&) const override { |
635 | 0 | const auto& sources = |
636 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
637 | 0 | const auto& quantile = |
638 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
639 | 0 | AggregateFunctionPercentile::data(place).add(sources.get_data()[row_num], |
640 | 0 | quantile.get_data(), NullMap(1, 0), 1); |
641 | 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 |
642 | | |
643 | | void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns, |
644 | 0 | Arena&) const override { |
645 | 0 | const auto& sources = |
646 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
647 | 0 | const auto& quantile = |
648 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
649 | 0 | DCHECK_EQ(sources.get_data().size(), batch_size); |
650 | 0 | AggregateFunctionPercentile::data(place).add_batch(sources.get_data(), |
651 | 0 | quantile.get_data()[0]); |
652 | 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 |
653 | | |
654 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
655 | 0 | AggregateFunctionPercentile::data(place).reset(); |
656 | 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 |
657 | | |
658 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
659 | 0 | Arena&) const override { |
660 | 0 | AggregateFunctionPercentile::data(place).merge(AggregateFunctionPercentile::data(rhs)); |
661 | 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 |
662 | | |
663 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
664 | 0 | AggregateFunctionPercentile::data(place).write(buf); |
665 | 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 |
666 | | |
667 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
668 | 0 | Arena&) const override { |
669 | 0 | AggregateFunctionPercentile::data(place).read(buf); |
670 | 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 |
671 | | |
672 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
673 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
674 | 0 | col.insert_value(AggregateFunctionPercentile::data(place).get()); |
675 | 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 |
676 | | }; |
677 | | |
678 | | template <PrimitiveType T> |
679 | | class AggregateFunctionPercentileArray final |
680 | | : public IAggregateFunctionDataHelper<PercentileState<T>, |
681 | | AggregateFunctionPercentileArray<T>>, |
682 | | MultiExpression, |
683 | | NotNullableAggregateFunction { |
684 | | public: |
685 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
686 | | using Base = |
687 | | IAggregateFunctionDataHelper<PercentileState<T>, AggregateFunctionPercentileArray<T>>; |
688 | 1 | 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 _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 688 | 1 | AggregateFunctionPercentileArray(const DataTypes& argument_types_) : Base(argument_types_) {} |
Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
689 | | |
690 | 1 | String get_name() const override { return "percentile_array"; }Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Line | Count | Source | 690 | 1 | String get_name() const override { return "percentile_array"; } |
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
691 | | |
692 | 0 | DataTypePtr get_return_type() const override { |
693 | 0 | return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>())); |
694 | 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 |
695 | | |
696 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
697 | 0 | Arena&) const override { |
698 | 0 | const auto& sources = |
699 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
700 | 0 | const auto& quantile_array = |
701 | 0 | assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
702 | 0 | const auto& offset_column_data = quantile_array.get_offsets(); |
703 | 0 | const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
704 | 0 | quantile_array.get_data()) |
705 | 0 | .get_null_map_data(); |
706 | 0 | const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
707 | 0 | quantile_array.get_data()) |
708 | 0 | .get_nested_column(); |
709 | 0 | const auto& nested_column_data = |
710 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column); |
711 | |
|
712 | 0 | AggregateFunctionPercentileArray::data(place).add( |
713 | 0 | sources.get_element(row_num), nested_column_data.get_data(), null_maps, |
714 | 0 | offset_column_data.data()[row_num] - offset_column_data[(ssize_t)row_num - 1]); |
715 | 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 |
716 | | |
717 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
718 | 0 | AggregateFunctionPercentileArray::data(place).reset(); |
719 | 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 |
720 | | |
721 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
722 | 0 | Arena&) const override { |
723 | 0 | AggregateFunctionPercentileArray::data(place).merge( |
724 | 0 | AggregateFunctionPercentileArray::data(rhs)); |
725 | 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 |
726 | | |
727 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
728 | 0 | AggregateFunctionPercentileArray::data(place).write(buf); |
729 | 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 |
730 | | |
731 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
732 | 0 | Arena&) const override { |
733 | 0 | AggregateFunctionPercentileArray::data(place).read(buf); |
734 | 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 |
735 | | |
736 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
737 | 0 | auto& to_arr = assert_cast<ColumnArray&>(to); |
738 | 0 | auto& to_nested_col = to_arr.get_data(); |
739 | 0 | if (to_nested_col.is_nullable()) { |
740 | 0 | auto col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col); |
741 | 0 | AggregateFunctionPercentileArray::data(place).insert_result_into( |
742 | 0 | col_null->get_nested_column()); |
743 | 0 | col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0); |
744 | 0 | } else { |
745 | 0 | AggregateFunctionPercentileArray::data(place).insert_result_into(to_nested_col); |
746 | 0 | } |
747 | 0 | to_arr.get_offsets().push_back(to_nested_col.size()); |
748 | 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 |
749 | | }; |
750 | | |
751 | | template <PrimitiveType T> |
752 | | class AggregateFunctionPercentileV2 final |
753 | | : public IAggregateFunctionDataHelper<PercentileExactState<T>, |
754 | | AggregateFunctionPercentileV2<T>>, |
755 | | MultiExpression, |
756 | | NullableAggregateFunction { |
757 | | public: |
758 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
759 | | using Base = |
760 | | IAggregateFunctionDataHelper<PercentileExactState<T>, AggregateFunctionPercentileV2<T>>; |
761 | 2 | AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 761 | 2 | AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {} |
Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
762 | | |
763 | 2 | String get_name() const override { return "percentile_v2"; }Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Line | Count | Source | 763 | 2 | String get_name() const override { return "percentile_v2"; } |
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
764 | | |
765 | 0 | DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE15get_return_typeEv |
766 | | |
767 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
768 | 0 | Arena&) const override { |
769 | 0 | const auto& sources = |
770 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
771 | 0 | const auto& quantile = |
772 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
773 | 0 | AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1, |
774 | 0 | quantile.get_data()[0]); |
775 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE |
776 | | |
777 | | void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns, |
778 | 0 | Arena&) const override { |
779 | 0 | const auto& sources = |
780 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
781 | 0 | const auto& quantile = |
782 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
783 | 0 | DCHECK_EQ(sources.get_data().size(), batch_size); |
784 | 0 | AggregateFunctionPercentileV2::data(place).add_single_range( |
785 | 0 | sources.get_data().data(), batch_size, quantile.get_data()[0]); |
786 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE |
787 | | |
788 | | void add_batch_range(size_t batch_begin, size_t batch_end, AggregateDataPtr place, |
789 | 0 | const IColumn** columns, Arena&, bool has_null) override { |
790 | 0 | const auto& sources = |
791 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
792 | 0 | const auto& quantile = |
793 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
794 | 0 | DCHECK(!has_null); |
795 | 0 | AggregateFunctionPercentileV2::data(place).add_single_range( |
796 | 0 | sources.get_data().data() + batch_begin, batch_end - batch_begin + 1, |
797 | 0 | quantile.get_data()[0]); |
798 | 0 | } Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb |
799 | | |
800 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
801 | 0 | AggregateFunctionPercentileV2::data(place).reset(); |
802 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE5resetEPc Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE5resetEPc |
803 | | |
804 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
805 | 0 | Arena&) const override { |
806 | 0 | AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs)); |
807 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE |
808 | | |
809 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
810 | 0 | AggregateFunctionPercentileV2::data(place).write(buf); |
811 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE |
812 | | |
813 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
814 | 0 | Arena&) const override { |
815 | 0 | AggregateFunctionPercentileV2::data(place).read(buf); |
816 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE |
817 | | |
818 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
819 | 0 | auto& col = assert_cast<ColumnFloat64&>(to); |
820 | 0 | col.insert_value(AggregateFunctionPercentileV2::data(place).get()); |
821 | 0 | } Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE |
822 | | }; |
823 | | |
824 | | template <PrimitiveType T> |
825 | | class AggregateFunctionPercentileArrayV2 final |
826 | | : public IAggregateFunctionDataHelper<PercentileExactState<T>, |
827 | | AggregateFunctionPercentileArrayV2<T>>, |
828 | | MultiExpression, |
829 | | NotNullableAggregateFunction { |
830 | | public: |
831 | | using ColVecType = typename PrimitiveTypeTraits<T>::ColumnType; |
832 | | using Base = IAggregateFunctionDataHelper<PercentileExactState<T>, |
833 | | AggregateFunctionPercentileArrayV2<T>>; |
834 | 1 | AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Line | Count | Source | 834 | 1 | AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {} |
Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE |
835 | | |
836 | 1 | String get_name() const override { return "percentile_array_v2"; }Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev Line | Count | Source | 836 | 1 | String get_name() const override { return "percentile_array_v2"; } |
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev |
837 | | |
838 | 0 | DataTypePtr get_return_type() const override { |
839 | 0 | return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>())); |
840 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE15get_return_typeEv Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE15get_return_typeEv |
841 | | |
842 | | void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num, |
843 | 0 | Arena&) const override { |
844 | 0 | const auto& sources = |
845 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
846 | 0 | const auto& quantile_array = |
847 | 0 | assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
848 | 0 | const auto& offset_column_data = quantile_array.get_offsets(); |
849 | 0 | const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
850 | 0 | quantile_array.get_data()) |
851 | 0 | .get_null_map_data(); |
852 | 0 | const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
853 | 0 | quantile_array.get_data()) |
854 | 0 | .get_nested_column(); |
855 | 0 | const auto& nested_column_data = |
856 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column); |
857 | 0 | size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1]; |
858 | 0 | AggregateFunctionPercentileArrayV2::data(place).add_many_range( |
859 | 0 | &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start, |
860 | 0 | cast_set<int64_t>(offset_column_data[row_num] - start)); |
861 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE |
862 | | |
863 | | void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns, |
864 | 0 | Arena&) const override { |
865 | 0 | const auto& sources = |
866 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
867 | 0 | const auto& quantile_array = |
868 | 0 | assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
869 | 0 | const auto& offset_column_data = quantile_array.get_offsets(); |
870 | 0 | const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
871 | 0 | quantile_array.get_data()) |
872 | 0 | .get_null_map_data(); |
873 | 0 | const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
874 | 0 | quantile_array.get_data()) |
875 | 0 | .get_nested_column(); |
876 | 0 | const auto& nested_column_data = |
877 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column); |
878 | 0 | DCHECK_EQ(sources.get_data().size(), batch_size); |
879 | 0 | AggregateFunctionPercentileArrayV2::data(place).add_many_range( |
880 | 0 | sources.get_data().data(), batch_size, nested_column_data.get_data(), null_maps, 0, |
881 | 0 | cast_set<int64_t>(offset_column_data[0])); |
882 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE |
883 | | |
884 | | void add_batch_range(size_t batch_begin, size_t batch_end, AggregateDataPtr place, |
885 | 0 | const IColumn** columns, Arena&, bool has_null) override { |
886 | 0 | const auto& sources = |
887 | 0 | assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]); |
888 | 0 | const auto& quantile_array = |
889 | 0 | assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]); |
890 | 0 | const auto& offset_column_data = quantile_array.get_offsets(); |
891 | 0 | const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
892 | 0 | quantile_array.get_data()) |
893 | 0 | .get_null_map_data(); |
894 | 0 | const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>( |
895 | 0 | quantile_array.get_data()) |
896 | 0 | .get_nested_column(); |
897 | 0 | const auto& nested_column_data = |
898 | 0 | assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column); |
899 | 0 | DCHECK(!has_null); |
900 | 0 | size_t start = batch_begin == 0 ? 0 : offset_column_data[batch_begin - 1]; |
901 | 0 | AggregateFunctionPercentileArrayV2::data(place).add_many_range( |
902 | 0 | sources.get_data().data() + batch_begin, batch_end - batch_begin + 1, |
903 | 0 | nested_column_data.get_data(), null_maps, start, |
904 | 0 | cast_set<int64_t>(offset_column_data[batch_begin] - start)); |
905 | 0 | } Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb Unexecuted instantiation: _ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE15add_batch_rangeEmmPcPPKNS_7IColumnERNS_5ArenaEb |
906 | | |
907 | 0 | void reset(AggregateDataPtr __restrict place) const override { |
908 | 0 | AggregateFunctionPercentileArrayV2::data(place).reset(); |
909 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE5resetEPc Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE5resetEPc |
910 | | |
911 | | void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs, |
912 | 0 | Arena&) const override { |
913 | 0 | AggregateFunctionPercentileArrayV2::data(place).merge( |
914 | 0 | AggregateFunctionPercentileArrayV2::data(rhs)); |
915 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE |
916 | | |
917 | 0 | void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override { |
918 | 0 | AggregateFunctionPercentileArrayV2::data(place).write(buf); |
919 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE |
920 | | |
921 | | void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf, |
922 | 0 | Arena&) const override { |
923 | 0 | AggregateFunctionPercentileArrayV2::data(place).read(buf); |
924 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE |
925 | | |
926 | 0 | void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override { |
927 | 0 | auto& to_arr = assert_cast<ColumnArray&>(to); |
928 | 0 | auto& to_nested_col = to_arr.get_data(); |
929 | 0 | if (to_nested_col.is_nullable()) { |
930 | 0 | auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col); |
931 | 0 | AggregateFunctionPercentileArrayV2::data(place).insert_result_into( |
932 | 0 | col_null->get_nested_column()); |
933 | 0 | col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0); |
934 | 0 | } else { |
935 | 0 | AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col); |
936 | 0 | } |
937 | 0 | to_arr.get_offsets().push_back(to_nested_col.size()); |
938 | 0 | } Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE |
939 | | }; |
940 | | |
941 | | } // namespace doris |