// Copyright (C) 2019-2020 Zilliz. All rights reserved. // // Licensed 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 #include #include #include #include #include "db/Types.h" #include "utils/Json.h" namespace milvus { namespace query { enum class CompareOperator { LT = 0, LTE, EQ, GT, GTE, NE, }; enum class QueryRelation { INVALID = 0, R1, R2, R3, R4, AND, OR, }; struct QueryColumn { std::string name; std::string column_value; }; struct TermQuery { milvus::json json_obj; // std::string field_name; // std::vector field_value; // float boost; }; using TermQueryPtr = std::shared_ptr; struct CompareExpr { CompareOperator compare_operator; std::string operand; }; struct RangeQuery { milvus::json json_obj; // std::string field_name; // std::vector compare_expr; // float boost; }; using RangeQueryPtr = std::shared_ptr; struct VectorRecord { std::vector float_data; std::vector binary_data; }; struct VectorQuery { std::string field_name; milvus::json extra_params = {}; int64_t topk; int64_t nq; std::string metric_type = ""; float boost; VectorRecord query_vector; }; using VectorQueryPtr = std::shared_ptr; struct LeafQuery; using LeafQueryPtr = std::shared_ptr; struct BinaryQuery; using BinaryQueryPtr = std::shared_ptr; struct GeneralQuery { LeafQueryPtr leaf; BinaryQueryPtr bin = std::make_shared(); }; using GeneralQueryPtr = std::shared_ptr; struct LeafQuery { TermQueryPtr term_query; RangeQueryPtr range_query; std::string vector_placeholder; float query_boost; }; struct BinaryQuery { GeneralQueryPtr left_query; GeneralQueryPtr right_query; QueryRelation relation; float query_boost; }; struct Query { GeneralQueryPtr root; std::unordered_map vectors; std::string collection_id; std::vector partitions; std::vector field_names; std::set index_fields; std::unordered_map metric_types; }; using QueryPtr = std::shared_ptr; } // namespace query } // namespace milvus