orca-sdk 0.0.93__py3-none-any.whl → 0.0.95__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. orca_sdk/__init__.py +13 -4
  2. orca_sdk/_generated_api_client/api/__init__.py +84 -34
  3. orca_sdk/_generated_api_client/api/classification_model/create_classification_model_classification_model_post.py +170 -0
  4. orca_sdk/_generated_api_client/api/classification_model/{get_model_classification_model_name_or_id_get.py → delete_classification_model_classification_model_name_or_id_delete.py} +20 -20
  5. orca_sdk/_generated_api_client/api/classification_model/{delete_evaluation_classification_model_model_name_or_id_evaluation_task_id_delete.py → delete_classification_model_evaluation_classification_model_model_name_or_id_evaluation_task_id_delete.py} +4 -4
  6. orca_sdk/_generated_api_client/api/classification_model/{create_evaluation_classification_model_model_name_or_id_evaluation_post.py → evaluate_classification_model_classification_model_model_name_or_id_evaluation_post.py} +14 -14
  7. orca_sdk/_generated_api_client/api/classification_model/get_classification_model_classification_model_name_or_id_get.py +156 -0
  8. orca_sdk/_generated_api_client/api/classification_model/{get_evaluation_classification_model_model_name_or_id_evaluation_task_id_get.py → get_classification_model_evaluation_classification_model_model_name_or_id_evaluation_task_id_get.py} +16 -16
  9. orca_sdk/_generated_api_client/api/classification_model/{list_evaluations_classification_model_model_name_or_id_evaluation_get.py → list_classification_model_evaluations_classification_model_model_name_or_id_evaluation_get.py} +16 -16
  10. orca_sdk/_generated_api_client/api/classification_model/list_classification_models_classification_model_get.py +127 -0
  11. orca_sdk/_generated_api_client/api/classification_model/{predict_gpu_classification_model_name_or_id_prediction_post.py → predict_label_gpu_classification_model_name_or_id_prediction_post.py} +14 -14
  12. orca_sdk/_generated_api_client/api/classification_model/update_classification_model_classification_model_name_or_id_patch.py +183 -0
  13. orca_sdk/_generated_api_client/api/datasource/download_datasource_datasource_name_or_id_download_get.py +172 -0
  14. orca_sdk/_generated_api_client/api/memoryset/clone_memoryset_memoryset_name_or_id_clone_post.py +22 -22
  15. orca_sdk/_generated_api_client/api/memoryset/create_memoryset_memoryset_post.py +22 -22
  16. orca_sdk/_generated_api_client/api/memoryset/get_memories_memoryset_name_or_id_memories_get_post.py +38 -16
  17. orca_sdk/_generated_api_client/api/memoryset/get_memory_memoryset_name_or_id_memory_memory_id_get.py +29 -12
  18. orca_sdk/_generated_api_client/api/memoryset/get_memoryset_memoryset_name_or_id_get.py +12 -12
  19. orca_sdk/_generated_api_client/api/memoryset/insert_memories_gpu_memoryset_name_or_id_memory_post.py +17 -14
  20. orca_sdk/_generated_api_client/api/memoryset/list_memorysets_memoryset_get.py +72 -19
  21. orca_sdk/_generated_api_client/api/memoryset/memoryset_lookup_gpu_memoryset_name_or_id_lookup_post.py +31 -12
  22. orca_sdk/_generated_api_client/api/memoryset/potential_duplicate_groups_memoryset_name_or_id_potential_duplicate_groups_get.py +49 -20
  23. orca_sdk/_generated_api_client/api/memoryset/query_memoryset_memoryset_name_or_id_memories_post.py +38 -16
  24. orca_sdk/_generated_api_client/api/memoryset/update_memories_gpu_memoryset_name_or_id_memories_patch.py +54 -29
  25. orca_sdk/_generated_api_client/api/memoryset/update_memory_gpu_memoryset_name_or_id_memory_patch.py +44 -26
  26. orca_sdk/_generated_api_client/api/memoryset/update_memoryset_memoryset_name_or_id_patch.py +22 -22
  27. orca_sdk/_generated_api_client/api/predictive_model/__init__.py +0 -0
  28. orca_sdk/_generated_api_client/api/predictive_model/list_predictive_models_predictive_model_get.py +150 -0
  29. orca_sdk/_generated_api_client/api/regression_model/__init__.py +0 -0
  30. orca_sdk/_generated_api_client/api/{classification_model/create_model_classification_model_post.py → regression_model/create_regression_model_regression_model_post.py} +27 -27
  31. orca_sdk/_generated_api_client/api/regression_model/delete_regression_model_evaluation_regression_model_model_name_or_id_evaluation_task_id_delete.py +168 -0
  32. orca_sdk/_generated_api_client/api/{classification_model/delete_model_classification_model_name_or_id_delete.py → regression_model/delete_regression_model_regression_model_name_or_id_delete.py} +5 -5
  33. orca_sdk/_generated_api_client/api/regression_model/evaluate_regression_model_regression_model_model_name_or_id_evaluation_post.py +183 -0
  34. orca_sdk/_generated_api_client/api/regression_model/get_regression_model_evaluation_regression_model_model_name_or_id_evaluation_task_id_get.py +170 -0
  35. orca_sdk/_generated_api_client/api/regression_model/get_regression_model_regression_model_name_or_id_get.py +156 -0
  36. orca_sdk/_generated_api_client/api/regression_model/list_regression_model_evaluations_regression_model_model_name_or_id_evaluation_get.py +161 -0
  37. orca_sdk/_generated_api_client/api/{classification_model/list_models_classification_model_get.py → regression_model/list_regression_models_regression_model_get.py} +17 -17
  38. orca_sdk/_generated_api_client/api/regression_model/predict_score_gpu_regression_model_name_or_id_prediction_post.py +190 -0
  39. orca_sdk/_generated_api_client/api/{classification_model/update_model_classification_model_name_or_id_patch.py → regression_model/update_regression_model_regression_model_name_or_id_patch.py} +27 -27
  40. orca_sdk/_generated_api_client/api/task/get_task_task_task_id_get.py +156 -0
  41. orca_sdk/_generated_api_client/api/task/list_tasks_task_get.py +60 -10
  42. orca_sdk/_generated_api_client/api/telemetry/count_predictions_telemetry_prediction_count_post.py +10 -10
  43. orca_sdk/_generated_api_client/api/telemetry/get_prediction_telemetry_prediction_prediction_id_get.py +35 -12
  44. orca_sdk/_generated_api_client/api/telemetry/list_memories_with_feedback_telemetry_memories_post.py +20 -12
  45. orca_sdk/_generated_api_client/api/telemetry/list_predictions_telemetry_prediction_post.py +35 -12
  46. orca_sdk/_generated_api_client/models/__init__.py +90 -24
  47. orca_sdk/_generated_api_client/models/base_score_prediction_result.py +108 -0
  48. orca_sdk/_generated_api_client/models/{evaluation_request.py → classification_evaluation_request.py} +13 -45
  49. orca_sdk/_generated_api_client/models/{classification_evaluation_result.py → classification_metrics.py} +106 -56
  50. orca_sdk/_generated_api_client/models/{rac_model_metadata.py → classification_model_metadata.py} +51 -43
  51. orca_sdk/_generated_api_client/models/{prediction_request.py → classification_prediction_request.py} +31 -6
  52. orca_sdk/_generated_api_client/models/{clone_labeled_memoryset_request.py → clone_memoryset_request.py} +5 -5
  53. orca_sdk/_generated_api_client/models/column_info.py +31 -0
  54. orca_sdk/_generated_api_client/models/count_predictions_request.py +195 -0
  55. orca_sdk/_generated_api_client/models/{create_rac_model_request.py → create_classification_model_request.py} +25 -57
  56. orca_sdk/_generated_api_client/models/{create_labeled_memoryset_request.py → create_memoryset_request.py} +73 -56
  57. orca_sdk/_generated_api_client/models/create_memoryset_request_index_params.py +66 -0
  58. orca_sdk/_generated_api_client/models/create_memoryset_request_index_type.py +13 -0
  59. orca_sdk/_generated_api_client/models/create_regression_model_request.py +137 -0
  60. orca_sdk/_generated_api_client/models/embedding_evaluation_payload.py +187 -0
  61. orca_sdk/_generated_api_client/models/embedding_evaluation_response.py +10 -0
  62. orca_sdk/_generated_api_client/models/evaluation_response.py +22 -9
  63. orca_sdk/_generated_api_client/models/evaluation_response_classification_metrics.py +140 -0
  64. orca_sdk/_generated_api_client/models/evaluation_response_regression_metrics.py +140 -0
  65. orca_sdk/_generated_api_client/models/http_validation_error.py +86 -0
  66. orca_sdk/_generated_api_client/models/list_predictions_request.py +62 -0
  67. orca_sdk/_generated_api_client/models/memory_type.py +9 -0
  68. orca_sdk/_generated_api_client/models/memoryset_analysis_configs.py +0 -20
  69. orca_sdk/_generated_api_client/models/{labeled_memoryset_metadata.py → memoryset_metadata.py} +73 -13
  70. orca_sdk/_generated_api_client/models/memoryset_metadata_index_params.py +55 -0
  71. orca_sdk/_generated_api_client/models/memoryset_metadata_index_type.py +13 -0
  72. orca_sdk/_generated_api_client/models/{labeled_memoryset_update.py → memoryset_update.py} +19 -31
  73. orca_sdk/_generated_api_client/models/not_found_error_response_resource_type_0.py +1 -0
  74. orca_sdk/_generated_api_client/models/{paginated_labeled_memory_with_feedback_metrics.py → paginated_union_labeled_memory_with_feedback_metrics_scored_memory_with_feedback_metrics.py} +37 -10
  75. orca_sdk/_generated_api_client/models/{precision_recall_curve.py → pr_curve.py} +5 -13
  76. orca_sdk/_generated_api_client/models/{rac_model_update.py → predictive_model_update.py} +14 -5
  77. orca_sdk/_generated_api_client/models/pretrained_embedding_model_metadata.py +11 -1
  78. orca_sdk/_generated_api_client/models/pretrained_embedding_model_name.py +5 -0
  79. orca_sdk/_generated_api_client/models/rar_head_type.py +8 -0
  80. orca_sdk/_generated_api_client/models/regression_evaluation_request.py +148 -0
  81. orca_sdk/_generated_api_client/models/regression_metrics.py +172 -0
  82. orca_sdk/_generated_api_client/models/regression_model_metadata.py +177 -0
  83. orca_sdk/_generated_api_client/models/regression_prediction_request.py +195 -0
  84. orca_sdk/_generated_api_client/models/roc_curve.py +0 -8
  85. orca_sdk/_generated_api_client/models/score_prediction_memory_lookup.py +196 -0
  86. orca_sdk/_generated_api_client/models/score_prediction_memory_lookup_metadata.py +68 -0
  87. orca_sdk/_generated_api_client/models/score_prediction_with_memories_and_feedback.py +252 -0
  88. orca_sdk/_generated_api_client/models/scored_memory.py +172 -0
  89. orca_sdk/_generated_api_client/models/scored_memory_insert.py +128 -0
  90. orca_sdk/_generated_api_client/models/scored_memory_insert_metadata.py +68 -0
  91. orca_sdk/_generated_api_client/models/scored_memory_lookup.py +180 -0
  92. orca_sdk/_generated_api_client/models/scored_memory_lookup_metadata.py +68 -0
  93. orca_sdk/_generated_api_client/models/scored_memory_metadata.py +68 -0
  94. orca_sdk/_generated_api_client/models/scored_memory_update.py +171 -0
  95. orca_sdk/_generated_api_client/models/scored_memory_update_metadata_type_0.py +68 -0
  96. orca_sdk/_generated_api_client/models/scored_memory_with_feedback_metrics.py +193 -0
  97. orca_sdk/_generated_api_client/models/scored_memory_with_feedback_metrics_feedback_metrics.py +68 -0
  98. orca_sdk/_generated_api_client/models/scored_memory_with_feedback_metrics_metadata.py +68 -0
  99. orca_sdk/_generated_api_client/models/update_prediction_request.py +20 -0
  100. orca_sdk/_generated_api_client/models/validation_error.py +99 -0
  101. orca_sdk/_shared/__init__.py +9 -1
  102. orca_sdk/_shared/metrics.py +257 -87
  103. orca_sdk/_shared/metrics_test.py +136 -77
  104. orca_sdk/_utils/data_parsing.py +0 -3
  105. orca_sdk/_utils/data_parsing_test.py +0 -3
  106. orca_sdk/_utils/prediction_result_ui.py +55 -23
  107. orca_sdk/classification_model.py +184 -174
  108. orca_sdk/classification_model_test.py +178 -142
  109. orca_sdk/conftest.py +77 -26
  110. orca_sdk/datasource.py +34 -0
  111. orca_sdk/datasource_test.py +9 -1
  112. orca_sdk/embedding_model.py +136 -14
  113. orca_sdk/embedding_model_test.py +10 -6
  114. orca_sdk/job.py +329 -0
  115. orca_sdk/job_test.py +48 -0
  116. orca_sdk/memoryset.py +882 -161
  117. orca_sdk/memoryset_test.py +58 -23
  118. orca_sdk/regression_model.py +647 -0
  119. orca_sdk/regression_model_test.py +338 -0
  120. orca_sdk/telemetry.py +225 -106
  121. orca_sdk/telemetry_test.py +34 -30
  122. {orca_sdk-0.0.93.dist-info → orca_sdk-0.0.95.dist-info}/METADATA +2 -4
  123. {orca_sdk-0.0.93.dist-info → orca_sdk-0.0.95.dist-info}/RECORD +124 -74
  124. orca_sdk/_utils/task.py +0 -73
  125. {orca_sdk-0.0.93.dist-info → orca_sdk-0.0.95.dist-info}/WHEEL +0 -0
@@ -18,18 +18,21 @@ from attrs import define as _attrs_define
18
18
  from attrs import field as _attrs_field
19
19
  from dateutil.parser import isoparse
20
20
 
21
+ from ..models.memory_type import MemoryType
22
+ from ..models.memoryset_metadata_index_type import MemorysetMetadataIndexType
21
23
  from ..models.pretrained_embedding_model_name import PretrainedEmbeddingModelName
22
24
  from ..models.task_status import TaskStatus
23
25
 
24
26
  if TYPE_CHECKING:
27
+ from ..models.memoryset_metadata_index_params import MemorysetMetadataIndexParams
25
28
  from ..models.memoryset_metrics import MemorysetMetrics
26
29
 
27
30
 
28
- T = TypeVar("T", bound="LabeledMemorysetMetadata")
31
+ T = TypeVar("T", bound="MemorysetMetadata")
29
32
 
30
33
 
31
34
  @_attrs_define
32
- class LabeledMemorysetMetadata:
35
+ class MemorysetMetadata:
33
36
  """
34
37
  Attributes:
35
38
  id (str):
@@ -40,13 +43,17 @@ class LabeledMemorysetMetadata:
40
43
  length (int):
41
44
  pretrained_embedding_model_name (Union[None, PretrainedEmbeddingModelName]):
42
45
  finetuned_embedding_model_id (Union[None, str]):
43
- label_names (List[str]):
44
46
  created_at (datetime.datetime):
45
47
  updated_at (datetime.datetime):
46
48
  memories_updated_at (datetime.datetime):
47
49
  insertion_task_id (str):
48
50
  insertion_status (TaskStatus): Status of task in the task queue
49
51
  metrics (MemorysetMetrics):
52
+ memory_type (MemoryType):
53
+ label_names (Union[List[str], None]):
54
+ index_type (MemorysetMetadataIndexType):
55
+ index_params (MemorysetMetadataIndexParams):
56
+ database_uri (Union[None, str]):
50
57
  """
51
58
 
52
59
  id: str
@@ -57,13 +64,17 @@ class LabeledMemorysetMetadata:
57
64
  length: int
58
65
  pretrained_embedding_model_name: Union[None, PretrainedEmbeddingModelName]
59
66
  finetuned_embedding_model_id: Union[None, str]
60
- label_names: List[str]
61
67
  created_at: datetime.datetime
62
68
  updated_at: datetime.datetime
63
69
  memories_updated_at: datetime.datetime
64
70
  insertion_task_id: str
65
71
  insertion_status: TaskStatus
66
72
  metrics: "MemorysetMetrics"
73
+ memory_type: MemoryType
74
+ label_names: Union[List[str], None]
75
+ index_type: MemorysetMetadataIndexType
76
+ index_params: "MemorysetMetadataIndexParams"
77
+ database_uri: Union[None, str]
67
78
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
68
79
 
69
80
  def to_dict(self) -> dict[str, Any]:
@@ -93,8 +104,6 @@ class LabeledMemorysetMetadata:
93
104
  finetuned_embedding_model_id: Union[None, str]
94
105
  finetuned_embedding_model_id = self.finetuned_embedding_model_id
95
106
 
96
- label_names = self.label_names
97
-
98
107
  created_at = self.created_at.isoformat()
99
108
 
100
109
  updated_at = self.updated_at.isoformat()
@@ -109,6 +118,22 @@ class LabeledMemorysetMetadata:
109
118
 
110
119
  metrics = self.metrics.to_dict()
111
120
 
121
+ memory_type = self.memory_type.value if isinstance(self.memory_type, Enum) else self.memory_type
122
+
123
+ label_names: Union[List[str], None]
124
+ if isinstance(self.label_names, list):
125
+ label_names = self.label_names
126
+
127
+ else:
128
+ label_names = self.label_names
129
+
130
+ index_type = self.index_type.value if isinstance(self.index_type, Enum) else self.index_type
131
+
132
+ index_params = self.index_params.to_dict()
133
+
134
+ database_uri: Union[None, str]
135
+ database_uri = self.database_uri
136
+
112
137
  field_dict: dict[str, Any] = {}
113
138
  field_dict.update(self.additional_properties)
114
139
  field_dict.update(
@@ -121,13 +146,17 @@ class LabeledMemorysetMetadata:
121
146
  "length": length,
122
147
  "pretrained_embedding_model_name": pretrained_embedding_model_name,
123
148
  "finetuned_embedding_model_id": finetuned_embedding_model_id,
124
- "label_names": label_names,
125
149
  "created_at": created_at,
126
150
  "updated_at": updated_at,
127
151
  "memories_updated_at": memories_updated_at,
128
152
  "insertion_task_id": insertion_task_id,
129
153
  "insertion_status": insertion_status,
130
154
  "metrics": metrics,
155
+ "memory_type": memory_type,
156
+ "label_names": label_names,
157
+ "index_type": index_type,
158
+ "index_params": index_params,
159
+ "database_uri": database_uri,
131
160
  }
132
161
  )
133
162
 
@@ -135,6 +164,7 @@ class LabeledMemorysetMetadata:
135
164
 
136
165
  @classmethod
137
166
  def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
167
+ from ..models.memoryset_metadata_index_params import MemorysetMetadataIndexParams
138
168
  from ..models.memoryset_metrics import MemorysetMetrics
139
169
 
140
170
  d = src_dict.copy()
@@ -179,8 +209,6 @@ class LabeledMemorysetMetadata:
179
209
 
180
210
  finetuned_embedding_model_id = _parse_finetuned_embedding_model_id(d.pop("finetuned_embedding_model_id"))
181
211
 
182
- label_names = cast(List[str], d.pop("label_names"))
183
-
184
212
  created_at = isoparse(d.pop("created_at"))
185
213
 
186
214
  updated_at = isoparse(d.pop("updated_at"))
@@ -193,7 +221,35 @@ class LabeledMemorysetMetadata:
193
221
 
194
222
  metrics = MemorysetMetrics.from_dict(d.pop("metrics"))
195
223
 
196
- labeled_memoryset_metadata = cls(
224
+ memory_type = MemoryType(d.pop("memory_type"))
225
+
226
+ def _parse_label_names(data: object) -> Union[List[str], None]:
227
+ if data is None:
228
+ return data
229
+ try:
230
+ if not isinstance(data, list):
231
+ raise TypeError()
232
+ label_names_type_0 = cast(List[str], data)
233
+
234
+ return label_names_type_0
235
+ except: # noqa: E722
236
+ pass
237
+ return cast(Union[List[str], None], data)
238
+
239
+ label_names = _parse_label_names(d.pop("label_names"))
240
+
241
+ index_type = MemorysetMetadataIndexType(d.pop("index_type"))
242
+
243
+ index_params = MemorysetMetadataIndexParams.from_dict(d.pop("index_params"))
244
+
245
+ def _parse_database_uri(data: object) -> Union[None, str]:
246
+ if data is None:
247
+ return data
248
+ return cast(Union[None, str], data)
249
+
250
+ database_uri = _parse_database_uri(d.pop("database_uri"))
251
+
252
+ memoryset_metadata = cls(
197
253
  id=id,
198
254
  org_id=org_id,
199
255
  collection_name=collection_name,
@@ -202,17 +258,21 @@ class LabeledMemorysetMetadata:
202
258
  length=length,
203
259
  pretrained_embedding_model_name=pretrained_embedding_model_name,
204
260
  finetuned_embedding_model_id=finetuned_embedding_model_id,
205
- label_names=label_names,
206
261
  created_at=created_at,
207
262
  updated_at=updated_at,
208
263
  memories_updated_at=memories_updated_at,
209
264
  insertion_task_id=insertion_task_id,
210
265
  insertion_status=insertion_status,
211
266
  metrics=metrics,
267
+ memory_type=memory_type,
268
+ label_names=label_names,
269
+ index_type=index_type,
270
+ index_params=index_params,
271
+ database_uri=database_uri,
212
272
  )
213
273
 
214
- labeled_memoryset_metadata.additional_properties = d
215
- return labeled_memoryset_metadata
274
+ memoryset_metadata.additional_properties = d
275
+ return memoryset_metadata
216
276
 
217
277
  @property
218
278
  def additional_keys(self) -> list[str]:
@@ -0,0 +1,55 @@
1
+ """
2
+ This file is generated by the openapi-python-client tool via the generate_api_client.py script
3
+
4
+ It is a customized template from the openapi-python-client tool's default template:
5
+ https://github.com/openapi-generators/openapi-python-client/blob/861ef5622f10fc96d240dc9becb0edf94e61446c/openapi_python_client/templates/model.py.jinja
6
+
7
+ The main change is:
8
+ - Fix typing issues
9
+ """
10
+
11
+ # flake8: noqa: C901
12
+
13
+ from typing import Any, Type, TypeVar
14
+
15
+ from attrs import define as _attrs_define
16
+ from attrs import field as _attrs_field
17
+
18
+ T = TypeVar("T", bound="MemorysetMetadataIndexParams")
19
+
20
+
21
+ @_attrs_define
22
+ class MemorysetMetadataIndexParams:
23
+ """ """
24
+
25
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
26
+
27
+ def to_dict(self) -> dict[str, Any]:
28
+ field_dict: dict[str, Any] = {}
29
+ field_dict.update(self.additional_properties)
30
+
31
+ return field_dict
32
+
33
+ @classmethod
34
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
35
+ d = src_dict.copy()
36
+ memoryset_metadata_index_params = cls()
37
+
38
+ memoryset_metadata_index_params.additional_properties = d
39
+ return memoryset_metadata_index_params
40
+
41
+ @property
42
+ def additional_keys(self) -> list[str]:
43
+ return list(self.additional_properties.keys())
44
+
45
+ def __getitem__(self, key: str) -> Any:
46
+ return self.additional_properties[key]
47
+
48
+ def __setitem__(self, key: str, value: Any) -> None:
49
+ self.additional_properties[key] = value
50
+
51
+ def __delitem__(self, key: str) -> None:
52
+ del self.additional_properties[key]
53
+
54
+ def __contains__(self, key: str) -> bool:
55
+ return key in self.additional_properties
@@ -0,0 +1,13 @@
1
+ from enum import Enum
2
+
3
+
4
+ class MemorysetMetadataIndexType(str, Enum):
5
+ DISKANN = "DISKANN"
6
+ FLAT = "FLAT"
7
+ HNSW = "HNSW"
8
+ IVF_FLAT = "IVF_FLAT"
9
+ IVF_PQ = "IVF_PQ"
10
+ IVF_SQ8 = "IVF_SQ8"
11
+
12
+ def __str__(self) -> str:
13
+ return str(self.value)
@@ -17,29 +17,26 @@ from attrs import field as _attrs_field
17
17
 
18
18
  from ..types import UNSET, Unset
19
19
 
20
- T = TypeVar("T", bound="LabeledMemorysetUpdate")
20
+ T = TypeVar("T", bound="MemorysetUpdate")
21
21
 
22
22
 
23
23
  @_attrs_define
24
- class LabeledMemorysetUpdate:
24
+ class MemorysetUpdate:
25
25
  """
26
26
  Attributes:
27
- label_names (Union[List[str], None, Unset]):
27
+ label_names (Union[Unset, List[str]]):
28
28
  description (Union[None, Unset, str]):
29
+ name (Union[Unset, str]):
29
30
  """
30
31
 
31
- label_names: Union[List[str], None, Unset] = UNSET
32
+ label_names: Union[Unset, List[str]] = UNSET
32
33
  description: Union[None, Unset, str] = UNSET
34
+ name: Union[Unset, str] = UNSET
33
35
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
34
36
 
35
37
  def to_dict(self) -> dict[str, Any]:
36
- label_names: Union[List[str], None, Unset]
37
- if isinstance(self.label_names, Unset):
38
- label_names = UNSET
39
- elif isinstance(self.label_names, list):
40
- label_names = self.label_names
41
-
42
- else:
38
+ label_names: Union[Unset, List[str]] = UNSET
39
+ if not isinstance(self.label_names, Unset):
43
40
  label_names = self.label_names
44
41
 
45
42
  description: Union[None, Unset, str]
@@ -48,6 +45,8 @@ class LabeledMemorysetUpdate:
48
45
  else:
49
46
  description = self.description
50
47
 
48
+ name = self.name
49
+
51
50
  field_dict: dict[str, Any] = {}
52
51
  field_dict.update(self.additional_properties)
53
52
  field_dict.update({})
@@ -55,29 +54,15 @@ class LabeledMemorysetUpdate:
55
54
  field_dict["label_names"] = label_names
56
55
  if description is not UNSET:
57
56
  field_dict["description"] = description
57
+ if name is not UNSET:
58
+ field_dict["name"] = name
58
59
 
59
60
  return field_dict
60
61
 
61
62
  @classmethod
62
63
  def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
63
64
  d = src_dict.copy()
64
-
65
- def _parse_label_names(data: object) -> Union[List[str], None, Unset]:
66
- if data is None:
67
- return data
68
- if isinstance(data, Unset):
69
- return data
70
- try:
71
- if not isinstance(data, list):
72
- raise TypeError()
73
- label_names_type_0 = cast(List[str], data)
74
-
75
- return label_names_type_0
76
- except: # noqa: E722
77
- pass
78
- return cast(Union[List[str], None, Unset], data)
79
-
80
- label_names = _parse_label_names(d.pop("label_names", UNSET))
65
+ label_names = cast(List[str], d.pop("label_names", UNSET))
81
66
 
82
67
  def _parse_description(data: object) -> Union[None, Unset, str]:
83
68
  if data is None:
@@ -88,13 +73,16 @@ class LabeledMemorysetUpdate:
88
73
 
89
74
  description = _parse_description(d.pop("description", UNSET))
90
75
 
91
- labeled_memoryset_update = cls(
76
+ name = d.pop("name", UNSET)
77
+
78
+ memoryset_update = cls(
92
79
  label_names=label_names,
93
80
  description=description,
81
+ name=name,
94
82
  )
95
83
 
96
- labeled_memoryset_update.additional_properties = d
97
- return labeled_memoryset_update
84
+ memoryset_update.additional_properties = d
85
+ return memoryset_update
98
86
 
99
87
  @property
100
88
  def additional_keys(self) -> list[str]:
@@ -15,6 +15,7 @@ class NotFoundErrorResponseResourceType0(str, Enum):
15
15
  ORG = "org"
16
16
  PREDICTION = "prediction"
17
17
  PRETRAINED_EMBEDDING_MODEL = "pretrained_embedding_model"
18
+ REGRESSION_MODEL = "regression_model"
18
19
  TASK = "task"
19
20
 
20
21
  def __str__(self) -> str:
@@ -10,38 +10,46 @@ The main change is:
10
10
 
11
11
  # flake8: noqa: C901
12
12
 
13
- from typing import TYPE_CHECKING, Any, List, Type, TypeVar
13
+ from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union
14
14
 
15
15
  from attrs import define as _attrs_define
16
16
  from attrs import field as _attrs_field
17
17
 
18
18
  if TYPE_CHECKING:
19
19
  from ..models.labeled_memory_with_feedback_metrics import LabeledMemoryWithFeedbackMetrics
20
+ from ..models.scored_memory_with_feedback_metrics import ScoredMemoryWithFeedbackMetrics
20
21
 
21
22
 
22
- T = TypeVar("T", bound="PaginatedLabeledMemoryWithFeedbackMetrics")
23
+ T = TypeVar("T", bound="PaginatedUnionLabeledMemoryWithFeedbackMetricsScoredMemoryWithFeedbackMetrics")
23
24
 
24
25
 
25
26
  @_attrs_define
26
- class PaginatedLabeledMemoryWithFeedbackMetrics:
27
+ class PaginatedUnionLabeledMemoryWithFeedbackMetricsScoredMemoryWithFeedbackMetrics:
27
28
  """
28
29
  Attributes:
29
- items (List['LabeledMemoryWithFeedbackMetrics']):
30
+ items (List[Union['LabeledMemoryWithFeedbackMetrics', 'ScoredMemoryWithFeedbackMetrics']]):
30
31
  total (int):
31
32
  offset (int):
32
33
  limit (int):
33
34
  """
34
35
 
35
- items: List["LabeledMemoryWithFeedbackMetrics"]
36
+ items: List[Union["LabeledMemoryWithFeedbackMetrics", "ScoredMemoryWithFeedbackMetrics"]]
36
37
  total: int
37
38
  offset: int
38
39
  limit: int
39
40
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
40
41
 
41
42
  def to_dict(self) -> dict[str, Any]:
43
+ from ..models.labeled_memory_with_feedback_metrics import LabeledMemoryWithFeedbackMetrics
44
+
42
45
  items = []
43
46
  for items_item_data in self.items:
44
- items_item = items_item_data.to_dict()
47
+ items_item: Dict[str, Any]
48
+ if isinstance(items_item_data, LabeledMemoryWithFeedbackMetrics):
49
+ items_item = items_item_data.to_dict()
50
+ else:
51
+ items_item = items_item_data.to_dict()
52
+
45
53
  items.append(items_item)
46
54
 
47
55
  total = self.total
@@ -66,12 +74,31 @@ class PaginatedLabeledMemoryWithFeedbackMetrics:
66
74
  @classmethod
67
75
  def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
68
76
  from ..models.labeled_memory_with_feedback_metrics import LabeledMemoryWithFeedbackMetrics
77
+ from ..models.scored_memory_with_feedback_metrics import ScoredMemoryWithFeedbackMetrics
69
78
 
70
79
  d = src_dict.copy()
71
80
  items = []
72
81
  _items = d.pop("items")
73
82
  for items_item_data in _items:
74
- items_item = LabeledMemoryWithFeedbackMetrics.from_dict(items_item_data)
83
+
84
+ def _parse_items_item(
85
+ data: object,
86
+ ) -> Union["LabeledMemoryWithFeedbackMetrics", "ScoredMemoryWithFeedbackMetrics"]:
87
+ try:
88
+ if not isinstance(data, dict):
89
+ raise TypeError()
90
+ items_item_type_0 = LabeledMemoryWithFeedbackMetrics.from_dict(data)
91
+
92
+ return items_item_type_0
93
+ except: # noqa: E722
94
+ pass
95
+ if not isinstance(data, dict):
96
+ raise TypeError()
97
+ items_item_type_1 = ScoredMemoryWithFeedbackMetrics.from_dict(data)
98
+
99
+ return items_item_type_1
100
+
101
+ items_item = _parse_items_item(items_item_data)
75
102
 
76
103
  items.append(items_item)
77
104
 
@@ -81,15 +108,15 @@ class PaginatedLabeledMemoryWithFeedbackMetrics:
81
108
 
82
109
  limit = d.pop("limit")
83
110
 
84
- paginated_labeled_memory_with_feedback_metrics = cls(
111
+ paginated_union_labeled_memory_with_feedback_metrics_scored_memory_with_feedback_metrics = cls(
85
112
  items=items,
86
113
  total=total,
87
114
  offset=offset,
88
115
  limit=limit,
89
116
  )
90
117
 
91
- paginated_labeled_memory_with_feedback_metrics.additional_properties = d
92
- return paginated_labeled_memory_with_feedback_metrics
118
+ paginated_union_labeled_memory_with_feedback_metrics_scored_memory_with_feedback_metrics.additional_properties = d
119
+ return paginated_union_labeled_memory_with_feedback_metrics_scored_memory_with_feedback_metrics
93
120
 
94
121
  @property
95
122
  def additional_keys(self) -> list[str]:
@@ -15,23 +15,21 @@ from typing import Any, List, Type, TypeVar, cast
15
15
  from attrs import define as _attrs_define
16
16
  from attrs import field as _attrs_field
17
17
 
18
- T = TypeVar("T", bound="PrecisionRecallCurve")
18
+ T = TypeVar("T", bound="PRCurve")
19
19
 
20
20
 
21
21
  @_attrs_define
22
- class PrecisionRecallCurve:
22
+ class PRCurve:
23
23
  """
24
24
  Attributes:
25
25
  thresholds (List[float]):
26
26
  precisions (List[float]):
27
27
  recalls (List[float]):
28
- auc (float):
29
28
  """
30
29
 
31
30
  thresholds: List[float]
32
31
  precisions: List[float]
33
32
  recalls: List[float]
34
- auc: float
35
33
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
36
34
 
37
35
  def to_dict(self) -> dict[str, Any]:
@@ -41,8 +39,6 @@ class PrecisionRecallCurve:
41
39
 
42
40
  recalls = self.recalls
43
41
 
44
- auc = self.auc
45
-
46
42
  field_dict: dict[str, Any] = {}
47
43
  field_dict.update(self.additional_properties)
48
44
  field_dict.update(
@@ -50,7 +46,6 @@ class PrecisionRecallCurve:
50
46
  "thresholds": thresholds,
51
47
  "precisions": precisions,
52
48
  "recalls": recalls,
53
- "auc": auc,
54
49
  }
55
50
  )
56
51
 
@@ -65,17 +60,14 @@ class PrecisionRecallCurve:
65
60
 
66
61
  recalls = cast(List[float], d.pop("recalls"))
67
62
 
68
- auc = d.pop("auc")
69
-
70
- precision_recall_curve = cls(
63
+ pr_curve = cls(
71
64
  thresholds=thresholds,
72
65
  precisions=precisions,
73
66
  recalls=recalls,
74
- auc=auc,
75
67
  )
76
68
 
77
- precision_recall_curve.additional_properties = d
78
- return precision_recall_curve
69
+ pr_curve.additional_properties = d
70
+ return pr_curve
79
71
 
80
72
  @property
81
73
  def additional_keys(self) -> list[str]:
@@ -17,17 +17,19 @@ from attrs import field as _attrs_field
17
17
 
18
18
  from ..types import UNSET, Unset
19
19
 
20
- T = TypeVar("T", bound="RACModelUpdate")
20
+ T = TypeVar("T", bound="PredictiveModelUpdate")
21
21
 
22
22
 
23
23
  @_attrs_define
24
- class RACModelUpdate:
24
+ class PredictiveModelUpdate:
25
25
  """
26
26
  Attributes:
27
27
  description (Union[None, Unset, str]):
28
+ locked (Union[Unset, bool]):
28
29
  """
29
30
 
30
31
  description: Union[None, Unset, str] = UNSET
32
+ locked: Union[Unset, bool] = UNSET
31
33
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
32
34
 
33
35
  def to_dict(self) -> dict[str, Any]:
@@ -37,11 +39,15 @@ class RACModelUpdate:
37
39
  else:
38
40
  description = self.description
39
41
 
42
+ locked = self.locked
43
+
40
44
  field_dict: dict[str, Any] = {}
41
45
  field_dict.update(self.additional_properties)
42
46
  field_dict.update({})
43
47
  if description is not UNSET:
44
48
  field_dict["description"] = description
49
+ if locked is not UNSET:
50
+ field_dict["locked"] = locked
45
51
 
46
52
  return field_dict
47
53
 
@@ -58,12 +64,15 @@ class RACModelUpdate:
58
64
 
59
65
  description = _parse_description(d.pop("description", UNSET))
60
66
 
61
- rac_model_update = cls(
67
+ locked = d.pop("locked", UNSET)
68
+
69
+ predictive_model_update = cls(
62
70
  description=description,
71
+ locked=locked,
63
72
  )
64
73
 
65
- rac_model_update.additional_properties = d
66
- return rac_model_update
74
+ predictive_model_update.additional_properties = d
75
+ return predictive_model_update
67
76
 
68
77
  @property
69
78
  def additional_keys(self) -> list[str]:
@@ -11,12 +11,13 @@ The main change is:
11
11
  # flake8: noqa: C901
12
12
 
13
13
  from enum import Enum
14
- from typing import Any, Type, TypeVar
14
+ from typing import Any, Type, TypeVar, Union
15
15
 
16
16
  from attrs import define as _attrs_define
17
17
  from attrs import field as _attrs_field
18
18
 
19
19
  from ..models.pretrained_embedding_model_name import PretrainedEmbeddingModelName
20
+ from ..types import UNSET, Unset
20
21
 
21
22
  T = TypeVar("T", bound="PretrainedEmbeddingModelMetadata")
22
23
 
@@ -29,12 +30,14 @@ class PretrainedEmbeddingModelMetadata:
29
30
  max_seq_length (int):
30
31
  uses_context (bool):
31
32
  name (PretrainedEmbeddingModelName): Names of pretrained embedding models that are supported by OrcaCloud
33
+ experimental (Union[Unset, bool]): Default: False.
32
34
  """
33
35
 
34
36
  embedding_dim: int
35
37
  max_seq_length: int
36
38
  uses_context: bool
37
39
  name: PretrainedEmbeddingModelName
40
+ experimental: Union[Unset, bool] = False
38
41
  additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
39
42
 
40
43
  def to_dict(self) -> dict[str, Any]:
@@ -46,6 +49,8 @@ class PretrainedEmbeddingModelMetadata:
46
49
 
47
50
  name = self.name.value if isinstance(self.name, Enum) else self.name
48
51
 
52
+ experimental = self.experimental
53
+
49
54
  field_dict: dict[str, Any] = {}
50
55
  field_dict.update(self.additional_properties)
51
56
  field_dict.update(
@@ -56,6 +61,8 @@ class PretrainedEmbeddingModelMetadata:
56
61
  "name": name,
57
62
  }
58
63
  )
64
+ if experimental is not UNSET:
65
+ field_dict["experimental"] = experimental
59
66
 
60
67
  return field_dict
61
68
 
@@ -70,11 +77,14 @@ class PretrainedEmbeddingModelMetadata:
70
77
 
71
78
  name = PretrainedEmbeddingModelName(d.pop("name"))
72
79
 
80
+ experimental = d.pop("experimental", UNSET)
81
+
73
82
  pretrained_embedding_model_metadata = cls(
74
83
  embedding_dim=embedding_dim,
75
84
  max_seq_length=max_seq_length,
76
85
  uses_context=uses_context,
77
86
  name=name,
87
+ experimental=experimental,
78
88
  )
79
89
 
80
90
  pretrained_embedding_model_metadata.additional_properties = d
@@ -2,11 +2,16 @@ from enum import Enum
2
2
 
3
3
 
4
4
  class PretrainedEmbeddingModelName(str, Enum):
5
+ BGE_BASE = "BGE_BASE"
5
6
  CDE_SMALL = "CDE_SMALL"
6
7
  CLIP_BASE = "CLIP_BASE"
7
8
  DISTILBERT = "DISTILBERT"
9
+ E5_LARGE = "E5_LARGE"
10
+ GIST_LARGE = "GIST_LARGE"
8
11
  GTE_BASE = "GTE_BASE"
9
12
  GTE_SMALL = "GTE_SMALL"
13
+ MXBAI_LARGE = "MXBAI_LARGE"
14
+ QWEN2_1_5B = "QWEN2_1_5B"
10
15
 
11
16
  def __str__(self) -> str:
12
17
  return str(self.value)
@@ -0,0 +1,8 @@
1
+ from enum import Enum
2
+
3
+
4
+ class RARHeadType(str, Enum):
5
+ MMOE = "MMOE"
6
+
7
+ def __str__(self) -> str:
8
+ return str(self.value)