Coverage Report

Created: 2026-03-17 11:27

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/aggregate/aggregate_function_uniq.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
// This file is copied from
18
// https://github.com/ClickHouse/ClickHouse/blob/master/src/AggregateFunctions/AggregateFunctionUniq.h
19
// and modified by Doris
20
21
#pragma once
22
23
#include <stddef.h>
24
25
#include <boost/iterator/iterator_facade.hpp>
26
#include <memory>
27
#include <type_traits>
28
#include <vector>
29
30
#include "common/compiler_util.h" // IWYU pragma: keep
31
#include "core/assert_cast.h"
32
#include "core/column/column.h"
33
#include "core/column/column_vector.h"
34
#include "core/data_type/data_type_number.h"
35
#include "core/data_type/primitive_type.h"
36
#include "core/string_ref.h"
37
#include "core/types.h"
38
#include "core/uint128.h"
39
#include "exec/common/hash_table/hash.h"
40
#include "exec/common/hash_table/phmap_fwd_decl.h"
41
#include "exprs/aggregate/aggregate_function.h"
42
#include "util/io_helper.h"
43
#include "util/var_int.h"
44
45
template <typename T>
46
struct HashCRC32;
47
48
namespace doris {
49
#include "common/compile_check_begin.h"
50
51
class Arena;
52
class BufferReadable;
53
class BufferWritable;
54
template <PrimitiveType T>
55
class ColumnDecimal;
56
/// uniqExact
57
58
template <PrimitiveType T>
59
struct AggregateFunctionUniqExactData {
60
    static constexpr bool is_string_key = is_string_type(T) || is_varbinary(T);
61
    using Key = std::conditional_t<
62
            is_string_key, UInt128,
63
            std::conditional_t<T == TYPE_ARRAY, UInt64,
64
                               std::conditional_t<T == TYPE_BOOLEAN, UInt8,
65
                                                  typename PrimitiveTypeTraits<T>::CppType>>>;
66
    using Hash = HashCRC32<Key>;
67
68
    using Set = flat_hash_set<Key, Hash>;
69
70
761
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
761
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
761
        return UInt128 {hash_value.high64, hash_value.low64};
73
761
    }
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE7get_keyERKNS_9StringRefE
Line
Count
Source
70
761
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
761
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
761
        return UInt128 {hash_value.high64, hash_value.low64};
73
761
    }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE41EE7get_keyERKNS_9StringRefE
74
14
    static UInt64 ALWAYS_INLINE get_key(const IColumn& column, size_t row_num) {
75
14
        UInt64 hash_value = 0;
76
14
        column.update_xxHash_with_value(row_num, row_num + 1, hash_value, nullptr);
77
14
        return hash_value;
78
14
    }
79
80
    Set set;
81
82
43
    static String get_name() { return "multi_distinct"; }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE2EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE3EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE4EE8get_nameB5cxx11Ev
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE5EE8get_nameB5cxx11Ev
Line
Count
Source
82
25
    static String get_name() { return "multi_distinct"; }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE6EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE7EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE28EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE29EE8get_nameB5cxx11Ev
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE30EE8get_nameB5cxx11Ev
Line
Count
Source
82
16
    static String get_name() { return "multi_distinct"; }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE35EE8get_nameB5cxx11Ev
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE8get_nameB5cxx11Ev
Line
Count
Source
82
2
    static String get_name() { return "multi_distinct"; }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE17EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE8EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE9EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE25EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE26EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE42EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE41EE8get_nameB5cxx11Ev
83
84
34
    void reset() { set.clear(); }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE2EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE3EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE4EE5resetEv
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE5EE5resetEv
Line
Count
Source
84
31
    void reset() { set.clear(); }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE6EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE7EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE28EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE29EE5resetEv
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE30EE5resetEv
Line
Count
Source
84
3
    void reset() { set.clear(); }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE35EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE17EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE8EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE9EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE25EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE26EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE42EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE41EE5resetEv
85
};
86
87
namespace detail {
88
89
/** The structure for the delegation work to add one element to the `uniq` aggregate functions.
90
  * Used for partial specialization to add strings.
91
  */
92
template <PrimitiveType T, typename Data>
93
struct OneAdder {
94
732
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
732
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
492
            StringRef value = column.get_data_at(row_num);
97
492
            data.set.insert(Data::get_key(value));
98
492
        } else if constexpr (T == TYPE_ARRAY) {
99
14
            data.set.insert(Data::get_key(column, row_num));
100
226
        } else {
101
226
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
226
                                        TypeCheckOnRelease::DISABLE>(column)
103
226
                                    .get_data()[row_num]);
104
226
        }
105
732
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS2_2EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
2
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
2
        } else {
101
2
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
2
                                        TypeCheckOnRelease::DISABLE>(column)
103
2
                                    .get_data()[row_num]);
104
2
        }
105
2
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS2_3EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS2_4EEEE3addERS4_RKNS_7IColumnEm
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS2_5EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
176
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
176
        } else {
101
176
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
176
                                        TypeCheckOnRelease::DISABLE>(column)
103
176
                                    .get_data()[row_num]);
104
176
        }
105
176
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS2_6EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS2_7EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS2_28EEEE3addERS4_RKNS_7IColumnEm
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS2_29EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
4
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
4
        } else {
101
4
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
4
                                        TypeCheckOnRelease::DISABLE>(column)
103
4
                                    .get_data()[row_num]);
104
4
        }
105
4
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS2_30EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
17
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
17
        } else {
101
17
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
17
                                        TypeCheckOnRelease::DISABLE>(column)
103
17
                                    .get_data()[row_num]);
104
17
        }
105
17
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS2_35EEEE3addERS4_RKNS_7IColumnEm
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS2_10EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
492
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
492
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
492
            StringRef value = column.get_data_at(row_num);
97
492
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
        } else {
101
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
                                        TypeCheckOnRelease::DISABLE>(column)
103
                                    .get_data()[row_num]);
104
        }
105
492
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS2_17EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
14
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
14
        } else if constexpr (T == TYPE_ARRAY) {
99
14
            data.set.insert(Data::get_key(column, row_num));
100
        } else {
101
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
                                        TypeCheckOnRelease::DISABLE>(column)
103
                                    .get_data()[row_num]);
104
        }
105
14
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS2_8EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS2_9EEEE3addERS4_RKNS_7IColumnEm
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS2_25EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
6
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
6
        } else {
101
6
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
6
                                        TypeCheckOnRelease::DISABLE>(column)
103
6
                                    .get_data()[row_num]);
104
6
        }
105
6
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS2_26EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
15
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
15
        } else {
101
15
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
15
                                        TypeCheckOnRelease::DISABLE>(column)
103
15
                                    .get_data()[row_num]);
104
15
        }
105
15
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS2_42EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
6
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
            StringRef value = column.get_data_at(row_num);
97
            data.set.insert(Data::get_key(value));
98
        } else if constexpr (T == TYPE_ARRAY) {
99
            data.set.insert(Data::get_key(column, row_num));
100
6
        } else {
101
6
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
6
                                        TypeCheckOnRelease::DISABLE>(column)
103
6
                                    .get_data()[row_num]);
104
6
        }
105
6
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS2_41EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE3ENS_38AggregateFunctionUniqDistributeKeyDataILS2_3EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE4ENS_38AggregateFunctionUniqDistributeKeyDataILS2_4EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE5ENS_38AggregateFunctionUniqDistributeKeyDataILS2_5EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE6ENS_38AggregateFunctionUniqDistributeKeyDataILS2_6EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE7ENS_38AggregateFunctionUniqDistributeKeyDataILS2_7EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE28ENS_38AggregateFunctionUniqDistributeKeyDataILS2_28EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE29ENS_38AggregateFunctionUniqDistributeKeyDataILS2_29EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE30ENS_38AggregateFunctionUniqDistributeKeyDataILS2_30EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE35ENS_38AggregateFunctionUniqDistributeKeyDataILS2_35EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE10ENS_38AggregateFunctionUniqDistributeKeyDataILS2_10EEEE3addERS4_RKNS_7IColumnEm
106
};
107
108
} // namespace detail
109
110
/// Calculates the number of different values approximately or exactly.
111
template <PrimitiveType T, typename Data>
112
class AggregateFunctionUniq final
113
        : public IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>,
114
          VarargsExpression,
115
          NotNullableAggregateFunction {
116
public:
117
    using KeyType = std::conditional_t<
118
            is_string_type(T) || is_varbinary(T), UInt128,
119
            std::conditional_t<T == TYPE_ARRAY, UInt64, typename PrimitiveTypeTraits<T>::CppType>>;
120
    AggregateFunctionUniq(const DataTypes& argument_types_)
121
1.39k
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
2
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
16
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
706
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
58
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
2
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
12
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
1
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
13
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
559
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
4
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
10
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
2
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
8
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
122
123
43
    String get_name() const override { return Data::get_name(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE8get_nameB5cxx11Ev
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE8get_nameB5cxx11Ev
Line
Count
Source
123
25
    String get_name() const override { return Data::get_name(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE8get_nameB5cxx11Ev
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE8get_nameB5cxx11Ev
Line
Count
Source
123
16
    String get_name() const override { return Data::get_name(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE8get_nameB5cxx11Ev
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE8get_nameB5cxx11Ev
Line
Count
Source
123
2
    String get_name() const override { return Data::get_name(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE8get_nameB5cxx11Ev
124
125
1.64k
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE15get_return_typeEv
Line
Count
Source
125
3
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE15get_return_typeEv
Line
Count
Source
125
82
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE15get_return_typeEv
Line
Count
Source
125
786
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE15get_return_typeEv
Line
Count
Source
125
149
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE15get_return_typeEv
Line
Count
Source
125
14
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE15get_return_typeEv
Line
Count
Source
125
18
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE15get_return_typeEv
Line
Count
Source
125
17
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE15get_return_typeEv
Line
Count
Source
125
21
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE15get_return_typeEv
Line
Count
Source
125
511
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE15get_return_typeEv
Line
Count
Source
125
8
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE15get_return_typeEv
Line
Count
Source
125
17
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE15get_return_typeEv
Line
Count
Source
125
4
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE15get_return_typeEv
Line
Count
Source
125
12
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE15get_return_typeEv
126
127
34
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE5resetEPc
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE5resetEPc
Line
Count
Source
127
31
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE5resetEPc
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE5resetEPc
Line
Count
Source
127
3
    void reset(AggregateDataPtr __restrict place) const override { this->data(place).reset(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE5resetEPc
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE5resetEPc
128
129
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
130
732
             Arena&) const override {
131
732
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
732
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
2
             Arena&) const override {
131
2
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
2
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
176
             Arena&) const override {
131
176
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
176
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
4
             Arena&) const override {
131
4
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
4
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
17
             Arena&) const override {
131
17
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
17
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
492
             Arena&) const override {
131
492
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
492
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
14
             Arena&) const override {
131
14
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
14
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
6
             Arena&) const override {
131
6
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
6
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
15
             Arena&) const override {
131
15
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
15
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
6
             Arena&) const override {
131
6
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
6
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
133
134
    static ALWAYS_INLINE const KeyType* get_keys(std::vector<KeyType>& keys_container,
135
1.18k
                                                 const IColumn& column, size_t batch_size) {
136
1.18k
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
58
            keys_container.resize(batch_size);
138
327
            for (size_t i = 0; i != batch_size; ++i) {
139
269
                StringRef value = column.get_data_at(i);
140
269
                keys_container[i] = Data::get_key(value);
141
269
            }
142
58
            return keys_container.data();
143
58
        } else if constexpr (T == TYPE_ARRAY) {
144
0
            keys_container.resize(batch_size);
145
0
            for (size_t i = 0; i != batch_size; ++i) {
146
0
                keys_container[i] = Data::get_key(column, i);
147
0
            }
148
0
            return keys_container.data();
149
1.13k
        } else {
150
1.13k
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
1.13k
                    .get_data()
152
1.13k
                    .data();
153
1.13k
        }
154
1.18k
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE8get_keysERSt6vectorIhSaIhEERKNS_7IColumnEm
Line
Count
Source
135
4
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
4
        } else {
150
4
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
4
                    .get_data()
152
4
                    .data();
153
4
        }
154
4
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE8get_keysERSt6vectorIaSaIaEERKNS_7IColumnEm
Line
Count
Source
135
28
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
28
        } else {
150
28
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
28
                    .get_data()
152
28
                    .data();
153
28
        }
154
28
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE8get_keysERSt6vectorIsSaIsEERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE8get_keysERSt6vectorIiSaIiEERKNS_7IColumnEm
Line
Count
Source
135
727
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
727
        } else {
150
727
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
727
                    .get_data()
152
727
                    .data();
153
727
        }
154
727
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE8get_keysERSt6vectorIlSaIlEERKNS_7IColumnEm
Line
Count
Source
135
167
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
167
        } else {
150
167
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
167
                    .get_data()
152
167
                    .data();
153
167
        }
154
167
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE8get_keysERSt6vectorInSaInEERKNS_7IColumnEm
Line
Count
Source
135
4
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
4
        } else {
150
4
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
4
                    .get_data()
152
4
                    .data();
153
4
        }
154
4
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE8get_keysERSt6vectorINS_7DecimalIiEESaIS7_EERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE8get_keysERSt6vectorINS_7DecimalIlEESaIS7_EERKNS_7IColumnEm
Line
Count
Source
135
5
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
5
        } else {
150
5
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
5
                    .get_data()
152
5
                    .data();
153
5
        }
154
5
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE8get_keysERSt6vectorINS_12Decimal128V3ESaIS6_EERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE8get_keysERSt6vectorINS_7DecimalIN4wide7integerILm256EiEEEESaISA_EERKNS_7IColumnEm
Line
Count
Source
135
11
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
11
        } else {
150
11
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
11
                    .get_data()
152
11
                    .data();
153
11
        }
154
11
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE8get_keysERSt6vectorIN4wide7integerILm128EjEESaIS8_EERKNS_7IColumnEm
Line
Count
Source
135
58
                                                 const IColumn& column, size_t batch_size) {
136
58
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
58
            keys_container.resize(batch_size);
138
327
            for (size_t i = 0; i != batch_size; ++i) {
139
269
                StringRef value = column.get_data_at(i);
140
269
                keys_container[i] = Data::get_key(value);
141
269
            }
142
58
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
        } else {
150
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
                    .get_data()
152
                    .data();
153
        }
154
58
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE8get_keysERSt6vectorImSaImEERKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE8get_keysERSt6vectorIfSaIfEERKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE8get_keysERSt6vectorIdSaIdEERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE8get_keysERSt6vectorINS_11DateV2ValueINS_15DateV2ValueTypeEEESaIS8_EERKNS_7IColumnEm
Line
Count
Source
135
148
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
148
        } else {
150
148
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
148
                    .get_data()
152
148
                    .data();
153
148
        }
154
148
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE8get_keysERSt6vectorINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEESaIS8_EERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE8get_keysERSt6vectorINS_16TimestampTzValueESaIS6_EERKNS_7IColumnEm
Line
Count
Source
135
36
                                                 const IColumn& column, size_t batch_size) {
136
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
            keys_container.resize(batch_size);
138
            for (size_t i = 0; i != batch_size; ++i) {
139
                StringRef value = column.get_data_at(i);
140
                keys_container[i] = Data::get_key(value);
141
            }
142
            return keys_container.data();
143
        } else if constexpr (T == TYPE_ARRAY) {
144
            keys_container.resize(batch_size);
145
            for (size_t i = 0; i != batch_size; ++i) {
146
                keys_container[i] = Data::get_key(column, i);
147
            }
148
            return keys_container.data();
149
36
        } else {
150
36
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
36
                    .get_data()
152
36
                    .data();
153
36
        }
154
36
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE8get_keysERSt6vectorIN4wide7integerILm128EjEESaIS8_EERKNS_7IColumnEm
155
156
    void add_batch(size_t batch_size, AggregateDataPtr* places, size_t place_offset,
157
924
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
924
        std::vector<KeyType> keys_container;
159
924
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
924
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
40.6k
        for (size_t i = 0; i != batch_size; ++i) {
164
39.6k
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
39.6k
        }
166
167
40.6k
        for (size_t i = 0; i != batch_size; ++i) {
168
39.6k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
34.6k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
34.6k
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
34.6k
            }
172
173
39.6k
            array_of_data_set[i]->insert(keys[i]);
174
39.6k
        }
175
924
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
4
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
4
        std::vector<KeyType> keys_container;
159
4
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
4
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
17
        for (size_t i = 0; i != batch_size; ++i) {
164
13
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
13
        }
166
167
17
        for (size_t i = 0; i != batch_size; ++i) {
168
13
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
13
            array_of_data_set[i]->insert(keys[i]);
174
13
        }
175
4
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
4
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
4
        std::vector<KeyType> keys_container;
159
4
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
4
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
10
        for (size_t i = 0; i != batch_size; ++i) {
164
6
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
6
        }
166
167
10
        for (size_t i = 0; i != batch_size; ++i) {
168
6
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
6
            array_of_data_set[i]->insert(keys[i]);
174
6
        }
175
4
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
554
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
554
        std::vector<KeyType> keys_container;
159
554
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
554
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
38.5k
        for (size_t i = 0; i != batch_size; ++i) {
164
37.9k
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
37.9k
        }
166
167
38.5k
        for (size_t i = 0; i != batch_size; ++i) {
168
37.9k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
34.4k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
34.4k
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
34.4k
            }
172
173
37.9k
            array_of_data_set[i]->insert(keys[i]);
174
37.9k
        }
175
554
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
104
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
104
        std::vector<KeyType> keys_container;
159
104
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
104
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
306
        for (size_t i = 0; i != batch_size; ++i) {
164
202
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
202
        }
166
167
306
        for (size_t i = 0; i != batch_size; ++i) {
168
202
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
202
            array_of_data_set[i]->insert(keys[i]);
174
202
        }
175
104
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
5
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
5
        std::vector<KeyType> keys_container;
159
5
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
5
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
35
        for (size_t i = 0; i != batch_size; ++i) {
164
30
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
30
        }
166
167
35
        for (size_t i = 0; i != batch_size; ++i) {
168
30
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
30
            array_of_data_set[i]->insert(keys[i]);
174
30
        }
175
5
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
11
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
11
        std::vector<KeyType> keys_container;
159
11
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
11
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
65
        for (size_t i = 0; i != batch_size; ++i) {
164
54
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
54
        }
166
167
65
        for (size_t i = 0; i != batch_size; ++i) {
168
54
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
54
            array_of_data_set[i]->insert(keys[i]);
174
54
        }
175
11
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
58
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
58
        std::vector<KeyType> keys_container;
159
58
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
58
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
327
        for (size_t i = 0; i != batch_size; ++i) {
164
269
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
269
        }
166
167
327
        for (size_t i = 0; i != batch_size; ++i) {
168
269
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
28
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
28
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
28
            }
172
173
269
            array_of_data_set[i]->insert(keys[i]);
174
269
        }
175
58
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
148
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
148
        std::vector<KeyType> keys_container;
159
148
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
148
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
1.20k
        for (size_t i = 0; i != batch_size; ++i) {
164
1.05k
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
1.05k
        }
166
167
1.20k
        for (size_t i = 0; i != batch_size; ++i) {
168
1.05k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
152
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
152
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
152
            }
172
173
1.05k
            array_of_data_set[i]->insert(keys[i]);
174
1.05k
        }
175
148
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
36
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
36
        std::vector<KeyType> keys_container;
159
36
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
36
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
106
        for (size_t i = 0; i != batch_size; ++i) {
164
70
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
70
        }
166
167
106
        for (size_t i = 0; i != batch_size; ++i) {
168
70
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
169
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch(
170
0
                        keys[i + HASH_MAP_PREFETCH_DIST]);
171
0
            }
172
173
70
            array_of_data_set[i]->insert(keys[i]);
174
70
        }
175
36
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
176
177
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
178
91
               Arena&) const override {
179
91
        auto& rhs_set = this->data(rhs).set;
180
91
        if (rhs_set.size() == 0) return;
181
182
91
        auto& set = this->data(place).set;
183
91
        set.rehash(set.size() + rhs_set.size());
184
185
104
        for (auto elem : rhs_set) {
186
104
            set.insert(elem);
187
104
        }
188
91
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
178
91
               Arena&) const override {
179
91
        auto& rhs_set = this->data(rhs).set;
180
91
        if (rhs_set.size() == 0) return;
181
182
91
        auto& set = this->data(place).set;
183
91
        set.rehash(set.size() + rhs_set.size());
184
185
104
        for (auto elem : rhs_set) {
186
104
            set.insert(elem);
187
104
        }
188
91
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE5mergeEPcPKcRNS_5ArenaE
189
190
    void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns,
191
264
                                Arena&) const override {
192
264
        std::vector<KeyType> keys_container;
193
264
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
194
264
        auto& set = this->data(place).set;
195
196
41.0k
        for (size_t i = 0; i != batch_size; ++i) {
197
40.7k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
198
39.7k
                set.prefetch(keys[i + HASH_MAP_PREFETCH_DIST]);
199
39.7k
            }
200
40.7k
            set.insert(keys[i]);
201
40.7k
        }
202
264
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
191
24
                                Arena&) const override {
192
24
        std::vector<KeyType> keys_container;
193
24
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
194
24
        auto& set = this->data(place).set;
195
196
78
        for (size_t i = 0; i != batch_size; ++i) {
197
54
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
198
0
                set.prefetch(keys[i + HASH_MAP_PREFETCH_DIST]);
199
0
            }
200
54
            set.insert(keys[i]);
201
54
        }
202
24
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
191
173
                                Arena&) const override {
192
173
        std::vector<KeyType> keys_container;
193
173
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
194
173
        auto& set = this->data(place).set;
195
196
792
        for (size_t i = 0; i != batch_size; ++i) {
197
619
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
198
52
                set.prefetch(keys[i + HASH_MAP_PREFETCH_DIST]);
199
52
            }
200
619
            set.insert(keys[i]);
201
619
        }
202
173
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
191
63
                                Arena&) const override {
192
63
        std::vector<KeyType> keys_container;
193
63
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
194
63
        auto& set = this->data(place).set;
195
196
40.1k
        for (size_t i = 0; i != batch_size; ++i) {
197
40.1k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
198
39.6k
                set.prefetch(keys[i + HASH_MAP_PREFETCH_DIST]);
199
39.6k
            }
200
40.1k
            set.insert(keys[i]);
201
40.1k
        }
202
63
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
191
4
                                Arena&) const override {
192
4
        std::vector<KeyType> keys_container;
193
4
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
194
4
        auto& set = this->data(place).set;
195
196
8
        for (size_t i = 0; i != batch_size; ++i) {
197
4
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
198
0
                set.prefetch(keys[i + HASH_MAP_PREFETCH_DIST]);
199
0
            }
200
4
            set.insert(keys[i]);
201
4
        }
202
4
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
203
204
10.7k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
10.7k
        auto& set = this->data(place).set;
206
10.7k
        buf.write_var_uint(set.size());
207
36.8k
        for (const auto& elem : set) {
208
36.8k
            buf.write_binary(elem);
209
36.8k
        }
210
10.7k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
14
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
14
        auto& set = this->data(place).set;
206
14
        buf.write_var_uint(set.size());
207
14
        for (const auto& elem : set) {
208
13
            buf.write_binary(elem);
209
13
        }
210
14
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
6
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
6
        auto& set = this->data(place).set;
206
6
        buf.write_var_uint(set.size());
207
6
        for (const auto& elem : set) {
208
6
            buf.write_binary(elem);
209
6
        }
210
6
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
9.45k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
9.45k
        auto& set = this->data(place).set;
206
9.45k
        buf.write_var_uint(set.size());
207
35.7k
        for (const auto& elem : set) {
208
35.7k
            buf.write_binary(elem);
209
35.7k
        }
210
9.45k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
78
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
78
        auto& set = this->data(place).set;
206
78
        buf.write_var_uint(set.size());
207
78
        for (const auto& elem : set) {
208
78
            buf.write_binary(elem);
209
78
        }
210
78
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
11
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
11
        auto& set = this->data(place).set;
206
11
        buf.write_var_uint(set.size());
207
24
        for (const auto& elem : set) {
208
24
            buf.write_binary(elem);
209
24
        }
210
11
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
10
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
10
        auto& set = this->data(place).set;
206
10
        buf.write_var_uint(set.size());
207
20
        for (const auto& elem : set) {
208
20
            buf.write_binary(elem);
209
20
        }
210
10
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
1.01k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
1.01k
        auto& set = this->data(place).set;
206
1.01k
        buf.write_var_uint(set.size());
207
1.01k
        for (const auto& elem : set) {
208
742
            buf.write_binary(elem);
209
742
        }
210
1.01k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
2
        auto& set = this->data(place).set;
206
2
        buf.write_var_uint(set.size());
207
12
        for (const auto& elem : set) {
208
12
            buf.write_binary(elem);
209
12
        }
210
2
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
116
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
116
        auto& set = this->data(place).set;
206
116
        buf.write_var_uint(set.size());
207
119
        for (const auto& elem : set) {
208
119
            buf.write_binary(elem);
209
119
        }
210
116
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
1
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
1
        auto& set = this->data(place).set;
206
1
        buf.write_var_uint(set.size());
207
12
        for (const auto& elem : set) {
208
12
            buf.write_binary(elem);
209
12
        }
210
1
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
204
42
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
205
42
        auto& set = this->data(place).set;
206
42
        buf.write_var_uint(set.size());
207
68
        for (const auto& elem : set) {
208
68
            buf.write_binary(elem);
209
68
        }
210
42
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE9serializeEPKcRNS_14BufferWritableE
211
212
    void deserialize_and_merge(AggregateDataPtr __restrict place, AggregateDataPtr __restrict rhs,
213
10.5k
                               BufferReadable& buf, Arena&) const override {
214
10.5k
        auto& set = this->data(place).set;
215
10.5k
        UInt64 size;
216
10.5k
        buf.read_var_uint(size);
217
218
10.5k
        set.rehash(size + set.size());
219
220
47.2k
        for (size_t i = 0; i < size; ++i) {
221
36.6k
            KeyType ref;
222
36.6k
            buf.read_binary(ref);
223
36.6k
            set.insert(ref);
224
36.6k
        }
225
10.5k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
14
                               BufferReadable& buf, Arena&) const override {
214
14
        auto& set = this->data(place).set;
215
14
        UInt64 size;
216
14
        buf.read_var_uint(size);
217
218
14
        set.rehash(size + set.size());
219
220
27
        for (size_t i = 0; i < size; ++i) {
221
13
            KeyType ref;
222
13
            buf.read_binary(ref);
223
13
            set.insert(ref);
224
13
        }
225
14
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
6
                               BufferReadable& buf, Arena&) const override {
214
6
        auto& set = this->data(place).set;
215
6
        UInt64 size;
216
6
        buf.read_var_uint(size);
217
218
6
        set.rehash(size + set.size());
219
220
12
        for (size_t i = 0; i < size; ++i) {
221
6
            KeyType ref;
222
6
            buf.read_binary(ref);
223
6
            set.insert(ref);
224
6
        }
225
6
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
9.41k
                               BufferReadable& buf, Arena&) const override {
214
9.41k
        auto& set = this->data(place).set;
215
9.41k
        UInt64 size;
216
9.41k
        buf.read_var_uint(size);
217
218
9.41k
        set.rehash(size + set.size());
219
220
45.0k
        for (size_t i = 0; i < size; ++i) {
221
35.6k
            KeyType ref;
222
35.6k
            buf.read_binary(ref);
223
35.6k
            set.insert(ref);
224
35.6k
        }
225
9.41k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
78
                               BufferReadable& buf, Arena&) const override {
214
78
        auto& set = this->data(place).set;
215
78
        UInt64 size;
216
78
        buf.read_var_uint(size);
217
218
78
        set.rehash(size + set.size());
219
220
156
        for (size_t i = 0; i < size; ++i) {
221
78
            KeyType ref;
222
78
            buf.read_binary(ref);
223
78
            set.insert(ref);
224
78
        }
225
78
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
11
                               BufferReadable& buf, Arena&) const override {
214
11
        auto& set = this->data(place).set;
215
11
        UInt64 size;
216
11
        buf.read_var_uint(size);
217
218
11
        set.rehash(size + set.size());
219
220
35
        for (size_t i = 0; i < size; ++i) {
221
24
            KeyType ref;
222
24
            buf.read_binary(ref);
223
24
            set.insert(ref);
224
24
        }
225
11
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
10
                               BufferReadable& buf, Arena&) const override {
214
10
        auto& set = this->data(place).set;
215
10
        UInt64 size;
216
10
        buf.read_var_uint(size);
217
218
10
        set.rehash(size + set.size());
219
220
30
        for (size_t i = 0; i < size; ++i) {
221
20
            KeyType ref;
222
20
            buf.read_binary(ref);
223
20
            set.insert(ref);
224
20
        }
225
10
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
894
                               BufferReadable& buf, Arena&) const override {
214
894
        auto& set = this->data(place).set;
215
894
        UInt64 size;
216
894
        buf.read_var_uint(size);
217
218
894
        set.rehash(size + set.size());
219
220
1.49k
        for (size_t i = 0; i < size; ++i) {
221
602
            KeyType ref;
222
602
            buf.read_binary(ref);
223
602
            set.insert(ref);
224
602
        }
225
894
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
2
                               BufferReadable& buf, Arena&) const override {
214
2
        auto& set = this->data(place).set;
215
2
        UInt64 size;
216
2
        buf.read_var_uint(size);
217
218
2
        set.rehash(size + set.size());
219
220
14
        for (size_t i = 0; i < size; ++i) {
221
12
            KeyType ref;
222
12
            buf.read_binary(ref);
223
12
            set.insert(ref);
224
12
        }
225
2
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
116
                               BufferReadable& buf, Arena&) const override {
214
116
        auto& set = this->data(place).set;
215
116
        UInt64 size;
216
116
        buf.read_var_uint(size);
217
218
116
        set.rehash(size + set.size());
219
220
235
        for (size_t i = 0; i < size; ++i) {
221
119
            KeyType ref;
222
119
            buf.read_binary(ref);
223
119
            set.insert(ref);
224
119
        }
225
116
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
1
                               BufferReadable& buf, Arena&) const override {
214
1
        auto& set = this->data(place).set;
215
1
        UInt64 size;
216
1
        buf.read_var_uint(size);
217
218
1
        set.rehash(size + set.size());
219
220
13
        for (size_t i = 0; i < size; ++i) {
221
12
            KeyType ref;
222
12
            buf.read_binary(ref);
223
12
            set.insert(ref);
224
12
        }
225
1
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
213
42
                               BufferReadable& buf, Arena&) const override {
214
42
        auto& set = this->data(place).set;
215
42
        UInt64 size;
216
42
        buf.read_var_uint(size);
217
218
42
        set.rehash(size + set.size());
219
220
110
        for (size_t i = 0; i < size; ++i) {
221
68
            KeyType ref;
222
68
            buf.read_binary(ref);
223
68
            set.insert(ref);
224
68
        }
225
42
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
226
227
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
228
91
                     Arena&) const override {
229
91
        auto& set = this->data(place).set;
230
91
        UInt64 size;
231
91
        buf.read_var_uint(size);
232
233
91
        set.rehash(size + set.size());
234
235
195
        for (size_t i = 0; i < size; ++i) {
236
104
            KeyType ref;
237
104
            buf.read_binary(ref);
238
104
            set.insert(ref);
239
104
        }
240
91
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
228
91
                     Arena&) const override {
229
91
        auto& set = this->data(place).set;
230
91
        UInt64 size;
231
91
        buf.read_var_uint(size);
232
233
91
        set.rehash(size + set.size());
234
235
195
        for (size_t i = 0; i < size; ++i) {
236
104
            KeyType ref;
237
104
            buf.read_binary(ref);
238
104
            set.insert(ref);
239
104
        }
240
91
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
241
242
10.5k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
10.5k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
10.5k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
11
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
11
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
11
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
58
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
58
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
58
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
9.37k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
9.37k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
9.37k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
207
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
207
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
207
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
10
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
10
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
10
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
11
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
11
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
11
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
17
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
17
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
17
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
16
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
16
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
16
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
724
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
724
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
724
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
2
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
2
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
2
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
95
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
95
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
95
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
1
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
1
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
1
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
242
42
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
243
42
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
244
42
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE18insert_result_intoEPKcRNS_7IColumnE
245
};
246
247
} // namespace doris
248
249
#include "common/compile_check_end.h"