All Downloads are FREE. Search and download functionalities are using the official Maven repository.

google.cloud.vision.v1p3beta1.product_search.proto Maven / Gradle / Ivy

// Copyright 2019 Google LLC.
//
// 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.
//

syntax = "proto3";

package google.cloud.vision.v1p3beta1;

import "google/api/annotations.proto";
import "google/api/resource.proto";
import "google/cloud/vision/v1p3beta1/geometry.proto";
import "google/cloud/vision/v1p3beta1/product_search_service.proto";
import "google/protobuf/timestamp.proto";

option cc_enable_arenas = true;
option go_package = "google.golang.org/genproto/googleapis/cloud/vision/v1p3beta1;vision";
option java_multiple_files = true;
option java_outer_classname = "ProductSearchProto";
option java_package = "com.google.cloud.vision.v1p3beta1";

// Parameters for a product search request.
message ProductSearchParams {
  // The resource name of the catalog to search.
  //
  // Format is: `productSearch/catalogs/CATALOG_NAME`.
  string catalog_name = 1;

  // The category to search in.
  // Optional. It is inferred by the system if it is not specified.
  // [Deprecated] Use `product_category`.
  ProductSearchCategory category = 2;

  // The product category to search in.
  // Optional. It is inferred by the system if it is not specified.
  // Supported values are `bag`, `shoe`, `sunglasses`, `dress`, `outerwear`,
  // `skirt`, `top`, `shorts`, and `pants`.
  string product_category = 5;

  // The bounding polygon around the area of interest in the image.
  // Optional. If it is not specified, system discretion will be applied.
  // [Deprecated] Use `bounding_poly`.
  NormalizedBoundingPoly normalized_bounding_poly = 3;

  // The bounding polygon around the area of interest in the image.
  // Optional. If it is not specified, system discretion will be applied.
  BoundingPoly bounding_poly = 9;

  // Specifies the verbosity of the  product search results.
  // Optional. Defaults to `BASIC`.
  ProductSearchResultsView view = 4;

  // The resource name of a
  // [ProductSet][google.cloud.vision.v1p3beta1.ProductSet] to be searched for
  // similar images.
  //
  // Format is:
  // `projects/PROJECT_ID/locations/LOC_ID/productSets/PRODUCT_SET_ID`.
  string product_set = 6 [(google.api.resource_reference) = {
                            type: "vision.googleapis.com/ProductSet"
                          }];

  // The list of product categories to search in. Currently, we only consider
  // the first category, and either "homegoods" or "apparel" should be
  // specified.
  repeated string product_categories = 7;

  // The filtering expression. This can be used to restrict search results based
  // on Product labels. We currently support an AND of OR of key-value
  // expressions, where each expression within an OR must have the same key.
  //
  // For example, "(color = red OR color = blue) AND brand = Google" is
  // acceptable, but not "(color = red OR brand = Google)" or "color: red".
  string filter = 8;
}

// Results for a product search request.
message ProductSearchResults {
  // Information about a product.
  message ProductInfo {
    // Product ID.
    string product_id = 1;

    // The URI of the image which matched the query image.
    //
    // This field is returned only if `view` is set to `FULL` in
    // the request.
    string image_uri = 2;

    // A confidence level on the match, ranging from 0 (no confidence) to
    // 1 (full confidence).
    //
    // This field is returned only if `view` is set to `FULL` in
    // the request.
    float score = 3;
  }

  // Information about a product.
  message Result {
    // The Product.
    Product product = 1;

    // A confidence level on the match, ranging from 0 (no confidence) to
    // 1 (full confidence).
    //
    // This field is returned only if `view` is set to `FULL` in
    // the request.
    float score = 2;

    // The resource name of the image from the product that is the closest match
    // to the query.
    string image = 3;
  }

  // Product category.
  // [Deprecated] Use `product_category`.
  ProductSearchCategory category = 1;

  // Product category.
  // Supported values are `bag` and `shoe`.
  // [Deprecated] `product_category` is provided in each Product.
  string product_category = 4;

  // Timestamp of the index which provided these results. Changes made after
  // this time are not reflected in the current results.
  google.protobuf.Timestamp index_time = 2;

  // List of detected products.
  repeated ProductInfo products = 3;

  // List of results, one for each product match.
  repeated Result results = 5;
}

// Supported product search categories.
enum ProductSearchCategory {
  // Default value used when a category is not specified.
  PRODUCT_SEARCH_CATEGORY_UNSPECIFIED = 0;

  // Shoes category.
  SHOES = 1;

  // Bags category.
  BAGS = 2;
}

// Specifies the fields to include in product search results.
enum ProductSearchResultsView {
  // Product search results contain only `product_category` and `product_id`.
  // Default value.
  BASIC = 0;

  // Product search results contain `product_category`, `product_id`,
  // `image_uri`, and `score`.
  FULL = 1;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy