Kuzu C++ API
Loading...
Searching...
No Matches
unary_function_executor.h
Go to the documentation of this file.
1#pragma once
2
3#include "value_vector.h"
5
6namespace kuzu {
7namespace function {
8
13
15 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
16 static inline void operation(void* inputVector, uint64_t inputPos, void* resultVector,
17 uint64_t resultPos, void* /*dataPtr*/) {
18 auto& inputVector_ = *(common::ValueVector*)inputVector;
19 auto& resultVector_ = *(common::ValueVector*)resultVector;
20 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
21 resultVector_.getValue<RESULT_TYPE>(resultPos));
22 }
23};
24
26 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
27 static inline void operation(void* inputVector, uint64_t inputPos, void* resultVector,
28 uint64_t /* resultPos */, void* dataPtr) {
29 auto& inputVector_ = *(common::ValueVector*)inputVector;
30 auto& resultVector_ = *(common::ValueVector*)resultVector;
31 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos), resultVector_, dataPtr);
32 }
33};
34
36 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
37 static void operation(void* inputVector, uint64_t inputPos, void* resultVector,
38 uint64_t resultPos, void* /*dataPtr*/) {
39 auto& inputVector_ = *(common::ValueVector*)inputVector;
40 auto& resultVector_ = *(common::ValueVector*)resultVector;
41 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
42 resultVector_.getValue<RESULT_TYPE>(resultPos), resultVector_);
43 }
44};
45
47 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
48 static void operation(void* /*inputVector*/, uint64_t /*inputPos*/, void* resultVector,
49 uint64_t resultPos, void* dataPtr) {
50 auto& resultVector_ = *(common::ValueVector*)resultVector;
51 FUNC::operation(resultVector_.getValue<RESULT_TYPE>(resultPos), resultVector_, dataPtr);
52 }
53};
54
56 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
57 static void operation(void* inputVector, uint64_t inputPos, void* resultVector,
58 uint64_t resultPos, void* dataPtr) {
59 auto& inputVector_ = *(common::ValueVector*)inputVector;
60 auto resultVector_ = (common::ValueVector*)resultVector;
61 // TODO(Ziyi): the reinterpret_cast is not safe since we don't always pass
62 // CastFunctionBindData
63 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
64 resultVector_->getValue<RESULT_TYPE>(resultPos), resultVector_, inputPos,
65 &reinterpret_cast<CastFunctionBindData*>(dataPtr)->option);
66 }
67};
68
70 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
71 static inline void operation(void* inputVector, uint64_t inputPos, void* resultVector,
72 uint64_t resultPos, void* /*dataPtr*/) {
73 auto& inputVector_ = *(common::ValueVector*)inputVector;
74 auto& resultVector_ = *(common::ValueVector*)resultVector;
75 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
76 resultVector_.getValue<RESULT_TYPE>(resultPos), inputVector_, resultVector_);
77 }
78};
79
81 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
82 static void operation(void* inputVector, uint64_t inputPos, void* resultVector,
83 uint64_t resultPos, void* /*dataPtr*/) {
84 auto& inputVector_ = *(common::ValueVector*)inputVector;
85 auto& resultVector_ = *(common::ValueVector*)resultVector;
86 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
87 resultVector_.getValue<RESULT_TYPE>(resultPos), inputVector_, resultVector_);
88 }
89};
90
92 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
93 static inline void operation(void* inputVector, uint64_t inputPos, void* resultVector,
94 uint64_t resultPos, void* dataPtr) {
95 auto& inputVector_ = *(common::ValueVector*)inputVector;
96 auto& resultVector_ = *(common::ValueVector*)resultVector;
97 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
98 resultVector_.getValue<RESULT_TYPE>(resultPos), dataPtr);
99 }
100};
101
103
104 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC, typename OP_WRAPPER>
105 static void executeOnValue(common::ValueVector& inputVector, uint64_t inputPos,
106 common::ValueVector& resultVector, uint64_t resultPos, void* dataPtr) {
107 OP_WRAPPER::template operation<OPERAND_TYPE, RESULT_TYPE, FUNC>((void*)&inputVector,
108 inputPos, (void*)&resultVector, resultPos, dataPtr);
109 }
110
111 static std::pair<common::sel_t, common::sel_t> getSelectedPos(common::idx_t selIdx,
112 common::SelectionVector* operandSelVector, common::SelectionVector* resultSelVector,
113 bool operandIsUnfiltered, bool resultIsUnfiltered) {
114 common::sel_t operandPos = operandIsUnfiltered ? selIdx : (*operandSelVector)[selIdx];
115 common::sel_t resultPos = resultIsUnfiltered ? selIdx : (*resultSelVector)[selIdx];
116 return {operandPos, resultPos};
117 }
118
119 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC, typename OP_WRAPPER>
121 common::SelectionVector* operandSelVector, common::ValueVector& result,
122 common::SelectionVector* resultSelVector, void* dataPtr) {
123 const bool noNullsGuaranteed = operand.hasNoNullsGuarantee();
124 if (noNullsGuaranteed) {
125 result.setAllNonNull();
126 }
127
128 const bool operandIsUnfiltered = operandSelVector->isUnfiltered();
129 const bool resultIsUnfiltered = resultSelVector->isUnfiltered();
130
131 for (auto i = 0u; i < operandSelVector->getSelSize(); i++) {
132 const auto [operandPos, resultPos] = getSelectedPos(i, operandSelVector,
133 resultSelVector, operandIsUnfiltered, resultIsUnfiltered);
134 if (noNullsGuaranteed) {
136 result, resultPos, dataPtr);
137 } else {
138 result.setNull(resultPos, operand.isNull(operandPos));
139 if (!result.isNull(resultPos)) {
141 result, resultPos, dataPtr);
142 }
143 }
144 }
145 }
146
147 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC, typename OP_WRAPPER>
148 static void executeSwitch(common::ValueVector& operand,
149 common::SelectionVector* operandSelVector, common::ValueVector& result,
150 common::SelectionVector* resultSelVector, void* dataPtr) {
151 result.resetAuxiliaryBuffer();
152 if (operand.state->isFlat()) {
153 auto inputPos = (*operandSelVector)[0];
154 auto resultPos = (*resultSelVector)[0];
155 result.setNull(resultPos, operand.isNull(inputPos));
156 if (!result.isNull(resultPos)) {
158 result, resultPos, dataPtr);
159 }
160 } else {
162 operandSelVector, result, resultSelVector, dataPtr);
163 }
164 }
165
166 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
167 static void execute(common::ValueVector& operand, common::SelectionVector* operandSelVector,
168 common::ValueVector& result, common::SelectionVector* resultSelVector) {
170 operandSelVector, result, resultSelVector, nullptr /* dataPtr */);
171 }
172
173 template<typename OPERAND_TYPE, typename RESULT_TYPE, typename FUNC>
175 common::SelectionVector* operandSelVector, common::ValueVector& result,
176 common::SelectionVector* resultSelVector, void* dataPtr) {
177 result.resetAuxiliaryBuffer();
178 auto inputPos = (*operandSelVector)[0];
179 auto resultPos = (*resultSelVector)[0];
181 inputPos, result, resultPos, dataPtr);
182 }
183};
184
185} // namespace function
186} // namespace kuzu
Definition sel_vector.h:98
sel_t getSelSize() const
Definition sel_vector.h:68
bool isUnfiltered() const
Definition sel_vector.h:75
Definition value_vector.h:21
void setAllNonNull()
Definition value_vector.h:76
uint8_t isNull(uint32_t pos) const
Definition value_vector.h:84
bool hasNoNullsGuarantee() const
Definition value_vector.h:78
void setNull(uint32_t pos, bool isNull)
std::shared_ptr< DataChunkState > state
Definition value_vector.h:146
uint32_t idx_t
Definition types.h:45
uint64_t sel_t
Definition types.h:30
Definition binary_function_executor.h:6
Definition array_utils.h:7
Definition cast_function_bind_data.h:9
common::CSVOption option
Definition cast_function_bind_data.h:12
Definition unary_function_executor.h:80
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *)
Definition unary_function_executor.h:82
Definition unary_function_executor.h:55
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:57
Definition unary_function_executor.h:102
static void executeOnValue(common::ValueVector &inputVector, uint64_t inputPos, common::ValueVector &resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:105
static std::pair< common::sel_t, common::sel_t > getSelectedPos(common::idx_t selIdx, common::SelectionVector *operandSelVector, common::SelectionVector *resultSelVector, bool operandIsUnfiltered, bool resultIsUnfiltered)
Definition unary_function_executor.h:111
static void executeSequence(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:174
static void executeSwitch(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:148
static void executeOnSelectedValues(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:120
static void execute(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector)
Definition unary_function_executor.h:167
Definition unary_function_executor.h:14
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *)
Definition unary_function_executor.h:16
Definition unary_function_executor.h:69
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *)
Definition unary_function_executor.h:71
Definition unary_function_executor.h:25
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t, void *dataPtr)
Definition unary_function_executor.h:27
Definition unary_function_executor.h:35
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *)
Definition unary_function_executor.h:37
Definition unary_function_executor.h:46
static void operation(void *, uint64_t, void *resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:48
Definition unary_function_executor.h:91
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:93