Coverage Report

Created: 2026-05-09 15:32

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
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