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* ) {
20 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
21 resultVector_.getValue<RESULT_TYPE>(resultPos));
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 ,
void* dataPtr) {
31 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos), resultVector_, dataPtr);
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* ) {
41 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
42 resultVector_.getValue<RESULT_TYPE>(resultPos), resultVector_);
47 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC>
48 static void operation(
void* , uint64_t ,
void* resultVector,
49 uint64_t resultPos,
void* dataPtr) {
51 FUNC::operation(resultVector_.getValue<RESULT_TYPE>(resultPos), resultVector_, dataPtr);
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) {
63 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
64 resultVector_->getValue<RESULT_TYPE>(resultPos), resultVector_, inputPos,
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* ) {
75 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
76 resultVector_.getValue<RESULT_TYPE>(resultPos), inputVector_, resultVector_);
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* ) {
86 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
87 resultVector_.getValue<RESULT_TYPE>(resultPos), inputVector_, resultVector_);
92 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC>
93 static void operation(
void* inputVector, uint64_t inputPos,
void* resultVector,
94 uint64_t resultPos,
void* dataPtr) {
97 FUNC::operation(inputVector_, resultVector_, inputPos, resultPos, dataPtr);
102 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC>
103 static inline void operation(
void* inputVector, uint64_t inputPos,
void* resultVector,
104 uint64_t resultPos,
void* dataPtr) {
107 FUNC::operation(inputVector_.getValue<OPERAND_TYPE>(inputPos),
108 resultVector_.getValue<RESULT_TYPE>(resultPos), dataPtr);
114 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC,
typename OP_WRAPPER>
117 OP_WRAPPER::template operation<OPERAND_TYPE, RESULT_TYPE, FUNC>((
void*)&inputVector,
118 inputPos, (
void*)&resultVector, resultPos, dataPtr);
123 bool operandIsUnfiltered,
bool resultIsUnfiltered) {
124 common::sel_t operandPos = operandIsUnfiltered ? selIdx : (*operandSelVector)[selIdx];
125 common::sel_t resultPos = resultIsUnfiltered ? selIdx : (*resultSelVector)[selIdx];
126 return {operandPos, resultPos};
129 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC,
typename OP_WRAPPER>
134 if (noNullsGuaranteed) {
138 const bool operandIsUnfiltered = operandSelVector->
isUnfiltered();
139 const bool resultIsUnfiltered = resultSelVector->
isUnfiltered();
141 for (
auto i = 0u; i < operandSelVector->
getSelSize(); i++) {
142 const auto [operandPos, resultPos] =
getSelectedPos(i, operandSelVector,
143 resultSelVector, operandIsUnfiltered, resultIsUnfiltered);
144 if (noNullsGuaranteed) {
146 result, resultPos, dataPtr);
149 if (!result.
isNull(resultPos)) {
151 result, resultPos, dataPtr);
157 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC,
typename OP_WRAPPER>
162 if (operand.
state->isFlat()) {
163 auto inputPos = (*operandSelVector)[0];
164 auto resultPos = (*resultSelVector)[0];
166 if (!result.
isNull(resultPos)) {
168 result, resultPos, dataPtr);
172 operandSelVector, result, resultSelVector, dataPtr);
176 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC>
180 operandSelVector, result, resultSelVector,
nullptr );
183 template<
typename OPERAND_TYPE,
typename RESULT_TYPE,
typename FUNC>
188 auto inputPos = (*operandSelVector)[0];
189 auto resultPos = (*resultSelVector)[0];
191 inputPos, result, resultPos, dataPtr);
Definition sel_vector.h:96
sel_t getSelSize() const
Definition sel_vector.h:66
bool isUnfiltered() const
Definition sel_vector.h:73
Definition value_vector.h:21
void resetAuxiliaryBuffer()
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:91
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:93
Definition unary_function_executor.h:112
static void executeOnValue(common::ValueVector &inputVector, uint64_t inputPos, common::ValueVector &resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:115
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:121
static void executeSequence(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:184
static void executeSwitch(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:158
static void executeOnSelectedValues(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector, void *dataPtr)
Definition unary_function_executor.h:130
static void execute(common::ValueVector &operand, common::SelectionVector *operandSelVector, common::ValueVector &result, common::SelectionVector *resultSelVector)
Definition unary_function_executor.h:177
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:101
static void operation(void *inputVector, uint64_t inputPos, void *resultVector, uint64_t resultPos, void *dataPtr)
Definition unary_function_executor.h:103