Coverage Report

Created: 2026-04-28 15:58

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
928
    PercentileApproxState() = default;
54
928
    ~PercentileApproxState() = default;
55
56
877
    void init(double quantile, float compression = 10000) {
57
877
        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
432
            if (compression < 2048 || compression > 10000) {
63
0
                compression = 10000;
64
0
            }
65
432
            digest = TDigest::create_unique(compression);
66
432
            check_quantile(quantile);
67
432
            target_quantile = quantile;
68
432
            compressions = compression;
69
432
            init_flag = true;
70
432
        }
71
877
    }
72
73
321
    void write(BufferWritable& buf) const {
74
321
        buf.write_binary(init_flag);
75
321
        if (!init_flag) {
76
0
            return;
77
0
        }
78
79
321
        buf.write_binary(target_quantile);
80
321
        buf.write_binary(compressions);
81
321
        uint32_t serialize_size = digest->serialized_size();
82
321
        std::string result(serialize_size, '0');
83
321
        DCHECK(digest.get() != nullptr);
84
321
        digest->serialize((uint8_t*)result.c_str());
85
86
321
        buf.write_binary(result);
87
321
    }
88
89
282
    void read(BufferReadable& buf) {
90
282
        buf.read_binary(init_flag);
91
282
        if (!init_flag) {
92
0
            return;
93
0
        }
94
95
282
        buf.read_binary(target_quantile);
96
282
        buf.read_binary(compressions);
97
282
        std::string str;
98
282
        buf.read_binary(str);
99
282
        digest = TDigest::create_unique(compressions);
100
282
        digest->unserialize((uint8_t*)str.c_str());
101
282
    }
102
103
364
    double get() const {
104
364
        if (init_flag) {
105
362
            return digest->quantile(static_cast<float>(target_quantile));
106
362
        } else {
107
2
            return std::nan("");
108
2
        }
109
364
    }
110
111
282
    void merge(const PercentileApproxState& rhs) {
112
282
        if (!rhs.init_flag) {
113
0
            return;
114
0
        }
115
282
        if (init_flag) {
116
131
            DCHECK(digest.get() != nullptr);
117
131
            digest->merge(rhs.digest.get());
118
151
        } else {
119
151
            digest = TDigest::create_unique(compressions);
120
151
            digest->merge(rhs.digest.get());
121
151
            init_flag = true;
122
151
        }
123
282
        if (target_quantile == PercentileApproxState::INIT_QUANTILE) {
124
151
            target_quantile = rhs.target_quantile;
125
151
        }
126
282
    }
127
128
737
    void add(double source) { digest->add(static_cast<float>(source)); }
129
130
134
    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
134
        if (weight <= 0) {
133
10
            return;
134
10
        }
135
124
        digest->add(static_cast<float>(source), static_cast<float>(weight));
136
124
    }
137
138
158
    void reset() {
139
158
        target_quantile = INIT_QUANTILE;
140
158
        init_flag = false;
141
158
        digest = TDigest::create_unique(compressions);
142
158
    }
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
821
            : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}
_ZN5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
155
739
            : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}
_ZN5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
155
37
            : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}
_ZN5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
155
23
            : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}
_ZN5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
155
22
            : IAggregateFunctionDataHelper<PercentileApproxState, Derived>(argument_types_) {}
156
157
101
    String get_name() const override { return "percentile_approx"; }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE8get_nameB5cxx11Ev
Line
Count
Source
157
55
    String get_name() const override { return "percentile_approx"; }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE8get_nameB5cxx11Ev
Line
Count
Source
157
36
    String get_name() const override { return "percentile_approx"; }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE8get_nameB5cxx11Ev
Line
Count
Source
157
10
    String get_name() const override { return "percentile_approx"; }
Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE8get_nameB5cxx11Ev
158
159
158
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE5resetEPc
Line
Count
Source
159
50
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE5resetEPc
Line
Count
Source
159
105
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE5resetEPc
Line
Count
Source
159
3
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE5resetEPc
160
161
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
162
282
               Arena&) const override {
163
282
        this->data(place).merge(this->data(rhs));
164
282
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
162
206
               Arena&) const override {
163
206
        this->data(place).merge(this->data(rhs));
164
206
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
162
58
               Arena&) const override {
163
58
        this->data(place).merge(this->data(rhs));
164
58
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
162
8
               Arena&) const override {
163
8
        this->data(place).merge(this->data(rhs));
164
8
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
162
10
               Arena&) const override {
163
10
        this->data(place).merge(this->data(rhs));
164
10
    }
165
166
321
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
167
321
        this->data(place).write(buf);
168
321
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
166
245
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
167
245
        this->data(place).write(buf);
168
245
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
166
58
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
167
58
        this->data(place).write(buf);
168
58
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
166
8
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
167
8
        this->data(place).write(buf);
168
8
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
166
10
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
167
10
        this->data(place).write(buf);
168
10
    }
169
170
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
171
282
                     Arena&) const override {
172
282
        this->data(place).read(buf);
173
282
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_42AggregateFunctionPercentileApproxTwoParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
171
206
                     Arena&) const override {
172
206
        this->data(place).read(buf);
173
206
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_44AggregateFunctionPercentileApproxThreeParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
171
58
                     Arena&) const override {
172
58
        this->data(place).read(buf);
173
58
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_52AggregateFunctionPercentileApproxWeightedThreeParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
171
8
                     Arena&) const override {
172
8
        this->data(place).read(buf);
173
8
    }
_ZNK5doris37AggregateFunctionPercentileApproxBaseINS_51AggregateFunctionPercentileApproxWeightedFourParamsEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
171
10
                     Arena&) const override {
172
10
        this->data(place).read(buf);
173
10
    }
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
739
            : AggregateFunctionPercentileApproxBase<AggregateFunctionPercentileApproxTwoParams>(
183
739
                      argument_types_) {}
184
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
185
305
             Arena&) const override {
186
305
        const auto& sources =
187
305
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]);
188
305
        const auto& quantile =
189
305
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
190
305
        this->data(place).init(quantile.get_element(0));
191
305
        this->data(place).add(sources.get_element(row_num));
192
305
    }
193
194
120
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
195
196
102
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
197
102
        auto& col = assert_cast<ColumnFloat64&>(to);
198
102
        double result = this->data(place).get();
199
200
102
        if (std::isnan(result)) {
201
1
            col.insert_default();
202
101
        } else {
203
101
            col.get_data().push_back(result);
204
101
        }
205
102
    }
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
37
            : AggregateFunctionPercentileApproxBase<AggregateFunctionPercentileApproxThreeParams>(
216
37
                      argument_types_) {}
217
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
218
438
             Arena&) const override {
219
438
        const auto& sources =
220
438
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]);
221
438
        const auto& quantile =
222
438
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
223
438
        const auto& compression =
224
438
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]);
225
226
438
        this->data(place).init(quantile.get_element(0),
227
438
                               static_cast<float>(compression.get_element(0)));
228
438
        this->data(place).add(sources.get_element(row_num));
229
438
    }
230
231
92
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
232
233
225
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
234
225
        auto& col = assert_cast<ColumnFloat64&>(to);
235
225
        double result = this->data(place).get();
236
237
225
        if (std::isnan(result)) {
238
0
            col.insert_default();
239
225
        } else {
240
225
            col.get_data().push_back(result);
241
225
        }
242
225
    }
243
};
244
245
class AggregateFunctionPercentileApproxWeightedThreeParams final
246
        : public AggregateFunctionPercentileApproxBase<
247
                  AggregateFunctionPercentileApproxWeightedThreeParams>,
248
          MultiExpression,
249
          NullableAggregateFunction {
250
public:
251
    AggregateFunctionPercentileApproxWeightedThreeParams(const DataTypes& argument_types_)
252
23
            : AggregateFunctionPercentileApproxBase<
253
23
                      AggregateFunctionPercentileApproxWeightedThreeParams>(argument_types_) {}
254
255
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
256
54
             Arena&) const override {
257
54
        const auto& sources =
258
54
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]);
259
54
        const auto& weight =
260
54
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
261
54
        const auto& quantile =
262
54
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]);
263
264
54
        this->data(place).init(quantile.get_element(0));
265
54
        this->data(place).add_with_weight(sources.get_element(row_num),
266
54
                                          weight.get_element(row_num));
267
54
    }
268
269
55
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
270
271
27
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
272
27
        auto& col = assert_cast<ColumnFloat64&>(to);
273
27
        double result = this->data(place).get();
274
275
27
        if (std::isnan(result)) {
276
1
            col.insert_default();
277
26
        } else {
278
26
            col.get_data().push_back(result);
279
26
        }
280
27
    }
281
};
282
283
class AggregateFunctionPercentileApproxWeightedFourParams final
284
        : public AggregateFunctionPercentileApproxBase<
285
                  AggregateFunctionPercentileApproxWeightedFourParams>,
286
          MultiExpression,
287
          NullableAggregateFunction {
288
public:
289
    AggregateFunctionPercentileApproxWeightedFourParams(const DataTypes& argument_types_)
290
22
            : AggregateFunctionPercentileApproxBase<
291
22
                      AggregateFunctionPercentileApproxWeightedFourParams>(argument_types_) {}
292
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
293
80
             Arena&) const override {
294
80
        const auto& sources =
295
80
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[0]);
296
80
        const auto& weight =
297
80
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
298
80
        const auto& quantile =
299
80
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[2]);
300
80
        const auto& compression =
301
80
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[3]);
302
303
80
        this->data(place).init(quantile.get_element(0),
304
80
                               static_cast<float>(compression.get_element(0)));
305
80
        this->data(place).add_with_weight(sources.get_element(row_num),
306
80
                                          weight.get_element(row_num));
307
80
    }
308
309
43
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
310
311
10
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
312
10
        auto& col = assert_cast<ColumnFloat64&>(to);
313
10
        double result = this->data(place).get();
314
315
10
        if (std::isnan(result)) {
316
0
            col.insert_default();
317
10
        } else {
318
10
            col.get_data().push_back(result);
319
10
        }
320
10
    }
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
393
    void write(BufferWritable& buf) const {
330
393
        buf.write_binary(inited_flag);
331
393
        if (!inited_flag) {
332
8
            return;
333
8
        }
334
385
        int size_num = cast_set<int>(vec_quantile.size());
335
385
        buf.write_binary(size_num);
336
689
        for (const auto& quantile : vec_quantile) {
337
689
            buf.write_binary(quantile);
338
689
        }
339
689
        for (auto& counts : vec_counts) {
340
689
            counts.serialize(buf);
341
689
        }
342
385
    }
Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE3EE5writeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE4EE5writeERNS_14BufferWritableE
_ZNK5doris15PercentileStateILNS_13PrimitiveTypeE5EE5writeERNS_14BufferWritableE
Line
Count
Source
329
160
    void write(BufferWritable& buf) const {
330
160
        buf.write_binary(inited_flag);
331
160
        if (!inited_flag) {
332
8
            return;
333
8
        }
334
152
        int size_num = cast_set<int>(vec_quantile.size());
335
152
        buf.write_binary(size_num);
336
456
        for (const auto& quantile : vec_quantile) {
337
456
            buf.write_binary(quantile);
338
456
        }
339
456
        for (auto& counts : vec_counts) {
340
456
            counts.serialize(buf);
341
456
        }
342
152
    }
_ZNK5doris15PercentileStateILNS_13PrimitiveTypeE6EE5writeERNS_14BufferWritableE
Line
Count
Source
329
233
    void write(BufferWritable& buf) const {
330
233
        buf.write_binary(inited_flag);
331
233
        if (!inited_flag) {
332
0
            return;
333
0
        }
334
233
        int size_num = cast_set<int>(vec_quantile.size());
335
233
        buf.write_binary(size_num);
336
233
        for (const auto& quantile : vec_quantile) {
337
233
            buf.write_binary(quantile);
338
233
        }
339
233
        for (auto& counts : vec_counts) {
340
233
            counts.serialize(buf);
341
233
        }
342
233
    }
Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE7EE5writeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE8EE5writeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris15PercentileStateILNS_13PrimitiveTypeE9EE5writeERNS_14BufferWritableE
343
344
354
    void read(BufferReadable& buf) {
345
354
        buf.read_binary(inited_flag);
346
354
        if (!inited_flag) {
347
8
            return;
348
8
        }
349
346
        int size_num = 0;
350
346
        buf.read_binary(size_num);
351
346
        double data = 0.0;
352
346
        vec_quantile.clear();
353
918
        for (int i = 0; i < size_num; ++i) {
354
572
            buf.read_binary(data);
355
572
            vec_quantile.emplace_back(data);
356
572
        }
357
346
        vec_counts.clear();
358
346
        vec_counts.resize(size_num);
359
918
        for (int i = 0; i < size_num; ++i) {
360
572
            vec_counts[i].unserialize(buf);
361
572
        }
362
346
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE4readERNS_14BufferReadableE
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE4readERNS_14BufferReadableE
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE4readERNS_14BufferReadableE
Line
Count
Source
344
121
    void read(BufferReadable& buf) {
345
121
        buf.read_binary(inited_flag);
346
121
        if (!inited_flag) {
347
8
            return;
348
8
        }
349
113
        int size_num = 0;
350
113
        buf.read_binary(size_num);
351
113
        double data = 0.0;
352
113
        vec_quantile.clear();
353
452
        for (int i = 0; i < size_num; ++i) {
354
339
            buf.read_binary(data);
355
339
            vec_quantile.emplace_back(data);
356
339
        }
357
113
        vec_counts.clear();
358
113
        vec_counts.resize(size_num);
359
452
        for (int i = 0; i < size_num; ++i) {
360
339
            vec_counts[i].unserialize(buf);
361
339
        }
362
113
    }
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE4readERNS_14BufferReadableE
Line
Count
Source
344
233
    void read(BufferReadable& buf) {
345
233
        buf.read_binary(inited_flag);
346
233
        if (!inited_flag) {
347
0
            return;
348
0
        }
349
233
        int size_num = 0;
350
233
        buf.read_binary(size_num);
351
233
        double data = 0.0;
352
233
        vec_quantile.clear();
353
466
        for (int i = 0; i < size_num; ++i) {
354
233
            buf.read_binary(data);
355
233
            vec_quantile.emplace_back(data);
356
233
        }
357
233
        vec_counts.clear();
358
233
        vec_counts.resize(size_num);
359
466
        for (int i = 0; i < size_num; ++i) {
360
233
            vec_counts[i].unserialize(buf);
361
233
        }
362
233
    }
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
222
             const PaddedPODArray<Float64>& quantiles, const NullMap& null_maps, int64_t arg_size) {
366
222
        if (!inited_flag) {
367
222
            vec_counts.resize(arg_size);
368
222
            vec_quantile.resize(arg_size, -1);
369
222
            inited_flag = true;
370
644
            for (int i = 0; i < arg_size; ++i) {
371
                // throw Exception func call percentile_array(id, [1,0,null])
372
422
                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
422
                check_quantile(quantiles[i]);
377
422
                vec_quantile[i] = quantiles[i];
378
422
            }
379
222
        }
380
644
        for (int i = 0; i < arg_size; ++i) {
381
422
            vec_counts[i].increment(source);
382
422
        }
383
222
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE3addEaRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE3addEsRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE3addEiRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl
Line
Count
Source
365
100
             const PaddedPODArray<Float64>& quantiles, const NullMap& null_maps, int64_t arg_size) {
366
100
        if (!inited_flag) {
367
100
            vec_counts.resize(arg_size);
368
100
            vec_quantile.resize(arg_size, -1);
369
100
            inited_flag = true;
370
400
            for (int i = 0; i < arg_size; ++i) {
371
                // throw Exception func call percentile_array(id, [1,0,null])
372
300
                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
300
                check_quantile(quantiles[i]);
377
300
                vec_quantile[i] = quantiles[i];
378
300
            }
379
100
        }
380
400
        for (int i = 0; i < arg_size; ++i) {
381
300
            vec_counts[i].increment(source);
382
300
        }
383
100
    }
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE3addElRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEl
Line
Count
Source
365
122
             const PaddedPODArray<Float64>& quantiles, const NullMap& null_maps, int64_t arg_size) {
366
122
        if (!inited_flag) {
367
122
            vec_counts.resize(arg_size);
368
122
            vec_quantile.resize(arg_size, -1);
369
122
            inited_flag = true;
370
244
            for (int i = 0; i < arg_size; ++i) {
371
                // throw Exception func call percentile_array(id, [1,0,null])
372
122
                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
122
                check_quantile(quantiles[i]);
377
122
                vec_quantile[i] = quantiles[i];
378
122
            }
379
122
        }
380
244
        for (int i = 0; i < arg_size; ++i) {
381
122
            vec_counts[i].increment(source);
382
122
        }
383
122
    }
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
354
    void merge(const PercentileState& rhs) {
398
354
        if (!rhs.inited_flag) {
399
8
            return;
400
8
        }
401
346
        int size_num = cast_set<int>(rhs.vec_quantile.size());
402
346
        if (!inited_flag) {
403
187
            vec_counts.resize(size_num);
404
187
            vec_quantile.resize(size_num, -1);
405
187
            inited_flag = true;
406
187
        }
407
408
918
        for (int i = 0; i < size_num; ++i) {
409
572
            if (vec_quantile[i] == -1.0) {
410
291
                vec_quantile[i] = rhs.vec_quantile[i];
411
291
            }
412
572
            vec_counts[i].merge(&(rhs.vec_counts[i]));
413
572
        }
414
346
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE5mergeERKS2_
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE5mergeERKS2_
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE5mergeERKS2_
Line
Count
Source
397
121
    void merge(const PercentileState& rhs) {
398
121
        if (!rhs.inited_flag) {
399
8
            return;
400
8
        }
401
113
        int size_num = cast_set<int>(rhs.vec_quantile.size());
402
113
        if (!inited_flag) {
403
52
            vec_counts.resize(size_num);
404
52
            vec_quantile.resize(size_num, -1);
405
52
            inited_flag = true;
406
52
        }
407
408
452
        for (int i = 0; i < size_num; ++i) {
409
339
            if (vec_quantile[i] == -1.0) {
410
156
                vec_quantile[i] = rhs.vec_quantile[i];
411
156
            }
412
339
            vec_counts[i].merge(&(rhs.vec_counts[i]));
413
339
        }
414
113
    }
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE5mergeERKS2_
Line
Count
Source
397
233
    void merge(const PercentileState& rhs) {
398
233
        if (!rhs.inited_flag) {
399
0
            return;
400
0
        }
401
233
        int size_num = cast_set<int>(rhs.vec_quantile.size());
402
233
        if (!inited_flag) {
403
135
            vec_counts.resize(size_num);
404
135
            vec_quantile.resize(size_num, -1);
405
135
            inited_flag = true;
406
135
        }
407
408
466
        for (int i = 0; i < size_num; ++i) {
409
233
            if (vec_quantile[i] == -1.0) {
410
135
                vec_quantile[i] = rhs.vec_quantile[i];
411
135
            }
412
233
            vec_counts[i].merge(&(rhs.vec_counts[i]));
413
233
        }
414
233
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE5mergeERKS2_
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE5mergeERKS2_
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE5mergeERKS2_
415
416
111
    void reset() {
417
111
        vec_counts.clear();
418
111
        vec_quantile.clear();
419
111
        inited_flag = false;
420
111
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE3EE5resetEv
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE4EE5resetEv
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE5EE5resetEv
Line
Count
Source
416
26
    void reset() {
417
26
        vec_counts.clear();
418
26
        vec_quantile.clear();
419
26
        inited_flag = false;
420
26
    }
_ZN5doris15PercentileStateILNS_13PrimitiveTypeE6EE5resetEv
Line
Count
Source
416
85
    void reset() {
417
85
        vec_counts.clear();
418
85
        vec_quantile.clear();
419
85
        inited_flag = false;
420
85
    }
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE7EE5resetEv
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE8EE5resetEv
Unexecuted instantiation: _ZN5doris15PercentileStateILNS_13PrimitiveTypeE9EE5resetEv
421
422
24
    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
_ZNK5doris15PercentileStateILNS_13PrimitiveTypeE6EE3getEv
Line
Count
Source
422
24
    double get() const { return vec_counts.empty() ? 0 : vec_counts[0].terminate(vec_quantile[0]); }
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
818
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
818
        if (!inited_flag) {
440
321
            _set_single_level(quantile);
441
321
            inited_flag = true;
442
321
        }
443
818
        _append(data, count);
444
818
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE16add_single_rangeEPKamd
Line
Count
Source
438
31
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
31
        if (!inited_flag) {
440
6
            _set_single_level(quantile);
441
6
            inited_flag = true;
442
6
        }
443
31
        _append(data, count);
444
31
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE16add_single_rangeEPKsmd
Line
Count
Source
438
311
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
311
        if (!inited_flag) {
440
100
            _set_single_level(quantile);
441
100
            inited_flag = true;
442
100
        }
443
311
        _append(data, count);
444
311
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE16add_single_rangeEPKimd
Line
Count
Source
438
231
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
231
        if (!inited_flag) {
440
76
            _set_single_level(quantile);
441
76
            inited_flag = true;
442
76
        }
443
231
        _append(data, count);
444
231
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE16add_single_rangeEPKlmd
Line
Count
Source
438
197
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
197
        if (!inited_flag) {
440
111
            _set_single_level(quantile);
441
111
            inited_flag = true;
442
111
        }
443
197
        _append(data, count);
444
197
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE16add_single_rangeEPKnmd
Line
Count
Source
438
3
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
3
        if (!inited_flag) {
440
2
            _set_single_level(quantile);
441
2
            inited_flag = true;
442
2
        }
443
3
        _append(data, count);
444
3
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE16add_single_rangeEPKfmd
Line
Count
Source
438
3
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
3
        if (!inited_flag) {
440
2
            _set_single_level(quantile);
441
2
            inited_flag = true;
442
2
        }
443
3
        _append(data, count);
444
3
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE16add_single_rangeEPKdmd
Line
Count
Source
438
42
    void add_single_range(const ValueType* data, size_t count, double quantile) {
439
42
        if (!inited_flag) {
440
24
            _set_single_level(quantile);
441
24
            inited_flag = true;
442
24
        }
443
42
        _append(data, count);
444
42
    }
445
446
    void add_many_range(const ValueType* data, size_t count,
447
                        const PaddedPODArray<Float64>& quantiles_data, const NullMap& null_maps,
448
665
                        size_t start, int64_t arg_size) {
449
665
        if (!inited_flag) {
450
343
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
343
            inited_flag = true;
452
343
        }
453
665
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
665
        _append(data, count);
457
665
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE14add_many_rangeEPKamRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
15
                        size_t start, int64_t arg_size) {
449
15
        if (!inited_flag) {
450
12
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
12
            inited_flag = true;
452
12
        }
453
15
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
15
        _append(data, count);
457
15
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE14add_many_rangeEPKsmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
30
                        size_t start, int64_t arg_size) {
449
30
        if (!inited_flag) {
450
14
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
14
            inited_flag = true;
452
14
        }
453
30
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
30
        _append(data, count);
457
30
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE14add_many_rangeEPKimRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
485
                        size_t start, int64_t arg_size) {
449
485
        if (!inited_flag) {
450
241
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
241
            inited_flag = true;
452
241
        }
453
485
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
485
        _append(data, count);
457
485
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE14add_many_rangeEPKlmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
33
                        size_t start, int64_t arg_size) {
449
33
        if (!inited_flag) {
450
16
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
16
            inited_flag = true;
452
16
        }
453
33
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
33
        _append(data, count);
457
33
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE14add_many_rangeEPKnmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
15
                        size_t start, int64_t arg_size) {
449
15
        if (!inited_flag) {
450
12
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
12
            inited_flag = true;
452
12
        }
453
15
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
15
        _append(data, count);
457
15
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE14add_many_rangeEPKfmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
3
                        size_t start, int64_t arg_size) {
449
3
        if (!inited_flag) {
450
2
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
2
            inited_flag = true;
452
2
        }
453
3
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
3
        _append(data, count);
457
3
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE14add_many_rangeEPKdmRKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS5_IhLm4096ES8_Lm16ELm15EEEml
Line
Count
Source
448
84
                        size_t start, int64_t arg_size) {
449
84
        if (!inited_flag) {
450
46
            _set_many_levels(quantiles_data, null_maps, start, arg_size);
451
46
            inited_flag = true;
452
46
        }
453
84
        if (levels.empty()) {
454
0
            return;
455
0
        }
456
84
        _append(data, count);
457
84
    }
458
459
416
    void write(BufferWritable& buf) const {
460
416
        buf.write_binary(inited_flag);
461
416
        if (!inited_flag) {
462
1
            return;
463
1
        }
464
465
415
        levels.write(buf);
466
415
        size_t size = values.size();
467
415
        buf.write_binary(size);
468
415
        if (size > 0) {
469
415
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
415
        }
471
415
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5writeERNS_14BufferWritableE
Line
Count
Source
459
4
    void write(BufferWritable& buf) const {
460
4
        buf.write_binary(inited_flag);
461
4
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
4
        levels.write(buf);
466
4
        size_t size = values.size();
467
4
        buf.write_binary(size);
468
4
        if (size > 0) {
469
4
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
4
        }
471
4
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5writeERNS_14BufferWritableE
Line
Count
Source
459
6
    void write(BufferWritable& buf) const {
460
6
        buf.write_binary(inited_flag);
461
6
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
6
        levels.write(buf);
466
6
        size_t size = values.size();
467
6
        buf.write_binary(size);
468
6
        if (size > 0) {
469
6
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
6
        }
471
6
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5writeERNS_14BufferWritableE
Line
Count
Source
459
261
    void write(BufferWritable& buf) const {
460
261
        buf.write_binary(inited_flag);
461
261
        if (!inited_flag) {
462
1
            return;
463
1
        }
464
465
260
        levels.write(buf);
466
260
        size_t size = values.size();
467
260
        buf.write_binary(size);
468
260
        if (size > 0) {
469
260
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
260
        }
471
260
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5writeERNS_14BufferWritableE
Line
Count
Source
459
92
    void write(BufferWritable& buf) const {
460
92
        buf.write_binary(inited_flag);
461
92
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
92
        levels.write(buf);
466
92
        size_t size = values.size();
467
92
        buf.write_binary(size);
468
92
        if (size > 0) {
469
92
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
92
        }
471
92
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5writeERNS_14BufferWritableE
Line
Count
Source
459
4
    void write(BufferWritable& buf) const {
460
4
        buf.write_binary(inited_flag);
461
4
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
4
        levels.write(buf);
466
4
        size_t size = values.size();
467
4
        buf.write_binary(size);
468
4
        if (size > 0) {
469
4
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
4
        }
471
4
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5writeERNS_14BufferWritableE
Line
Count
Source
459
4
    void write(BufferWritable& buf) const {
460
4
        buf.write_binary(inited_flag);
461
4
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
4
        levels.write(buf);
466
4
        size_t size = values.size();
467
4
        buf.write_binary(size);
468
4
        if (size > 0) {
469
4
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
4
        }
471
4
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5writeERNS_14BufferWritableE
Line
Count
Source
459
45
    void write(BufferWritable& buf) const {
460
45
        buf.write_binary(inited_flag);
461
45
        if (!inited_flag) {
462
0
            return;
463
0
        }
464
465
45
        levels.write(buf);
466
45
        size_t size = values.size();
467
45
        buf.write_binary(size);
468
45
        if (size > 0) {
469
45
            buf.write(reinterpret_cast<const char*>(values.data()), sizeof(ValueType) * size);
470
45
        }
471
45
    }
472
473
416
    void read(BufferReadable& buf) {
474
416
        reset();
475
416
        buf.read_binary(inited_flag);
476
416
        if (!inited_flag) {
477
1
            return;
478
1
        }
479
480
415
        levels.read(buf);
481
415
        size_t size = 0;
482
415
        buf.read_binary(size);
483
415
        values.resize(size);
484
415
        if (size > 0) {
485
415
            auto raw = buf.read(sizeof(ValueType) * size);
486
415
            memcpy(values.data(), raw.data, raw.size);
487
415
        }
488
415
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE4readERNS_14BufferReadableE
Line
Count
Source
473
4
    void read(BufferReadable& buf) {
474
4
        reset();
475
4
        buf.read_binary(inited_flag);
476
4
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
4
        levels.read(buf);
481
4
        size_t size = 0;
482
4
        buf.read_binary(size);
483
4
        values.resize(size);
484
4
        if (size > 0) {
485
4
            auto raw = buf.read(sizeof(ValueType) * size);
486
4
            memcpy(values.data(), raw.data, raw.size);
487
4
        }
488
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE4readERNS_14BufferReadableE
Line
Count
Source
473
6
    void read(BufferReadable& buf) {
474
6
        reset();
475
6
        buf.read_binary(inited_flag);
476
6
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
6
        levels.read(buf);
481
6
        size_t size = 0;
482
6
        buf.read_binary(size);
483
6
        values.resize(size);
484
6
        if (size > 0) {
485
6
            auto raw = buf.read(sizeof(ValueType) * size);
486
6
            memcpy(values.data(), raw.data, raw.size);
487
6
        }
488
6
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE4readERNS_14BufferReadableE
Line
Count
Source
473
261
    void read(BufferReadable& buf) {
474
261
        reset();
475
261
        buf.read_binary(inited_flag);
476
261
        if (!inited_flag) {
477
1
            return;
478
1
        }
479
480
260
        levels.read(buf);
481
260
        size_t size = 0;
482
260
        buf.read_binary(size);
483
260
        values.resize(size);
484
260
        if (size > 0) {
485
260
            auto raw = buf.read(sizeof(ValueType) * size);
486
260
            memcpy(values.data(), raw.data, raw.size);
487
260
        }
488
260
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE4readERNS_14BufferReadableE
Line
Count
Source
473
92
    void read(BufferReadable& buf) {
474
92
        reset();
475
92
        buf.read_binary(inited_flag);
476
92
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
92
        levels.read(buf);
481
92
        size_t size = 0;
482
92
        buf.read_binary(size);
483
92
        values.resize(size);
484
92
        if (size > 0) {
485
92
            auto raw = buf.read(sizeof(ValueType) * size);
486
92
            memcpy(values.data(), raw.data, raw.size);
487
92
        }
488
92
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE4readERNS_14BufferReadableE
Line
Count
Source
473
4
    void read(BufferReadable& buf) {
474
4
        reset();
475
4
        buf.read_binary(inited_flag);
476
4
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
4
        levels.read(buf);
481
4
        size_t size = 0;
482
4
        buf.read_binary(size);
483
4
        values.resize(size);
484
4
        if (size > 0) {
485
4
            auto raw = buf.read(sizeof(ValueType) * size);
486
4
            memcpy(values.data(), raw.data, raw.size);
487
4
        }
488
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE4readERNS_14BufferReadableE
Line
Count
Source
473
4
    void read(BufferReadable& buf) {
474
4
        reset();
475
4
        buf.read_binary(inited_flag);
476
4
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
4
        levels.read(buf);
481
4
        size_t size = 0;
482
4
        buf.read_binary(size);
483
4
        values.resize(size);
484
4
        if (size > 0) {
485
4
            auto raw = buf.read(sizeof(ValueType) * size);
486
4
            memcpy(values.data(), raw.data, raw.size);
487
4
        }
488
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE4readERNS_14BufferReadableE
Line
Count
Source
473
45
    void read(BufferReadable& buf) {
474
45
        reset();
475
45
        buf.read_binary(inited_flag);
476
45
        if (!inited_flag) {
477
0
            return;
478
0
        }
479
480
45
        levels.read(buf);
481
45
        size_t size = 0;
482
45
        buf.read_binary(size);
483
45
        values.resize(size);
484
45
        if (size > 0) {
485
45
            auto raw = buf.read(sizeof(ValueType) * size);
486
45
            memcpy(values.data(), raw.data, raw.size);
487
45
        }
488
45
    }
489
490
416
    void merge(const PercentileExactState& rhs) {
491
416
        if (!rhs.inited_flag) {
492
1
            return;
493
1
        }
494
495
415
        if (!inited_flag) {
496
246
            levels = rhs.levels;
497
246
            inited_flag = true;
498
246
        } else {
499
169
            levels.merge(rhs.levels);
500
169
        }
501
415
        _append(rhs.values.data(), rhs.values.size());
502
415
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5mergeERKS2_
Line
Count
Source
490
4
    void merge(const PercentileExactState& rhs) {
491
4
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
4
        if (!inited_flag) {
496
2
            levels = rhs.levels;
497
2
            inited_flag = true;
498
2
        } else {
499
2
            levels.merge(rhs.levels);
500
2
        }
501
4
        _append(rhs.values.data(), rhs.values.size());
502
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5mergeERKS2_
Line
Count
Source
490
6
    void merge(const PercentileExactState& rhs) {
491
6
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
6
        if (!inited_flag) {
496
3
            levels = rhs.levels;
497
3
            inited_flag = true;
498
3
        } else {
499
3
            levels.merge(rhs.levels);
500
3
        }
501
6
        _append(rhs.values.data(), rhs.values.size());
502
6
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5mergeERKS2_
Line
Count
Source
490
261
    void merge(const PercentileExactState& rhs) {
491
261
        if (!rhs.inited_flag) {
492
1
            return;
493
1
        }
494
495
260
        if (!inited_flag) {
496
166
            levels = rhs.levels;
497
166
            inited_flag = true;
498
166
        } else {
499
94
            levels.merge(rhs.levels);
500
94
        }
501
260
        _append(rhs.values.data(), rhs.values.size());
502
260
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5mergeERKS2_
Line
Count
Source
490
92
    void merge(const PercentileExactState& rhs) {
491
92
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
92
        if (!inited_flag) {
496
46
            levels = rhs.levels;
497
46
            inited_flag = true;
498
46
        } else {
499
46
            levels.merge(rhs.levels);
500
46
        }
501
92
        _append(rhs.values.data(), rhs.values.size());
502
92
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5mergeERKS2_
Line
Count
Source
490
4
    void merge(const PercentileExactState& rhs) {
491
4
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
4
        if (!inited_flag) {
496
2
            levels = rhs.levels;
497
2
            inited_flag = true;
498
2
        } else {
499
2
            levels.merge(rhs.levels);
500
2
        }
501
4
        _append(rhs.values.data(), rhs.values.size());
502
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5mergeERKS2_
Line
Count
Source
490
4
    void merge(const PercentileExactState& rhs) {
491
4
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
4
        if (!inited_flag) {
496
2
            levels = rhs.levels;
497
2
            inited_flag = true;
498
2
        } else {
499
2
            levels.merge(rhs.levels);
500
2
        }
501
4
        _append(rhs.values.data(), rhs.values.size());
502
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5mergeERKS2_
Line
Count
Source
490
45
    void merge(const PercentileExactState& rhs) {
491
45
        if (!rhs.inited_flag) {
492
0
            return;
493
0
        }
494
495
45
        if (!inited_flag) {
496
25
            levels = rhs.levels;
497
25
            inited_flag = true;
498
25
        } else {
499
20
            levels.merge(rhs.levels);
500
20
        }
501
45
        _append(rhs.values.data(), rhs.values.size());
502
45
    }
503
504
536
    void reset() {
505
536
        values.clear();
506
536
        levels.clear();
507
536
        inited_flag = false;
508
536
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE5resetEv
Line
Count
Source
504
4
    void reset() {
505
4
        values.clear();
506
4
        levels.clear();
507
4
        inited_flag = false;
508
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE5resetEv
Line
Count
Source
504
111
    void reset() {
505
111
        values.clear();
506
111
        levels.clear();
507
111
        inited_flag = false;
508
111
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE5resetEv
Line
Count
Source
504
270
    void reset() {
505
270
        values.clear();
506
270
        levels.clear();
507
270
        inited_flag = false;
508
270
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE5resetEv
Line
Count
Source
504
92
    void reset() {
505
92
        values.clear();
506
92
        levels.clear();
507
92
        inited_flag = false;
508
92
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE5resetEv
Line
Count
Source
504
4
    void reset() {
505
4
        values.clear();
506
4
        levels.clear();
507
4
        inited_flag = false;
508
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE5resetEv
Line
Count
Source
504
4
    void reset() {
505
4
        values.clear();
506
4
        levels.clear();
507
4
        inited_flag = false;
508
4
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE5resetEv
Line
Count
Source
504
51
    void reset() {
505
51
        values.clear();
506
51
        levels.clear();
507
51
        inited_flag = false;
508
51
    }
509
510
363
    double get() const {
511
363
        if (!inited_flag || levels.empty() || values.empty()) {
512
2
            return 0.0;
513
2
        }
514
515
363
        DCHECK_EQ(levels.quantiles.size(), 1);
516
361
        return _get_result(levels.quantiles[0]);
517
363
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE3getEv
Line
Count
Source
510
30
    double get() const {
511
30
        if (!inited_flag || levels.empty() || values.empty()) {
512
1
            return 0.0;
513
1
        }
514
515
30
        DCHECK_EQ(levels.quantiles.size(), 1);
516
29
        return _get_result(levels.quantiles[0]);
517
30
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE3getEv
Line
Count
Source
510
177
    double get() const {
511
177
        if (!inited_flag || levels.empty() || values.empty()) {
512
0
            return 0.0;
513
0
        }
514
515
177
        DCHECK_EQ(levels.quantiles.size(), 1);
516
177
        return _get_result(levels.quantiles[0]);
517
177
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE3getEv
Line
Count
Source
510
54
    double get() const {
511
54
        if (!inited_flag || levels.empty() || values.empty()) {
512
0
            return 0.0;
513
0
        }
514
515
54
        DCHECK_EQ(levels.quantiles.size(), 1);
516
54
        return _get_result(levels.quantiles[0]);
517
54
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE3getEv
Line
Count
Source
510
67
    double get() const {
511
67
        if (!inited_flag || levels.empty() || values.empty()) {
512
1
            return 0.0;
513
1
        }
514
515
67
        DCHECK_EQ(levels.quantiles.size(), 1);
516
66
        return _get_result(levels.quantiles[0]);
517
67
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE3getEv
Line
Count
Source
510
1
    double get() const {
511
1
        if (!inited_flag || levels.empty() || values.empty()) {
512
0
            return 0.0;
513
0
        }
514
515
1
        DCHECK_EQ(levels.quantiles.size(), 1);
516
1
        return _get_result(levels.quantiles[0]);
517
1
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE3getEv
Line
Count
Source
510
1
    double get() const {
511
1
        if (!inited_flag || levels.empty() || values.empty()) {
512
0
            return 0.0;
513
0
        }
514
515
1
        DCHECK_EQ(levels.quantiles.size(), 1);
516
1
        return _get_result(levels.quantiles[0]);
517
1
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE3getEv
Line
Count
Source
510
33
    double get() const {
511
33
        if (!inited_flag || levels.empty() || values.empty()) {
512
0
            return 0.0;
513
0
        }
514
515
33
        DCHECK_EQ(levels.quantiles.size(), 1);
516
33
        return _get_result(levels.quantiles[0]);
517
33
    }
518
519
258
    void insert_result_into(IColumn& to) const {
520
258
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
258
        if (!inited_flag || levels.empty() || values.empty()) {
522
3
            return;
523
3
        }
524
525
255
        size_t old_size = column_data.size();
526
255
        size_t size = levels.quantiles.size();
527
255
        column_data.resize(old_size + size);
528
255
        auto* result = column_data.data() + old_size;
529
530
255
        if (values.size() == 1) {
531
452
            for (size_t i = 0; i < size; ++i) {
532
320
                result[i] = static_cast<double>(values.front());
533
320
            }
534
132
            return;
535
132
        }
536
537
123
        size_t prev_index = 0;
538
123
        const auto& quantiles = levels.quantiles;
539
123
        const auto& permutation = levels.get_permutation();
540
417
        for (size_t i = 0; i < size; ++i) {
541
294
            auto level_index = permutation[i];
542
294
            auto level = quantiles[level_index];
543
294
            double u = static_cast<double>(values.size() - 1) * level;
544
294
            auto index = static_cast<size_t>(u);
545
546
294
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
294
            } else {
550
294
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
294
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
294
                result[level_index] =
553
294
                        static_cast<double>(values[index]) +
554
294
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
294
                                                            static_cast<double>(values[index]));
556
294
                prev_index = index;
557
294
            }
558
294
        }
559
123
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
11
    void insert_result_into(IColumn& to) const {
520
11
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
11
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
11
        size_t old_size = column_data.size();
526
11
        size_t size = levels.quantiles.size();
527
11
        column_data.resize(old_size + size);
528
11
        auto* result = column_data.data() + old_size;
529
530
11
        if (values.size() == 1) {
531
32
            for (size_t i = 0; i < size; ++i) {
532
24
                result[i] = static_cast<double>(values.front());
533
24
            }
534
8
            return;
535
8
        }
536
537
3
        size_t prev_index = 0;
538
3
        const auto& quantiles = levels.quantiles;
539
3
        const auto& permutation = levels.get_permutation();
540
11
        for (size_t i = 0; i < size; ++i) {
541
8
            auto level_index = permutation[i];
542
8
            auto level = quantiles[level_index];
543
8
            double u = static_cast<double>(values.size() - 1) * level;
544
8
            auto index = static_cast<size_t>(u);
545
546
8
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
8
            } else {
550
8
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
8
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
8
                result[level_index] =
553
8
                        static_cast<double>(values[index]) +
554
8
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
8
                                                            static_cast<double>(values[index]));
556
8
                prev_index = index;
557
8
            }
558
8
        }
559
3
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
12
    void insert_result_into(IColumn& to) const {
520
12
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
12
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
12
        size_t old_size = column_data.size();
526
12
        size_t size = levels.quantiles.size();
527
12
        column_data.resize(old_size + size);
528
12
        auto* result = column_data.data() + old_size;
529
530
12
        if (values.size() == 1) {
531
32
            for (size_t i = 0; i < size; ++i) {
532
24
                result[i] = static_cast<double>(values.front());
533
24
            }
534
8
            return;
535
8
        }
536
537
4
        size_t prev_index = 0;
538
4
        const auto& quantiles = levels.quantiles;
539
4
        const auto& permutation = levels.get_permutation();
540
15
        for (size_t i = 0; i < size; ++i) {
541
11
            auto level_index = permutation[i];
542
11
            auto level = quantiles[level_index];
543
11
            double u = static_cast<double>(values.size() - 1) * level;
544
11
            auto index = static_cast<size_t>(u);
545
546
11
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
11
            } else {
550
11
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
11
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
11
                result[level_index] =
553
11
                        static_cast<double>(values[index]) +
554
11
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
11
                                                            static_cast<double>(values[index]));
556
11
                prev_index = index;
557
11
            }
558
11
        }
559
4
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
170
    void insert_result_into(IColumn& to) const {
520
170
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
170
        if (!inited_flag || levels.empty() || values.empty()) {
522
3
            return;
523
3
        }
524
525
167
        size_t old_size = column_data.size();
526
167
        size_t size = levels.quantiles.size();
527
167
        column_data.resize(old_size + size);
528
167
        auto* result = column_data.data() + old_size;
529
530
167
        if (values.size() == 1) {
531
297
            for (size_t i = 0; i < size; ++i) {
532
206
                result[i] = static_cast<double>(values.front());
533
206
            }
534
91
            return;
535
91
        }
536
537
76
        size_t prev_index = 0;
538
76
        const auto& quantiles = levels.quantiles;
539
76
        const auto& permutation = levels.get_permutation();
540
245
        for (size_t i = 0; i < size; ++i) {
541
169
            auto level_index = permutation[i];
542
169
            auto level = quantiles[level_index];
543
169
            double u = static_cast<double>(values.size() - 1) * level;
544
169
            auto index = static_cast<size_t>(u);
545
546
169
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
169
            } else {
550
169
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
169
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
169
                result[level_index] =
553
169
                        static_cast<double>(values[index]) +
554
169
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
169
                                                            static_cast<double>(values[index]));
556
169
                prev_index = index;
557
169
            }
558
169
        }
559
76
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
12
    void insert_result_into(IColumn& to) const {
520
12
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
12
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
12
        size_t old_size = column_data.size();
526
12
        size_t size = levels.quantiles.size();
527
12
        column_data.resize(old_size + size);
528
12
        auto* result = column_data.data() + old_size;
529
530
12
        if (values.size() == 1) {
531
32
            for (size_t i = 0; i < size; ++i) {
532
24
                result[i] = static_cast<double>(values.front());
533
24
            }
534
8
            return;
535
8
        }
536
537
4
        size_t prev_index = 0;
538
4
        const auto& quantiles = levels.quantiles;
539
4
        const auto& permutation = levels.get_permutation();
540
15
        for (size_t i = 0; i < size; ++i) {
541
11
            auto level_index = permutation[i];
542
11
            auto level = quantiles[level_index];
543
11
            double u = static_cast<double>(values.size() - 1) * level;
544
11
            auto index = static_cast<size_t>(u);
545
546
11
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
11
            } else {
550
11
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
11
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
11
                result[level_index] =
553
11
                        static_cast<double>(values[index]) +
554
11
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
11
                                                            static_cast<double>(values[index]));
556
11
                prev_index = index;
557
11
            }
558
11
        }
559
4
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
11
    void insert_result_into(IColumn& to) const {
520
11
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
11
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
11
        size_t old_size = column_data.size();
526
11
        size_t size = levels.quantiles.size();
527
11
        column_data.resize(old_size + size);
528
11
        auto* result = column_data.data() + old_size;
529
530
11
        if (values.size() == 1) {
531
32
            for (size_t i = 0; i < size; ++i) {
532
24
                result[i] = static_cast<double>(values.front());
533
24
            }
534
8
            return;
535
8
        }
536
537
3
        size_t prev_index = 0;
538
3
        const auto& quantiles = levels.quantiles;
539
3
        const auto& permutation = levels.get_permutation();
540
11
        for (size_t i = 0; i < size; ++i) {
541
8
            auto level_index = permutation[i];
542
8
            auto level = quantiles[level_index];
543
8
            double u = static_cast<double>(values.size() - 1) * level;
544
8
            auto index = static_cast<size_t>(u);
545
546
8
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
8
            } else {
550
8
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
8
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
8
                result[level_index] =
553
8
                        static_cast<double>(values[index]) +
554
8
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
8
                                                            static_cast<double>(values[index]));
556
8
                prev_index = index;
557
8
            }
558
8
        }
559
3
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
1
    void insert_result_into(IColumn& to) const {
520
1
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
1
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
1
        size_t old_size = column_data.size();
526
1
        size_t size = levels.quantiles.size();
527
1
        column_data.resize(old_size + size);
528
1
        auto* result = column_data.data() + old_size;
529
530
1
        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
1
        size_t prev_index = 0;
538
1
        const auto& quantiles = levels.quantiles;
539
1
        const auto& permutation = levels.get_permutation();
540
3
        for (size_t i = 0; i < size; ++i) {
541
2
            auto level_index = permutation[i];
542
2
            auto level = quantiles[level_index];
543
2
            double u = static_cast<double>(values.size() - 1) * level;
544
2
            auto index = static_cast<size_t>(u);
545
546
2
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
2
            } else {
550
2
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
2
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
2
                result[level_index] =
553
2
                        static_cast<double>(values[index]) +
554
2
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
2
                                                            static_cast<double>(values[index]));
556
2
                prev_index = index;
557
2
            }
558
2
        }
559
1
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
519
41
    void insert_result_into(IColumn& to) const {
520
41
        auto& column_data = assert_cast<ColumnFloat64&>(to).get_data();
521
41
        if (!inited_flag || levels.empty() || values.empty()) {
522
0
            return;
523
0
        }
524
525
41
        size_t old_size = column_data.size();
526
41
        size_t size = levels.quantiles.size();
527
41
        column_data.resize(old_size + size);
528
41
        auto* result = column_data.data() + old_size;
529
530
41
        if (values.size() == 1) {
531
27
            for (size_t i = 0; i < size; ++i) {
532
18
                result[i] = static_cast<double>(values.front());
533
18
            }
534
9
            return;
535
9
        }
536
537
32
        size_t prev_index = 0;
538
32
        const auto& quantiles = levels.quantiles;
539
32
        const auto& permutation = levels.get_permutation();
540
117
        for (size_t i = 0; i < size; ++i) {
541
85
            auto level_index = permutation[i];
542
85
            auto level = quantiles[level_index];
543
85
            double u = static_cast<double>(values.size() - 1) * level;
544
85
            auto index = static_cast<size_t>(u);
545
546
85
            if (index + 1 >= values.size()) {
547
0
                result[level_index] =
548
0
                        static_cast<double>(*std::max_element(values.begin(), values.end()));
549
85
            } else {
550
85
                std::nth_element(values.begin() + prev_index, values.begin() + index, values.end());
551
85
                auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
552
85
                result[level_index] =
553
85
                        static_cast<double>(values[index]) +
554
85
                        (u - static_cast<double>(index)) * (static_cast<double>(*nth_elem) -
555
85
                                                            static_cast<double>(values[index]));
556
85
                prev_index = index;
557
85
            }
558
85
        }
559
32
    }
560
561
private:
562
321
    void _set_single_level(double quantile) {
563
321
        DCHECK(levels.empty());
564
321
        check_quantile(quantile);
565
321
        levels.quantiles.push_back(quantile);
566
321
        levels.permutation.push_back(0);
567
321
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE17_set_single_levelEd
Line
Count
Source
562
6
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
6
        check_quantile(quantile);
565
6
        levels.quantiles.push_back(quantile);
566
6
        levels.permutation.push_back(0);
567
6
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE17_set_single_levelEd
Line
Count
Source
562
100
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
100
        check_quantile(quantile);
565
100
        levels.quantiles.push_back(quantile);
566
100
        levels.permutation.push_back(0);
567
100
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE17_set_single_levelEd
Line
Count
Source
562
76
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
76
        check_quantile(quantile);
565
76
        levels.quantiles.push_back(quantile);
566
76
        levels.permutation.push_back(0);
567
76
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE17_set_single_levelEd
Line
Count
Source
562
111
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
111
        check_quantile(quantile);
565
111
        levels.quantiles.push_back(quantile);
566
111
        levels.permutation.push_back(0);
567
111
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE17_set_single_levelEd
Line
Count
Source
562
2
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
2
        check_quantile(quantile);
565
2
        levels.quantiles.push_back(quantile);
566
2
        levels.permutation.push_back(0);
567
2
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE17_set_single_levelEd
Line
Count
Source
562
2
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
2
        check_quantile(quantile);
565
2
        levels.quantiles.push_back(quantile);
566
2
        levels.permutation.push_back(0);
567
2
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE17_set_single_levelEd
Line
Count
Source
562
24
    void _set_single_level(double quantile) {
563
        DCHECK(levels.empty());
564
24
        check_quantile(quantile);
565
24
        levels.quantiles.push_back(quantile);
566
24
        levels.permutation.push_back(0);
567
24
    }
568
569
    void _set_many_levels(const PaddedPODArray<Float64>& quantiles_data, const NullMap& null_maps,
570
343
                          size_t start, int64_t arg_size) {
571
343
        DCHECK(levels.empty());
572
343
        size_t size = cast_set<size_t>(arg_size);
573
343
        levels.quantiles.resize(size);
574
343
        levels.permutation.resize(size);
575
1.12k
        for (size_t i = 0; i < size; ++i) {
576
783
            if (null_maps[start + i]) {
577
1
                throw Exception(ErrorCode::INVALID_ARGUMENT,
578
1
                                "quantiles in func percentile_array should not have null");
579
1
            }
580
782
            check_quantile(quantiles_data[start + i]);
581
782
            levels.quantiles[i] = quantiles_data[start + i];
582
782
            levels.permutation[i] = i;
583
782
        }
584
343
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
12
                          size_t start, int64_t arg_size) {
571
12
        DCHECK(levels.empty());
572
12
        size_t size = cast_set<size_t>(arg_size);
573
12
        levels.quantiles.resize(size);
574
12
        levels.permutation.resize(size);
575
46
        for (size_t i = 0; i < size; ++i) {
576
34
            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
34
            check_quantile(quantiles_data[start + i]);
581
34
            levels.quantiles[i] = quantiles_data[start + i];
582
34
            levels.permutation[i] = i;
583
34
        }
584
12
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
14
                          size_t start, int64_t arg_size) {
571
14
        DCHECK(levels.empty());
572
14
        size_t size = cast_set<size_t>(arg_size);
573
14
        levels.quantiles.resize(size);
574
14
        levels.permutation.resize(size);
575
54
        for (size_t i = 0; i < size; ++i) {
576
40
            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
40
            check_quantile(quantiles_data[start + i]);
581
40
            levels.quantiles[i] = quantiles_data[start + i];
582
40
            levels.permutation[i] = i;
583
40
        }
584
14
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
241
                          size_t start, int64_t arg_size) {
571
241
        DCHECK(levels.empty());
572
241
        size_t size = cast_set<size_t>(arg_size);
573
241
        levels.quantiles.resize(size);
574
241
        levels.permutation.resize(size);
575
769
        for (size_t i = 0; i < size; ++i) {
576
528
            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
528
            check_quantile(quantiles_data[start + i]);
581
528
            levels.quantiles[i] = quantiles_data[start + i];
582
528
            levels.permutation[i] = i;
583
528
        }
584
241
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
16
                          size_t start, int64_t arg_size) {
571
16
        DCHECK(levels.empty());
572
16
        size_t size = cast_set<size_t>(arg_size);
573
16
        levels.quantiles.resize(size);
574
16
        levels.permutation.resize(size);
575
59
        for (size_t i = 0; i < size; ++i) {
576
44
            if (null_maps[start + i]) {
577
1
                throw Exception(ErrorCode::INVALID_ARGUMENT,
578
1
                                "quantiles in func percentile_array should not have null");
579
1
            }
580
43
            check_quantile(quantiles_data[start + i]);
581
43
            levels.quantiles[i] = quantiles_data[start + i];
582
43
            levels.permutation[i] = i;
583
43
        }
584
16
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
12
                          size_t start, int64_t arg_size) {
571
12
        DCHECK(levels.empty());
572
12
        size_t size = cast_set<size_t>(arg_size);
573
12
        levels.quantiles.resize(size);
574
12
        levels.permutation.resize(size);
575
46
        for (size_t i = 0; i < size; ++i) {
576
34
            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
34
            check_quantile(quantiles_data[start + i]);
581
34
            levels.quantiles[i] = quantiles_data[start + i];
582
34
            levels.permutation[i] = i;
583
34
        }
584
12
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
2
                          size_t start, int64_t arg_size) {
571
2
        DCHECK(levels.empty());
572
2
        size_t size = cast_set<size_t>(arg_size);
573
2
        levels.quantiles.resize(size);
574
2
        levels.permutation.resize(size);
575
6
        for (size_t i = 0; i < size; ++i) {
576
4
            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
4
            check_quantile(quantiles_data[start + i]);
581
4
            levels.quantiles[i] = quantiles_data[start + i];
582
4
            levels.permutation[i] = i;
583
4
        }
584
2
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE16_set_many_levelsERKNS_8PODArrayIdLm4096ENS_9AllocatorILb0ELb0ELb0ENS_22DefaultMemoryAllocatorELb1EEELm16ELm15EEERKNS3_IhLm4096ES6_Lm16ELm15EEEml
Line
Count
Source
570
46
                          size_t start, int64_t arg_size) {
571
46
        DCHECK(levels.empty());
572
46
        size_t size = cast_set<size_t>(arg_size);
573
46
        levels.quantiles.resize(size);
574
46
        levels.permutation.resize(size);
575
145
        for (size_t i = 0; i < size; ++i) {
576
99
            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
99
            check_quantile(quantiles_data[start + i]);
581
99
            levels.quantiles[i] = quantiles_data[start + i];
582
99
            levels.permutation[i] = i;
583
99
        }
584
46
    }
585
586
1.88k
    void _append(const ValueType* data, size_t count) {
587
1.88k
        if (count == 0) {
588
0
            return;
589
0
        }
590
1.88k
        values.reserve(values.size() + count);
591
1.88k
        values.insert_assume_reserved(data, data + count);
592
1.88k
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE7_appendEPKam
Line
Count
Source
586
50
    void _append(const ValueType* data, size_t count) {
587
50
        if (count == 0) {
588
0
            return;
589
0
        }
590
50
        values.reserve(values.size() + count);
591
50
        values.insert_assume_reserved(data, data + count);
592
50
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE7_appendEPKsm
Line
Count
Source
586
347
    void _append(const ValueType* data, size_t count) {
587
347
        if (count == 0) {
588
0
            return;
589
0
        }
590
347
        values.reserve(values.size() + count);
591
347
        values.insert_assume_reserved(data, data + count);
592
347
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE7_appendEPKim
Line
Count
Source
586
974
    void _append(const ValueType* data, size_t count) {
587
974
        if (count == 0) {
588
0
            return;
589
0
        }
590
974
        values.reserve(values.size() + count);
591
974
        values.insert_assume_reserved(data, data + count);
592
974
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE7_appendEPKlm
Line
Count
Source
586
319
    void _append(const ValueType* data, size_t count) {
587
319
        if (count == 0) {
588
0
            return;
589
0
        }
590
319
        values.reserve(values.size() + count);
591
319
        values.insert_assume_reserved(data, data + count);
592
319
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE7_appendEPKnm
Line
Count
Source
586
22
    void _append(const ValueType* data, size_t count) {
587
22
        if (count == 0) {
588
0
            return;
589
0
        }
590
22
        values.reserve(values.size() + count);
591
22
        values.insert_assume_reserved(data, data + count);
592
22
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE7_appendEPKfm
Line
Count
Source
586
10
    void _append(const ValueType* data, size_t count) {
587
10
        if (count == 0) {
588
0
            return;
589
0
        }
590
10
        values.reserve(values.size() + count);
591
10
        values.insert_assume_reserved(data, data + count);
592
10
    }
_ZN5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE7_appendEPKdm
Line
Count
Source
586
167
    void _append(const ValueType* data, size_t count) {
587
167
        if (count == 0) {
588
0
            return;
589
0
        }
590
167
        values.reserve(values.size() + count);
591
167
        values.insert_assume_reserved(data, data + count);
592
167
    }
593
594
361
    double _get_result(double quantile) const {
595
361
        if (values.size() == 1) {
596
114
            return static_cast<double>(values.front());
597
114
        }
598
599
247
        double u = static_cast<double>(values.size() - 1) * quantile;
600
247
        auto index = static_cast<size_t>(u);
601
602
247
        if (index + 1 >= values.size()) {
603
6
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
6
        }
605
606
241
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
241
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
241
        return static_cast<double>(values[index]) +
610
241
               (u - static_cast<double>(index)) *
611
241
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
247
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE3EE11_get_resultEd
Line
Count
Source
594
29
    double _get_result(double quantile) const {
595
29
        if (values.size() == 1) {
596
4
            return static_cast<double>(values.front());
597
4
        }
598
599
25
        double u = static_cast<double>(values.size() - 1) * quantile;
600
25
        auto index = static_cast<size_t>(u);
601
602
25
        if (index + 1 >= values.size()) {
603
6
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
6
        }
605
606
19
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
19
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
19
        return static_cast<double>(values[index]) +
610
19
               (u - static_cast<double>(index)) *
611
19
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
25
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE4EE11_get_resultEd
Line
Count
Source
594
177
    double _get_result(double quantile) const {
595
177
        if (values.size() == 1) {
596
42
            return static_cast<double>(values.front());
597
42
        }
598
599
135
        double u = static_cast<double>(values.size() - 1) * quantile;
600
135
        auto index = static_cast<size_t>(u);
601
602
135
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
135
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
135
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
135
        return static_cast<double>(values[index]) +
610
135
               (u - static_cast<double>(index)) *
611
135
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
135
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE5EE11_get_resultEd
Line
Count
Source
594
54
    double _get_result(double quantile) const {
595
54
        if (values.size() == 1) {
596
21
            return static_cast<double>(values.front());
597
21
        }
598
599
33
        double u = static_cast<double>(values.size() - 1) * quantile;
600
33
        auto index = static_cast<size_t>(u);
601
602
33
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
33
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
33
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
33
        return static_cast<double>(values[index]) +
610
33
               (u - static_cast<double>(index)) *
611
33
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
33
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE6EE11_get_resultEd
Line
Count
Source
594
66
    double _get_result(double quantile) const {
595
66
        if (values.size() == 1) {
596
35
            return static_cast<double>(values.front());
597
35
        }
598
599
31
        double u = static_cast<double>(values.size() - 1) * quantile;
600
31
        auto index = static_cast<size_t>(u);
601
602
31
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
31
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
31
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
31
        return static_cast<double>(values[index]) +
610
31
               (u - static_cast<double>(index)) *
611
31
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
31
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE7EE11_get_resultEd
Line
Count
Source
594
1
    double _get_result(double quantile) const {
595
1
        if (values.size() == 1) {
596
0
            return static_cast<double>(values.front());
597
0
        }
598
599
1
        double u = static_cast<double>(values.size() - 1) * quantile;
600
1
        auto index = static_cast<size_t>(u);
601
602
1
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
1
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
1
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
1
        return static_cast<double>(values[index]) +
610
1
               (u - static_cast<double>(index)) *
611
1
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
1
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE8EE11_get_resultEd
Line
Count
Source
594
1
    double _get_result(double quantile) const {
595
1
        if (values.size() == 1) {
596
0
            return static_cast<double>(values.front());
597
0
        }
598
599
1
        double u = static_cast<double>(values.size() - 1) * quantile;
600
1
        auto index = static_cast<size_t>(u);
601
602
1
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
1
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
1
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
1
        return static_cast<double>(values[index]) +
610
1
               (u - static_cast<double>(index)) *
611
1
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
1
    }
_ZNK5doris20PercentileExactStateILNS_13PrimitiveTypeE9EE11_get_resultEd
Line
Count
Source
594
33
    double _get_result(double quantile) const {
595
33
        if (values.size() == 1) {
596
12
            return static_cast<double>(values.front());
597
12
        }
598
599
21
        double u = static_cast<double>(values.size() - 1) * quantile;
600
21
        auto index = static_cast<size_t>(u);
601
602
21
        if (index + 1 >= values.size()) {
603
0
            return static_cast<double>(*std::max_element(values.begin(), values.end()));
604
0
        }
605
606
21
        std::nth_element(values.begin(), values.begin() + index, values.end());
607
21
        auto* nth_elem = std::min_element(values.begin() + index + 1, values.end());
608
609
21
        return static_cast<double>(values[index]) +
610
21
               (u - static_cast<double>(index)) *
611
21
                       (static_cast<double>(*nth_elem) - static_cast<double>(values[index]));
612
21
    }
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
1.43k
    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
1.43k
    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
140
    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
140
    String get_name() const override { return "percentile"; }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev
630
631
21
    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
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE15get_return_typeEv
Line
Count
Source
631
21
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
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
122
             Arena&) const override {
635
122
        const auto& sources =
636
122
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
637
122
        const auto& quantile =
638
122
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
639
122
        AggregateFunctionPercentile::data(place).add(sources.get_data()[row_num],
640
122
                                                     quantile.get_data(), NullMap(1, 0), 1);
641
122
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
634
122
             Arena&) const override {
635
122
        const auto& sources =
636
122
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
637
122
        const auto& quantile =
638
122
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
639
122
        AggregateFunctionPercentile::data(place).add(sources.get_data()[row_num],
640
122
                                                     quantile.get_data(), NullMap(1, 0), 1);
641
122
    }
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
85
    void reset(AggregateDataPtr __restrict place) const override {
655
85
        AggregateFunctionPercentile::data(place).reset();
656
85
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE5resetEPc
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE5resetEPc
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE5resetEPc
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE5resetEPc
Line
Count
Source
654
85
    void reset(AggregateDataPtr __restrict place) const override {
655
85
        AggregateFunctionPercentile::data(place).reset();
656
85
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE5resetEPc
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE5resetEPc
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE5resetEPc
657
658
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
659
233
               Arena&) const override {
660
233
        AggregateFunctionPercentile::data(place).merge(AggregateFunctionPercentile::data(rhs));
661
233
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
659
233
               Arena&) const override {
660
233
        AggregateFunctionPercentile::data(place).merge(AggregateFunctionPercentile::data(rhs));
661
233
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE
662
663
233
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
664
233
        AggregateFunctionPercentile::data(place).write(buf);
665
233
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
663
233
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
664
233
        AggregateFunctionPercentile::data(place).write(buf);
665
233
    }
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
233
                     Arena&) const override {
669
233
        AggregateFunctionPercentile::data(place).read(buf);
670
233
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
668
233
                     Arena&) const override {
669
233
        AggregateFunctionPercentile::data(place).read(buf);
670
233
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
671
672
24
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
673
24
        auto& col = assert_cast<ColumnFloat64&>(to);
674
24
        col.insert_value(AggregateFunctionPercentile::data(place).get());
675
24
    }
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris27AggregateFunctionPercentileILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
672
24
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
673
24
        auto& col = assert_cast<ColumnFloat64&>(to);
674
24
        col.insert_value(AggregateFunctionPercentile::data(place).get());
675
24
    }
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
412
    AggregateFunctionPercentileArray(const DataTypes& argument_types_) : Base(argument_types_) {}
Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
_ZN5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
688
411
    AggregateFunctionPercentileArray(const DataTypes& argument_types_) : Base(argument_types_) {}
_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
21
    String get_name() const override { return "percentile_array"; }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev
Line
Count
Source
690
20
    String get_name() const override { return "percentile_array"; }
_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
100
             Arena&) const override {
698
100
        const auto& sources =
699
100
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
700
100
        const auto& quantile_array =
701
100
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
702
100
        const auto& offset_column_data = quantile_array.get_offsets();
703
100
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
704
100
                                        quantile_array.get_data())
705
100
                                        .get_null_map_data();
706
100
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
707
100
                                            quantile_array.get_data())
708
100
                                            .get_nested_column();
709
100
        const auto& nested_column_data =
710
100
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
711
712
100
        AggregateFunctionPercentileArray::data(place).add(
713
100
                sources.get_element(row_num), nested_column_data.get_data(), null_maps,
714
100
                offset_column_data.data()[row_num] - offset_column_data[(ssize_t)row_num - 1]);
715
100
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
697
100
             Arena&) const override {
698
100
        const auto& sources =
699
100
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
700
100
        const auto& quantile_array =
701
100
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
702
100
        const auto& offset_column_data = quantile_array.get_offsets();
703
100
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
704
100
                                        quantile_array.get_data())
705
100
                                        .get_null_map_data();
706
100
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
707
100
                                            quantile_array.get_data())
708
100
                                            .get_nested_column();
709
100
        const auto& nested_column_data =
710
100
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
711
712
100
        AggregateFunctionPercentileArray::data(place).add(
713
100
                sources.get_element(row_num), nested_column_data.get_data(), null_maps,
714
100
                offset_column_data.data()[row_num] - offset_column_data[(ssize_t)row_num - 1]);
715
100
    }
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
26
    void reset(AggregateDataPtr __restrict place) const override {
718
26
        AggregateFunctionPercentileArray::data(place).reset();
719
26
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE5resetEPc
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE5resetEPc
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE5resetEPc
Line
Count
Source
717
26
    void reset(AggregateDataPtr __restrict place) const override {
718
26
        AggregateFunctionPercentileArray::data(place).reset();
719
26
    }
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
121
               Arena&) const override {
723
121
        AggregateFunctionPercentileArray::data(place).merge(
724
121
                AggregateFunctionPercentileArray::data(rhs));
725
121
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
722
121
               Arena&) const override {
723
121
        AggregateFunctionPercentileArray::data(place).merge(
724
121
                AggregateFunctionPercentileArray::data(rhs));
725
121
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE
726
727
160
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
728
160
        AggregateFunctionPercentileArray::data(place).write(buf);
729
160
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
727
160
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
728
160
        AggregateFunctionPercentileArray::data(place).write(buf);
729
160
    }
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
121
                     Arena&) const override {
733
121
        AggregateFunctionPercentileArray::data(place).read(buf);
734
121
    }
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris32AggregateFunctionPercentileArrayILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
732
121
                     Arena&) const override {
733
121
        AggregateFunctionPercentileArray::data(place).read(buf);
734
121
    }
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
107
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
8
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
14
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
28
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
42
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
2
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
2
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
761
11
    AggregateFunctionPercentileV2(const DataTypes& argument_types_) : Base(argument_types_) {}
762
763
50
    String get_name() const override { return "percentile_v2"; }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev
Line
Count
Source
763
4
    String get_name() const override { return "percentile_v2"; }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev
Line
Count
Source
763
33
    String get_name() const override { return "percentile_v2"; }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev
Line
Count
Source
763
1
    String get_name() const override { return "percentile_v2"; }
_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
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev
Line
Count
Source
763
10
    String get_name() const override { return "percentile_v2"; }
764
765
230
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE15get_return_typeEv
Line
Count
Source
765
16
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE15get_return_typeEv
Line
Count
Source
765
50
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE15get_return_typeEv
Line
Count
Source
765
53
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE15get_return_typeEv
Line
Count
Source
765
72
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE15get_return_typeEv
Line
Count
Source
765
4
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE15get_return_typeEv
Line
Count
Source
765
4
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE15get_return_typeEv
Line
Count
Source
765
31
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeFloat64>(); }
766
767
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
768
811
             Arena&) const override {
769
811
        const auto& sources =
770
811
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
811
        const auto& quantile =
772
811
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
811
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
811
                                                                    quantile.get_data()[0]);
775
811
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
31
             Arena&) const override {
769
31
        const auto& sources =
770
31
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
31
        const auto& quantile =
772
31
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
31
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
31
                                                                    quantile.get_data()[0]);
775
31
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
311
             Arena&) const override {
769
311
        const auto& sources =
770
311
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
311
        const auto& quantile =
772
311
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
311
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
311
                                                                    quantile.get_data()[0]);
775
311
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
229
             Arena&) const override {
769
229
        const auto& sources =
770
229
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
229
        const auto& quantile =
772
229
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
229
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
229
                                                                    quantile.get_data()[0]);
775
229
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
192
             Arena&) const override {
769
192
        const auto& sources =
770
192
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
192
        const auto& quantile =
772
192
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
192
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
192
                                                                    quantile.get_data()[0]);
775
192
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
3
             Arena&) const override {
769
3
        const auto& sources =
770
3
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
3
        const auto& quantile =
772
3
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
3
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
3
                                                                    quantile.get_data()[0]);
775
3
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
3
             Arena&) const override {
769
3
        const auto& sources =
770
3
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
3
        const auto& quantile =
772
3
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
3
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
3
                                                                    quantile.get_data()[0]);
775
3
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
768
42
             Arena&) const override {
769
42
        const auto& sources =
770
42
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
771
42
        const auto& quantile =
772
42
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
773
42
        AggregateFunctionPercentileV2::data(place).add_single_range(&sources.get_data()[row_num], 1,
774
42
                                                                    quantile.get_data()[0]);
775
42
    }
776
777
    void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns,
778
7
                                Arena&) const override {
779
7
        const auto& sources =
780
7
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
781
7
        const auto& quantile =
782
7
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
783
7
        DCHECK_EQ(sources.get_data().size(), batch_size);
784
7
        AggregateFunctionPercentileV2::data(place).add_single_range(
785
7
                sources.get_data().data(), batch_size, quantile.get_data()[0]);
786
7
    }
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
778
2
                                Arena&) const override {
779
2
        const auto& sources =
780
2
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
781
2
        const auto& quantile =
782
2
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
783
        DCHECK_EQ(sources.get_data().size(), batch_size);
784
2
        AggregateFunctionPercentileV2::data(place).add_single_range(
785
2
                sources.get_data().data(), batch_size, quantile.get_data()[0]);
786
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
778
5
                                Arena&) const override {
779
5
        const auto& sources =
780
5
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
781
5
        const auto& quantile =
782
5
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(*columns[1]);
783
        DCHECK_EQ(sources.get_data().size(), batch_size);
784
5
        AggregateFunctionPercentileV2::data(place).add_single_range(
785
5
                sources.get_data().data(), batch_size, quantile.get_data()[0]);
786
5
    }
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
117
    void reset(AggregateDataPtr __restrict place) const override {
801
117
        AggregateFunctionPercentileV2::data(place).reset();
802
117
    }
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE5resetEPc
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE5resetEPc
Line
Count
Source
800
105
    void reset(AggregateDataPtr __restrict place) const override {
801
105
        AggregateFunctionPercentileV2::data(place).reset();
802
105
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE5resetEPc
Line
Count
Source
800
9
    void reset(AggregateDataPtr __restrict place) const override {
801
9
        AggregateFunctionPercentileV2::data(place).reset();
802
9
    }
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE5resetEPc
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE5resetEPc
Unexecuted instantiation: _ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE5resetEPc
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE5resetEPc
Line
Count
Source
800
3
    void reset(AggregateDataPtr __restrict place) const override {
801
3
        AggregateFunctionPercentileV2::data(place).reset();
802
3
    }
803
804
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
805
142
               Arena&) const override {
806
142
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
142
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
2
               Arena&) const override {
806
2
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
2
               Arena&) const override {
806
2
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
43
               Arena&) const override {
806
43
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
43
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
89
               Arena&) const override {
806
89
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
89
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
2
               Arena&) const override {
806
2
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
2
               Arena&) const override {
806
2
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
805
2
               Arena&) const override {
806
2
        AggregateFunctionPercentileV2::data(place).merge(AggregateFunctionPercentileV2::data(rhs));
807
2
    }
808
809
142
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
142
        AggregateFunctionPercentileV2::data(place).write(buf);
811
142
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
2
        AggregateFunctionPercentileV2::data(place).write(buf);
811
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
2
        AggregateFunctionPercentileV2::data(place).write(buf);
811
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
43
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
43
        AggregateFunctionPercentileV2::data(place).write(buf);
811
43
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
89
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
89
        AggregateFunctionPercentileV2::data(place).write(buf);
811
89
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
2
        AggregateFunctionPercentileV2::data(place).write(buf);
811
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
2
        AggregateFunctionPercentileV2::data(place).write(buf);
811
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
809
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
810
2
        AggregateFunctionPercentileV2::data(place).write(buf);
811
2
    }
812
813
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
814
142
                     Arena&) const override {
815
142
        AggregateFunctionPercentileV2::data(place).read(buf);
816
142
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
2
                     Arena&) const override {
815
2
        AggregateFunctionPercentileV2::data(place).read(buf);
816
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
2
                     Arena&) const override {
815
2
        AggregateFunctionPercentileV2::data(place).read(buf);
816
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
43
                     Arena&) const override {
815
43
        AggregateFunctionPercentileV2::data(place).read(buf);
816
43
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
89
                     Arena&) const override {
815
89
        AggregateFunctionPercentileV2::data(place).read(buf);
816
89
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
2
                     Arena&) const override {
815
2
        AggregateFunctionPercentileV2::data(place).read(buf);
816
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
2
                     Arena&) const override {
815
2
        AggregateFunctionPercentileV2::data(place).read(buf);
816
2
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
814
2
                     Arena&) const override {
815
2
        AggregateFunctionPercentileV2::data(place).read(buf);
816
2
    }
817
818
363
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
363
        auto& col = assert_cast<ColumnFloat64&>(to);
820
363
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
363
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
30
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
30
        auto& col = assert_cast<ColumnFloat64&>(to);
820
30
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
30
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
177
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
177
        auto& col = assert_cast<ColumnFloat64&>(to);
820
177
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
177
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
54
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
54
        auto& col = assert_cast<ColumnFloat64&>(to);
820
54
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
54
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
67
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
67
        auto& col = assert_cast<ColumnFloat64&>(to);
820
67
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
67
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
1
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
1
        auto& col = assert_cast<ColumnFloat64&>(to);
820
1
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
1
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
1
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
1
        auto& col = assert_cast<ColumnFloat64&>(to);
820
1
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
1
    }
_ZNK5doris29AggregateFunctionPercentileV2ILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
818
33
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
819
33
        auto& col = assert_cast<ColumnFloat64&>(to);
820
33
        col.insert_value(AggregateFunctionPercentileV2::data(place).get());
821
33
    }
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
87
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
4
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
6
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
45
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
13
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
4
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
2
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
_ZN5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
834
13
    AggregateFunctionPercentileArrayV2(const DataTypes& argument_types_) : Base(argument_types_) {}
835
836
10
    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
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev
Line
Count
Source
836
9
    String get_name() const override { return "percentile_array_v2"; }
837
838
165
    DataTypePtr get_return_type() const override {
839
165
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
165
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE15get_return_typeEv
Line
Count
Source
838
8
    DataTypePtr get_return_type() const override {
839
8
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
8
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE15get_return_typeEv
Line
Count
Source
838
12
    DataTypePtr get_return_type() const override {
839
12
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
12
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE15get_return_typeEv
Line
Count
Source
838
81
    DataTypePtr get_return_type() const override {
839
81
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
81
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE15get_return_typeEv
Line
Count
Source
838
21
    DataTypePtr get_return_type() const override {
839
21
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
21
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE15get_return_typeEv
Line
Count
Source
838
8
    DataTypePtr get_return_type() const override {
839
8
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
8
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE15get_return_typeEv
Line
Count
Source
838
4
    DataTypePtr get_return_type() const override {
839
4
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
4
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE15get_return_typeEv
Line
Count
Source
838
31
    DataTypePtr get_return_type() const override {
839
31
        return std::make_shared<DataTypeArray>(make_nullable(std::make_shared<DataTypeFloat64>()));
840
31
    }
841
842
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
843
664
             Arena&) const override {
844
664
        const auto& sources =
845
664
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
664
        const auto& quantile_array =
847
664
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
664
        const auto& offset_column_data = quantile_array.get_offsets();
849
664
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
664
                                        quantile_array.get_data())
851
664
                                        .get_null_map_data();
852
664
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
664
                                            quantile_array.get_data())
854
664
                                            .get_nested_column();
855
664
        const auto& nested_column_data =
856
664
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
664
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
664
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
664
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
664
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
664
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
15
             Arena&) const override {
844
15
        const auto& sources =
845
15
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
15
        const auto& quantile_array =
847
15
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
15
        const auto& offset_column_data = quantile_array.get_offsets();
849
15
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
15
                                        quantile_array.get_data())
851
15
                                        .get_null_map_data();
852
15
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
15
                                            quantile_array.get_data())
854
15
                                            .get_nested_column();
855
15
        const auto& nested_column_data =
856
15
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
15
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
15
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
15
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
15
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
15
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
30
             Arena&) const override {
844
30
        const auto& sources =
845
30
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
30
        const auto& quantile_array =
847
30
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
30
        const auto& offset_column_data = quantile_array.get_offsets();
849
30
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
30
                                        quantile_array.get_data())
851
30
                                        .get_null_map_data();
852
30
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
30
                                            quantile_array.get_data())
854
30
                                            .get_nested_column();
855
30
        const auto& nested_column_data =
856
30
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
30
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
30
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
30
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
30
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
30
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
484
             Arena&) const override {
844
484
        const auto& sources =
845
484
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
484
        const auto& quantile_array =
847
484
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
484
        const auto& offset_column_data = quantile_array.get_offsets();
849
484
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
484
                                        quantile_array.get_data())
851
484
                                        .get_null_map_data();
852
484
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
484
                                            quantile_array.get_data())
854
484
                                            .get_nested_column();
855
484
        const auto& nested_column_data =
856
484
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
484
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
484
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
484
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
484
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
484
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
33
             Arena&) const override {
844
33
        const auto& sources =
845
33
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
33
        const auto& quantile_array =
847
33
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
33
        const auto& offset_column_data = quantile_array.get_offsets();
849
33
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
33
                                        quantile_array.get_data())
851
33
                                        .get_null_map_data();
852
33
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
33
                                            quantile_array.get_data())
854
33
                                            .get_nested_column();
855
33
        const auto& nested_column_data =
856
33
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
33
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
33
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
33
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
33
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
33
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
15
             Arena&) const override {
844
15
        const auto& sources =
845
15
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
15
        const auto& quantile_array =
847
15
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
15
        const auto& offset_column_data = quantile_array.get_offsets();
849
15
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
15
                                        quantile_array.get_data())
851
15
                                        .get_null_map_data();
852
15
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
15
                                            quantile_array.get_data())
854
15
                                            .get_nested_column();
855
15
        const auto& nested_column_data =
856
15
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
15
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
15
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
15
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
15
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
15
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
3
             Arena&) const override {
844
3
        const auto& sources =
845
3
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
3
        const auto& quantile_array =
847
3
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
3
        const auto& offset_column_data = quantile_array.get_offsets();
849
3
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
3
                                        quantile_array.get_data())
851
3
                                        .get_null_map_data();
852
3
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
3
                                            quantile_array.get_data())
854
3
                                            .get_nested_column();
855
3
        const auto& nested_column_data =
856
3
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
3
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
3
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
3
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
3
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
3
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
843
84
             Arena&) const override {
844
84
        const auto& sources =
845
84
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
846
84
        const auto& quantile_array =
847
84
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
848
84
        const auto& offset_column_data = quantile_array.get_offsets();
849
84
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
850
84
                                        quantile_array.get_data())
851
84
                                        .get_null_map_data();
852
84
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
853
84
                                            quantile_array.get_data())
854
84
                                            .get_nested_column();
855
84
        const auto& nested_column_data =
856
84
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
857
84
        size_t start = row_num == 0 ? 0 : offset_column_data[row_num - 1];
858
84
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
859
84
                &sources.get_data()[row_num], 1, nested_column_data.get_data(), null_maps, start,
860
84
                cast_set<int64_t>(offset_column_data[row_num] - start));
861
84
    }
862
863
    void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns,
864
1
                                Arena&) const override {
865
1
        const auto& sources =
866
1
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
867
1
        const auto& quantile_array =
868
1
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
869
1
        const auto& offset_column_data = quantile_array.get_offsets();
870
1
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
871
1
                                        quantile_array.get_data())
872
1
                                        .get_null_map_data();
873
1
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
874
1
                                            quantile_array.get_data())
875
1
                                            .get_nested_column();
876
1
        const auto& nested_column_data =
877
1
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
878
1
        DCHECK_EQ(sources.get_data().size(), batch_size);
879
1
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
880
1
                sources.get_data().data(), batch_size, nested_column_data.get_data(), null_maps, 0,
881
1
                cast_set<int64_t>(offset_column_data[0]));
882
1
    }
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
864
1
                                Arena&) const override {
865
1
        const auto& sources =
866
1
                assert_cast<const ColVecType&, TypeCheckOnRelease::DISABLE>(*columns[0]);
867
1
        const auto& quantile_array =
868
1
                assert_cast<const ColumnArray&, TypeCheckOnRelease::DISABLE>(*columns[1]);
869
1
        const auto& offset_column_data = quantile_array.get_offsets();
870
1
        const auto& null_maps = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
871
1
                                        quantile_array.get_data())
872
1
                                        .get_null_map_data();
873
1
        const auto& nested_column = assert_cast<const ColumnNullable&, TypeCheckOnRelease::DISABLE>(
874
1
                                            quantile_array.get_data())
875
1
                                            .get_nested_column();
876
1
        const auto& nested_column_data =
877
1
                assert_cast<const ColumnFloat64&, TypeCheckOnRelease::DISABLE>(nested_column);
878
        DCHECK_EQ(sources.get_data().size(), batch_size);
879
1
        AggregateFunctionPercentileArrayV2::data(place).add_many_range(
880
1
                sources.get_data().data(), batch_size, nested_column_data.get_data(), null_maps, 0,
881
1
                cast_set<int64_t>(offset_column_data[0]));
882
1
    }
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
3
    void reset(AggregateDataPtr __restrict place) const override {
908
3
        AggregateFunctionPercentileArrayV2::data(place).reset();
909
3
    }
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE5resetEPc
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE5resetEPc
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE5resetEPc
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE5resetEPc
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE5resetEPc
Unexecuted instantiation: _ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE5resetEPc
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE5resetEPc
Line
Count
Source
907
3
    void reset(AggregateDataPtr __restrict place) const override {
908
3
        AggregateFunctionPercentileArrayV2::data(place).reset();
909
3
    }
910
911
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
912
274
               Arena&) const override {
913
274
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
274
                AggregateFunctionPercentileArrayV2::data(rhs));
915
274
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
2
               Arena&) const override {
913
2
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
2
                AggregateFunctionPercentileArrayV2::data(rhs));
915
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
4
               Arena&) const override {
913
4
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
4
                AggregateFunctionPercentileArrayV2::data(rhs));
915
4
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
218
               Arena&) const override {
913
218
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
218
                AggregateFunctionPercentileArrayV2::data(rhs));
915
218
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
3
               Arena&) const override {
913
3
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
3
                AggregateFunctionPercentileArrayV2::data(rhs));
915
3
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
2
               Arena&) const override {
913
2
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
2
                AggregateFunctionPercentileArrayV2::data(rhs));
915
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
2
               Arena&) const override {
913
2
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
2
                AggregateFunctionPercentileArrayV2::data(rhs));
915
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
912
43
               Arena&) const override {
913
43
        AggregateFunctionPercentileArrayV2::data(place).merge(
914
43
                AggregateFunctionPercentileArrayV2::data(rhs));
915
43
    }
916
917
274
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
274
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
274
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
2
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
4
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
4
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
4
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
218
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
218
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
218
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
3
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
3
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
3
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
2
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
2
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
917
43
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
918
43
        AggregateFunctionPercentileArrayV2::data(place).write(buf);
919
43
    }
920
921
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
922
274
                     Arena&) const override {
923
274
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
274
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
2
                     Arena&) const override {
923
2
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
4
                     Arena&) const override {
923
4
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
4
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
218
                     Arena&) const override {
923
218
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
218
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
3
                     Arena&) const override {
923
3
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
3
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
2
                     Arena&) const override {
923
2
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
2
                     Arena&) const override {
923
2
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
2
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
922
43
                     Arena&) const override {
923
43
        AggregateFunctionPercentileArrayV2::data(place).read(buf);
924
43
    }
925
926
258
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
258
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
258
        auto& to_nested_col = to_arr.get_data();
929
258
        if (to_nested_col.is_nullable()) {
930
258
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
258
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
258
                    col_null->get_nested_column());
933
258
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
258
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
258
        to_arr.get_offsets().push_back(to_nested_col.size());
938
258
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE3EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
11
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
11
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
11
        auto& to_nested_col = to_arr.get_data();
929
11
        if (to_nested_col.is_nullable()) {
930
11
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
11
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
11
                    col_null->get_nested_column());
933
11
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
11
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
11
        to_arr.get_offsets().push_back(to_nested_col.size());
938
11
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE4EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
12
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
12
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
12
        auto& to_nested_col = to_arr.get_data();
929
12
        if (to_nested_col.is_nullable()) {
930
12
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
12
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
12
                    col_null->get_nested_column());
933
12
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
12
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
12
        to_arr.get_offsets().push_back(to_nested_col.size());
938
12
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE5EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
170
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
170
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
170
        auto& to_nested_col = to_arr.get_data();
929
170
        if (to_nested_col.is_nullable()) {
930
170
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
170
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
170
                    col_null->get_nested_column());
933
170
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
170
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
170
        to_arr.get_offsets().push_back(to_nested_col.size());
938
170
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE6EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
12
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
12
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
12
        auto& to_nested_col = to_arr.get_data();
929
12
        if (to_nested_col.is_nullable()) {
930
12
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
12
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
12
                    col_null->get_nested_column());
933
12
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
12
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
12
        to_arr.get_offsets().push_back(to_nested_col.size());
938
12
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE7EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
11
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
11
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
11
        auto& to_nested_col = to_arr.get_data();
929
11
        if (to_nested_col.is_nullable()) {
930
11
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
11
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
11
                    col_null->get_nested_column());
933
11
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
11
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
11
        to_arr.get_offsets().push_back(to_nested_col.size());
938
11
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE8EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
1
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
1
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
1
        auto& to_nested_col = to_arr.get_data();
929
1
        if (to_nested_col.is_nullable()) {
930
1
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
1
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
1
                    col_null->get_nested_column());
933
1
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
1
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
1
        to_arr.get_offsets().push_back(to_nested_col.size());
938
1
    }
_ZNK5doris34AggregateFunctionPercentileArrayV2ILNS_13PrimitiveTypeE9EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
926
41
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
927
41
        auto& to_arr = assert_cast<ColumnArray&>(to);
928
41
        auto& to_nested_col = to_arr.get_data();
929
41
        if (to_nested_col.is_nullable()) {
930
41
            auto* col_null = reinterpret_cast<ColumnNullable*>(&to_nested_col);
931
41
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(
932
41
                    col_null->get_nested_column());
933
41
            col_null->get_null_map_data().resize_fill(col_null->get_nested_column().size(), 0);
934
41
        } else {
935
0
            AggregateFunctionPercentileArrayV2::data(place).insert_result_into(to_nested_col);
936
0
        }
937
41
        to_arr.get_offsets().push_back(to_nested_col.size());
938
41
    }
939
};
940
941
} // namespace doris