Coverage Report

Created: 2026-06-12 03:18

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
112
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
112
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
112
        return UInt128 {hash_value.high64, hash_value.low64};
73
112
    }
_ZN5doris30AggregateFunctionUniqExactDataILNS_13PrimitiveTypeE10EE7get_keyERKNS_9StringRefE
Line
Count
Source
70
112
    static UInt128 ALWAYS_INLINE get_key(const StringRef& value) {
71
112
        auto hash_value = XXH_INLINE_XXH128(value.data, value.size, 0);
72
112
        return UInt128 {hash_value.high64, hash_value.low64};
73
112
    }
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
16
    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
5
    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
44
    static void ALWAYS_INLINE add(Data& data, const IColumn& column, size_t row_num) {
95
44
        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
30
        } else {
101
30
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
30
                                        TypeCheckOnRelease::DISABLE>(column)
103
30
                                    .get_data()[row_num]);
104
30
        }
105
44
    }
_ZN5doris6detail8OneAdderILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS2_2EEEE3addERS4_RKNS_7IColumnEm
Line
Count
Source
94
1
    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
1
        } else {
101
1
            data.set.insert(assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&,
102
1
                                        TypeCheckOnRelease::DISABLE>(column)
103
1
                                    .get_data()[row_num]);
104
1
        }
105
1
    }
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
99
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
3
            : 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
24
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
28
            : 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
17
            : 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
3
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
121
11
            : IAggregateFunctionDataHelper<Data, AggregateFunctionUniq<T, Data>>(argument_types_) {}
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEEC2ERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS9_EE
122
123
16
    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
5
    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
291
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE15get_return_typeEv
Line
Count
Source
125
6
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE15get_return_typeEv
Line
Count
Source
125
38
    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
48
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE15get_return_typeEv
Line
Count
Source
125
98
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE15get_return_typeEv
Line
Count
Source
125
12
    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
32
    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
5
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE15get_return_typeEv
Line
Count
Source
125
33
    DataTypePtr get_return_type() const override { return std::make_shared<DataTypeInt64>(); }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE15get_return_typeEv
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
44
             Arena&) const override {
131
44
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
44
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
130
1
             Arena&) const override {
131
1
        detail::OneAdder<T, Data>::add(this->data(place), *columns[0], row_num);
132
1
    }
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
381
                                                 const IColumn& column, size_t batch_size) {
136
381
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
16
            keys_container.resize(batch_size);
138
128
            for (size_t i = 0; i != batch_size; ++i) {
139
112
                StringRef value = column.get_data_at(i);
140
112
                keys_container[i] = Data::get_key(value);
141
112
            }
142
16
            return keys_container.data();
143
16
        } 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
365
        } else {
150
365
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
365
                    .get_data()
152
365
                    .data();
153
365
        }
154
381
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE8get_keysERSt6vectorIhSaIhEERKNS_7IColumnEm
Line
Count
Source
135
8
                                                 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
8
        } else {
150
8
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
8
                    .get_data()
152
8
                    .data();
153
8
        }
154
8
    }
_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
182
                                                 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
182
        } else {
150
182
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
182
                    .get_data()
152
182
                    .data();
153
182
        }
154
182
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE8get_keysERSt6vectorIlSaIlEERKNS_7IColumnEm
Line
Count
Source
135
34
                                                 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
34
        } else {
150
34
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
34
                    .get_data()
152
34
                    .data();
153
34
        }
154
34
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE8get_keysERSt6vectorInSaInEERKNS_7IColumnEm
Line
Count
Source
135
2
                                                 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
2
        } else {
150
2
            return assert_cast<const typename PrimitiveTypeTraits<T>::ColumnType&>(column)
151
2
                    .get_data()
152
2
                    .data();
153
2
        }
154
2
    }
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
16
                                                 const IColumn& column, size_t batch_size) {
136
16
        if constexpr (is_string_type(T) || is_varbinary(T)) {
137
16
            keys_container.resize(batch_size);
138
128
            for (size_t i = 0; i != batch_size; ++i) {
139
112
                StringRef value = column.get_data_at(i);
140
112
                keys_container[i] = Data::get_key(value);
141
112
            }
142
16
            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
16
    }
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
    }
_ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE8get_keysERSt6vectorINS_11DateV2ValueINS_19DateTimeV2ValueTypeEEESaIS8_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
    }
Unexecuted instantiation: _ZN5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE8get_keysERSt6vectorINS_16TimestampTzValueESaIS6_EERKNS_7IColumnEm
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
327
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
327
        std::vector<KeyType> keys_container;
159
327
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
327
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
38.3k
        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
        // Precompute hash values to avoid double computation in prefetch + insert
168
327
        std::vector<size_t> hash_values(batch_size);
169
38.3k
        for (size_t i = 0; i < batch_size; ++i) {
170
37.9k
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
37.9k
        }
172
173
38.3k
        for (size_t i = 0; i != batch_size; ++i) {
174
37.9k
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
175
34.3k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
34.3k
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
34.3k
            }
178
179
37.9k
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
37.9k
        }
181
327
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
8
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
8
        std::vector<KeyType> keys_container;
159
8
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
8
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
22
        for (size_t i = 0; i != batch_size; ++i) {
164
14
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
14
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
8
        std::vector<size_t> hash_values(batch_size);
169
22
        for (size_t i = 0; i < batch_size; ++i) {
170
14
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
14
        }
172
173
22
        for (size_t i = 0; i != batch_size; ++i) {
174
14
            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
14
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
14
        }
181
8
    }
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
179
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
179
        std::vector<KeyType> keys_container;
159
179
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
179
        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
179
        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
34.1k
                array_of_data_set[i + HASH_MAP_PREFETCH_DIST]->prefetch_hash(
176
34.1k
                        hash_values[i + HASH_MAP_PREFETCH_DIST]);
177
34.1k
            }
178
179
36.9k
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
36.9k
        }
181
179
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE9add_batchEmPPcmPPKNS_7IColumnERNS_5ArenaEb
Line
Count
Source
157
10
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
10
        std::vector<KeyType> keys_container;
159
10
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
10
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
29
        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
10
        std::vector<size_t> hash_values(batch_size);
169
29
        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
29
        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
10
    }
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
14
                   const IColumn** columns, Arena&, bool /*agg_many*/) const override {
158
14
        std::vector<KeyType> keys_container;
159
14
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
160
161
14
        std::vector<typename Data::Set*> array_of_data_set(batch_size);
162
163
99
        for (size_t i = 0; i != batch_size; ++i) {
164
85
            array_of_data_set[i] = &(this->data(places[i] + place_offset).set);
165
85
        }
166
167
        // Precompute hash values to avoid double computation in prefetch + insert
168
14
        std::vector<size_t> hash_values(batch_size);
169
99
        for (size_t i = 0; i < batch_size; ++i) {
170
85
            hash_values[i] = array_of_data_set[i]->hash(keys[i]);
171
85
        }
172
173
99
        for (size_t i = 0; i != batch_size; ++i) {
174
85
            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
85
            array_of_data_set[i]->emplace_with_hash(hash_values[i], keys[i]);
180
85
        }
181
14
    }
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
54
                                Arena&) const override {
198
54
        std::vector<KeyType> keys_container;
199
54
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
54
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
54
        std::vector<size_t> hash_values(batch_size);
204
243
        for (size_t i = 0; i < batch_size; ++i) {
205
189
            hash_values[i] = set.hash(keys[i]);
206
189
        }
207
208
243
        for (size_t i = 0; i != batch_size; ++i) {
209
189
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
18
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
18
            }
212
189
            set.emplace_with_hash(hash_values[i], keys[i]);
213
189
        }
214
54
    }
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
3
                                Arena&) const override {
198
3
        std::vector<KeyType> keys_container;
199
3
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
3
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
3
        std::vector<size_t> hash_values(batch_size);
204
30
        for (size_t i = 0; i < batch_size; ++i) {
205
27
            hash_values[i] = set.hash(keys[i]);
206
27
        }
207
208
30
        for (size_t i = 0; i != batch_size; ++i) {
209
27
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
9
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
9
            }
212
27
            set.emplace_with_hash(hash_values[i], keys[i]);
213
27
        }
214
3
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE22add_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
90
        for (size_t i = 0; i < batch_size; ++i) {
205
66
            hash_values[i] = set.hash(keys[i]);
206
66
        }
207
208
90
        for (size_t i = 0; i != batch_size; ++i) {
209
66
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
0
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
0
            }
212
66
            set.emplace_with_hash(hash_values[i], keys[i]);
213
66
        }
214
24
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
2
                                Arena&) const override {
198
2
        std::vector<KeyType> keys_container;
199
2
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
2
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
2
        std::vector<size_t> hash_values(batch_size);
204
6
        for (size_t i = 0; i < batch_size; ++i) {
205
4
            hash_values[i] = set.hash(keys[i]);
206
4
        }
207
208
6
        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
2
    }
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
2
                                Arena&) const override {
198
2
        std::vector<KeyType> keys_container;
199
2
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
2
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
2
        std::vector<size_t> hash_values(batch_size);
204
29
        for (size_t i = 0; i < batch_size; ++i) {
205
27
            hash_values[i] = set.hash(keys[i]);
206
27
        }
207
208
29
        for (size_t i = 0; i != batch_size; ++i) {
209
27
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
9
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
9
            }
212
27
            set.emplace_with_hash(hash_values[i], keys[i]);
213
27
        }
214
2
    }
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
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Line
Count
Source
197
11
                                Arena&) const override {
198
11
        std::vector<KeyType> keys_container;
199
11
        const KeyType* keys = get_keys(keys_container, *columns[0], batch_size);
200
11
        auto& set = this->data(place).set;
201
202
        // Precompute hash values to avoid double computation in prefetch + insert
203
11
        std::vector<size_t> hash_values(batch_size);
204
49
        for (size_t i = 0; i < batch_size; ++i) {
205
38
            hash_values[i] = set.hash(keys[i]);
206
38
        }
207
208
49
        for (size_t i = 0; i != batch_size; ++i) {
209
38
            if (i + HASH_MAP_PREFETCH_DIST < batch_size) {
210
0
                set.prefetch_hash(hash_values[i + HASH_MAP_PREFETCH_DIST]);
211
0
            }
212
38
            set.emplace_with_hash(hash_values[i], keys[i]);
213
38
        }
214
11
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE22add_batch_single_placeEmPcPPKNS_7IColumnERNS_5ArenaE
215
216
8.77k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
8.77k
        auto& set = this->data(place).set;
218
8.77k
        buf.write_var_uint(set.size());
219
35.0k
        for (const auto& elem : set) {
220
35.0k
            buf.write_binary(elem);
221
35.0k
        }
222
8.77k
    }
_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.63k
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
8.63k
        auto& set = this->data(place).set;
218
8.63k
        buf.write_var_uint(set.size());
219
34.8k
        for (const auto& elem : set) {
220
34.8k
            buf.write_binary(elem);
221
34.8k
        }
222
8.63k
    }
_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
28
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
28
        auto& set = this->data(place).set;
218
28
        buf.write_var_uint(set.size());
219
54
        for (const auto& elem : set) {
220
54
            buf.write_binary(elem);
221
54
        }
222
28
    }
_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
88
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
217
88
        auto& set = this->data(place).set;
218
88
        buf.write_var_uint(set.size());
219
88
        for (const auto& elem : set) {
220
88
            buf.write_binary(elem);
221
88
        }
222
88
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE9serializeEPKcRNS_14BufferWritableE
223
224
    void deserialize_and_merge(AggregateDataPtr __restrict place, AggregateDataPtr __restrict rhs,
225
8.77k
                               BufferReadable& buf, Arena&) const override {
226
8.77k
        auto& set = this->data(place).set;
227
8.77k
        UInt64 size;
228
8.77k
        buf.read_var_uint(size);
229
230
8.77k
        set.rehash(size + set.size());
231
232
43.8k
        for (size_t i = 0; i < size; ++i) {
233
35.0k
            KeyType ref;
234
35.0k
            buf.read_binary(ref);
235
35.0k
            set.insert(ref);
236
35.0k
        }
237
8.77k
    }
_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.63k
                               BufferReadable& buf, Arena&) const override {
226
8.63k
        auto& set = this->data(place).set;
227
8.63k
        UInt64 size;
228
8.63k
        buf.read_var_uint(size);
229
230
8.63k
        set.rehash(size + set.size());
231
232
43.5k
        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.63k
    }
_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
28
                               BufferReadable& buf, Arena&) const override {
226
28
        auto& set = this->data(place).set;
227
28
        UInt64 size;
228
28
        buf.read_var_uint(size);
229
230
28
        set.rehash(size + set.size());
231
232
82
        for (size_t i = 0; i < size; ++i) {
233
54
            KeyType ref;
234
54
            buf.read_binary(ref);
235
54
            set.insert(ref);
236
54
        }
237
28
    }
_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
88
                               BufferReadable& buf, Arena&) const override {
226
88
        auto& set = this->data(place).set;
227
88
        UInt64 size;
228
88
        buf.read_var_uint(size);
229
230
88
        set.rehash(size + set.size());
231
232
176
        for (size_t i = 0; i < size; ++i) {
233
88
            KeyType ref;
234
88
            buf.read_binary(ref);
235
88
            set.insert(ref);
236
88
        }
237
88
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE21deserialize_and_mergeEPcS5_RNS_14BufferReadableERNS_5ArenaE
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.54k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
8.54k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
8.54k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE2ENS_30AggregateFunctionUniqExactDataILS1_2EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
12
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
12
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
12
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE3ENS_30AggregateFunctionUniqExactDataILS1_3EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
26
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
26
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
26
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE4ENS_30AggregateFunctionUniqExactDataILS1_4EEEE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE5ENS_30AggregateFunctionUniqExactDataILS1_5EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
8.32k
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
8.32k
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
8.32k
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE6ENS_30AggregateFunctionUniqExactDataILS1_6EEEE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
254
57
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
57
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
57
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE7ENS_30AggregateFunctionUniqExactDataILS1_7EEEE18insert_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
    }
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
43
    void insert_result_into(ConstAggregateDataPtr __restrict place, IColumn& to) const override {
255
43
        assert_cast<ColumnInt64&>(to).get_data().push_back(this->data(place).set.size());
256
43
    }
_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
    }
_ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE26ENS_30AggregateFunctionUniqExactDataILS1_26EEEE18insert_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
    }
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE42ENS_30AggregateFunctionUniqExactDataILS1_42EEEE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris21AggregateFunctionUniqILNS_13PrimitiveTypeE41ENS_30AggregateFunctionUniqExactDataILS1_41EEEE18insert_result_intoEPKcRNS_7IColumnE
257
};
258
259
} // namespace doris