be/src/exprs/vcase_expr.h
Line | Count | Source |
1 | | // Licensed to the Apache Software Foundation (ASF) under one |
2 | | // or more contributor license agreements. See the NOTICE file |
3 | | // distributed with this work for additional information |
4 | | // regarding copyright ownership. The ASF licenses this file |
5 | | // to you under the Apache License, Version 2.0 (the |
6 | | // "License"); you may not use this file except in compliance |
7 | | // with the License. You may obtain a copy of the License at |
8 | | // |
9 | | // http://www.apache.org/licenses/LICENSE-2.0 |
10 | | // |
11 | | // Unless required by applicable law or agreed to in writing, |
12 | | // software distributed under the License is distributed on an |
13 | | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
14 | | // KIND, either express or implied. See the License for the |
15 | | // specific language governing permissions and limitations |
16 | | // under the License. |
17 | | |
18 | | #pragma once |
19 | | |
20 | | #include <string> |
21 | | |
22 | | #include "common/exception.h" |
23 | | #include "common/status.h" |
24 | | #include "core/column/column_array.h" |
25 | | #include "core/column/column_complex.h" |
26 | | #include "core/column/column_const.h" |
27 | | #include "core/column/column_decimal.h" |
28 | | #include "core/column/column_map.h" |
29 | | #include "core/column/column_nullable.h" |
30 | | #include "core/column/column_struct.h" |
31 | | #include "core/column/column_variant.h" |
32 | | #include "core/data_type/define_primitive_type.h" |
33 | | #include "core/data_type/primitive_type.h" |
34 | | #include "exprs/function/function.h" |
35 | | #include "exprs/function_context.h" |
36 | | #include "exprs/vexpr.h" |
37 | | |
38 | | namespace doris { |
39 | | class RowDescriptor; |
40 | | class RuntimeState; |
41 | | class TExprNode; |
42 | | |
43 | | class Block; |
44 | | } // namespace doris |
45 | | |
46 | | namespace doris { |
47 | | |
48 | | class VCaseExpr final : public VExpr { |
49 | | ENABLE_FACTORY_CREATOR(VCaseExpr); |
50 | | |
51 | | public: |
52 | | VCaseExpr(const TExprNode& node); |
53 | | ~VCaseExpr() override = default; |
54 | | Status execute_column_impl(VExprContext* context, const Block* block, const Selector* selector, |
55 | | size_t count, ColumnPtr& result_column) const override; |
56 | | Status prepare(RuntimeState* state, const RowDescriptor& desc, VExprContext* context) override; |
57 | | Status open(RuntimeState* state, VExprContext* context, |
58 | | FunctionContext::FunctionStateScope scope) override; |
59 | | void close(VExprContext* context, FunctionContext::FunctionStateScope scope) override; |
60 | | const std::string& expr_name() const override; |
61 | | std::string debug_string() const override; |
62 | 0 | bool has_else_expr() const { return _has_else_expr; } |
63 | 1 | Status clone_node(VExprSPtr* cloned_expr) const override { |
64 | 1 | DORIS_CHECK(cloned_expr != nullptr); |
65 | 1 | auto node = clone_texpr_node(); |
66 | 1 | TCaseExpr case_node; |
67 | 1 | case_node.__set_has_case_expr(false); |
68 | 1 | case_node.__set_has_else_expr(_has_else_expr); |
69 | 1 | node.__set_case_expr(case_node); |
70 | 1 | *cloned_expr = VCaseExpr::create_shared(node); |
71 | 1 | return Status::OK(); |
72 | 1 | } |
73 | | |
74 | | private: |
75 | | template <typename IndexType, typename ColumnType> |
76 | | ColumnPtr _execute_update_result_impl(const IndexType* then_idx, |
77 | | std::vector<ColumnPtr>& then_columns, |
78 | 1.92k | size_t rows_count) const { |
79 | 1.92k | auto result_column_ptr = data_type()->create_column(); |
80 | 1.92k | result_column_ptr->reserve(rows_count); |
81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || |
82 | | std::is_same_v<ColumnType, ColumnBitmap> || |
83 | | std::is_same_v<ColumnType, ColumnArray> || |
84 | | std::is_same_v<ColumnType, ColumnMap> || |
85 | | std::is_same_v<ColumnType, ColumnStruct> || |
86 | | std::is_same_v<ColumnType, ColumnVariant> || |
87 | | std::is_same_v<ColumnType, ColumnHLL> || |
88 | | std::is_same_v<ColumnType, ColumnQuantileState> || |
89 | | std::is_same_v<ColumnType, ColumnIPv4> || |
90 | 65 | std::is_same_v<ColumnType, ColumnIPv6>) { |
91 | | // result_column and all then_column is not nullable. |
92 | | // can't simd when type is string. |
93 | 65 | if (data_type()->is_nullable()) { |
94 | 3 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, |
95 | 3 | then_columns, rows_count); |
96 | 62 | } else { |
97 | 62 | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, |
98 | 62 | then_columns, rows_count); |
99 | 62 | } |
100 | 1.85k | } else if (data_type()->is_nullable()) { |
101 | | // result_column and all then_column is nullable. |
102 | 14 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, |
103 | 14 | then_columns, rows_count); |
104 | 1.84k | } else { |
105 | 1.84k | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, |
106 | 1.84k | then_columns, rows_count); |
107 | 1.84k | } |
108 | 1.92k | return result_column_ptr; |
109 | 1.92k | } Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_9ColumnStrIjEEEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EEPKT_RSt6vectorIS8_SaIS8_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_11ColumnArrayEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_9ColumnMapEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_12ColumnStructEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_13ColumnVariantEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 1.63k | size_t rows_count) const { | 79 | 1.63k | auto result_column_ptr = data_type()->create_column(); | 80 | 1.63k | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 1.63k | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 1 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 1 | then_columns, rows_count); | 104 | 1.63k | } else { | 105 | 1.63k | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 1.63k | then_columns, rows_count); | 107 | 1.63k | } | 108 | 1.63k | return result_column_ptr; | 109 | 1.63k | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 10 | size_t rows_count) const { | 79 | 10 | auto result_column_ptr = data_type()->create_column(); | 80 | 10 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 10 | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 10 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 10 | then_columns, rows_count); | 104 | 10 | } else { | 105 | 0 | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 0 | then_columns, rows_count); | 107 | 0 | } | 108 | 10 | return result_column_ptr; | 109 | 10 | } |
_ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 137 | size_t rows_count) const { | 79 | 137 | auto result_column_ptr = data_type()->create_column(); | 80 | 137 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 137 | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 0 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 0 | then_columns, rows_count); | 104 | 137 | } else { | 105 | 137 | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 137 | then_columns, rows_count); | 107 | 137 | } | 108 | 137 | return result_column_ptr; | 109 | 137 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 3 | size_t rows_count) const { | 79 | 3 | auto result_column_ptr = data_type()->create_column(); | 80 | 3 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 3 | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 3 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 3 | then_columns, rows_count); | 104 | 3 | } else { | 105 | 0 | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 0 | then_columns, rows_count); | 107 | 0 | } | 108 | 3 | return result_column_ptr; | 109 | 3 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 68 | size_t rows_count) const { | 79 | 68 | auto result_column_ptr = data_type()->create_column(); | 80 | 68 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 68 | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 0 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 0 | then_columns, rows_count); | 104 | 68 | } else { | 105 | 68 | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 68 | then_columns, rows_count); | 107 | 68 | } | 108 | 68 | return result_column_ptr; | 109 | 68 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_9ColumnStrIjEEEENS_3COWINS_7IColumnEE13immutable_ptrIS5_EEPKT_RSt6vectorIS8_SaIS8_EEm Line | Count | Source | 78 | 65 | size_t rows_count) const { | 79 | 65 | auto result_column_ptr = data_type()->create_column(); | 80 | 65 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | 65 | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | 65 | if (data_type()->is_nullable()) { | 94 | 3 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | 3 | then_columns, rows_count); | 96 | 62 | } else { | 97 | 62 | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | 62 | then_columns, rows_count); | 99 | 62 | } | 100 | | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | | then_columns, rows_count); | 104 | | } else { | 105 | | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | | then_columns, rows_count); | 107 | | } | 108 | 65 | return result_column_ptr; | 109 | 65 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Line | Count | Source | 78 | 2 | size_t rows_count) const { | 79 | 2 | auto result_column_ptr = data_type()->create_column(); | 80 | 2 | result_column_ptr->reserve(rows_count); | 81 | | if constexpr (std::is_same_v<ColumnType, ColumnString> || | 82 | | std::is_same_v<ColumnType, ColumnBitmap> || | 83 | | std::is_same_v<ColumnType, ColumnArray> || | 84 | | std::is_same_v<ColumnType, ColumnMap> || | 85 | | std::is_same_v<ColumnType, ColumnStruct> || | 86 | | std::is_same_v<ColumnType, ColumnVariant> || | 87 | | std::is_same_v<ColumnType, ColumnHLL> || | 88 | | std::is_same_v<ColumnType, ColumnQuantileState> || | 89 | | std::is_same_v<ColumnType, ColumnIPv4> || | 90 | | std::is_same_v<ColumnType, ColumnIPv6>) { | 91 | | // result_column and all then_column is not nullable. | 92 | | // can't simd when type is string. | 93 | | if (data_type()->is_nullable()) { | 94 | | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 95 | | then_columns, rows_count); | 96 | | } else { | 97 | | update_result_normal<IndexType, ColumnType, false>(result_column_ptr, then_idx, | 98 | | then_columns, rows_count); | 99 | | } | 100 | 2 | } else if (data_type()->is_nullable()) { | 101 | | // result_column and all then_column is nullable. | 102 | 0 | update_result_normal<IndexType, ColumnType, true>(result_column_ptr, then_idx, | 103 | 0 | then_columns, rows_count); | 104 | 2 | } else { | 105 | 2 | update_result_auto_simd<IndexType, ColumnType>(result_column_ptr, then_idx, | 106 | 2 | then_columns, rows_count); | 107 | 2 | } | 108 | 2 | return result_column_ptr; | 109 | 2 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_11ColumnArrayEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_9ColumnMapEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_12ColumnStructEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_13ColumnVariantEEENS_3COWINS_7IColumnEE13immutable_ptrIS4_EEPKT_RSt6vectorIS7_SaIS7_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr27_execute_update_result_implIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEEEENS_3COWINS_7IColumnEE13immutable_ptrIS6_EEPKT_RSt6vectorIS9_SaIS9_EEm |
110 | | |
111 | | template <typename IndexType> |
112 | | ColumnPtr _execute_update_result(const IndexType* then_idx, |
113 | | std::vector<ColumnPtr>& then_columns, |
114 | 1.92k | size_t rows_count) const { |
115 | 1.92k | #define CASE_TYPE(ptype, coltype) \ |
116 | 1.92k | case PrimitiveType::ptype: \ |
117 | 1.92k | return _execute_update_result_impl<IndexType, coltype>(then_idx, then_columns, rows_count); |
118 | | |
119 | 1.92k | switch (data_type()->get_primitive_type()) { |
120 | 0 | CASE_TYPE(TYPE_BOOLEAN, ColumnUInt8) |
121 | 1.63k | CASE_TYPE(TYPE_TINYINT, ColumnInt8) |
122 | 0 | CASE_TYPE(TYPE_SMALLINT, ColumnInt16) |
123 | 10 | CASE_TYPE(TYPE_INT, ColumnInt32) |
124 | 137 | CASE_TYPE(TYPE_BIGINT, ColumnInt64) |
125 | 0 | CASE_TYPE(TYPE_LARGEINT, ColumnInt128) |
126 | 0 | CASE_TYPE(TYPE_FLOAT, ColumnFloat32) |
127 | 3 | CASE_TYPE(TYPE_DOUBLE, ColumnFloat64) |
128 | 0 | CASE_TYPE(TYPE_DECIMAL32, ColumnDecimal32) |
129 | 68 | CASE_TYPE(TYPE_DECIMAL64, ColumnDecimal64) |
130 | 0 | CASE_TYPE(TYPE_DECIMAL256, ColumnDecimal256) |
131 | 0 | CASE_TYPE(TYPE_DECIMAL128I, ColumnDecimal128V3) |
132 | 0 | CASE_TYPE(TYPE_DECIMALV2, ColumnDecimal128V2) |
133 | 0 | CASE_TYPE(TYPE_STRING, ColumnString) |
134 | 0 | CASE_TYPE(TYPE_CHAR, ColumnString) |
135 | 65 | CASE_TYPE(TYPE_VARCHAR, ColumnString) |
136 | 0 | CASE_TYPE(TYPE_JSONB, ColumnString) |
137 | 0 | CASE_TYPE(TYPE_DATE, ColumnDate) |
138 | 0 | CASE_TYPE(TYPE_DATETIME, ColumnDateTime) |
139 | 2 | CASE_TYPE(TYPE_DATEV2, ColumnDateV2) |
140 | 0 | CASE_TYPE(TYPE_DATETIMEV2, ColumnDateTimeV2) |
141 | 0 | CASE_TYPE(TYPE_TIMESTAMPTZ, ColumnTimeStampTz) |
142 | 0 | CASE_TYPE(TYPE_IPV6, ColumnIPv6) |
143 | 0 | CASE_TYPE(TYPE_IPV4, ColumnIPv4) |
144 | 0 | CASE_TYPE(TYPE_ARRAY, ColumnArray) |
145 | 0 | CASE_TYPE(TYPE_MAP, ColumnMap) |
146 | 0 | CASE_TYPE(TYPE_STRUCT, ColumnStruct) |
147 | 0 | CASE_TYPE(TYPE_VARIANT, ColumnVariant) |
148 | 0 | CASE_TYPE(TYPE_BITMAP, ColumnBitmap) |
149 | 0 | CASE_TYPE(TYPE_HLL, ColumnHLL) |
150 | 0 | CASE_TYPE(TYPE_QUANTILE_STATE, ColumnQuantileState) |
151 | 0 | default: |
152 | 0 | throw Exception(ErrorCode::NOT_IMPLEMENTED_ERROR, "argument_type {} not supported", |
153 | 0 | data_type()->get_name()); |
154 | 1.92k | } |
155 | 1.92k | #undef CASE_TYPE |
156 | 1.92k | } Unexecuted instantiation: _ZNK5doris9VCaseExpr22_execute_update_resultItEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EEPKT_RSt6vectorIS6_SaIS6_EEm _ZNK5doris9VCaseExpr22_execute_update_resultIhEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EEPKT_RSt6vectorIS6_SaIS6_EEm Line | Count | Source | 114 | 1.92k | size_t rows_count) const { | 115 | 1.92k | #define CASE_TYPE(ptype, coltype) \ | 116 | 1.92k | case PrimitiveType::ptype: \ | 117 | 1.92k | return _execute_update_result_impl<IndexType, coltype>(then_idx, then_columns, rows_count); | 118 | | | 119 | 1.92k | switch (data_type()->get_primitive_type()) { | 120 | 0 | CASE_TYPE(TYPE_BOOLEAN, ColumnUInt8) | 121 | 1.63k | CASE_TYPE(TYPE_TINYINT, ColumnInt8) | 122 | 0 | CASE_TYPE(TYPE_SMALLINT, ColumnInt16) | 123 | 10 | CASE_TYPE(TYPE_INT, ColumnInt32) | 124 | 137 | CASE_TYPE(TYPE_BIGINT, ColumnInt64) | 125 | 0 | CASE_TYPE(TYPE_LARGEINT, ColumnInt128) | 126 | 0 | CASE_TYPE(TYPE_FLOAT, ColumnFloat32) | 127 | 3 | CASE_TYPE(TYPE_DOUBLE, ColumnFloat64) | 128 | 0 | CASE_TYPE(TYPE_DECIMAL32, ColumnDecimal32) | 129 | 68 | CASE_TYPE(TYPE_DECIMAL64, ColumnDecimal64) | 130 | 0 | CASE_TYPE(TYPE_DECIMAL256, ColumnDecimal256) | 131 | 0 | CASE_TYPE(TYPE_DECIMAL128I, ColumnDecimal128V3) | 132 | 0 | CASE_TYPE(TYPE_DECIMALV2, ColumnDecimal128V2) | 133 | 0 | CASE_TYPE(TYPE_STRING, ColumnString) | 134 | 0 | CASE_TYPE(TYPE_CHAR, ColumnString) | 135 | 65 | CASE_TYPE(TYPE_VARCHAR, ColumnString) | 136 | 0 | CASE_TYPE(TYPE_JSONB, ColumnString) | 137 | 0 | CASE_TYPE(TYPE_DATE, ColumnDate) | 138 | 0 | CASE_TYPE(TYPE_DATETIME, ColumnDateTime) | 139 | 2 | CASE_TYPE(TYPE_DATEV2, ColumnDateV2) | 140 | 0 | CASE_TYPE(TYPE_DATETIMEV2, ColumnDateTimeV2) | 141 | 0 | CASE_TYPE(TYPE_TIMESTAMPTZ, ColumnTimeStampTz) | 142 | 0 | CASE_TYPE(TYPE_IPV6, ColumnIPv6) | 143 | 0 | CASE_TYPE(TYPE_IPV4, ColumnIPv4) | 144 | 0 | CASE_TYPE(TYPE_ARRAY, ColumnArray) | 145 | 0 | CASE_TYPE(TYPE_MAP, ColumnMap) | 146 | 0 | CASE_TYPE(TYPE_STRUCT, ColumnStruct) | 147 | 0 | CASE_TYPE(TYPE_VARIANT, ColumnVariant) | 148 | 0 | CASE_TYPE(TYPE_BITMAP, ColumnBitmap) | 149 | 0 | CASE_TYPE(TYPE_HLL, ColumnHLL) | 150 | 0 | CASE_TYPE(TYPE_QUANTILE_STATE, ColumnQuantileState) | 151 | 0 | default: | 152 | 0 | throw Exception(ErrorCode::NOT_IMPLEMENTED_ERROR, "argument_type {} not supported", | 153 | 0 | data_type()->get_name()); | 154 | 1.92k | } | 155 | 1.92k | #undef CASE_TYPE | 156 | 1.92k | } |
|
157 | | |
158 | | template <typename IndexType, typename ColumnType, bool then_null> |
159 | | void update_result_normal(MutableColumnPtr& result_column_ptr, |
160 | | const IndexType* __restrict then_idx, |
161 | 79 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { |
162 | 79 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); |
163 | 79 | std::vector<uint8_t> is_consts(then_columns.size()); |
164 | 79 | std::vector<uint8_t> is_nullable(then_columns.size()); |
165 | 261 | for (size_t i = 0; i < then_columns.size(); i++) { |
166 | 182 | if (!then_columns[i]) { |
167 | 4 | continue; |
168 | 4 | } |
169 | 178 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); |
170 | 178 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); |
171 | 178 | } |
172 | | |
173 | 79 | auto* raw_result_column = result_column_ptr.get(); |
174 | 323 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
175 | 244 | if (!_has_else_expr && !then_idx[row_idx]) { |
176 | 8 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) |
177 | 8 | ->insert_default(); |
178 | 8 | continue; |
179 | 8 | } |
180 | 236 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; |
181 | 236 | if constexpr (then_null) { |
182 | 34 | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( |
183 | 34 | result_column_ptr.get()); |
184 | 34 | if (is_nullable[then_idx[row_idx]]) { |
185 | 27 | nullable->insert_from_with_type<ColumnType>( |
186 | 27 | *raw_then_columns[then_idx[row_idx]], target); |
187 | 27 | } else { |
188 | 7 | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( |
189 | 7 | nullable->get_nested_column_ptr().get()); |
190 | 7 | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); |
191 | 7 | nullable->push_false_to_nullmap(1); |
192 | 7 | } |
193 | 202 | } else { |
194 | 202 | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) |
195 | 202 | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); |
196 | 202 | } |
197 | 236 | } |
198 | 79 | } Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnStrIjEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnStrIjEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_11ColumnArrayELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_11ColumnArrayELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnMapELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_9ColumnMapELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnStructELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_12ColumnStructELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnVariantELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_13ColumnVariantELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalItNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 161 | 1 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 162 | 1 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); | 163 | 1 | std::vector<uint8_t> is_consts(then_columns.size()); | 164 | 1 | std::vector<uint8_t> is_nullable(then_columns.size()); | 165 | 4 | for (size_t i = 0; i < then_columns.size(); i++) { | 166 | 3 | if (!then_columns[i]) { | 167 | 1 | continue; | 168 | 1 | } | 169 | 2 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); | 170 | 2 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); | 171 | 2 | } | 172 | | | 173 | 1 | auto* raw_result_column = result_column_ptr.get(); | 174 | 3 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 175 | 2 | if (!_has_else_expr && !then_idx[row_idx]) { | 176 | 0 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) | 177 | 0 | ->insert_default(); | 178 | 0 | continue; | 179 | 0 | } | 180 | 2 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; | 181 | 2 | if constexpr (then_null) { | 182 | 2 | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 183 | 2 | result_column_ptr.get()); | 184 | 2 | if (is_nullable[then_idx[row_idx]]) { | 185 | 0 | nullable->insert_from_with_type<ColumnType>( | 186 | 0 | *raw_then_columns[then_idx[row_idx]], target); | 187 | 2 | } else { | 188 | 2 | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( | 189 | 2 | nullable->get_nested_column_ptr().get()); | 190 | 2 | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 191 | 2 | nullable->push_false_to_nullmap(1); | 192 | 2 | } | 193 | | } else { | 194 | | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 195 | | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 196 | | } | 197 | 2 | } | 198 | 1 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 161 | 10 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 162 | 10 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); | 163 | 10 | std::vector<uint8_t> is_consts(then_columns.size()); | 164 | 10 | std::vector<uint8_t> is_nullable(then_columns.size()); | 165 | 21 | for (size_t i = 0; i < then_columns.size(); i++) { | 166 | 11 | if (!then_columns[i]) { | 167 | 0 | continue; | 168 | 0 | } | 169 | 11 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); | 170 | 11 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); | 171 | 11 | } | 172 | | | 173 | 10 | auto* raw_result_column = result_column_ptr.get(); | 174 | 30 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 175 | 20 | if (!_has_else_expr && !then_idx[row_idx]) { | 176 | 0 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) | 177 | 0 | ->insert_default(); | 178 | 0 | continue; | 179 | 0 | } | 180 | 20 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; | 181 | 20 | if constexpr (then_null) { | 182 | 20 | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 183 | 20 | result_column_ptr.get()); | 184 | 20 | if (is_nullable[then_idx[row_idx]]) { | 185 | 20 | nullable->insert_from_with_type<ColumnType>( | 186 | 20 | *raw_then_columns[then_idx[row_idx]], target); | 187 | 20 | } else { | 188 | 0 | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( | 189 | 0 | nullable->get_nested_column_ptr().get()); | 190 | 0 | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 191 | 0 | nullable->push_false_to_nullmap(1); | 192 | 0 | } | 193 | | } else { | 194 | | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 195 | | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 196 | | } | 197 | 20 | } | 198 | 10 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 161 | 3 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 162 | 3 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); | 163 | 3 | std::vector<uint8_t> is_consts(then_columns.size()); | 164 | 3 | std::vector<uint8_t> is_nullable(then_columns.size()); | 165 | 11 | for (size_t i = 0; i < then_columns.size(); i++) { | 166 | 8 | if (!then_columns[i]) { | 167 | 0 | continue; | 168 | 0 | } | 169 | 8 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); | 170 | 8 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); | 171 | 8 | } | 172 | | | 173 | 3 | auto* raw_result_column = result_column_ptr.get(); | 174 | 13 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 175 | 10 | if (!_has_else_expr && !then_idx[row_idx]) { | 176 | 0 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) | 177 | 0 | ->insert_default(); | 178 | 0 | continue; | 179 | 0 | } | 180 | 10 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; | 181 | 10 | if constexpr (then_null) { | 182 | 10 | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 183 | 10 | result_column_ptr.get()); | 184 | 10 | if (is_nullable[then_idx[row_idx]]) { | 185 | 7 | nullable->insert_from_with_type<ColumnType>( | 186 | 7 | *raw_then_columns[then_idx[row_idx]], target); | 187 | 7 | } else { | 188 | 3 | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( | 189 | 3 | nullable->get_nested_column_ptr().get()); | 190 | 3 | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 191 | 3 | nullable->push_false_to_nullmap(1); | 192 | 3 | } | 193 | | } else { | 194 | | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 195 | | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 196 | | } | 197 | 10 | } | 198 | 3 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnStrIjEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm Line | Count | Source | 161 | 3 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 162 | 3 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); | 163 | 3 | std::vector<uint8_t> is_consts(then_columns.size()); | 164 | 3 | std::vector<uint8_t> is_nullable(then_columns.size()); | 165 | 8 | for (size_t i = 0; i < then_columns.size(); i++) { | 166 | 5 | if (!then_columns[i]) { | 167 | 3 | continue; | 168 | 3 | } | 169 | 2 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); | 170 | 2 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); | 171 | 2 | } | 172 | | | 173 | 3 | auto* raw_result_column = result_column_ptr.get(); | 174 | 13 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 175 | 10 | if (!_has_else_expr && !then_idx[row_idx]) { | 176 | 8 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) | 177 | 8 | ->insert_default(); | 178 | 8 | continue; | 179 | 8 | } | 180 | 2 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; | 181 | 2 | if constexpr (then_null) { | 182 | 2 | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 183 | 2 | result_column_ptr.get()); | 184 | 2 | if (is_nullable[then_idx[row_idx]]) { | 185 | 0 | nullable->insert_from_with_type<ColumnType>( | 186 | 0 | *raw_then_columns[then_idx[row_idx]], target); | 187 | 2 | } else { | 188 | 2 | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( | 189 | 2 | nullable->get_nested_column_ptr().get()); | 190 | 2 | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 191 | 2 | nullable->push_false_to_nullmap(1); | 192 | 2 | } | 193 | | } else { | 194 | | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 195 | | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 196 | | } | 197 | 2 | } | 198 | 3 | } |
_ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnStrIjEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS5_EEPKT_RSt6vectorINS6_13immutable_ptrIS5_EESaISF_EEm Line | Count | Source | 161 | 62 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 162 | 62 | std::vector<ColumnPtr> raw_then_columns(then_columns.size()); | 163 | 62 | std::vector<uint8_t> is_consts(then_columns.size()); | 164 | 62 | std::vector<uint8_t> is_nullable(then_columns.size()); | 165 | 217 | for (size_t i = 0; i < then_columns.size(); i++) { | 166 | 155 | if (!then_columns[i]) { | 167 | 0 | continue; | 168 | 0 | } | 169 | 155 | std::tie(raw_then_columns[i], is_consts[i]) = unpack_if_const(then_columns[i]); | 170 | 155 | is_nullable[i] = is_column_nullable(*raw_then_columns[i]); | 171 | 155 | } | 172 | | | 173 | 62 | auto* raw_result_column = result_column_ptr.get(); | 174 | 264 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 175 | 202 | if (!_has_else_expr && !then_idx[row_idx]) { | 176 | 0 | assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>(raw_result_column) | 177 | 0 | ->insert_default(); | 178 | 0 | continue; | 179 | 0 | } | 180 | 202 | size_t target = is_consts[then_idx[row_idx]] ? 0 : row_idx; | 181 | | if constexpr (then_null) { | 182 | | auto* nullable = assert_cast<ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 183 | | result_column_ptr.get()); | 184 | | if (is_nullable[then_idx[row_idx]]) { | 185 | | nullable->insert_from_with_type<ColumnType>( | 186 | | *raw_then_columns[then_idx[row_idx]], target); | 187 | | } else { | 188 | | auto* nested = assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>( | 189 | | nullable->get_nested_column_ptr().get()); | 190 | | nested->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 191 | | nullable->push_false_to_nullmap(1); | 192 | | } | 193 | 202 | } else { | 194 | 202 | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 195 | 202 | ->insert_from(*raw_then_columns[then_idx[row_idx]], target); | 196 | 202 | } | 197 | 202 | } | 198 | 62 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE37EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnVectorILNS_13PrimitiveTypeE36EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_11ColumnArrayELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_11ColumnArrayELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnMapELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_9ColumnMapELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnStructELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_12ColumnStructELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnVariantELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_13ColumnVariantELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS4_EEPKT_RSt6vectorINS5_13immutable_ptrIS4_EESaISE_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE22EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE19EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb1EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr20update_result_normalIhNS_17ColumnComplexTypeILNS_13PrimitiveTypeE24EEELb0EEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm |
199 | | |
200 | | template <typename IndexType, typename ColumnType> |
201 | | void update_result_auto_simd(MutableColumnPtr& result_column_ptr, |
202 | | const IndexType* __restrict then_idx, |
203 | 1.84k | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { |
204 | 2.89k | for (auto& then_ptr : then_columns) { |
205 | 2.89k | then_ptr = then_ptr->convert_to_full_column_if_const(); |
206 | 2.89k | } |
207 | | |
208 | 1.84k | result_column_ptr->resize(rows_count); |
209 | 1.84k | auto* __restrict result_raw_data = |
210 | 1.84k | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) |
211 | 1.84k | ->get_data() |
212 | 1.84k | .data(); |
213 | | |
214 | | // set default value |
215 | 4.02k | for (int i = 0; i < rows_count; i++) { |
216 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || |
217 | | std::is_same_v<ColumnType, ColumnDateTime> || |
218 | | std::is_same_v<ColumnType, ColumnDateV2> || |
219 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || |
220 | 10 | std::is_same_v<ColumnType, ColumnTimeStampTz>) { |
221 | 10 | result_raw_data[i] = ColumnType::default_value(); |
222 | 2.16k | } else { |
223 | 2.16k | result_raw_data[i] = {}; |
224 | 2.16k | } |
225 | 2.17k | } |
226 | | |
227 | 4.73k | for (IndexType i = 0; i < then_columns.size(); i++) { |
228 | 2.89k | if (!then_columns[i]) { |
229 | 0 | continue; |
230 | 0 | } |
231 | 2.89k | const auto* __restrict column_raw_data = |
232 | 2.89k | assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>( |
233 | 2.89k | then_columns[i].get()) |
234 | 2.89k | ->get_data() |
235 | 2.89k | .data(); |
236 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || |
237 | | std::is_same_v<ColumnType, ColumnDateTime> || |
238 | | std::is_same_v<ColumnType, ColumnDateV2> || |
239 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || |
240 | 6 | std::is_same_v<ColumnType, ColumnTimeStampTz>) { |
241 | 36 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
242 | 30 | result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx] |
243 | 30 | : result_raw_data[row_idx]; |
244 | 30 | } |
245 | 2.88k | } else { |
246 | 6.66k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
247 | 3.77k | result_raw_data[row_idx] += |
248 | 3.77k | typename ColumnType::value_type(then_idx[row_idx] == i) * |
249 | 3.77k | column_raw_data[row_idx]; |
250 | 3.77k | } |
251 | 2.88k | } |
252 | 2.89k | } |
253 | 1.84k | } Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdItNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE2EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE3EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 203 | 1.63k | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 204 | 2.51k | for (auto& then_ptr : then_columns) { | 205 | 2.51k | then_ptr = then_ptr->convert_to_full_column_if_const(); | 206 | 2.51k | } | 207 | | | 208 | 1.63k | result_column_ptr->resize(rows_count); | 209 | 1.63k | auto* __restrict result_raw_data = | 210 | 1.63k | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 211 | 1.63k | ->get_data() | 212 | 1.63k | .data(); | 213 | | | 214 | | // set default value | 215 | 3.38k | for (int i = 0; i < rows_count; i++) { | 216 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 217 | | std::is_same_v<ColumnType, ColumnDateTime> || | 218 | | std::is_same_v<ColumnType, ColumnDateV2> || | 219 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 220 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 221 | | result_raw_data[i] = ColumnType::default_value(); | 222 | 1.74k | } else { | 223 | 1.74k | result_raw_data[i] = {}; | 224 | 1.74k | } | 225 | 1.74k | } | 226 | | | 227 | 4.15k | for (IndexType i = 0; i < then_columns.size(); i++) { | 228 | 2.51k | if (!then_columns[i]) { | 229 | 0 | continue; | 230 | 0 | } | 231 | 2.51k | const auto* __restrict column_raw_data = | 232 | 2.51k | assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>( | 233 | 2.51k | then_columns[i].get()) | 234 | 2.51k | ->get_data() | 235 | 2.51k | .data(); | 236 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 237 | | std::is_same_v<ColumnType, ColumnDateTime> || | 238 | | std::is_same_v<ColumnType, ColumnDateV2> || | 239 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 240 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 241 | | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 242 | | result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx] | 243 | | : result_raw_data[row_idx]; | 244 | | } | 245 | 2.51k | } else { | 246 | 5.43k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 247 | 2.91k | result_raw_data[row_idx] += | 248 | 2.91k | typename ColumnType::value_type(then_idx[row_idx] == i) * | 249 | 2.91k | column_raw_data[row_idx]; | 250 | 2.91k | } | 251 | 2.51k | } | 252 | 2.51k | } | 253 | 1.63k | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE4EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE5EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE6EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 203 | 137 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 204 | 204 | for (auto& then_ptr : then_columns) { | 205 | 204 | then_ptr = then_ptr->convert_to_full_column_if_const(); | 206 | 204 | } | 207 | | | 208 | 137 | result_column_ptr->resize(rows_count); | 209 | 137 | auto* __restrict result_raw_data = | 210 | 137 | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 211 | 137 | ->get_data() | 212 | 137 | .data(); | 213 | | | 214 | | // set default value | 215 | 444 | for (int i = 0; i < rows_count; i++) { | 216 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 217 | | std::is_same_v<ColumnType, ColumnDateTime> || | 218 | | std::is_same_v<ColumnType, ColumnDateV2> || | 219 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 220 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 221 | | result_raw_data[i] = ColumnType::default_value(); | 222 | 307 | } else { | 223 | 307 | result_raw_data[i] = {}; | 224 | 307 | } | 225 | 307 | } | 226 | | | 227 | 341 | for (IndexType i = 0; i < then_columns.size(); i++) { | 228 | 204 | if (!then_columns[i]) { | 229 | 0 | continue; | 230 | 0 | } | 231 | 204 | const auto* __restrict column_raw_data = | 232 | 204 | assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>( | 233 | 204 | then_columns[i].get()) | 234 | 204 | ->get_data() | 235 | 204 | .data(); | 236 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 237 | | std::is_same_v<ColumnType, ColumnDateTime> || | 238 | | std::is_same_v<ColumnType, ColumnDateV2> || | 239 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 240 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 241 | | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 242 | | result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx] | 243 | | : result_raw_data[row_idx]; | 244 | | } | 245 | 204 | } else { | 246 | 763 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 247 | 559 | result_raw_data[row_idx] += | 248 | 559 | typename ColumnType::value_type(then_idx[row_idx] == i) * | 249 | 559 | column_raw_data[row_idx]; | 250 | 559 | } | 251 | 204 | } | 252 | 204 | } | 253 | 137 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE7EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE8EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE9EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE28EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE29EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 203 | 68 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 204 | 164 | for (auto& then_ptr : then_columns) { | 205 | 164 | then_ptr = then_ptr->convert_to_full_column_if_const(); | 206 | 164 | } | 207 | | | 208 | 68 | result_column_ptr->resize(rows_count); | 209 | 68 | auto* __restrict result_raw_data = | 210 | 68 | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 211 | 68 | ->get_data() | 212 | 68 | .data(); | 213 | | | 214 | | // set default value | 215 | 184 | for (int i = 0; i < rows_count; i++) { | 216 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 217 | | std::is_same_v<ColumnType, ColumnDateTime> || | 218 | | std::is_same_v<ColumnType, ColumnDateV2> || | 219 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 220 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 221 | | result_raw_data[i] = ColumnType::default_value(); | 222 | 116 | } else { | 223 | 116 | result_raw_data[i] = {}; | 224 | 116 | } | 225 | 116 | } | 226 | | | 227 | 232 | for (IndexType i = 0; i < then_columns.size(); i++) { | 228 | 164 | if (!then_columns[i]) { | 229 | 0 | continue; | 230 | 0 | } | 231 | 164 | const auto* __restrict column_raw_data = | 232 | 164 | assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>( | 233 | 164 | then_columns[i].get()) | 234 | 164 | ->get_data() | 235 | 164 | .data(); | 236 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 237 | | std::is_same_v<ColumnType, ColumnDateTime> || | 238 | | std::is_same_v<ColumnType, ColumnDateV2> || | 239 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 240 | | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 241 | | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 242 | | result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx] | 243 | | : result_raw_data[row_idx]; | 244 | | } | 245 | 164 | } else { | 246 | 468 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 247 | 304 | result_raw_data[row_idx] += | 248 | 304 | typename ColumnType::value_type(then_idx[row_idx] == i) * | 249 | 304 | column_raw_data[row_idx]; | 250 | 304 | } | 251 | 164 | } | 252 | 164 | } | 253 | 68 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE35EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE30EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_13ColumnDecimalILNS_13PrimitiveTypeE20EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE11EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE12EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE25EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Line | Count | Source | 203 | 2 | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 204 | 6 | for (auto& then_ptr : then_columns) { | 205 | 6 | then_ptr = then_ptr->convert_to_full_column_if_const(); | 206 | 6 | } | 207 | | | 208 | 2 | result_column_ptr->resize(rows_count); | 209 | 2 | auto* __restrict result_raw_data = | 210 | 2 | assert_cast<ColumnType*, TypeCheckOnRelease::DISABLE>(result_column_ptr.get()) | 211 | 2 | ->get_data() | 212 | 2 | .data(); | 213 | | | 214 | | // set default value | 215 | 12 | for (int i = 0; i < rows_count; i++) { | 216 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 217 | | std::is_same_v<ColumnType, ColumnDateTime> || | 218 | | std::is_same_v<ColumnType, ColumnDateV2> || | 219 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 220 | 10 | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 221 | 10 | result_raw_data[i] = ColumnType::default_value(); | 222 | | } else { | 223 | | result_raw_data[i] = {}; | 224 | | } | 225 | 10 | } | 226 | | | 227 | 8 | for (IndexType i = 0; i < then_columns.size(); i++) { | 228 | 6 | if (!then_columns[i]) { | 229 | 0 | continue; | 230 | 0 | } | 231 | 6 | const auto* __restrict column_raw_data = | 232 | 6 | assert_cast<const ColumnType*, TypeCheckOnRelease::DISABLE>( | 233 | 6 | then_columns[i].get()) | 234 | 6 | ->get_data() | 235 | 6 | .data(); | 236 | | if constexpr (std::is_same_v<ColumnType, ColumnDate> || | 237 | | std::is_same_v<ColumnType, ColumnDateTime> || | 238 | | std::is_same_v<ColumnType, ColumnDateV2> || | 239 | | std::is_same_v<ColumnType, ColumnDateTimeV2> || | 240 | 6 | std::is_same_v<ColumnType, ColumnTimeStampTz>) { | 241 | 36 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 242 | 30 | result_raw_data[row_idx] = (then_idx[row_idx] == i) ? column_raw_data[row_idx] | 243 | 30 | : result_raw_data[row_idx]; | 244 | 30 | } | 245 | | } else { | 246 | | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 247 | | result_raw_data[row_idx] += | 248 | | typename ColumnType::value_type(then_idx[row_idx] == i) * | 249 | | column_raw_data[row_idx]; | 250 | | } | 251 | | } | 252 | 6 | } | 253 | 2 | } |
Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE26EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm Unexecuted instantiation: _ZNK5doris9VCaseExpr23update_result_auto_simdIhNS_12ColumnVectorILNS_13PrimitiveTypeE42EEEEEvRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EEPKT_RSt6vectorINS7_13immutable_ptrIS6_EESaISG_EEm |
254 | | |
255 | | template <typename IndexType> |
256 | | ColumnPtr _execute_impl(const std::vector<ColumnPtr>& when_columns, |
257 | 1.92k | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { |
258 | 1.92k | std::vector<IndexType> then_idx(rows_count, 0); |
259 | 1.92k | IndexType* __restrict then_idx_ptr = then_idx.data(); |
260 | 3.07k | for (IndexType i = 0; i < when_columns.size(); i++) { |
261 | 1.15k | IndexType column_idx = i + 1; |
262 | 1.15k | auto [raw_when_column, is_consts] = unpack_if_const(when_columns[i]); |
263 | | |
264 | 1.15k | if (is_consts) { |
265 | 0 | if (raw_when_column->get_bool(0)) { |
266 | 0 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
267 | 0 | then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx]) * column_idx; |
268 | 0 | } |
269 | 0 | break; |
270 | 0 | } |
271 | 0 | continue; |
272 | 0 | } |
273 | | |
274 | 1.15k | if (is_column_nullable(*raw_when_column)) { |
275 | 688 | const auto* column_nullable_ptr = |
276 | 688 | assert_cast<const ColumnNullable*, TypeCheckOnRelease::DISABLE>( |
277 | 688 | raw_when_column.get()); |
278 | 688 | const auto* __restrict cond_raw_data = |
279 | 688 | assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>( |
280 | 688 | column_nullable_ptr->get_nested_column_ptr().get()) |
281 | 688 | ->get_data() |
282 | 688 | .data(); |
283 | 688 | if (!column_nullable_ptr->has_null()) { |
284 | 1.63k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
285 | 1.03k | then_idx_ptr[row_idx] |= |
286 | 1.03k | (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx; |
287 | 1.03k | } |
288 | 608 | continue; |
289 | 608 | } |
290 | 80 | const auto* __restrict cond_raw_nullmap = |
291 | 80 | column_nullable_ptr->get_null_map_column_ptr()->get_data().data(); |
292 | 506 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
293 | 426 | then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx] * cond_raw_data[row_idx] * |
294 | 426 | !cond_raw_nullmap[row_idx]) * |
295 | 426 | column_idx; |
296 | 426 | } |
297 | 462 | } else { |
298 | 462 | const auto* __restrict cond_raw_data = |
299 | 462 | assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>( |
300 | 462 | raw_when_column.get()) |
301 | 462 | ->get_data() |
302 | 462 | .data(); |
303 | 1.05k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { |
304 | 591 | then_idx_ptr[row_idx] |= |
305 | 591 | (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx; |
306 | 591 | } |
307 | 462 | } |
308 | 1.15k | } |
309 | | |
310 | 1.92k | return _execute_update_result<IndexType>(then_idx_ptr, then_columns, rows_count); |
311 | 1.92k | } Unexecuted instantiation: _ZNK5doris9VCaseExpr13_execute_implItEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EERKSt6vectorIS6_SaIS6_EERS9_m _ZNK5doris9VCaseExpr13_execute_implIhEENS_3COWINS_7IColumnEE13immutable_ptrIS3_EERKSt6vectorIS6_SaIS6_EERS9_m Line | Count | Source | 257 | 1.92k | std::vector<ColumnPtr>& then_columns, size_t rows_count) const { | 258 | 1.92k | std::vector<IndexType> then_idx(rows_count, 0); | 259 | 1.92k | IndexType* __restrict then_idx_ptr = then_idx.data(); | 260 | 3.07k | for (IndexType i = 0; i < when_columns.size(); i++) { | 261 | 1.15k | IndexType column_idx = i + 1; | 262 | 1.15k | auto [raw_when_column, is_consts] = unpack_if_const(when_columns[i]); | 263 | | | 264 | 1.15k | if (is_consts) { | 265 | 0 | if (raw_when_column->get_bool(0)) { | 266 | 0 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 267 | 0 | then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx]) * column_idx; | 268 | 0 | } | 269 | 0 | break; | 270 | 0 | } | 271 | 0 | continue; | 272 | 0 | } | 273 | | | 274 | 1.15k | if (is_column_nullable(*raw_when_column)) { | 275 | 688 | const auto* column_nullable_ptr = | 276 | 688 | assert_cast<const ColumnNullable*, TypeCheckOnRelease::DISABLE>( | 277 | 688 | raw_when_column.get()); | 278 | 688 | const auto* __restrict cond_raw_data = | 279 | 688 | assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>( | 280 | 688 | column_nullable_ptr->get_nested_column_ptr().get()) | 281 | 688 | ->get_data() | 282 | 688 | .data(); | 283 | 688 | if (!column_nullable_ptr->has_null()) { | 284 | 1.63k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 285 | 1.03k | then_idx_ptr[row_idx] |= | 286 | 1.03k | (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx; | 287 | 1.03k | } | 288 | 608 | continue; | 289 | 608 | } | 290 | 80 | const auto* __restrict cond_raw_nullmap = | 291 | 80 | column_nullable_ptr->get_null_map_column_ptr()->get_data().data(); | 292 | 506 | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 293 | 426 | then_idx_ptr[row_idx] |= (!then_idx_ptr[row_idx] * cond_raw_data[row_idx] * | 294 | 426 | !cond_raw_nullmap[row_idx]) * | 295 | 426 | column_idx; | 296 | 426 | } | 297 | 462 | } else { | 298 | 462 | const auto* __restrict cond_raw_data = | 299 | 462 | assert_cast<const ColumnUInt8*, TypeCheckOnRelease::DISABLE>( | 300 | 462 | raw_when_column.get()) | 301 | 462 | ->get_data() | 302 | 462 | .data(); | 303 | 1.05k | for (int row_idx = 0; row_idx < rows_count; row_idx++) { | 304 | 591 | then_idx_ptr[row_idx] |= | 305 | 591 | (!then_idx_ptr[row_idx]) * cond_raw_data[row_idx] * column_idx; | 306 | 591 | } | 307 | 462 | } | 308 | 1.15k | } | 309 | | | 310 | 1.92k | return _execute_update_result<IndexType>(then_idx_ptr, then_columns, rows_count); | 311 | 1.92k | } |
|
312 | | |
313 | | bool _has_else_expr; |
314 | | |
315 | | inline static const std::string FUNCTION_NAME = "case"; |
316 | | inline static const std::string EXPR_NAME = "vcase expr"; |
317 | | }; |
318 | | } // namespace doris |