Coverage Report

Created: 2026-05-31 14:31

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_decimal.h"
34
#include "core/column/column_vector.h"
35
#include "core/data_type/data_type_number.h"
36
#include "core/data_type/primitive_type.h"
37
#include "core/string_buffer.hpp"
38
#include "core/string_ref.h"
39
#include "core/types.h"
40
#include "core/uint128.h"
41
#include "exec/common/hash_table/hash.h"
42
#include "exec/common/hash_table/phmap_fwd_decl.h"
43
#include "exprs/aggregate/aggregate_function.h"
44
#include "util/var_int.h"
45
46
template <typename T>
47
struct HashCRC32;
48
49
namespace doris {
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
9.46k
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
9.46k
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
9.46k
        return UInt128 {hash_value.high64, hash_value.low64};
73
9.46k
    }
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE7get_keyERKNS_9StringRefE
Line
Count
Source
70
9.43k
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
9.43k
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
9.43k
        return UInt128 {hash_value.high64, hash_value.low64};
73
9.43k
    }
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE41EE7get_keyERKNS_9StringRefE
Line
Count
Source
70
24
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
24
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
24
        return UInt128 {hash_value.high64, hash_value.low64};
73
24
    }
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
15
    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
4
    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
10
    static String get_name() { return "multi_distinct"; }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE35EE8get_nameB5cxx11Ev
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE8get_nameB5cxx11Ev
Line
Count
Source
82
1
    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
8
    void reset() { set.clear(); }
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE2EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE3EE5resetEv
Unexecuted instantiation: _ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE4EE5resetEv
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE5EE5resetEv
Line
Count
Source
84
5
    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
45
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
45
        if constexpr (is_string_type(T) || is_varbinary(T)) {
96
0
            StringRef value = column.get_data_at(row_num);
97
0
            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
31
        } else {
101
31
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
31
                                        TypeCheckOnRelease::DISABLE>(column)
103
31
                                    .get_data()[row_num]);
104
31
        }
105
45
    }
_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
12
    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
12
        } else {
101
12
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
12
                                        TypeCheckOnRelease::DISABLE>(column)
103
12
                                    .get_data()[row_num]);
104
12
        }
105
12
    }
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS2_6EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS2_7EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS2_28EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS2_29EEEE3addERS4_RKNS_7IColumnEm
_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
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS2_10EEEE3addERS4_RKNS_7IColumnEm
_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
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS2_25EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS2_26EEEE3addERS4_RKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS2_42EEEE3addERS4_RKNS_7IColumnEm
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
134
            : 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
6
            : 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
30
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
36
            : 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
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
1
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
33
            : 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
4
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
16
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
122
123
15
    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
4
    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
10
    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
1
    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
572
    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
18
    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
117
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE15get_return_typeEv
Line
Count
Source
125
204
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE15get_return_typeEv
Line
Count
Source
125
17
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE15get_return_typeEv
Line
Count
Source
125
11
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE15get_return_typeEv
Line
Count
Source
125
156
    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
6
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE15get_return_typeEv
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE15get_return_typeEv
Line
Count
Source
125
32
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
126
127
8
    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
5
    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
45
             Arena&) const override {
131
45
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
45
    }
_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
12
             Arena&) const override {
131
12
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
12
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_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
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_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
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
133
134
    static ALWAYS_INLINE const KeyType* get_keys(std::vector<KeyType>& keys_container,
135
559
                                                 const IColumn& column, size_t batch_size) {
136
559
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
140
            keys_container.resize(batch_size);
138
9.86k
            for (size_t i = 0; i != batch_size; ++i) {
139
9.72k
                StringRef value = column.get_data_at(i);
140
9.72k
                keys_container[i] = Data::get_key(value);
141
9.72k
            }
142
140
            return keys_container.data();
143
140
        } 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
419
        } else {
150
419
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
419
                    .get_data()
152
419
                    .data();
153
419
        }
154
559
    }
_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
12
                                                 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
12
        } else {
150
12
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
12
                    .get_data()
152
12
                    .data();
153
12
        }
154
12
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE8get_keysERSt6vectorIsSaIsEERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE8get_keysERSt6vectorIiSaIiEERKNS_7IColumnEm
Line
Count
Source
135
172
                                                 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
172
        } else {
150
172
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
172
                    .get_data()
152
172
                    .data();
153
172
        }
154
172
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE8get_keysERSt6vectorIlSaIlEERKNS_7IColumnEm
Line
Count
Source
135
111
                                                 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
111
        } else {
150
111
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
111
                    .get_data()
152
111
                    .data();
153
111
        }
154
111
    }
_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
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE8get_keysERSt6vectorINS_7DecimalIlEESaIS7_EERKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE8get_keysERSt6vectorINS_12Decimal128V3ESaIS6_EERKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE8get_keysERSt6vectorINS_7DecimalIN4wide7integerILm256EiEEEESaISA_EERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE8get_keysERSt6vectorIN4wide7integerILm128EjEESaIS8_EERKNS_7IColumnEm
Line
Count
Source
135
116
                                                 const IColumn& column, size_t batch_size) {
136
116
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
116
            keys_container.resize(batch_size);
138
9.81k
            for (size_t i = 0; i != batch_size; ++i) {
139
9.70k
                StringRef value = column.get_data_at(i);
140
9.70k
                keys_container[i] = Data::get_key(value);
141
9.70k
            }
142
116
            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
116
    }
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
116
                                                 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
116
        } else {
150
116
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
116
                    .get_data()
152
116
                    .data();
153
116
        }
154
116
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE8get_keysERSt6vectorINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEESaIS8_EERKNS_7IColumnEm
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE8get_keysERSt6vectorINS_16TimestampTzValueESaIS6_EERKNS_7IColumnEm
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE8get_keysERSt6vectorIN4wide7integerILm128EjEESaIS8_EERKNS_7IColumnEm
Line
Count
Source
135
24
                                                 const IColumn& column, size_t batch_size) {
136
24
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
24
            keys_container.resize(batch_size);
138
48
            for (size_t i = 0; i != batch_size; ++i) {
139
24
                StringRef value = column.get_data_at(i);
140
24
                keys_container[i] = Data::get_key(value);
141
24
            }
142
24
            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
24
    }
155
156
    void add_batch(size_t batch_size, AggregateDataPtr* places, size_t place_offset,
157
252
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
252
        std::vector<KeyType> keys_container;
159
252
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
252
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
38.2k
        for (size_t i = 0; i != batch_size; ++i) {
164
38.0k
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
38.0k
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
252
        std::vector<size_t> hash_values(batch_size);
169
38.2k
        for (size_t i = 0; i < batch_size; ++i) {
170
38.0k
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
38.0k
        }
172
173
38.2k
        for (size_t i = 0; i != batch_size; ++i) {
174
38.0k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
35.4k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
35.4k
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
35.4k
            }
178
179
38.0k
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
38.0k
        }
181
252
    }
_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
        // Precompute hash values to avoid double computation in prefetch + insert
168
4
        std::vector<size_t> hash_values(batch_size);
169
17
        for (size_t i = 0; i < batch_size; ++i) {
170
13
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
13
        }
172
173
17
        for (size_t i = 0; i != batch_size; ++i) {
174
13
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
0
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
0
            }
178
179
13
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
13
        }
181
4
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
110
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
110
        std::vector<KeyType> keys_container;
159
110
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
110
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
37.0k
        for (size_t i = 0; i != batch_size; ++i) {
164
36.9k
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
36.9k
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
110
        std::vector<size_t> hash_values(batch_size);
169
37.0k
        for (size_t i = 0; i < batch_size; ++i) {
170
36.9k
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
36.9k
        }
172
173
37.0k
        for (size_t i = 0; i != batch_size; ++i) {
174
36.9k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
35.2k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
35.2k
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
35.2k
            }
178
179
36.9k
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
36.9k
        }
181
110
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
6
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
6
        std::vector<KeyType> keys_container;
159
6
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
6
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
25
        for (size_t i = 0; i != batch_size; ++i) {
164
19
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
19
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
6
        std::vector<size_t> hash_values(batch_size);
169
25
        for (size_t i = 0; i < batch_size; ++i) {
170
19
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
19
        }
172
173
25
        for (size_t i = 0; i != batch_size; ++i) {
174
19
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
0
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
0
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
0
            }
178
179
19
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
19
        }
181
6
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
16
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
16
        std::vector<KeyType> keys_container;
159
16
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
16
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
121
        for (size_t i = 0; i != batch_size; ++i) {
164
105
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
105
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
16
        std::vector<size_t> hash_values(batch_size);
169
121
        for (size_t i = 0; i < batch_size; ++i) {
170
105
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
105
        }
172
173
121
        for (size_t i = 0; i != batch_size; ++i) {
174
105
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
27
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
27
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
27
            }
178
179
105
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
105
        }
181
16
    }
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
116
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
116
        std::vector<KeyType> keys_container;
159
116
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
116
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
1.08k
        for (size_t i = 0; i != batch_size; ++i) {
164
965
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
965
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
116
        std::vector<size_t> hash_values(batch_size);
169
1.08k
        for (size_t i = 0; i < batch_size; ++i) {
170
965
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
965
        }
172
173
1.08k
        for (size_t i = 0; i != batch_size; ++i) {
174
965
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
152
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
152
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
152
            }
178
179
965
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
965
        }
181
116
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
182
183
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
184
0
               Arena&) const override {
185
0
        auto& rhs_set = this->data(rhs).set;
186
0
        if (rhs_set.size() == 0) return;
187
188
0
        auto& set = this->data(place).set;
189
0
        set.rehash(set.size() + rhs_set.size());
190
191
0
        for (auto elem : rhs_set) {
192
0
            set.insert(elem);
193
0
        }
194
0
    }
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
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE5mergeEPcPKcRNS_5ArenaE
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
195
196
    void add_batch_single_place(size_t batch_size, AggregateDataPtr place, const IColumn** columns,
197
307
                                Arena&) const override {
198
307
        std::vector<KeyType> keys_container;
199
307
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
307
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
307
        std::vector<size_t> hash_values(batch_size);
204
20.6k
        for (size_t i = 0; i < batch_size; ++i) {
205
20.3k
            hash_values[i] = set.hash(keys[i]);
206
20.3k
        }
207
208
20.6k
        for (size_t i = 0; i != batch_size; ++i) {
209
20.3k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
16.5k
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
16.5k
            }
212
20.3k
            set.emplace_with_hash(hash_values[i], keys[i]);
213
20.3k
        }
214
307
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
12
                                Arena&) const override {
198
12
        std::vector<KeyType> keys_container;
199
12
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
12
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
12
        std::vector<size_t> hash_values(batch_size);
204
39
        for (size_t i = 0; i < batch_size; ++i) {
205
27
            hash_values[i] = set.hash(keys[i]);
206
27
        }
207
208
39
        for (size_t i = 0; i != batch_size; ++i) {
209
27
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
0
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
0
            }
212
27
            set.emplace_with_hash(hash_values[i], keys[i]);
213
27
        }
214
12
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
62
                                Arena&) const override {
198
62
        std::vector<KeyType> keys_container;
199
62
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
62
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
62
        std::vector<size_t> hash_values(batch_size);
204
1.32k
        for (size_t i = 0; i < batch_size; ++i) {
205
1.26k
            hash_values[i] = set.hash(keys[i]);
206
1.26k
        }
207
208
1.36k
        for (size_t i = 0; i != batch_size; ++i) {
209
1.29k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
458
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
458
            }
212
1.29k
            set.emplace_with_hash(hash_values[i], keys[i]);
213
1.29k
        }
214
62
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
105
                                Arena&) const override {
198
105
        std::vector<KeyType> keys_container;
199
105
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
105
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
105
        std::vector<size_t> hash_values(batch_size);
204
9.37k
        for (size_t i = 0; i < batch_size; ++i) {
205
9.27k
            hash_values[i] = set.hash(keys[i]);
206
9.27k
        }
207
208
9.34k
        for (size_t i = 0; i != batch_size; ++i) {
209
9.23k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
7.93k
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
7.93k
            }
212
9.23k
            set.emplace_with_hash(hash_values[i], keys[i]);
213
9.23k
        }
214
105
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
4
                                Arena&) const override {
198
4
        std::vector<KeyType> keys_container;
199
4
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
4
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
4
        std::vector<size_t> hash_values(batch_size);
204
8
        for (size_t i = 0; i < batch_size; ++i) {
205
4
            hash_values[i] = set.hash(keys[i]);
206
4
        }
207
208
8
        for (size_t i = 0; i != batch_size; ++i) {
209
4
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
0
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
0
            }
212
4
            set.emplace_with_hash(hash_values[i], keys[i]);
213
4
        }
214
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
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
100
                                Arena&) const override {
198
100
        std::vector<KeyType> keys_container;
199
100
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
100
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
100
        std::vector<size_t> hash_values(batch_size);
204
9.90k
        for (size_t i = 0; i < batch_size; ++i) {
205
9.80k
            hash_values[i] = set.hash(keys[i]);
206
9.80k
        }
207
208
9.84k
        for (size_t i = 0; i != batch_size; ++i) {
209
9.74k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
8.15k
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
8.15k
            }
212
9.74k
            set.emplace_with_hash(hash_values[i], keys[i]);
213
9.74k
        }
214
100
    }
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
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
24
                                Arena&) const override {
198
24
        std::vector<KeyType> keys_container;
199
24
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
24
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
24
        std::vector<size_t> hash_values(batch_size);
204
48
        for (size_t i = 0; i < batch_size; ++i) {
205
24
            hash_values[i] = set.hash(keys[i]);
206
24
        }
207
208
48
        for (size_t i = 0; i != batch_size; ++i) {
209
24
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
0
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
0
            }
212
24
            set.emplace_with_hash(hash_values[i], keys[i]);
213
24
        }
214
24
    }
215
216
8.90k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
8.90k
        auto& set = this->data(place).set;
218
8.90k
        buf.write_var_uint(set.size());
219
35.3k
        for (const auto& elem : set) {
220
35.3k
            buf.write_binary(elem);
221
35.3k
        }
222
8.90k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
14
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
14
        auto& set = this->data(place).set;
218
14
        buf.write_var_uint(set.size());
219
14
        for (const auto& elem : set) {
220
13
            buf.write_binary(elem);
221
13
        }
222
14
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
8.54k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
8.54k
        auto& set = this->data(place).set;
218
8.54k
        buf.write_var_uint(set.size());
219
34.9k
        for (const auto& elem : set) {
220
34.9k
            buf.write_binary(elem);
221
34.9k
        }
222
8.54k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
14
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
14
        auto& set = this->data(place).set;
218
14
        buf.write_var_uint(set.size());
219
14
        for (const auto& elem : set) {
220
13
            buf.write_binary(elem);
221
13
        }
222
14
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
58
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
58
        auto& set = this->data(place).set;
218
58
        buf.write_var_uint(set.size());
219
100
        for (const auto& elem : set) {
220
100
            buf.write_binary(elem);
221
100
        }
222
58
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
2
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
2
        auto& set = this->data(place).set;
218
2
        buf.write_var_uint(set.size());
219
12
        for (const auto& elem : set) {
220
12
            buf.write_binary(elem);
221
12
        }
222
2
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE8ENS_30AggregateFunctionUniqExactDataILS1_8EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE9ENS_30AggregateFunctionUniqExactDataILS1_9EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE25ENS_30AggregateFunctionUniqExactDataILS1_25EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
244
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
244
        auto& set = this->data(place).set;
218
244
        buf.write_var_uint(set.size());
219
244
        for (const auto& elem : set) {
220
244
            buf.write_binary(elem);
221
244
        }
222
244
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
216
24
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
24
        auto& set = this->data(place).set;
218
24
        buf.write_var_uint(set.size());
219
24
        for (const auto& elem : set) {
220
24
            buf.write_binary(elem);
221
24
        }
222
24
    }
223
224
    void deserialize_and_merge(AggregateDataPtr __restrict place, AggregateDataPtr __restrict rhs,
225
8.90k
                               BufferReadable& buf, Arena&) const override {
226
8.90k
        auto& set = this->data(place).set;
227
8.90k
        UInt64 size;
228
8.90k
        buf.read_var_uint(size);
229
230
8.90k
        set.rehash(size + set.size());
231
232
44.2k
        for (size_t i = 0; i < size; ++i) {
233
35.3k
            KeyType ref;
234
35.3k
            buf.read_binary(ref);
235
35.3k
            set.insert(ref);
236
35.3k
        }
237
8.90k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
14
                               BufferReadable& buf, Arena&) const override {
226
14
        auto& set = this->data(place).set;
227
14
        UInt64 size;
228
14
        buf.read_var_uint(size);
229
230
14
        set.rehash(size + set.size());
231
232
27
        for (size_t i = 0; i < size; ++i) {
233
13
            KeyType ref;
234
13
            buf.read_binary(ref);
235
13
            set.insert(ref);
236
13
        }
237
14
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
8.54k
                               BufferReadable& buf, Arena&) const override {
226
8.54k
        auto& set = this->data(place).set;
227
8.54k
        UInt64 size;
228
8.54k
        buf.read_var_uint(size);
229
230
8.54k
        set.rehash(size + set.size());
231
232
43.4k
        for (size_t i = 0; i < size; ++i) {
233
34.9k
            KeyType ref;
234
34.9k
            buf.read_binary(ref);
235
34.9k
            set.insert(ref);
236
34.9k
        }
237
8.54k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
14
                               BufferReadable& buf, Arena&) const override {
226
14
        auto& set = this->data(place).set;
227
14
        UInt64 size;
228
14
        buf.read_var_uint(size);
229
230
14
        set.rehash(size + set.size());
231
232
27
        for (size_t i = 0; i < size; ++i) {
233
13
            KeyType ref;
234
13
            buf.read_binary(ref);
235
13
            set.insert(ref);
236
13
        }
237
14
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
58
                               BufferReadable& buf, Arena&) const override {
226
58
        auto& set = this->data(place).set;
227
58
        UInt64 size;
228
58
        buf.read_var_uint(size);
229
230
58
        set.rehash(size + set.size());
231
232
158
        for (size_t i = 0; i < size; ++i) {
233
100
            KeyType ref;
234
100
            buf.read_binary(ref);
235
100
            set.insert(ref);
236
100
        }
237
58
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
2
                               BufferReadable& buf, Arena&) const override {
226
2
        auto& set = this->data(place).set;
227
2
        UInt64 size;
228
2
        buf.read_var_uint(size);
229
230
2
        set.rehash(size + set.size());
231
232
14
        for (size_t i = 0; i < size; ++i) {
233
12
            KeyType ref;
234
12
            buf.read_binary(ref);
235
12
            set.insert(ref);
236
12
        }
237
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
225
244
                               BufferReadable& buf, Arena&) const override {
226
244
        auto& set = this->data(place).set;
227
244
        UInt64 size;
228
244
        buf.read_var_uint(size);
229
230
244
        set.rehash(size + set.size());
231
232
488
        for (size_t i = 0; i < size; ++i) {
233
244
            KeyType ref;
234
244
            buf.read_binary(ref);
235
244
            set.insert(ref);
236
244
        }
237
244
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
225
24
                               BufferReadable& buf, Arena&) const override {
226
24
        auto& set = this->data(place).set;
227
24
        UInt64 size;
228
24
        buf.read_var_uint(size);
229
230
24
        set.rehash(size + set.size());
231
232
48
        for (size_t i = 0; i < size; ++i) {
233
24
            KeyType ref;
234
24
            buf.read_binary(ref);
235
24
            set.insert(ref);
236
24
        }
237
24
    }
238
239
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
240
0
                     Arena&) const override {
241
0
        auto& set = this->data(place).set;
242
0
        UInt64 size;
243
0
        buf.read_var_uint(size);
244
245
0
        set.rehash(size + set.size());
246
247
0
        for (size_t i = 0; i < size; ++i) {
248
0
            KeyType ref;
249
0
            buf.read_binary(ref);
250
0
            set.insert(ref);
251
0
        }
252
0
    }
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
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
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
253
254
8.78k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
8.78k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
8.78k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
11
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
11
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
11
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
6
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
6
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
6
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
8.38k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
8.38k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
8.38k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
147
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
147
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
147
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
13
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
13
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
13
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE28ENS_30AggregateFunctionUniqExactDataILS1_28EEEE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE29ENS_30AggregateFunctionUniqExactDataILS1_29EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE30ENS_30AggregateFunctionUniqExactDataILS1_30EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
17
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
17
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
17
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE35ENS_30AggregateFunctionUniqExactDataILS1_35EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE10ENS_30AggregateFunctionUniqExactDataILS1_10EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
161
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
161
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
161
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE17ENS_30AggregateFunctionUniqExactDataILS1_17EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
2
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
2
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
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
254
35
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
35
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
35
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
8
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
8
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
8
    }
257
};
258
259
} // namespace doris