serving_config.proto 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. syntax = "proto3";
  15. package google.cloud.retail.v2alpha;
  16. import "google/api/field_behavior.proto";
  17. import "google/api/resource.proto";
  18. import "google/cloud/retail/v2alpha/common.proto";
  19. import "google/cloud/retail/v2alpha/search_service.proto";
  20. option csharp_namespace = "Google.Cloud.Retail.V2Alpha";
  21. option go_package = "google.golang.org/genproto/googleapis/cloud/retail/v2alpha;retail";
  22. option java_multiple_files = true;
  23. option java_outer_classname = "ServingConfigProto";
  24. option java_package = "com.google.cloud.retail.v2alpha";
  25. option objc_class_prefix = "RETAIL";
  26. option php_namespace = "Google\\Cloud\\Retail\\V2alpha";
  27. option ruby_package = "Google::Cloud::Retail::V2alpha";
  28. // Configures metadata that is used to generate serving time results (e.g.
  29. // search results or recommendation predictions).
  30. // The ServingConfig is passed in the search and predict request and together
  31. // with the Catalog.default_branch, generates results.
  32. message ServingConfig {
  33. option (google.api.resource) = {
  34. type: "retail.googleapis.com/ServingConfig"
  35. pattern: "projects/{project}/locations/{location}/catalogs/{catalog}/servingConfigs/{serving_config}"
  36. };
  37. // Immutable. Fully qualified name
  38. // `projects/*/locations/global/catalogs/*/servingConfig/*`
  39. string name = 1 [(google.api.field_behavior) = IMMUTABLE];
  40. // Required. The human readable serving config display name. Used in Retail
  41. // UI.
  42. //
  43. // This field must be a UTF-8 encoded string with a length limit of 128
  44. // characters. Otherwise, an INVALID_ARGUMENT error is returned.
  45. string display_name = 2 [(google.api.field_behavior) = REQUIRED];
  46. // The id of the model to use at serving time.
  47. // Currently only RecommendationModels are supported:
  48. // https://cloud.google.com/retail/recommendations-ai/docs/create-models
  49. // Can be changed but only to a compatible model (e.g.
  50. // others-you-may-like CTR to others-you-may-like CVR).
  51. //
  52. // Required when
  53. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  54. // is
  55. // [SOLUTION_TYPE_RECOMMENDATION][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_RECOMMENDATION].
  56. string model_id = 3;
  57. // How much price ranking we want in serving results.
  58. // Price reranking causes product items with a similar
  59. // recommendation probability to be ordered by price, with the
  60. // highest-priced items first. This setting could result in a decrease in
  61. // click-through and conversion rates.
  62. // Allowed values are:
  63. //
  64. // * 'no-price-reranking'
  65. // * 'low-price-raranking'
  66. // * 'medium-price-reranking'
  67. // * 'high-price-reranking'
  68. //
  69. // If not specified, we choose default based on model type. Default value:
  70. // 'no-price-reranking'.
  71. //
  72. // Can only be set if
  73. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  74. // is
  75. // [SOLUTION_TYPE_RECOMMENDATION][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_RECOMMENDATION].
  76. string price_reranking_level = 4;
  77. // Facet specifications for faceted search. If empty, no facets are returned.
  78. // The ids refer to the ids of [Control][google.cloud.retail.v2alpha.Control]
  79. // resources with only the Facet control set. These controls are assumed to be
  80. // in the same [Catalog][google.cloud.retail.v2alpha.Catalog] as the
  81. // [ServingConfig][google.cloud.retail.v2alpha.ServingConfig].
  82. // A maximum of 100 values are allowed. Otherwise, an INVALID_ARGUMENT error
  83. // is returned.
  84. //
  85. // Can only be set if
  86. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  87. // is
  88. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  89. repeated string facet_control_ids = 5;
  90. // The specification for dynamically generated facets. Notice that only
  91. // textual facets can be dynamically generated.
  92. //
  93. // Can only be set if
  94. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  95. // is
  96. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  97. SearchRequest.DynamicFacetSpec dynamic_facet_spec = 6;
  98. // Condition boost specifications. If a product matches multiple conditions
  99. // in the specifications, boost scores from these specifications are all
  100. // applied and combined in a non-linear way. Maximum number of
  101. // specifications is 100.
  102. //
  103. // Notice that if both
  104. // [ServingConfig.boost_control_ids][google.cloud.retail.v2alpha.ServingConfig.boost_control_ids]
  105. // and
  106. // [SearchRequest.boost_spec][google.cloud.retail.v2alpha.SearchRequest.boost_spec]
  107. // are set, the boost conditions from both places are evaluated. If a search
  108. // request matches multiple boost conditions, the final boost score is equal
  109. // to the sum of the boost scores from all matched boost conditions.
  110. //
  111. // Can only be set if
  112. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  113. // is
  114. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  115. repeated string boost_control_ids = 7;
  116. // Condition filter specifications. If a product matches multiple conditions
  117. // in the specifications, filters from these specifications are all
  118. // applied and combined via the AND operator. Maximum number of
  119. // specifications is 100.
  120. //
  121. // Can only be set if
  122. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  123. // is
  124. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  125. repeated string filter_control_ids = 9;
  126. // Condition redirect specifications. Only the first triggered redirect action
  127. // is applied, even if multiple apply. Maximum number of specifications is
  128. // 1000.
  129. //
  130. // Can only be set if
  131. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  132. // is
  133. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  134. repeated string redirect_control_ids = 10;
  135. // Condition synonyms specifications. If multiple syonyms conditions match,
  136. // all matching synonyms control in the list will execute. Order of controls
  137. // in the list will not matter. Maximum number of specifications is
  138. // 100.
  139. //
  140. // Can only be set if
  141. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  142. // is
  143. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  144. repeated string twoway_synonyms_control_ids = 18;
  145. // Condition oneway synonyms specifications. If multiple oneway synonyms
  146. // conditions match, all matching oneway synonyms controls in the list will
  147. // execute. Order of controls in the list will not matter. Maximum number of
  148. // specifications is 100.
  149. //
  150. // Can only be set if
  151. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  152. // is
  153. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  154. repeated string oneway_synonyms_control_ids = 12;
  155. // Condition do not associate specifications. If multiple do not associate
  156. // conditions match, all matching do not associate controls in the list will
  157. // execute.
  158. // - Order does not matter.
  159. // - Maximum number of specifications is 100.
  160. //
  161. // Can only be set if
  162. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  163. // is
  164. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  165. repeated string do_not_associate_control_ids = 13;
  166. // Condition replacement specifications.
  167. // - Applied according to the order in the list.
  168. // - A previously replaced term can not be re-replaced.
  169. // - Maximum number of specifications is 100.
  170. //
  171. // Can only be set if
  172. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  173. // is
  174. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  175. repeated string replacement_control_ids = 14;
  176. // Condition ignore specifications. If multiple ignore
  177. // conditions match, all matching ignore controls in the list will
  178. // execute.
  179. // - Order does not matter.
  180. // - Maximum number of specifications is 100.
  181. //
  182. // Can only be set if
  183. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  184. // is
  185. // [SOLUTION_TYPE_SEARCH][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_SEARCH].
  186. repeated string ignore_control_ids = 15;
  187. // How much diversity to use in recommendation model results e.g.
  188. // 'medium-diversity' or 'high-diversity'. Currently supported values:
  189. //
  190. // * 'no-diversity'
  191. // * 'low-diversity'
  192. // * 'medium-diversity'
  193. // * 'high-diversity'
  194. // * 'auto-diversity'
  195. //
  196. // If not specified, we choose default based on recommendation model
  197. // type. Default value: 'no-diversity'.
  198. //
  199. // Can only be set if
  200. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  201. // is
  202. // [SOLUTION_TYPE_RECOMMENDATION][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_RECOMMENDATION].
  203. string diversity_level = 8;
  204. // Whether to add additional category filters on the 'similar-items' model.
  205. // If not specified, we enable it by default.
  206. // Allowed values are:
  207. //
  208. // * 'no-category-match': No additional filtering of original results from
  209. // the model and the customer's filters.
  210. // * 'relaxed-category-match': Only keep results with categories that match
  211. // at least one item categories in the PredictRequests's context item.
  212. // * If customer also sends filters in the PredictRequest, then the results
  213. // will satisfy both conditions (user given and category match).
  214. //
  215. // Can only be set if
  216. // [solution_types][google.cloud.retail.v2alpha.ServingConfig.solution_types]
  217. // is
  218. // [SOLUTION_TYPE_RECOMMENDATION][google.cloud.retail.v2main.SolutionType.SOLUTION_TYPE_RECOMMENDATION].
  219. string enable_category_filter_level = 16;
  220. // Required. Immutable. Specifies the solution types that a serving config can
  221. // be associated with. Currently we support setting only one type of solution.
  222. repeated SolutionType solution_types = 19 [
  223. (google.api.field_behavior) = REQUIRED,
  224. (google.api.field_behavior) = IMMUTABLE
  225. ];
  226. }