// Licensed to the LF AI & Data foundation under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #pragma once #include #include "common/EasyAssert.h" #include "common/Types.h" #include "common/Vector.h" #include "exec/expression/Expr.h" #include "segcore/SegmentInterface.h" namespace milvus { namespace exec { template struct TermElementFuncSet { bool operator()(const std::unordered_set& srcs, T val) { return srcs.find(val) != srcs.end(); } }; template struct TermIndexFunc { typedef std:: conditional_t, std::string, T> IndexInnerType; using Index = index::ScalarIndex; FixedVector operator()(Index* index, size_t n, const IndexInnerType* val) { return index->In(n, val); } }; class PhyTermFilterExpr : public SegmentExpr { public: PhyTermFilterExpr( const std::vector>& input, const std::shared_ptr& expr, const std::string& name, const segcore::SegmentInternalInterface* segment, int64_t active_count, milvus::Timestamp timestamp, int64_t batch_size) : SegmentExpr(std::move(input), name, segment, expr->column_.field_id_, active_count, batch_size), expr_(expr), query_timestamp_(timestamp) { } void Eval(EvalCtx& context, VectorPtr& result) override; void SetUseCacheOffsets() { use_cache_offsets_ = true; } private: void InitPkCacheOffset(); template bool CanSkipSegment(); VectorPtr ExecPkTermImpl(); template VectorPtr ExecVisitorImpl(); template VectorPtr ExecVisitorImplForIndex(); template VectorPtr ExecVisitorImplForData(); template VectorPtr ExecVisitorImplTemplateJson(); template VectorPtr ExecTermJsonVariableInField(); template VectorPtr ExecTermJsonFieldInVariable(); template VectorPtr ExecVisitorImplTemplateArray(); template VectorPtr ExecTermArrayVariableInField(); template VectorPtr ExecTermArrayFieldInVariable(); private: std::shared_ptr expr_; milvus::Timestamp query_timestamp_; // If expr is like "pk in (..)", can use pk index to optimize bool use_cache_offsets_{false}; bool cached_offsets_inited_{false}; ColumnVectorPtr cached_offsets_; FixedVector cached_bits_; }; } //namespace exec } // namespace milvus