Coverage Report

Created: 2026-04-22 09:47

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/aggregate/aggregate_function_stddev.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 <boost/iterator/iterator_facade.hpp>
21
#include <cmath>
22
#include <cstddef>
23
#include <cstdint>
24
#include <memory>
25
#include <type_traits>
26
27
#include "core/assert_cast.h"
28
#include "core/column/column.h"
29
#include "core/column/column_nullable.h"
30
#include "core/data_type/data_type_decimal.h"
31
#include "core/data_type/data_type_number.h"
32
#include "core/types.h"
33
#include "exprs/aggregate/aggregate_function.h"
34
35
namespace doris {
36
class Arena;
37
class BufferReadable;
38
class BufferWritable;
39
template <PrimitiveType T>
40
class ColumnDecimal;
41
template <PrimitiveType T>
42
class ColumnVector;
43
44
template <PrimitiveType T, bool is_stddev>
45
struct BaseData {
46
8.00k
    BaseData() = default;
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EEC2Ev
Line
Count
Source
46
4.17k
    BaseData() = default;
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EEC2Ev
Line
Count
Source
46
3.83k
    BaseData() = default;
47
8.00k
    virtual ~BaseData() = default;
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EED2Ev
Line
Count
Source
47
4.17k
    virtual ~BaseData() = default;
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EED2Ev
Line
Count
Source
47
3.83k
    virtual ~BaseData() = default;
48
49
3.12k
    void write(BufferWritable& buf) const {
50
3.12k
        buf.write_binary(mean);
51
3.12k
        buf.write_binary(m2);
52
3.12k
        buf.write_binary(count);
53
3.12k
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE5writeERNS_14BufferWritableE
Line
Count
Source
49
1.64k
    void write(BufferWritable& buf) const {
50
1.64k
        buf.write_binary(mean);
51
1.64k
        buf.write_binary(m2);
52
1.64k
        buf.write_binary(count);
53
1.64k
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE5writeERNS_14BufferWritableE
Line
Count
Source
49
1.47k
    void write(BufferWritable& buf) const {
50
1.47k
        buf.write_binary(mean);
51
1.47k
        buf.write_binary(m2);
52
1.47k
        buf.write_binary(count);
53
1.47k
    }
54
55
3.00k
    void read(BufferReadable& buf) {
56
3.00k
        buf.read_binary(mean);
57
3.00k
        buf.read_binary(m2);
58
3.00k
        buf.read_binary(count);
59
3.00k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE4readERNS_14BufferReadableE
Line
Count
Source
55
1.59k
    void read(BufferReadable& buf) {
56
1.59k
        buf.read_binary(mean);
57
1.59k
        buf.read_binary(m2);
58
1.59k
        buf.read_binary(count);
59
1.59k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE4readERNS_14BufferReadableE
Line
Count
Source
55
1.40k
    void read(BufferReadable& buf) {
56
1.40k
        buf.read_binary(mean);
57
1.40k
        buf.read_binary(m2);
58
1.40k
        buf.read_binary(count);
59
1.40k
    }
60
61
842
    void reset() {
62
842
        mean = 0.0;
63
842
        m2 = 0.0;
64
842
        count = 0;
65
842
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE5resetEv
Line
Count
Source
61
434
    void reset() {
62
434
        mean = 0.0;
63
434
        m2 = 0.0;
64
434
        count = 0;
65
434
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE5resetEv
Line
Count
Source
61
408
    void reset() {
62
408
        mean = 0.0;
63
408
        m2 = 0.0;
64
408
        count = 0;
65
408
    }
66
67
1.34k
    double get_result(double res) const {
68
1.34k
        auto inf_to_nan = [](double val) {
69
            // This function performs squaring operations, and due to differences in computation order,
70
            // it might produce different values such as inf and nan.
71
            // In MySQL, this will directly result in an error due to exceeding the double range.
72
            // For performance reasons, we are uniformly changing it to nan
73
1.34k
            if (std::isinf(val)) {
74
0
                return std::nan("");
75
0
            }
76
1.34k
            return val;
77
1.34k
        };
_ZZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE10get_resultEdENKUldE_clEd
Line
Count
Source
68
682
        auto inf_to_nan = [](double val) {
69
            // This function performs squaring operations, and due to differences in computation order,
70
            // it might produce different values such as inf and nan.
71
            // In MySQL, this will directly result in an error due to exceeding the double range.
72
            // For performance reasons, we are uniformly changing it to nan
73
682
            if (std::isinf(val)) {
74
0
                return std::nan("");
75
0
            }
76
682
            return val;
77
682
        };
_ZZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE10get_resultEdENKUldE_clEd
Line
Count
Source
68
659
        auto inf_to_nan = [](double val) {
69
            // This function performs squaring operations, and due to differences in computation order,
70
            // it might produce different values such as inf and nan.
71
            // In MySQL, this will directly result in an error due to exceeding the double range.
72
            // For performance reasons, we are uniformly changing it to nan
73
659
            if (std::isinf(val)) {
74
0
                return std::nan("");
75
0
            }
76
659
            return val;
77
659
        };
78
1.34k
        if constexpr (is_stddev) {
79
659
            return inf_to_nan(std::sqrt(res));
80
682
        } else {
81
682
            return inf_to_nan(res);
82
682
        }
83
1.34k
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE10get_resultEd
Line
Count
Source
67
682
    double get_result(double res) const {
68
682
        auto inf_to_nan = [](double val) {
69
            // This function performs squaring operations, and due to differences in computation order,
70
            // it might produce different values such as inf and nan.
71
            // In MySQL, this will directly result in an error due to exceeding the double range.
72
            // For performance reasons, we are uniformly changing it to nan
73
682
            if (std::isinf(val)) {
74
682
                return std::nan("");
75
682
            }
76
682
            return val;
77
682
        };
78
        if constexpr (is_stddev) {
79
            return inf_to_nan(std::sqrt(res));
80
682
        } else {
81
682
            return inf_to_nan(res);
82
682
        }
83
682
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE10get_resultEd
Line
Count
Source
67
659
    double get_result(double res) const {
68
659
        auto inf_to_nan = [](double val) {
69
            // This function performs squaring operations, and due to differences in computation order,
70
            // it might produce different values such as inf and nan.
71
            // In MySQL, this will directly result in an error due to exceeding the double range.
72
            // For performance reasons, we are uniformly changing it to nan
73
659
            if (std::isinf(val)) {
74
659
                return std::nan("");
75
659
            }
76
659
            return val;
77
659
        };
78
659
        if constexpr (is_stddev) {
79
659
            return inf_to_nan(std::sqrt(res));
80
        } else {
81
            return inf_to_nan(res);
82
        }
83
659
    }
84
85
1.18k
    double get_pop_result() const {
86
1.18k
        if (count == 1) {
87
484
            return 0.0;
88
484
        }
89
696
        double res = m2 / (double)count;
90
696
        return get_result(res);
91
1.18k
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE14get_pop_resultEv
Line
Count
Source
85
595
    double get_pop_result() const {
86
595
        if (count == 1) {
87
242
            return 0.0;
88
242
        }
89
353
        double res = m2 / (double)count;
90
353
        return get_result(res);
91
595
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE14get_pop_resultEv
Line
Count
Source
85
585
    double get_pop_result() const {
86
585
        if (count == 1) {
87
242
            return 0.0;
88
242
        }
89
343
        double res = m2 / (double)count;
90
343
        return get_result(res);
91
585
    }
92
93
645
    double get_samp_result() const {
94
645
        double res = m2 / double(count - 1);
95
645
        return get_result(res);
96
645
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE15get_samp_resultEv
Line
Count
Source
93
329
    double get_samp_result() const {
94
329
        double res = m2 / double(count - 1);
95
329
        return get_result(res);
96
329
    }
_ZNK5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE15get_samp_resultEv
Line
Count
Source
93
316
    double get_samp_result() const {
94
316
        double res = m2 / double(count - 1);
95
316
        return get_result(res);
96
316
    }
97
98
3.00k
    void merge(const BaseData& rhs) {
99
3.00k
        if (rhs.count == 0) {
100
92
            return;
101
92
        }
102
2.90k
        double delta = mean - rhs.mean;
103
2.90k
        double sum_count = double(count + rhs.count);
104
2.90k
        mean = rhs.mean + delta * (double)count / sum_count;
105
2.90k
        m2 = rhs.m2 + m2 + (delta * delta) * (double)rhs.count * (double)count / sum_count;
106
2.90k
        count = int64_t(sum_count);
107
2.90k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE5mergeERKS2_
Line
Count
Source
98
1.59k
    void merge(const BaseData& rhs) {
99
1.59k
        if (rhs.count == 0) {
100
47
            return;
101
47
        }
102
1.55k
        double delta = mean - rhs.mean;
103
1.55k
        double sum_count = double(count + rhs.count);
104
1.55k
        mean = rhs.mean + delta * (double)count / sum_count;
105
1.55k
        m2 = rhs.m2 + m2 + (delta * delta) * (double)rhs.count * (double)count / sum_count;
106
1.55k
        count = int64_t(sum_count);
107
1.55k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE5mergeERKS2_
Line
Count
Source
98
1.40k
    void merge(const BaseData& rhs) {
99
1.40k
        if (rhs.count == 0) {
100
45
            return;
101
45
        }
102
1.35k
        double delta = mean - rhs.mean;
103
1.35k
        double sum_count = double(count + rhs.count);
104
1.35k
        mean = rhs.mean + delta * (double)count / sum_count;
105
1.35k
        m2 = rhs.m2 + m2 + (delta * delta) * (double)rhs.count * (double)count / sum_count;
106
1.35k
        count = int64_t(sum_count);
107
1.35k
    }
108
109
6.17k
    void add(const IColumn* column, size_t row_num) {
110
6.17k
        const auto& sources = assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
111
6.17k
                                          TypeCheckOnRelease::DISABLE>(*column);
112
6.17k
        double source_data = (double)sources.get_data()[row_num];
113
114
6.17k
        double delta = source_data - mean;
115
6.17k
        double r = delta / double(1 + count);
116
6.17k
        mean += r;
117
6.17k
        m2 += (double)count * delta * r;
118
6.17k
        count += 1;
119
6.17k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb0EE3addEPKNS_7IColumnEm
Line
Count
Source
109
3.13k
    void add(const IColumn* column, size_t row_num) {
110
3.13k
        const auto& sources = assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
111
3.13k
                                          TypeCheckOnRelease::DISABLE>(*column);
112
3.13k
        double source_data = (double)sources.get_data()[row_num];
113
114
3.13k
        double delta = source_data - mean;
115
3.13k
        double r = delta / double(1 + count);
116
3.13k
        mean += r;
117
3.13k
        m2 += (double)count * delta * r;
118
3.13k
        count += 1;
119
3.13k
    }
_ZN5doris8BaseDataILNS_13PrimitiveTypeE9ELb1EE3addEPKNS_7IColumnEm
Line
Count
Source
109
3.04k
    void add(const IColumn* column, size_t row_num) {
110
3.04k
        const auto& sources = assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
111
3.04k
                                          TypeCheckOnRelease::DISABLE>(*column);
112
3.04k
        double source_data = (double)sources.get_data()[row_num];
113
114
3.04k
        double delta = source_data - mean;
115
3.04k
        double r = delta / double(1 + count);
116
3.04k
        mean += r;
117
3.04k
        m2 += (double)count * delta * r;
118
3.04k
        count += 1;
119
3.04k
    }
120
121
    double mean {};
122
    double m2 {};
123
    int64_t count {};
124
};
125
126
template <PrimitiveType T, typename Name, bool is_stddev>
127
struct PopData : BaseData<T, is_stddev>, Name {
128
    using ColVecResult = std::conditional_t<is_decimal(T), ColumnDecimal128V2, ColumnFloat64>;
129
1.18k
    void insert_result_into(IColumn& to) const {
130
1.18k
        auto& col = assert_cast<ColVecResult&>(to);
131
        if constexpr (is_decimal(T)) {
132
            col.get_data().push_back(this->get_pop_result().value());
133
1.18k
        } else {
134
1.18k
            col.get_data().push_back(this->get_pop_result());
135
1.18k
        }
136
1.18k
    }
_ZNK5doris7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
129
595
    void insert_result_into(IColumn& to) const {
130
595
        auto& col = assert_cast<ColVecResult&>(to);
131
        if constexpr (is_decimal(T)) {
132
            col.get_data().push_back(this->get_pop_result().value());
133
595
        } else {
134
595
            col.get_data().push_back(this->get_pop_result());
135
595
        }
136
595
    }
_ZNK5doris7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
129
585
    void insert_result_into(IColumn& to) const {
130
585
        auto& col = assert_cast<ColVecResult&>(to);
131
        if constexpr (is_decimal(T)) {
132
            col.get_data().push_back(this->get_pop_result().value());
133
585
        } else {
134
585
            col.get_data().push_back(this->get_pop_result());
135
585
        }
136
585
    }
137
138
957
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
_ZN5doris7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EE15get_return_typeEv
Line
Count
Source
138
502
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
_ZN5doris7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EE15get_return_typeEv
Line
Count
Source
138
455
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
139
};
140
141
// For this series of functions, the Decimal type is not supported
142
// because the operations involve squaring,
143
// which can easily exceed the range of the Decimal type.
144
145
template <PrimitiveType T, typename Name, bool is_stddev>
146
struct SampData : BaseData<T, is_stddev>, Name {
147
    using ColVecResult = std::conditional_t<is_decimal(T), ColumnDecimal128V2, ColumnFloat64>;
148
1.12k
    void insert_result_into(IColumn& to) const {
149
1.12k
        auto& col = assert_cast<ColVecResult&>(to);
150
1.12k
        if (this->count == 1 || this->count == 0) {
151
483
            col.insert_default();
152
645
        } else {
153
            if constexpr (is_decimal(T)) {
154
                col.get_data().push_back(this->get_samp_result().value());
155
645
            } else {
156
645
                col.get_data().push_back(this->get_samp_result());
157
645
            }
158
645
        }
159
1.12k
    }
_ZNK5doris8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
148
573
    void insert_result_into(IColumn& to) const {
149
573
        auto& col = assert_cast<ColVecResult&>(to);
150
573
        if (this->count == 1 || this->count == 0) {
151
244
            col.insert_default();
152
329
        } else {
153
            if constexpr (is_decimal(T)) {
154
                col.get_data().push_back(this->get_samp_result().value());
155
329
            } else {
156
329
                col.get_data().push_back(this->get_samp_result());
157
329
            }
158
329
        }
159
573
    }
_ZNK5doris8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EE18insert_result_intoERNS_7IColumnE
Line
Count
Source
148
555
    void insert_result_into(IColumn& to) const {
149
555
        auto& col = assert_cast<ColVecResult&>(to);
150
555
        if (this->count == 1 || this->count == 0) {
151
239
            col.insert_default();
152
316
        } else {
153
            if constexpr (is_decimal(T)) {
154
                col.get_data().push_back(this->get_samp_result().value());
155
316
            } else {
156
316
                col.get_data().push_back(this->get_samp_result());
157
316
            }
158
316
        }
159
555
    }
160
161
833
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
_ZN5doris8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EE15get_return_typeEv
Line
Count
Source
161
425
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
_ZN5doris8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EE15get_return_typeEv
Line
Count
Source
161
408
    static DataTypePtr get_return_type() { return std::make_shared<DataTypeFloat64>(); }
162
};
163
164
struct StddevName {
165
154
    static const char* name() { return "stddev"; }
166
};
167
struct VarianceName {
168
153
    static const char* name() { return "variance"; }
169
};
170
struct VarianceSampName {
171
154
    static const char* name() { return "variance_samp"; }
172
};
173
struct StddevSampName {
174
133
    static const char* name() { return "stddev_samp"; }
175
};
176
177
template <typename Data>
178
class AggregateFunctionSampVariance final
179
        : public IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>,
180
          UnaryExpression,
181
          NullableAggregateFunction {
182
public:
183
    AggregateFunctionSampVariance(const DataTypes& argument_types_)
184
3.88k
            : IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>(
185
3.88k
                      argument_types_) {}
_ZN5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISA_EE
Line
Count
Source
184
1.07k
            : IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>(
185
1.07k
                      argument_types_) {}
_ZN5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISA_EE
Line
Count
Source
184
1.11k
            : IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>(
185
1.11k
                      argument_types_) {}
_ZN5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISA_EE
Line
Count
Source
184
1.08k
            : IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>(
185
1.08k
                      argument_types_) {}
_ZN5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaISA_EE
Line
Count
Source
184
603
            : IAggregateFunctionDataHelper<Data, AggregateFunctionSampVariance<Data>>(
185
603
                      argument_types_) {}
186
187
594
    String get_name() const override { return Data::name(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE8get_nameB5cxx11Ev
Line
Count
Source
187
154
    String get_name() const override { return Data::name(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE8get_nameB5cxx11Ev
Line
Count
Source
187
153
    String get_name() const override { return Data::name(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE8get_nameB5cxx11Ev
Line
Count
Source
187
154
    String get_name() const override { return Data::name(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE8get_nameB5cxx11Ev
Line
Count
Source
187
133
    String get_name() const override { return Data::name(); }
188
189
1.79k
    DataTypePtr get_return_type() const override { return Data::get_return_type(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE15get_return_typeEv
Line
Count
Source
189
425
    DataTypePtr get_return_type() const override { return Data::get_return_type(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE15get_return_typeEv
Line
Count
Source
189
502
    DataTypePtr get_return_type() const override { return Data::get_return_type(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE15get_return_typeEv
Line
Count
Source
189
455
    DataTypePtr get_return_type() const override { return Data::get_return_type(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE15get_return_typeEv
Line
Count
Source
189
408
    DataTypePtr get_return_type() const override { return Data::get_return_type(); }
190
191
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
192
6.17k
             Arena&) const override {
193
6.17k
        this->data(place).add(columns[0], row_num);
194
6.17k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
192
1.48k
             Arena&) const override {
193
1.48k
        this->data(place).add(columns[0], row_num);
194
1.48k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
192
1.64k
             Arena&) const override {
193
1.64k
        this->data(place).add(columns[0], row_num);
194
1.64k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
192
1.60k
             Arena&) const override {
193
1.60k
        this->data(place).add(columns[0], row_num);
194
1.60k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
192
1.44k
             Arena&) const override {
193
1.44k
        this->data(place).add(columns[0], row_num);
194
1.44k
    }
195
196
842
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE5resetEPc
Line
Count
Source
196
217
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE5resetEPc
Line
Count
Source
196
217
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE5resetEPc
Line
Count
Source
196
217
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE5resetEPc
Line
Count
Source
196
191
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
197
198
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
199
3.00k
               Arena&) const override {
200
3.00k
        this->data(place).merge(this->data(rhs));
201
3.00k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
199
757
               Arena&) const override {
200
757
        this->data(place).merge(this->data(rhs));
201
757
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
199
840
               Arena&) const override {
200
840
        this->data(place).merge(this->data(rhs));
201
840
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
199
772
               Arena&) const override {
200
772
        this->data(place).merge(this->data(rhs));
201
772
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
199
631
               Arena&) const override {
200
631
        this->data(place).merge(this->data(rhs));
201
631
    }
202
203
3.12k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
204
3.12k
        this->data(place).write(buf);
205
3.12k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
203
781
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
204
781
        this->data(place).write(buf);
205
781
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
203
866
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
204
866
        this->data(place).write(buf);
205
866
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
203
796
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
204
796
        this->data(place).write(buf);
205
796
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
203
679
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
204
679
        this->data(place).write(buf);
205
679
    }
206
207
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
208
3.00k
                     Arena&) const override {
209
3.00k
        this->data(place).read(buf);
210
3.00k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
208
757
                     Arena&) const override {
209
757
        this->data(place).read(buf);
210
757
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
208
840
                     Arena&) const override {
209
840
        this->data(place).read(buf);
210
840
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
208
772
                     Arena&) const override {
209
772
        this->data(place).read(buf);
210
772
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
208
631
                     Arena&) const override {
209
631
        this->data(place).read(buf);
210
631
    }
211
212
2.30k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
213
2.30k
        this->data(place).insert_result_into(to);
214
2.30k
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_16VarianceSampNameELb0EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
212
573
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
213
573
        this->data(place).insert_result_into(to);
214
573
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_12VarianceNameELb0EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
212
595
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
213
595
        this->data(place).insert_result_into(to);
214
595
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_7PopDataILNS_13PrimitiveTypeE9ENS_10StddevNameELb1EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
212
585
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
213
585
        this->data(place).insert_result_into(to);
214
585
    }
_ZNK5doris29AggregateFunctionSampVarianceINS_8SampDataILNS_13PrimitiveTypeE9ENS_14StddevSampNameELb1EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
212
555
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
213
555
        this->data(place).insert_result_into(to);
214
555
    }
215
};
216
217
} // namespace doris