oracle-ads 2.13.8__py3-none-any.whl → 2.13.9rc0__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.
- {oracle_ads-2.13.8.dist-info → oracle_ads-2.13.9rc0.dist-info}/METADATA +151 -151
- oracle_ads-2.13.9rc0.dist-info/RECORD +9 -0
- {oracle_ads-2.13.8.dist-info → oracle_ads-2.13.9rc0.dist-info}/WHEEL +2 -1
- {oracle_ads-2.13.8.dist-info → oracle_ads-2.13.9rc0.dist-info}/entry_points.txt +1 -2
- oracle_ads-2.13.9rc0.dist-info/top_level.txt +1 -0
- ads/aqua/__init__.py +0 -40
- ads/aqua/app.py +0 -506
- ads/aqua/cli.py +0 -96
- ads/aqua/client/__init__.py +0 -3
- ads/aqua/client/client.py +0 -836
- ads/aqua/client/openai_client.py +0 -305
- ads/aqua/common/__init__.py +0 -5
- ads/aqua/common/decorator.py +0 -125
- ads/aqua/common/entities.py +0 -266
- ads/aqua/common/enums.py +0 -122
- ads/aqua/common/errors.py +0 -109
- ads/aqua/common/utils.py +0 -1285
- ads/aqua/config/__init__.py +0 -4
- ads/aqua/config/container_config.py +0 -248
- ads/aqua/config/evaluation/__init__.py +0 -4
- ads/aqua/config/evaluation/evaluation_service_config.py +0 -147
- ads/aqua/config/utils/__init__.py +0 -4
- ads/aqua/config/utils/serializer.py +0 -339
- ads/aqua/constants.py +0 -114
- ads/aqua/data.py +0 -14
- ads/aqua/dummy_data/icon.txt +0 -1
- ads/aqua/dummy_data/oci_model_deployments.json +0 -56
- ads/aqua/dummy_data/oci_models.json +0 -1
- ads/aqua/dummy_data/readme.md +0 -26
- ads/aqua/evaluation/__init__.py +0 -8
- ads/aqua/evaluation/constants.py +0 -53
- ads/aqua/evaluation/entities.py +0 -186
- ads/aqua/evaluation/errors.py +0 -70
- ads/aqua/evaluation/evaluation.py +0 -1814
- ads/aqua/extension/__init__.py +0 -42
- ads/aqua/extension/aqua_ws_msg_handler.py +0 -76
- ads/aqua/extension/base_handler.py +0 -90
- ads/aqua/extension/common_handler.py +0 -121
- ads/aqua/extension/common_ws_msg_handler.py +0 -36
- ads/aqua/extension/deployment_handler.py +0 -298
- ads/aqua/extension/deployment_ws_msg_handler.py +0 -54
- ads/aqua/extension/errors.py +0 -30
- ads/aqua/extension/evaluation_handler.py +0 -129
- ads/aqua/extension/evaluation_ws_msg_handler.py +0 -61
- ads/aqua/extension/finetune_handler.py +0 -96
- ads/aqua/extension/model_handler.py +0 -390
- ads/aqua/extension/models/__init__.py +0 -0
- ads/aqua/extension/models/ws_models.py +0 -145
- ads/aqua/extension/models_ws_msg_handler.py +0 -50
- ads/aqua/extension/ui_handler.py +0 -282
- ads/aqua/extension/ui_websocket_handler.py +0 -130
- ads/aqua/extension/utils.py +0 -133
- ads/aqua/finetuning/__init__.py +0 -7
- ads/aqua/finetuning/constants.py +0 -23
- ads/aqua/finetuning/entities.py +0 -181
- ads/aqua/finetuning/finetuning.py +0 -731
- ads/aqua/model/__init__.py +0 -8
- ads/aqua/model/constants.py +0 -60
- ads/aqua/model/entities.py +0 -306
- ads/aqua/model/enums.py +0 -30
- ads/aqua/model/model.py +0 -2080
- ads/aqua/modeldeployment/__init__.py +0 -8
- ads/aqua/modeldeployment/constants.py +0 -10
- ads/aqua/modeldeployment/deployment.py +0 -1324
- ads/aqua/modeldeployment/entities.py +0 -653
- ads/aqua/modeldeployment/inference.py +0 -74
- ads/aqua/modeldeployment/utils.py +0 -543
- ads/aqua/resources/gpu_shapes_index.json +0 -94
- ads/aqua/server/__init__.py +0 -4
- ads/aqua/server/__main__.py +0 -24
- ads/aqua/server/app.py +0 -47
- ads/aqua/server/aqua_spec.yml +0 -1291
- ads/aqua/training/__init__.py +0 -4
- ads/aqua/training/exceptions.py +0 -476
- ads/aqua/ui.py +0 -499
- ads/automl/__init__.py +0 -9
- ads/automl/driver.py +0 -330
- ads/automl/provider.py +0 -975
- ads/bds/__init__.py +0 -5
- ads/bds/auth.py +0 -127
- ads/bds/big_data_service.py +0 -255
- ads/catalog/__init__.py +0 -19
- ads/catalog/model.py +0 -1576
- ads/catalog/notebook.py +0 -461
- ads/catalog/project.py +0 -468
- ads/catalog/summary.py +0 -178
- ads/common/__init__.py +0 -11
- ads/common/analyzer.py +0 -65
- ads/common/artifact/.model-ignore +0 -63
- ads/common/artifact/__init__.py +0 -10
- ads/common/auth.py +0 -1122
- ads/common/card_identifier.py +0 -83
- ads/common/config.py +0 -647
- ads/common/data.py +0 -165
- ads/common/decorator/__init__.py +0 -9
- ads/common/decorator/argument_to_case.py +0 -88
- ads/common/decorator/deprecate.py +0 -69
- ads/common/decorator/require_nonempty_arg.py +0 -65
- ads/common/decorator/runtime_dependency.py +0 -178
- ads/common/decorator/threaded.py +0 -97
- ads/common/decorator/utils.py +0 -35
- ads/common/dsc_file_system.py +0 -303
- ads/common/error.py +0 -14
- ads/common/extended_enum.py +0 -81
- ads/common/function/__init__.py +0 -5
- ads/common/function/fn_util.py +0 -142
- ads/common/function/func_conf.yaml +0 -25
- ads/common/ipython.py +0 -76
- ads/common/model.py +0 -679
- ads/common/model_artifact.py +0 -1759
- ads/common/model_artifact_schema.json +0 -107
- ads/common/model_export_util.py +0 -664
- ads/common/model_metadata.py +0 -24
- ads/common/object_storage_details.py +0 -296
- ads/common/oci_client.py +0 -175
- ads/common/oci_datascience.py +0 -46
- ads/common/oci_logging.py +0 -1144
- ads/common/oci_mixin.py +0 -957
- ads/common/oci_resource.py +0 -136
- ads/common/serializer.py +0 -559
- ads/common/utils.py +0 -1852
- ads/common/word_lists.py +0 -1491
- ads/common/work_request.py +0 -189
- ads/data_labeling/__init__.py +0 -13
- ads/data_labeling/boundingbox.py +0 -253
- ads/data_labeling/constants.py +0 -47
- ads/data_labeling/data_labeling_service.py +0 -244
- ads/data_labeling/interface/__init__.py +0 -5
- ads/data_labeling/interface/loader.py +0 -16
- ads/data_labeling/interface/parser.py +0 -16
- ads/data_labeling/interface/reader.py +0 -23
- ads/data_labeling/loader/__init__.py +0 -5
- ads/data_labeling/loader/file_loader.py +0 -241
- ads/data_labeling/metadata.py +0 -110
- ads/data_labeling/mixin/__init__.py +0 -5
- ads/data_labeling/mixin/data_labeling.py +0 -232
- ads/data_labeling/ner.py +0 -129
- ads/data_labeling/parser/__init__.py +0 -5
- ads/data_labeling/parser/dls_record_parser.py +0 -388
- ads/data_labeling/parser/export_metadata_parser.py +0 -94
- ads/data_labeling/parser/export_record_parser.py +0 -473
- ads/data_labeling/reader/__init__.py +0 -5
- ads/data_labeling/reader/dataset_reader.py +0 -574
- ads/data_labeling/reader/dls_record_reader.py +0 -121
- ads/data_labeling/reader/export_record_reader.py +0 -62
- ads/data_labeling/reader/jsonl_reader.py +0 -75
- ads/data_labeling/reader/metadata_reader.py +0 -203
- ads/data_labeling/reader/record_reader.py +0 -263
- ads/data_labeling/record.py +0 -52
- ads/data_labeling/visualizer/__init__.py +0 -5
- ads/data_labeling/visualizer/image_visualizer.py +0 -525
- ads/data_labeling/visualizer/text_visualizer.py +0 -357
- ads/database/__init__.py +0 -5
- ads/database/connection.py +0 -338
- ads/dataset/__init__.py +0 -10
- ads/dataset/capabilities.md +0 -51
- ads/dataset/classification_dataset.py +0 -339
- ads/dataset/correlation.py +0 -226
- ads/dataset/correlation_plot.py +0 -563
- ads/dataset/dask_series.py +0 -173
- ads/dataset/dataframe_transformer.py +0 -110
- ads/dataset/dataset.py +0 -1979
- ads/dataset/dataset_browser.py +0 -360
- ads/dataset/dataset_with_target.py +0 -995
- ads/dataset/exception.py +0 -25
- ads/dataset/factory.py +0 -987
- ads/dataset/feature_engineering_transformer.py +0 -35
- ads/dataset/feature_selection.py +0 -107
- ads/dataset/forecasting_dataset.py +0 -26
- ads/dataset/helper.py +0 -1450
- ads/dataset/label_encoder.py +0 -99
- ads/dataset/mixin/__init__.py +0 -5
- ads/dataset/mixin/dataset_accessor.py +0 -134
- ads/dataset/pipeline.py +0 -58
- ads/dataset/plot.py +0 -710
- ads/dataset/progress.py +0 -86
- ads/dataset/recommendation.py +0 -297
- ads/dataset/recommendation_transformer.py +0 -502
- ads/dataset/regression_dataset.py +0 -14
- ads/dataset/sampled_dataset.py +0 -1050
- ads/dataset/target.py +0 -98
- ads/dataset/timeseries.py +0 -18
- ads/dbmixin/__init__.py +0 -5
- ads/dbmixin/db_pandas_accessor.py +0 -153
- ads/environment/__init__.py +0 -9
- ads/environment/ml_runtime.py +0 -66
- ads/evaluations/README.md +0 -14
- ads/evaluations/__init__.py +0 -109
- ads/evaluations/evaluation_plot.py +0 -983
- ads/evaluations/evaluator.py +0 -1334
- ads/evaluations/statistical_metrics.py +0 -543
- ads/experiments/__init__.py +0 -9
- ads/experiments/capabilities.md +0 -0
- ads/explanations/__init__.py +0 -21
- ads/explanations/base_explainer.py +0 -142
- ads/explanations/capabilities.md +0 -83
- ads/explanations/explainer.py +0 -190
- ads/explanations/mlx_global_explainer.py +0 -1050
- ads/explanations/mlx_interface.py +0 -386
- ads/explanations/mlx_local_explainer.py +0 -287
- ads/explanations/mlx_whatif_explainer.py +0 -201
- ads/feature_engineering/__init__.py +0 -20
- ads/feature_engineering/accessor/__init__.py +0 -5
- ads/feature_engineering/accessor/dataframe_accessor.py +0 -535
- ads/feature_engineering/accessor/mixin/__init__.py +0 -5
- ads/feature_engineering/accessor/mixin/correlation.py +0 -166
- ads/feature_engineering/accessor/mixin/eda_mixin.py +0 -266
- ads/feature_engineering/accessor/mixin/eda_mixin_series.py +0 -85
- ads/feature_engineering/accessor/mixin/feature_types_mixin.py +0 -211
- ads/feature_engineering/accessor/mixin/utils.py +0 -65
- ads/feature_engineering/accessor/series_accessor.py +0 -431
- ads/feature_engineering/adsimage/__init__.py +0 -5
- ads/feature_engineering/adsimage/image.py +0 -192
- ads/feature_engineering/adsimage/image_reader.py +0 -170
- ads/feature_engineering/adsimage/interface/__init__.py +0 -5
- ads/feature_engineering/adsimage/interface/reader.py +0 -19
- ads/feature_engineering/adsstring/__init__.py +0 -7
- ads/feature_engineering/adsstring/oci_language/__init__.py +0 -8
- ads/feature_engineering/adsstring/string/__init__.py +0 -8
- ads/feature_engineering/data_schema.json +0 -57
- ads/feature_engineering/dataset/__init__.py +0 -5
- ads/feature_engineering/dataset/zip_code_data.py +0 -42062
- ads/feature_engineering/exceptions.py +0 -40
- ads/feature_engineering/feature_type/__init__.py +0 -133
- ads/feature_engineering/feature_type/address.py +0 -184
- ads/feature_engineering/feature_type/adsstring/__init__.py +0 -5
- ads/feature_engineering/feature_type/adsstring/common_regex_mixin.py +0 -164
- ads/feature_engineering/feature_type/adsstring/oci_language.py +0 -93
- ads/feature_engineering/feature_type/adsstring/parsers/__init__.py +0 -5
- ads/feature_engineering/feature_type/adsstring/parsers/base.py +0 -47
- ads/feature_engineering/feature_type/adsstring/parsers/nltk_parser.py +0 -96
- ads/feature_engineering/feature_type/adsstring/parsers/spacy_parser.py +0 -221
- ads/feature_engineering/feature_type/adsstring/string.py +0 -258
- ads/feature_engineering/feature_type/base.py +0 -58
- ads/feature_engineering/feature_type/boolean.py +0 -183
- ads/feature_engineering/feature_type/category.py +0 -146
- ads/feature_engineering/feature_type/constant.py +0 -137
- ads/feature_engineering/feature_type/continuous.py +0 -151
- ads/feature_engineering/feature_type/creditcard.py +0 -314
- ads/feature_engineering/feature_type/datetime.py +0 -190
- ads/feature_engineering/feature_type/discrete.py +0 -134
- ads/feature_engineering/feature_type/document.py +0 -43
- ads/feature_engineering/feature_type/gis.py +0 -251
- ads/feature_engineering/feature_type/handler/__init__.py +0 -5
- ads/feature_engineering/feature_type/handler/feature_validator.py +0 -524
- ads/feature_engineering/feature_type/handler/feature_warning.py +0 -319
- ads/feature_engineering/feature_type/handler/warnings.py +0 -128
- ads/feature_engineering/feature_type/integer.py +0 -142
- ads/feature_engineering/feature_type/ip_address.py +0 -144
- ads/feature_engineering/feature_type/ip_address_v4.py +0 -138
- ads/feature_engineering/feature_type/ip_address_v6.py +0 -138
- ads/feature_engineering/feature_type/lat_long.py +0 -256
- ads/feature_engineering/feature_type/object.py +0 -43
- ads/feature_engineering/feature_type/ordinal.py +0 -132
- ads/feature_engineering/feature_type/phone_number.py +0 -135
- ads/feature_engineering/feature_type/string.py +0 -171
- ads/feature_engineering/feature_type/text.py +0 -93
- ads/feature_engineering/feature_type/unknown.py +0 -43
- ads/feature_engineering/feature_type/zip_code.py +0 -164
- ads/feature_engineering/feature_type_manager.py +0 -406
- ads/feature_engineering/schema.py +0 -795
- ads/feature_engineering/utils.py +0 -245
- ads/feature_store/.readthedocs.yaml +0 -19
- ads/feature_store/README.md +0 -65
- ads/feature_store/__init__.py +0 -9
- ads/feature_store/common/__init__.py +0 -0
- ads/feature_store/common/enums.py +0 -339
- ads/feature_store/common/exceptions.py +0 -18
- ads/feature_store/common/spark_session_singleton.py +0 -125
- ads/feature_store/common/utils/__init__.py +0 -0
- ads/feature_store/common/utils/base64_encoder_decoder.py +0 -72
- ads/feature_store/common/utils/feature_schema_mapper.py +0 -283
- ads/feature_store/common/utils/transformation_utils.py +0 -82
- ads/feature_store/common/utils/utility.py +0 -403
- ads/feature_store/data_validation/__init__.py +0 -0
- ads/feature_store/data_validation/great_expectation.py +0 -129
- ads/feature_store/dataset.py +0 -1230
- ads/feature_store/dataset_job.py +0 -530
- ads/feature_store/docs/Dockerfile +0 -7
- ads/feature_store/docs/Makefile +0 -44
- ads/feature_store/docs/conf.py +0 -28
- ads/feature_store/docs/requirements.txt +0 -14
- ads/feature_store/docs/source/ads.feature_store.query.rst +0 -20
- ads/feature_store/docs/source/cicd.rst +0 -137
- ads/feature_store/docs/source/conf.py +0 -86
- ads/feature_store/docs/source/data_versioning.rst +0 -33
- ads/feature_store/docs/source/dataset.rst +0 -388
- ads/feature_store/docs/source/dataset_job.rst +0 -27
- ads/feature_store/docs/source/demo.rst +0 -70
- ads/feature_store/docs/source/entity.rst +0 -78
- ads/feature_store/docs/source/feature_group.rst +0 -624
- ads/feature_store/docs/source/feature_group_job.rst +0 -29
- ads/feature_store/docs/source/feature_store.rst +0 -122
- ads/feature_store/docs/source/feature_store_class.rst +0 -123
- ads/feature_store/docs/source/feature_validation.rst +0 -66
- ads/feature_store/docs/source/figures/cicd.png +0 -0
- ads/feature_store/docs/source/figures/data_validation.png +0 -0
- ads/feature_store/docs/source/figures/data_versioning.png +0 -0
- ads/feature_store/docs/source/figures/dataset.gif +0 -0
- ads/feature_store/docs/source/figures/dataset.png +0 -0
- ads/feature_store/docs/source/figures/dataset_lineage.png +0 -0
- ads/feature_store/docs/source/figures/dataset_statistics.png +0 -0
- ads/feature_store/docs/source/figures/dataset_statistics_viz.png +0 -0
- ads/feature_store/docs/source/figures/dataset_validation_results.png +0 -0
- ads/feature_store/docs/source/figures/dataset_validation_summary.png +0 -0
- ads/feature_store/docs/source/figures/drift_monitoring.png +0 -0
- ads/feature_store/docs/source/figures/entity.png +0 -0
- ads/feature_store/docs/source/figures/feature_group.png +0 -0
- ads/feature_store/docs/source/figures/feature_group_lineage.png +0 -0
- ads/feature_store/docs/source/figures/feature_group_statistics_viz.png +0 -0
- ads/feature_store/docs/source/figures/feature_store_deployment.png +0 -0
- ads/feature_store/docs/source/figures/feature_store_overview.png +0 -0
- ads/feature_store/docs/source/figures/featuregroup.gif +0 -0
- ads/feature_store/docs/source/figures/lineage_d1.png +0 -0
- ads/feature_store/docs/source/figures/lineage_d2.png +0 -0
- ads/feature_store/docs/source/figures/lineage_fg.png +0 -0
- ads/feature_store/docs/source/figures/logo-dark-mode.png +0 -0
- ads/feature_store/docs/source/figures/logo-light-mode.png +0 -0
- ads/feature_store/docs/source/figures/overview.png +0 -0
- ads/feature_store/docs/source/figures/resource_manager.png +0 -0
- ads/feature_store/docs/source/figures/resource_manager_feature_store_stack.png +0 -0
- ads/feature_store/docs/source/figures/resource_manager_home.png +0 -0
- ads/feature_store/docs/source/figures/stats_1.png +0 -0
- ads/feature_store/docs/source/figures/stats_2.png +0 -0
- ads/feature_store/docs/source/figures/stats_d.png +0 -0
- ads/feature_store/docs/source/figures/stats_fg.png +0 -0
- ads/feature_store/docs/source/figures/transformation.png +0 -0
- ads/feature_store/docs/source/figures/transformations.gif +0 -0
- ads/feature_store/docs/source/figures/validation.png +0 -0
- ads/feature_store/docs/source/figures/validation_fg.png +0 -0
- ads/feature_store/docs/source/figures/validation_results.png +0 -0
- ads/feature_store/docs/source/figures/validation_summary.png +0 -0
- ads/feature_store/docs/source/index.rst +0 -81
- ads/feature_store/docs/source/module.rst +0 -8
- ads/feature_store/docs/source/notebook.rst +0 -94
- ads/feature_store/docs/source/overview.rst +0 -47
- ads/feature_store/docs/source/quickstart.rst +0 -176
- ads/feature_store/docs/source/release_notes.rst +0 -194
- ads/feature_store/docs/source/setup_feature_store.rst +0 -81
- ads/feature_store/docs/source/statistics.rst +0 -58
- ads/feature_store/docs/source/transformation.rst +0 -199
- ads/feature_store/docs/source/ui.rst +0 -65
- ads/feature_store/docs/source/user_guides.setup.feature_store_operator.rst +0 -66
- ads/feature_store/docs/source/user_guides.setup.helm_chart.rst +0 -192
- ads/feature_store/docs/source/user_guides.setup.terraform.rst +0 -338
- ads/feature_store/entity.py +0 -718
- ads/feature_store/execution_strategy/__init__.py +0 -0
- ads/feature_store/execution_strategy/delta_lake/__init__.py +0 -0
- ads/feature_store/execution_strategy/delta_lake/delta_lake_service.py +0 -375
- ads/feature_store/execution_strategy/engine/__init__.py +0 -0
- ads/feature_store/execution_strategy/engine/spark_engine.py +0 -316
- ads/feature_store/execution_strategy/execution_strategy.py +0 -113
- ads/feature_store/execution_strategy/execution_strategy_provider.py +0 -47
- ads/feature_store/execution_strategy/spark/__init__.py +0 -0
- ads/feature_store/execution_strategy/spark/spark_execution.py +0 -618
- ads/feature_store/feature.py +0 -192
- ads/feature_store/feature_group.py +0 -1494
- ads/feature_store/feature_group_expectation.py +0 -346
- ads/feature_store/feature_group_job.py +0 -602
- ads/feature_store/feature_lineage/__init__.py +0 -0
- ads/feature_store/feature_lineage/graphviz_service.py +0 -180
- ads/feature_store/feature_option_details.py +0 -50
- ads/feature_store/feature_statistics/__init__.py +0 -0
- ads/feature_store/feature_statistics/statistics_service.py +0 -99
- ads/feature_store/feature_store.py +0 -699
- ads/feature_store/feature_store_registrar.py +0 -518
- ads/feature_store/input_feature_detail.py +0 -149
- ads/feature_store/mixin/__init__.py +0 -4
- ads/feature_store/mixin/oci_feature_store.py +0 -145
- ads/feature_store/model_details.py +0 -73
- ads/feature_store/query/__init__.py +0 -0
- ads/feature_store/query/filter.py +0 -266
- ads/feature_store/query/generator/__init__.py +0 -0
- ads/feature_store/query/generator/query_generator.py +0 -298
- ads/feature_store/query/join.py +0 -161
- ads/feature_store/query/query.py +0 -403
- ads/feature_store/query/validator/__init__.py +0 -0
- ads/feature_store/query/validator/query_validator.py +0 -57
- ads/feature_store/response/__init__.py +0 -0
- ads/feature_store/response/response_builder.py +0 -68
- ads/feature_store/service/__init__.py +0 -0
- ads/feature_store/service/oci_dataset.py +0 -139
- ads/feature_store/service/oci_dataset_job.py +0 -199
- ads/feature_store/service/oci_entity.py +0 -125
- ads/feature_store/service/oci_feature_group.py +0 -164
- ads/feature_store/service/oci_feature_group_job.py +0 -214
- ads/feature_store/service/oci_feature_store.py +0 -182
- ads/feature_store/service/oci_lineage.py +0 -87
- ads/feature_store/service/oci_transformation.py +0 -104
- ads/feature_store/statistics/__init__.py +0 -0
- ads/feature_store/statistics/abs_feature_value.py +0 -49
- ads/feature_store/statistics/charts/__init__.py +0 -0
- ads/feature_store/statistics/charts/abstract_feature_plot.py +0 -37
- ads/feature_store/statistics/charts/box_plot.py +0 -148
- ads/feature_store/statistics/charts/frequency_distribution.py +0 -65
- ads/feature_store/statistics/charts/probability_distribution.py +0 -68
- ads/feature_store/statistics/charts/top_k_frequent_elements.py +0 -98
- ads/feature_store/statistics/feature_stat.py +0 -126
- ads/feature_store/statistics/generic_feature_value.py +0 -33
- ads/feature_store/statistics/statistics.py +0 -41
- ads/feature_store/statistics_config.py +0 -101
- ads/feature_store/templates/feature_store_template.yaml +0 -45
- ads/feature_store/transformation.py +0 -499
- ads/feature_store/validation_output.py +0 -57
- ads/hpo/__init__.py +0 -9
- ads/hpo/_imports.py +0 -91
- ads/hpo/ads_search_space.py +0 -439
- ads/hpo/distributions.py +0 -325
- ads/hpo/objective.py +0 -280
- ads/hpo/search_cv.py +0 -1657
- ads/hpo/stopping_criterion.py +0 -75
- ads/hpo/tuner_artifact.py +0 -413
- ads/hpo/utils.py +0 -91
- ads/hpo/validation.py +0 -140
- ads/hpo/visualization/__init__.py +0 -5
- ads/hpo/visualization/_contour.py +0 -23
- ads/hpo/visualization/_edf.py +0 -20
- ads/hpo/visualization/_intermediate_values.py +0 -21
- ads/hpo/visualization/_optimization_history.py +0 -25
- ads/hpo/visualization/_parallel_coordinate.py +0 -169
- ads/hpo/visualization/_param_importances.py +0 -26
- ads/jobs/__init__.py +0 -53
- ads/jobs/ads_job.py +0 -663
- ads/jobs/builders/__init__.py +0 -5
- ads/jobs/builders/base.py +0 -156
- ads/jobs/builders/infrastructure/__init__.py +0 -6
- ads/jobs/builders/infrastructure/base.py +0 -165
- ads/jobs/builders/infrastructure/dataflow.py +0 -1252
- ads/jobs/builders/infrastructure/dsc_job.py +0 -1894
- ads/jobs/builders/infrastructure/dsc_job_runtime.py +0 -1233
- ads/jobs/builders/infrastructure/utils.py +0 -65
- ads/jobs/builders/runtimes/__init__.py +0 -5
- ads/jobs/builders/runtimes/artifact.py +0 -338
- ads/jobs/builders/runtimes/base.py +0 -325
- ads/jobs/builders/runtimes/container_runtime.py +0 -242
- ads/jobs/builders/runtimes/python_runtime.py +0 -1016
- ads/jobs/builders/runtimes/pytorch_runtime.py +0 -204
- ads/jobs/cli.py +0 -104
- ads/jobs/env_var_parser.py +0 -131
- ads/jobs/extension.py +0 -160
- ads/jobs/schema/__init__.py +0 -5
- ads/jobs/schema/infrastructure_schema.json +0 -116
- ads/jobs/schema/job_schema.json +0 -42
- ads/jobs/schema/runtime_schema.json +0 -183
- ads/jobs/schema/validator.py +0 -141
- ads/jobs/serializer.py +0 -296
- ads/jobs/templates/__init__.py +0 -5
- ads/jobs/templates/container.py +0 -6
- ads/jobs/templates/driver_notebook.py +0 -177
- ads/jobs/templates/driver_oci.py +0 -500
- ads/jobs/templates/driver_python.py +0 -48
- ads/jobs/templates/driver_pytorch.py +0 -852
- ads/jobs/templates/driver_utils.py +0 -615
- ads/jobs/templates/hostname_from_env.c +0 -55
- ads/jobs/templates/oci_metrics.py +0 -181
- ads/jobs/utils.py +0 -104
- ads/llm/__init__.py +0 -28
- ads/llm/autogen/__init__.py +0 -2
- ads/llm/autogen/constants.py +0 -15
- ads/llm/autogen/reports/__init__.py +0 -2
- ads/llm/autogen/reports/base.py +0 -67
- ads/llm/autogen/reports/data.py +0 -103
- ads/llm/autogen/reports/session.py +0 -526
- ads/llm/autogen/reports/templates/chat_box.html +0 -13
- ads/llm/autogen/reports/templates/chat_box_lt.html +0 -5
- ads/llm/autogen/reports/templates/chat_box_rt.html +0 -6
- ads/llm/autogen/reports/utils.py +0 -56
- ads/llm/autogen/v02/__init__.py +0 -4
- ads/llm/autogen/v02/client.py +0 -295
- ads/llm/autogen/v02/log_handlers/__init__.py +0 -2
- ads/llm/autogen/v02/log_handlers/oci_file_handler.py +0 -83
- ads/llm/autogen/v02/loggers/__init__.py +0 -6
- ads/llm/autogen/v02/loggers/metric_logger.py +0 -320
- ads/llm/autogen/v02/loggers/session_logger.py +0 -580
- ads/llm/autogen/v02/loggers/utils.py +0 -86
- ads/llm/autogen/v02/runtime_logging.py +0 -163
- ads/llm/chain.py +0 -268
- ads/llm/chat_template.py +0 -31
- ads/llm/deploy.py +0 -63
- ads/llm/guardrails/__init__.py +0 -5
- ads/llm/guardrails/base.py +0 -442
- ads/llm/guardrails/huggingface.py +0 -44
- ads/llm/langchain/__init__.py +0 -5
- ads/llm/langchain/plugins/__init__.py +0 -5
- ads/llm/langchain/plugins/chat_models/__init__.py +0 -5
- ads/llm/langchain/plugins/chat_models/oci_data_science.py +0 -1027
- ads/llm/langchain/plugins/embeddings/__init__.py +0 -4
- ads/llm/langchain/plugins/embeddings/oci_data_science_model_deployment_endpoint.py +0 -184
- ads/llm/langchain/plugins/llms/__init__.py +0 -5
- ads/llm/langchain/plugins/llms/oci_data_science_model_deployment_endpoint.py +0 -979
- ads/llm/requirements.txt +0 -3
- ads/llm/serialize.py +0 -219
- ads/llm/serializers/__init__.py +0 -0
- ads/llm/serializers/retrieval_qa.py +0 -153
- ads/llm/serializers/runnable_parallel.py +0 -27
- ads/llm/templates/score_chain.jinja2 +0 -155
- ads/llm/templates/tool_chat_template_hermes.jinja +0 -130
- ads/llm/templates/tool_chat_template_mistral_parallel.jinja +0 -94
- ads/model/__init__.py +0 -52
- ads/model/artifact.py +0 -573
- ads/model/artifact_downloader.py +0 -254
- ads/model/artifact_uploader.py +0 -267
- ads/model/base_properties.py +0 -238
- ads/model/common/.model-ignore +0 -66
- ads/model/common/__init__.py +0 -5
- ads/model/common/utils.py +0 -142
- ads/model/datascience_model.py +0 -2635
- ads/model/deployment/__init__.py +0 -20
- ads/model/deployment/common/__init__.py +0 -5
- ads/model/deployment/common/utils.py +0 -308
- ads/model/deployment/model_deployer.py +0 -466
- ads/model/deployment/model_deployment.py +0 -1846
- ads/model/deployment/model_deployment_infrastructure.py +0 -671
- ads/model/deployment/model_deployment_properties.py +0 -493
- ads/model/deployment/model_deployment_runtime.py +0 -838
- ads/model/extractor/__init__.py +0 -5
- ads/model/extractor/automl_extractor.py +0 -74
- ads/model/extractor/embedding_onnx_extractor.py +0 -80
- ads/model/extractor/huggingface_extractor.py +0 -88
- ads/model/extractor/keras_extractor.py +0 -84
- ads/model/extractor/lightgbm_extractor.py +0 -93
- ads/model/extractor/model_info_extractor.py +0 -114
- ads/model/extractor/model_info_extractor_factory.py +0 -105
- ads/model/extractor/pytorch_extractor.py +0 -87
- ads/model/extractor/sklearn_extractor.py +0 -112
- ads/model/extractor/spark_extractor.py +0 -89
- ads/model/extractor/tensorflow_extractor.py +0 -85
- ads/model/extractor/xgboost_extractor.py +0 -94
- ads/model/framework/__init__.py +0 -5
- ads/model/framework/automl_model.py +0 -178
- ads/model/framework/embedding_onnx_model.py +0 -438
- ads/model/framework/huggingface_model.py +0 -399
- ads/model/framework/lightgbm_model.py +0 -266
- ads/model/framework/pytorch_model.py +0 -266
- ads/model/framework/sklearn_model.py +0 -250
- ads/model/framework/spark_model.py +0 -326
- ads/model/framework/tensorflow_model.py +0 -254
- ads/model/framework/xgboost_model.py +0 -258
- ads/model/generic_model.py +0 -3518
- ads/model/model_artifact_boilerplate/README.md +0 -381
- ads/model/model_artifact_boilerplate/__init__.py +0 -5
- ads/model/model_artifact_boilerplate/artifact_introspection_test/__init__.py +0 -5
- ads/model/model_artifact_boilerplate/artifact_introspection_test/model_artifact_validate.py +0 -427
- ads/model/model_artifact_boilerplate/artifact_introspection_test/requirements.txt +0 -2
- ads/model/model_artifact_boilerplate/runtime.yaml +0 -7
- ads/model/model_artifact_boilerplate/score.py +0 -61
- ads/model/model_file_description_schema.json +0 -68
- ads/model/model_introspect.py +0 -331
- ads/model/model_metadata.py +0 -1810
- ads/model/model_metadata_mixin.py +0 -460
- ads/model/model_properties.py +0 -63
- ads/model/model_version_set.py +0 -739
- ads/model/runtime/__init__.py +0 -5
- ads/model/runtime/env_info.py +0 -306
- ads/model/runtime/model_deployment_details.py +0 -37
- ads/model/runtime/model_provenance_details.py +0 -58
- ads/model/runtime/runtime_info.py +0 -81
- ads/model/runtime/schemas/inference_env_info_schema.yaml +0 -16
- ads/model/runtime/schemas/model_provenance_schema.yaml +0 -36
- ads/model/runtime/schemas/training_env_info_schema.yaml +0 -16
- ads/model/runtime/utils.py +0 -201
- ads/model/serde/__init__.py +0 -5
- ads/model/serde/common.py +0 -40
- ads/model/serde/model_input.py +0 -547
- ads/model/serde/model_serializer.py +0 -1184
- ads/model/service/__init__.py +0 -5
- ads/model/service/oci_datascience_model.py +0 -1076
- ads/model/service/oci_datascience_model_deployment.py +0 -500
- ads/model/service/oci_datascience_model_version_set.py +0 -176
- ads/model/transformer/__init__.py +0 -5
- ads/model/transformer/onnx_transformer.py +0 -324
- ads/mysqldb/__init__.py +0 -5
- ads/mysqldb/mysql_db.py +0 -227
- ads/opctl/__init__.py +0 -18
- ads/opctl/anomaly_detection.py +0 -11
- ads/opctl/backend/__init__.py +0 -5
- ads/opctl/backend/ads_dataflow.py +0 -353
- ads/opctl/backend/ads_ml_job.py +0 -710
- ads/opctl/backend/ads_ml_pipeline.py +0 -164
- ads/opctl/backend/ads_model_deployment.py +0 -209
- ads/opctl/backend/base.py +0 -146
- ads/opctl/backend/local.py +0 -1053
- ads/opctl/backend/marketplace/__init__.py +0 -9
- ads/opctl/backend/marketplace/helm_helper.py +0 -173
- ads/opctl/backend/marketplace/local_marketplace.py +0 -271
- ads/opctl/backend/marketplace/marketplace_backend_runner.py +0 -71
- ads/opctl/backend/marketplace/marketplace_operator_interface.py +0 -44
- ads/opctl/backend/marketplace/marketplace_operator_runner.py +0 -24
- ads/opctl/backend/marketplace/marketplace_utils.py +0 -212
- ads/opctl/backend/marketplace/models/__init__.py +0 -5
- ads/opctl/backend/marketplace/models/bearer_token.py +0 -94
- ads/opctl/backend/marketplace/models/marketplace_type.py +0 -70
- ads/opctl/backend/marketplace/models/ocir_details.py +0 -56
- ads/opctl/backend/marketplace/prerequisite_checker.py +0 -238
- ads/opctl/cli.py +0 -707
- ads/opctl/cmds.py +0 -869
- ads/opctl/conda/__init__.py +0 -5
- ads/opctl/conda/cli.py +0 -193
- ads/opctl/conda/cmds.py +0 -749
- ads/opctl/conda/config.yaml +0 -34
- ads/opctl/conda/manifest_template.yaml +0 -13
- ads/opctl/conda/multipart_uploader.py +0 -188
- ads/opctl/conda/pack.py +0 -89
- ads/opctl/config/__init__.py +0 -5
- ads/opctl/config/base.py +0 -57
- ads/opctl/config/diagnostics/__init__.py +0 -5
- ads/opctl/config/diagnostics/distributed/default_requirements_config.yaml +0 -62
- ads/opctl/config/merger.py +0 -255
- ads/opctl/config/resolver.py +0 -297
- ads/opctl/config/utils.py +0 -79
- ads/opctl/config/validator.py +0 -17
- ads/opctl/config/versioner.py +0 -68
- ads/opctl/config/yaml_parsers/__init__.py +0 -7
- ads/opctl/config/yaml_parsers/base.py +0 -58
- ads/opctl/config/yaml_parsers/distributed/__init__.py +0 -7
- ads/opctl/config/yaml_parsers/distributed/yaml_parser.py +0 -201
- ads/opctl/constants.py +0 -66
- ads/opctl/decorator/__init__.py +0 -5
- ads/opctl/decorator/common.py +0 -129
- ads/opctl/diagnostics/__init__.py +0 -5
- ads/opctl/diagnostics/__main__.py +0 -25
- ads/opctl/diagnostics/check_distributed_job_requirements.py +0 -212
- ads/opctl/diagnostics/check_requirements.py +0 -144
- ads/opctl/diagnostics/requirement_exception.py +0 -9
- ads/opctl/distributed/README.md +0 -109
- ads/opctl/distributed/__init__.py +0 -5
- ads/opctl/distributed/certificates.py +0 -32
- ads/opctl/distributed/cli.py +0 -207
- ads/opctl/distributed/cmds.py +0 -731
- ads/opctl/distributed/common/__init__.py +0 -5
- ads/opctl/distributed/common/abstract_cluster_provider.py +0 -449
- ads/opctl/distributed/common/abstract_framework_spec_builder.py +0 -88
- ads/opctl/distributed/common/cluster_config_helper.py +0 -103
- ads/opctl/distributed/common/cluster_provider_factory.py +0 -21
- ads/opctl/distributed/common/cluster_runner.py +0 -54
- ads/opctl/distributed/common/framework_factory.py +0 -29
- ads/opctl/docker/Dockerfile.job +0 -103
- ads/opctl/docker/Dockerfile.job.arm +0 -107
- ads/opctl/docker/Dockerfile.job.gpu +0 -175
- ads/opctl/docker/base-env.yaml +0 -13
- ads/opctl/docker/cuda.repo +0 -6
- ads/opctl/docker/operator/.dockerignore +0 -0
- ads/opctl/docker/operator/Dockerfile +0 -41
- ads/opctl/docker/operator/Dockerfile.gpu +0 -85
- ads/opctl/docker/operator/cuda.repo +0 -6
- ads/opctl/docker/operator/environment.yaml +0 -8
- ads/opctl/forecast.py +0 -11
- ads/opctl/index.yaml +0 -3
- ads/opctl/model/__init__.py +0 -5
- ads/opctl/model/cli.py +0 -65
- ads/opctl/model/cmds.py +0 -73
- ads/opctl/operator/README.md +0 -4
- ads/opctl/operator/__init__.py +0 -31
- ads/opctl/operator/cli.py +0 -344
- ads/opctl/operator/cmd.py +0 -596
- ads/opctl/operator/common/__init__.py +0 -5
- ads/opctl/operator/common/backend_factory.py +0 -460
- ads/opctl/operator/common/const.py +0 -27
- ads/opctl/operator/common/data/synthetic.csv +0 -16001
- ads/opctl/operator/common/dictionary_merger.py +0 -148
- ads/opctl/operator/common/errors.py +0 -42
- ads/opctl/operator/common/operator_config.py +0 -99
- ads/opctl/operator/common/operator_loader.py +0 -811
- ads/opctl/operator/common/operator_schema.yaml +0 -130
- ads/opctl/operator/common/operator_yaml_generator.py +0 -152
- ads/opctl/operator/common/utils.py +0 -208
- ads/opctl/operator/lowcode/__init__.py +0 -5
- ads/opctl/operator/lowcode/anomaly/MLoperator +0 -16
- ads/opctl/operator/lowcode/anomaly/README.md +0 -207
- ads/opctl/operator/lowcode/anomaly/__init__.py +0 -5
- ads/opctl/operator/lowcode/anomaly/__main__.py +0 -103
- ads/opctl/operator/lowcode/anomaly/cmd.py +0 -35
- ads/opctl/operator/lowcode/anomaly/const.py +0 -167
- ads/opctl/operator/lowcode/anomaly/environment.yaml +0 -10
- ads/opctl/operator/lowcode/anomaly/model/__init__.py +0 -5
- ads/opctl/operator/lowcode/anomaly/model/anomaly_dataset.py +0 -146
- ads/opctl/operator/lowcode/anomaly/model/anomaly_merlion.py +0 -162
- ads/opctl/operator/lowcode/anomaly/model/automlx.py +0 -99
- ads/opctl/operator/lowcode/anomaly/model/autots.py +0 -115
- ads/opctl/operator/lowcode/anomaly/model/base_model.py +0 -404
- ads/opctl/operator/lowcode/anomaly/model/factory.py +0 -110
- ads/opctl/operator/lowcode/anomaly/model/isolationforest.py +0 -78
- ads/opctl/operator/lowcode/anomaly/model/oneclasssvm.py +0 -78
- ads/opctl/operator/lowcode/anomaly/model/randomcutforest.py +0 -120
- ads/opctl/operator/lowcode/anomaly/model/tods.py +0 -119
- ads/opctl/operator/lowcode/anomaly/operator_config.py +0 -127
- ads/opctl/operator/lowcode/anomaly/schema.yaml +0 -401
- ads/opctl/operator/lowcode/anomaly/utils.py +0 -88
- ads/opctl/operator/lowcode/common/__init__.py +0 -5
- ads/opctl/operator/lowcode/common/const.py +0 -10
- ads/opctl/operator/lowcode/common/data.py +0 -116
- ads/opctl/operator/lowcode/common/errors.py +0 -47
- ads/opctl/operator/lowcode/common/transformations.py +0 -296
- ads/opctl/operator/lowcode/common/utils.py +0 -293
- ads/opctl/operator/lowcode/feature_store_marketplace/MLoperator +0 -13
- ads/opctl/operator/lowcode/feature_store_marketplace/README.md +0 -30
- ads/opctl/operator/lowcode/feature_store_marketplace/__init__.py +0 -5
- ads/opctl/operator/lowcode/feature_store_marketplace/__main__.py +0 -116
- ads/opctl/operator/lowcode/feature_store_marketplace/cmd.py +0 -85
- ads/opctl/operator/lowcode/feature_store_marketplace/const.py +0 -15
- ads/opctl/operator/lowcode/feature_store_marketplace/environment.yaml +0 -0
- ads/opctl/operator/lowcode/feature_store_marketplace/models/__init__.py +0 -4
- ads/opctl/operator/lowcode/feature_store_marketplace/models/apigw_config.py +0 -32
- ads/opctl/operator/lowcode/feature_store_marketplace/models/db_config.py +0 -43
- ads/opctl/operator/lowcode/feature_store_marketplace/models/mysql_config.py +0 -120
- ads/opctl/operator/lowcode/feature_store_marketplace/models/serializable_yaml_model.py +0 -34
- ads/opctl/operator/lowcode/feature_store_marketplace/operator_utils.py +0 -386
- ads/opctl/operator/lowcode/feature_store_marketplace/schema.yaml +0 -160
- ads/opctl/operator/lowcode/forecast/MLoperator +0 -25
- ads/opctl/operator/lowcode/forecast/README.md +0 -209
- ads/opctl/operator/lowcode/forecast/__init__.py +0 -5
- ads/opctl/operator/lowcode/forecast/__main__.py +0 -89
- ads/opctl/operator/lowcode/forecast/cmd.py +0 -40
- ads/opctl/operator/lowcode/forecast/const.py +0 -92
- ads/opctl/operator/lowcode/forecast/environment.yaml +0 -20
- ads/opctl/operator/lowcode/forecast/errors.py +0 -26
- ads/opctl/operator/lowcode/forecast/model/__init__.py +0 -5
- ads/opctl/operator/lowcode/forecast/model/arima.py +0 -279
- ads/opctl/operator/lowcode/forecast/model/automlx.py +0 -542
- ads/opctl/operator/lowcode/forecast/model/autots.py +0 -312
- ads/opctl/operator/lowcode/forecast/model/base_model.py +0 -863
- ads/opctl/operator/lowcode/forecast/model/factory.py +0 -106
- ads/opctl/operator/lowcode/forecast/model/forecast_datasets.py +0 -492
- ads/opctl/operator/lowcode/forecast/model/ml_forecast.py +0 -243
- ads/opctl/operator/lowcode/forecast/model/neuralprophet.py +0 -486
- ads/opctl/operator/lowcode/forecast/model/prophet.py +0 -445
- ads/opctl/operator/lowcode/forecast/model_evaluator.py +0 -244
- ads/opctl/operator/lowcode/forecast/operator_config.py +0 -234
- ads/opctl/operator/lowcode/forecast/schema.yaml +0 -506
- ads/opctl/operator/lowcode/forecast/utils.py +0 -413
- ads/opctl/operator/lowcode/forecast/whatifserve/__init__.py +0 -7
- ads/opctl/operator/lowcode/forecast/whatifserve/deployment_manager.py +0 -285
- ads/opctl/operator/lowcode/forecast/whatifserve/score.py +0 -246
- ads/opctl/operator/lowcode/pii/MLoperator +0 -17
- ads/opctl/operator/lowcode/pii/README.md +0 -208
- ads/opctl/operator/lowcode/pii/__init__.py +0 -5
- ads/opctl/operator/lowcode/pii/__main__.py +0 -78
- ads/opctl/operator/lowcode/pii/cmd.py +0 -39
- ads/opctl/operator/lowcode/pii/constant.py +0 -84
- ads/opctl/operator/lowcode/pii/environment.yaml +0 -17
- ads/opctl/operator/lowcode/pii/errors.py +0 -27
- ads/opctl/operator/lowcode/pii/model/__init__.py +0 -5
- ads/opctl/operator/lowcode/pii/model/factory.py +0 -82
- ads/opctl/operator/lowcode/pii/model/guardrails.py +0 -167
- ads/opctl/operator/lowcode/pii/model/pii.py +0 -145
- ads/opctl/operator/lowcode/pii/model/processor/__init__.py +0 -34
- ads/opctl/operator/lowcode/pii/model/processor/email_replacer.py +0 -34
- ads/opctl/operator/lowcode/pii/model/processor/mbi_replacer.py +0 -35
- ads/opctl/operator/lowcode/pii/model/processor/name_replacer.py +0 -225
- ads/opctl/operator/lowcode/pii/model/processor/number_replacer.py +0 -73
- ads/opctl/operator/lowcode/pii/model/processor/remover.py +0 -26
- ads/opctl/operator/lowcode/pii/model/report.py +0 -487
- ads/opctl/operator/lowcode/pii/operator_config.py +0 -95
- ads/opctl/operator/lowcode/pii/schema.yaml +0 -108
- ads/opctl/operator/lowcode/pii/utils.py +0 -43
- ads/opctl/operator/lowcode/recommender/MLoperator +0 -16
- ads/opctl/operator/lowcode/recommender/README.md +0 -206
- ads/opctl/operator/lowcode/recommender/__init__.py +0 -5
- ads/opctl/operator/lowcode/recommender/__main__.py +0 -82
- ads/opctl/operator/lowcode/recommender/cmd.py +0 -33
- ads/opctl/operator/lowcode/recommender/constant.py +0 -30
- ads/opctl/operator/lowcode/recommender/environment.yaml +0 -11
- ads/opctl/operator/lowcode/recommender/model/base_model.py +0 -212
- ads/opctl/operator/lowcode/recommender/model/factory.py +0 -56
- ads/opctl/operator/lowcode/recommender/model/recommender_dataset.py +0 -25
- ads/opctl/operator/lowcode/recommender/model/svd.py +0 -106
- ads/opctl/operator/lowcode/recommender/operator_config.py +0 -81
- ads/opctl/operator/lowcode/recommender/schema.yaml +0 -265
- ads/opctl/operator/lowcode/recommender/utils.py +0 -13
- ads/opctl/operator/runtime/__init__.py +0 -5
- ads/opctl/operator/runtime/const.py +0 -17
- ads/opctl/operator/runtime/container_runtime_schema.yaml +0 -50
- ads/opctl/operator/runtime/marketplace_runtime.py +0 -50
- ads/opctl/operator/runtime/python_marketplace_runtime_schema.yaml +0 -21
- ads/opctl/operator/runtime/python_runtime_schema.yaml +0 -21
- ads/opctl/operator/runtime/runtime.py +0 -115
- ads/opctl/schema.yaml.yml +0 -36
- ads/opctl/script.py +0 -40
- ads/opctl/spark/__init__.py +0 -5
- ads/opctl/spark/cli.py +0 -43
- ads/opctl/spark/cmds.py +0 -147
- ads/opctl/templates/diagnostic_report_template.jinja2 +0 -102
- ads/opctl/utils.py +0 -344
- ads/oracledb/__init__.py +0 -5
- ads/oracledb/oracle_db.py +0 -346
- ads/pipeline/__init__.py +0 -39
- ads/pipeline/ads_pipeline.py +0 -2279
- ads/pipeline/ads_pipeline_run.py +0 -772
- ads/pipeline/ads_pipeline_step.py +0 -605
- ads/pipeline/builders/__init__.py +0 -5
- ads/pipeline/builders/infrastructure/__init__.py +0 -5
- ads/pipeline/builders/infrastructure/custom_script.py +0 -32
- ads/pipeline/cli.py +0 -119
- ads/pipeline/extension.py +0 -291
- ads/pipeline/schema/__init__.py +0 -5
- ads/pipeline/schema/cs_step_schema.json +0 -35
- ads/pipeline/schema/ml_step_schema.json +0 -31
- ads/pipeline/schema/pipeline_schema.json +0 -71
- ads/pipeline/visualizer/__init__.py +0 -5
- ads/pipeline/visualizer/base.py +0 -570
- ads/pipeline/visualizer/graph_renderer.py +0 -272
- ads/pipeline/visualizer/text_renderer.py +0 -84
- ads/secrets/__init__.py +0 -11
- ads/secrets/adb.py +0 -386
- ads/secrets/auth_token.py +0 -86
- ads/secrets/big_data_service.py +0 -365
- ads/secrets/mysqldb.py +0 -149
- ads/secrets/oracledb.py +0 -160
- ads/secrets/secrets.py +0 -407
- ads/telemetry/__init__.py +0 -7
- ads/telemetry/base.py +0 -69
- ads/telemetry/client.py +0 -125
- ads/telemetry/telemetry.py +0 -257
- ads/templates/dataflow_pyspark.jinja2 +0 -13
- ads/templates/dataflow_sparksql.jinja2 +0 -22
- ads/templates/func.jinja2 +0 -20
- ads/templates/schemas/openapi.json +0 -1740
- ads/templates/score-pkl.jinja2 +0 -173
- ads/templates/score.jinja2 +0 -322
- ads/templates/score_embedding_onnx.jinja2 +0 -202
- ads/templates/score_generic.jinja2 +0 -165
- ads/templates/score_huggingface_pipeline.jinja2 +0 -217
- ads/templates/score_lightgbm.jinja2 +0 -185
- ads/templates/score_onnx.jinja2 +0 -407
- ads/templates/score_onnx_new.jinja2 +0 -473
- ads/templates/score_oracle_automl.jinja2 +0 -185
- ads/templates/score_pyspark.jinja2 +0 -154
- ads/templates/score_pytorch.jinja2 +0 -219
- ads/templates/score_scikit-learn.jinja2 +0 -184
- ads/templates/score_tensorflow.jinja2 +0 -184
- ads/templates/score_xgboost.jinja2 +0 -178
- ads/text_dataset/__init__.py +0 -5
- ads/text_dataset/backends.py +0 -211
- ads/text_dataset/dataset.py +0 -445
- ads/text_dataset/extractor.py +0 -207
- ads/text_dataset/options.py +0 -53
- ads/text_dataset/udfs.py +0 -22
- ads/text_dataset/utils.py +0 -49
- ads/type_discovery/__init__.py +0 -9
- ads/type_discovery/abstract_detector.py +0 -21
- ads/type_discovery/constant_detector.py +0 -41
- ads/type_discovery/continuous_detector.py +0 -54
- ads/type_discovery/credit_card_detector.py +0 -99
- ads/type_discovery/datetime_detector.py +0 -92
- ads/type_discovery/discrete_detector.py +0 -118
- ads/type_discovery/document_detector.py +0 -146
- ads/type_discovery/ip_detector.py +0 -68
- ads/type_discovery/latlon_detector.py +0 -90
- ads/type_discovery/phone_number_detector.py +0 -63
- ads/type_discovery/type_discovery_driver.py +0 -87
- ads/type_discovery/typed_feature.py +0 -594
- ads/type_discovery/unknown_detector.py +0 -41
- ads/type_discovery/zipcode_detector.py +0 -48
- ads/vault/__init__.py +0 -7
- ads/vault/vault.py +0 -237
- oracle_ads-2.13.8.dist-info/RECORD +0 -858
- {oracle_ads-2.13.8.dist-info → oracle_ads-2.13.9rc0.dist-info}/licenses/LICENSE.txt +0 -0
@@ -1,207 +0,0 @@
|
|
1
|
-
# Anomaly Detection Operator
|
2
|
-
|
3
|
-
Anomaly Detection is the identification of rare items, events, or observations in data that differ significantly from the expectation. This can be used for several scenarios like asset monitoring, maintenance and prognostic surveillance in industries such as utility, aviation and manufacturing.
|
4
|
-
|
5
|
-
Below are the steps to configure and run the Anomaly Detection Operator on different resources.
|
6
|
-
|
7
|
-
## 1. Prerequisites
|
8
|
-
|
9
|
-
Follow the [CLI Configuration](https://accelerated-data-science.readthedocs.io/en/latest/user_guide/cli/opctl/configure.html) steps from the ADS documentation. This step is mandatory as it sets up default values for different options while running the Anomaly Detection Operator on OCI Data Science jobs or OCI Data Flow applications. If you have previously done this and used a flexible shape, make sure to adjust `ml_job_config.ini` with shape config details and `docker_registry` information.
|
10
|
-
|
11
|
-
- ocpus = 1
|
12
|
-
- memory_in_gbs = 16
|
13
|
-
- docker_registry = `<iad.ocir.io/namespace/>`
|
14
|
-
|
15
|
-
## 2. Generating configs
|
16
|
-
|
17
|
-
To generate starter configs, run the command below. This will create a list of YAML configs and place them in the `output` folder.
|
18
|
-
|
19
|
-
```bash
|
20
|
-
ads operator init -t anomaly --overwrite --output ~/anomaly/
|
21
|
-
```
|
22
|
-
|
23
|
-
The most important files expected to be generated are:
|
24
|
-
|
25
|
-
- `anomaly.yaml`: Contains anomaly detection related configuration.
|
26
|
-
- `backend_operator_local_python_config.yaml`: This includes a local backend configuration for running anomaly detection in a local environment. The environment should be set up manually before running the operator.
|
27
|
-
- `backend_operator_local_container_config.yaml`: This includes a local backend configuration for running anomaly detection within a local container. The container should be built before running the operator. Please refer to the instructions below for details on how to accomplish this.
|
28
|
-
- `backend_job_container_config.yaml`: Contains Data Science job-related config to run anomaly detection in a Data Science job within a container (BYOC) runtime. The container should be built and published before running the operator. Please refer to the instructions below for details on how to accomplish this.
|
29
|
-
- `backend_job_python_config.yaml`: Contains Data Science job-related config to run anomaly detection in a Data Science job within a conda runtime. The conda should be built and published before running the operator.
|
30
|
-
|
31
|
-
All generated configurations should be ready to use without the need for any additional adjustments. However, they are provided as starter kit configurations that can be customized as needed.
|
32
|
-
|
33
|
-
## 3. Running anomaly detection on the local conda environment
|
34
|
-
|
35
|
-
To run anomaly detection locally, create and activate a new conda environment (`ads-anomaly`). Install all the required libraries listed in the `environment.yaml` file.
|
36
|
-
|
37
|
-
```yaml
|
38
|
-
- report-creator
|
39
|
-
- cerberus
|
40
|
-
- "git+https://github.com/oracle/accelerated-data-science.git@feature/anomaly#egg=oracle-ads"
|
41
|
-
```
|
42
|
-
|
43
|
-
Please review the previously generated `anomaly.yaml` file using the `init` command, and make any necessary adjustments to the input and output file locations. By default, it assumes that the files should be located in the same folder from which the `init` command was executed.
|
44
|
-
|
45
|
-
Use the command below to verify the anomaly detection config.
|
46
|
-
|
47
|
-
```bash
|
48
|
-
ads operator verify -f ~/anomaly/anomaly.yaml
|
49
|
-
```
|
50
|
-
|
51
|
-
Use the following command to run the anomaly detection within the `ads-anomaly` conda environment.
|
52
|
-
|
53
|
-
```bash
|
54
|
-
ads operator run -f ~/anomaly/anomaly.yaml -b local
|
55
|
-
```
|
56
|
-
|
57
|
-
The operator will run in your local environment without requiring any additional modifications.
|
58
|
-
|
59
|
-
## 4. Running anomaly detection on the local container
|
60
|
-
|
61
|
-
To run the anomaly detection operator within a local container, follow these steps:
|
62
|
-
|
63
|
-
Use the command below to build the anomaly detection container.
|
64
|
-
|
65
|
-
```bash
|
66
|
-
ads operator build-image -t anomaly
|
67
|
-
```
|
68
|
-
|
69
|
-
This will create a new `anomaly:v1` image, with `/etc/operator` as the designated working directory within the container.
|
70
|
-
|
71
|
-
|
72
|
-
Check the `backend_operator_local_container_config.yaml` config file. By default, it should have a `volume` section with the `.oci` configs folder mounted.
|
73
|
-
|
74
|
-
```yaml
|
75
|
-
volume:
|
76
|
-
- "/Users/<user>/.oci:/root/.oci"
|
77
|
-
```
|
78
|
-
|
79
|
-
Mounting the OCI configs folder is only required if an OCI Object Storage bucket will be used to store the input anomaly detection data or output anomaly detection result. The input/output folders can also be mounted to the container.
|
80
|
-
|
81
|
-
```yaml
|
82
|
-
volume:
|
83
|
-
- /Users/<user>/.oci:/root/.oci
|
84
|
-
- /Users/<user>/anomaly/data:/etc/operator/data
|
85
|
-
- /Users/<user>/anomaly/result:/etc/operator/result
|
86
|
-
```
|
87
|
-
|
88
|
-
The full config can look like:
|
89
|
-
```yaml
|
90
|
-
kind: operator.local
|
91
|
-
spec:
|
92
|
-
image: anomaly:v1
|
93
|
-
volume:
|
94
|
-
- /Users/<user>/.oci:/root/.oci
|
95
|
-
- /Users/<user>/anomaly/data:/etc/operator/data
|
96
|
-
- /Users/<user>/anomaly/result:/etc/operator/result
|
97
|
-
type: container
|
98
|
-
version: v1
|
99
|
-
```
|
100
|
-
|
101
|
-
Run the anomaly detection within a container using the command below:
|
102
|
-
|
103
|
-
```bash
|
104
|
-
ads operator run -f ~/anomaly/anomaly.yaml --backend-config ~/anomaly/backend_operator_local_container_config.yaml
|
105
|
-
```
|
106
|
-
|
107
|
-
## 5. Running anomaly detection in the Data Science job within container runtime
|
108
|
-
|
109
|
-
To execute the anomaly detection operator within a Data Science job using container runtime, please follow the steps outlined below:
|
110
|
-
|
111
|
-
You can use the following command to build the anomaly detection container. This step can be skipped if you have already done this for running the operator within a local container.
|
112
|
-
|
113
|
-
```bash
|
114
|
-
ads operator build-image -t anomaly
|
115
|
-
```
|
116
|
-
|
117
|
-
This will create a new `anomaly:v1` image, with `/etc/operator` as the designated working directory within the container.
|
118
|
-
|
119
|
-
Publish the `anomaly:v1` container to the [Oracle Container Registry](https://docs.public.oneportal.content.oci.oraclecloud.com/en-us/iaas/Content/Registry/home.htm). To become familiar with OCI, read the documentation links posted below.
|
120
|
-
|
121
|
-
- [Access Container Registry](https://docs.public.oneportal.content.oci.oraclecloud.com/en-us/iaas/Content/Registry/Concepts/registryoverview.htm#access)
|
122
|
-
- [Create repositories](https://docs.public.oneportal.content.oci.oraclecloud.com/en-us/iaas/Content/Registry/Tasks/registrycreatingarepository.htm#top)
|
123
|
-
- [Push images](https://docs.public.oneportal.content.oci.oraclecloud.com/en-us/iaas/Content/Registry/Tasks/registrypushingimagesusingthedockercli.htm#Pushing_Images_Using_the_Docker_CLI)
|
124
|
-
|
125
|
-
To publish `anomaly:v1` to OCR, use the command posted below:
|
126
|
-
|
127
|
-
```bash
|
128
|
-
ads operator publish-image anomaly:v1 --registry <iad.ocir.io/tenancy/>
|
129
|
-
```
|
130
|
-
|
131
|
-
After the container is published to OCR, it can be used within Data Science jobs service. Check the `backend_job_container_config.yaml` config file. It should contain pre-populated infrastructure and runtime sections. The runtime section should contain an image property, something like `image: iad.ocir.io/<tenancy>/anomaly:v1`. More details about supported options can be found in the ADS Jobs documentation - [Run a Container](https://accelerated-data-science.readthedocs.io/en/latest/user_guide/jobs/run_container.html).
|
132
|
-
|
133
|
-
Adjust the `anomaly.yaml` config with proper input/output folders. When the anomaly detection is run in the Data Science job, it will not have access to local folders. Therefore, input data and output folders should be placed in the Object Storage bucket. Open the `anomaly.yaml` and adjust the following fields:
|
134
|
-
|
135
|
-
```yaml
|
136
|
-
input_data:
|
137
|
-
url: oci://bucket@namespace/anomaly/input_data/data.csv
|
138
|
-
output_directory:
|
139
|
-
url: oci://bucket@namespace/anomaly/result/
|
140
|
-
test_data:
|
141
|
-
url: oci://bucket@namespace/anomaly/input_data/test.csv
|
142
|
-
```
|
143
|
-
|
144
|
-
Run the anomaly detection on the Data Science jobs using the command posted below:
|
145
|
-
|
146
|
-
```bash
|
147
|
-
ads operator run -f ~/anomaly/anomaly.yaml --backend-config ~/anomaly/backend_job_container_config.yaml
|
148
|
-
```
|
149
|
-
|
150
|
-
The logs can be monitored using the `ads opctl watch` command.
|
151
|
-
|
152
|
-
```bash
|
153
|
-
ads opctl watch <OCID>
|
154
|
-
```
|
155
|
-
|
156
|
-
## 6. Running anomaly detection in the Data Science job within conda runtime
|
157
|
-
|
158
|
-
To execute the anomaly detection operator within a Data Science job using conda runtime, please follow the steps outlined below:
|
159
|
-
|
160
|
-
You can use the following command to build the anomaly detection conda environment.
|
161
|
-
|
162
|
-
```bash
|
163
|
-
ads operator build-conda -t anomaly
|
164
|
-
```
|
165
|
-
|
166
|
-
This will create a new `anomaly_v1` conda environment and place it in the folder specified within `ads opctl configure` command.
|
167
|
-
|
168
|
-
Use the command below to Publish the `anomaly_v1` conda environment to the Object Storage bucket.
|
169
|
-
|
170
|
-
```bash
|
171
|
-
ads operator publish-conda -t anomaly
|
172
|
-
```
|
173
|
-
More details about configuring CLI can be found here - [Configuring CLI](https://accelerated-data-science.readthedocs.io/en/latest/user_guide/cli/opctl/configure.html)
|
174
|
-
|
175
|
-
|
176
|
-
After the conda environment is published to Object Storage, it can be used within Data Science jobs service. Check the `backend_job_python_config.yaml` config file. It should contain pre-populated infrastructure and runtime sections. The runtime section should contain a `conda` section.
|
177
|
-
|
178
|
-
```yaml
|
179
|
-
conda:
|
180
|
-
type: published
|
181
|
-
uri: oci://bucket@namespace/conda_environments/cpu/anomaly/1/anomaly_v1
|
182
|
-
```
|
183
|
-
|
184
|
-
More details about supported options can be found in the ADS Jobs documentation - [Run a Python Workload](https://accelerated-data-science.readthedocs.io/en/latest/user_guide/jobs/run_python.html).
|
185
|
-
|
186
|
-
Adjust the `anomaly.yaml` config with proper input/output folders. When the anomaly detection is run in the Data Science job, it will not have access to local folders. Therefore, input data and output folders should be placed in the Object Storage bucket. Open the `anomaly.yaml` and adjust the following fields:
|
187
|
-
|
188
|
-
```yaml
|
189
|
-
input_data:
|
190
|
-
url: oci://bucket@namespace/anomaly/input_data/data.csv
|
191
|
-
output_directory:
|
192
|
-
url: oci://bucket@namespace/anomaly/result/
|
193
|
-
test_data:
|
194
|
-
url: oci://bucket@namespace/anomaly/input_data/test.csv
|
195
|
-
```
|
196
|
-
|
197
|
-
Run the anomaly detection on the Data Science jobs using the command posted below:
|
198
|
-
|
199
|
-
```bash
|
200
|
-
ads operator run -f ~/anomaly/anomaly.yaml --backend-config ~/anomaly/backend_job_python_config.yaml
|
201
|
-
```
|
202
|
-
|
203
|
-
The logs can be monitored using the `ads opctl watch` command.
|
204
|
-
|
205
|
-
```bash
|
206
|
-
ads opctl watch <OCID>
|
207
|
-
```
|
@@ -1,103 +0,0 @@
|
|
1
|
-
#!/usr/bin/env python
|
2
|
-
|
3
|
-
# Copyright (c) 2024 Oracle and/or its affiliates.
|
4
|
-
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl/
|
5
|
-
|
6
|
-
import json
|
7
|
-
import os
|
8
|
-
import sys
|
9
|
-
from typing import Dict, List
|
10
|
-
|
11
|
-
import yaml
|
12
|
-
|
13
|
-
from ads.opctl import logger
|
14
|
-
from ads.opctl.operator.common.const import ENV_OPERATOR_ARGS
|
15
|
-
from ads.opctl.operator.common.utils import _parse_input_args
|
16
|
-
|
17
|
-
from .model.anomaly_dataset import AnomalyDatasets
|
18
|
-
from .operator_config import AnomalyOperatorConfig
|
19
|
-
|
20
|
-
|
21
|
-
def operate(operator_config: AnomalyOperatorConfig) -> None:
|
22
|
-
"""Runs the anomaly detection operator."""
|
23
|
-
from .model.factory import AnomalyOperatorModelFactory
|
24
|
-
|
25
|
-
datasets = AnomalyDatasets(operator_config.spec)
|
26
|
-
try:
|
27
|
-
AnomalyOperatorModelFactory.get_model(
|
28
|
-
operator_config, datasets
|
29
|
-
).generate_report()
|
30
|
-
except Exception as e:
|
31
|
-
if operator_config.spec.model == "auto":
|
32
|
-
logger.debug(
|
33
|
-
f"Failed to forecast with error {e.args}. Trying again with model `autots`."
|
34
|
-
)
|
35
|
-
operator_config.spec.model = "autots"
|
36
|
-
operator_config.spec.model_kwargs = {}
|
37
|
-
datasets = AnomalyDatasets(operator_config.spec)
|
38
|
-
try:
|
39
|
-
AnomalyOperatorModelFactory.get_model(
|
40
|
-
operator_config, datasets
|
41
|
-
).generate_report()
|
42
|
-
except Exception as ee:
|
43
|
-
logger.debug(
|
44
|
-
f"Failed to backup forecast with error {ee.args}. Raising original error."
|
45
|
-
)
|
46
|
-
raise ee
|
47
|
-
else:
|
48
|
-
raise e
|
49
|
-
|
50
|
-
|
51
|
-
def verify(spec: Dict) -> bool:
|
52
|
-
"""Verifies the anomaly detection operator config."""
|
53
|
-
operator = AnomalyOperatorConfig.from_dict(spec)
|
54
|
-
msg_header = (
|
55
|
-
f"{'*' * 50} The operator config has been successfully verified {'*' * 50}"
|
56
|
-
)
|
57
|
-
print(msg_header)
|
58
|
-
print(operator.to_yaml())
|
59
|
-
print("*" * len(msg_header))
|
60
|
-
|
61
|
-
|
62
|
-
def main(raw_args: List[str]):
|
63
|
-
"""The entry point of the anomaly the operator."""
|
64
|
-
args, _ = _parse_input_args(raw_args)
|
65
|
-
if not args.file and not args.spec and not os.environ.get(ENV_OPERATOR_ARGS):
|
66
|
-
logger.info(
|
67
|
-
"Please specify -f[--file] or -s[--spec] or "
|
68
|
-
f"pass operator's arguments via {ENV_OPERATOR_ARGS} environment variable."
|
69
|
-
)
|
70
|
-
return
|
71
|
-
|
72
|
-
logger.info("-" * 100)
|
73
|
-
logger.info(
|
74
|
-
f"{'Running' if not args.verify else 'Verifying'} the anomaly detection operator."
|
75
|
-
)
|
76
|
-
|
77
|
-
# if spec provided as input string, then convert the string into YAML
|
78
|
-
yaml_string = ""
|
79
|
-
if args.spec or os.environ.get(ENV_OPERATOR_ARGS):
|
80
|
-
operator_spec_str = args.spec or os.environ.get(ENV_OPERATOR_ARGS)
|
81
|
-
try:
|
82
|
-
yaml_string = yaml.safe_dump(json.loads(operator_spec_str))
|
83
|
-
except json.JSONDecodeError:
|
84
|
-
yaml_string = yaml.safe_dump(yaml.safe_load(operator_spec_str))
|
85
|
-
except Exception:
|
86
|
-
yaml_string = operator_spec_str
|
87
|
-
|
88
|
-
operator_config = AnomalyOperatorConfig.from_yaml(
|
89
|
-
uri=args.file,
|
90
|
-
yaml_string=yaml_string,
|
91
|
-
)
|
92
|
-
|
93
|
-
logger.info(operator_config.to_yaml())
|
94
|
-
|
95
|
-
# run operator
|
96
|
-
if args.verify:
|
97
|
-
verify(operator_config)
|
98
|
-
else:
|
99
|
-
operate(operator_config)
|
100
|
-
|
101
|
-
|
102
|
-
if __name__ == "__main__":
|
103
|
-
main(sys.argv[1:])
|
@@ -1,35 +0,0 @@
|
|
1
|
-
#!/usr/bin/env python
|
2
|
-
# -*- coding: utf-8 -*--
|
3
|
-
|
4
|
-
# Copyright (c) 2023 Oracle and/or its affiliates.
|
5
|
-
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl/
|
6
|
-
|
7
|
-
from typing import Dict
|
8
|
-
|
9
|
-
from ads.opctl import logger
|
10
|
-
from ads.opctl.operator.common.utils import _load_yaml_from_uri
|
11
|
-
from ads.opctl.operator.common.operator_yaml_generator import YamlGenerator
|
12
|
-
|
13
|
-
|
14
|
-
def init(**kwargs: Dict) -> str:
|
15
|
-
"""
|
16
|
-
Generates operator config by the schema.
|
17
|
-
|
18
|
-
Properties
|
19
|
-
----------
|
20
|
-
kwargs: (Dict, optional).
|
21
|
-
Additional key value arguments.
|
22
|
-
|
23
|
-
- type: str
|
24
|
-
The type of the operator.
|
25
|
-
|
26
|
-
Returns
|
27
|
-
-------
|
28
|
-
str
|
29
|
-
The YAML specification generated based on the schema.
|
30
|
-
"""
|
31
|
-
logger.info("==== Generating anomaly detection configuration yaml file ====")
|
32
|
-
|
33
|
-
return YamlGenerator(
|
34
|
-
schema=_load_yaml_from_uri(__file__.replace("cmd.py", "schema.yaml"))
|
35
|
-
).generate_example_dict(values={"type": kwargs.get("type")})
|
@@ -1,167 +0,0 @@
|
|
1
|
-
#!/usr/bin/env python
|
2
|
-
|
3
|
-
# Copyright (c) 2023, 2025 Oracle and/or its affiliates.
|
4
|
-
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl/
|
5
|
-
|
6
|
-
from ads.common.extended_enum import ExtendedEnum
|
7
|
-
from ads.opctl.operator.lowcode.common.const import DataColumns
|
8
|
-
|
9
|
-
|
10
|
-
class SupportedModels(ExtendedEnum):
|
11
|
-
"""Supported anomaly models."""
|
12
|
-
|
13
|
-
AutoTS = "autots"
|
14
|
-
Auto = "auto"
|
15
|
-
IQR = "iqr"
|
16
|
-
LOF = "lof"
|
17
|
-
ZSCORE = "zscore"
|
18
|
-
ROLLING_ZSCORE = "rolling_zscore"
|
19
|
-
MAD = "mad"
|
20
|
-
EE = "ee"
|
21
|
-
ISOLATIONFOREST = "isolationforest"
|
22
|
-
|
23
|
-
# point anomaly
|
24
|
-
DAGMM = "dagmm"
|
25
|
-
DEEP_POINT_ANOMALY_DETECTOR = "deep_point_anomaly_detector"
|
26
|
-
LSTM_ED = "lstm_ed"
|
27
|
-
SPECTRAL_RESIDUAL = "spectral_residual"
|
28
|
-
VAE = "vae"
|
29
|
-
|
30
|
-
# forecast_based
|
31
|
-
ARIMA = "arima"
|
32
|
-
ETS = "ets"
|
33
|
-
PROPHET = "prophet"
|
34
|
-
SARIMA = "sarima"
|
35
|
-
|
36
|
-
# changepoint
|
37
|
-
BOCPD = "bocpd"
|
38
|
-
|
39
|
-
|
40
|
-
class NonTimeADSupportedModels(ExtendedEnum):
|
41
|
-
"""Supported non time-based anomaly detection models."""
|
42
|
-
|
43
|
-
OneClassSVM = "oneclasssvm"
|
44
|
-
IsolationForest = "isolationforest"
|
45
|
-
RandomCutForest = "randomcutforest"
|
46
|
-
# TODO : Add DBScan
|
47
|
-
# DBScan = "dbscan"
|
48
|
-
|
49
|
-
|
50
|
-
class TODSSubModels(ExtendedEnum):
|
51
|
-
"""Supported TODS sub models."""
|
52
|
-
|
53
|
-
OCSVM = "ocsvm"
|
54
|
-
DeepLog = "deeplog"
|
55
|
-
Telemanom = "telemanom"
|
56
|
-
IsolationForest = "isolationforest"
|
57
|
-
LSTMODetector = "lstmodetector"
|
58
|
-
KNN = "knn"
|
59
|
-
|
60
|
-
|
61
|
-
TODS_IMPORT_MODEL_MAP = {
|
62
|
-
TODSSubModels.OCSVM: ".OCSVM_skinterface",
|
63
|
-
TODSSubModels.DeepLog: ".DeepLog_skinterface",
|
64
|
-
TODSSubModels.Telemanom: ".Telemanom_skinterface",
|
65
|
-
TODSSubModels.IsolationForest: ".IsolationForest_skinterface",
|
66
|
-
TODSSubModels.LSTMODetector: ".LSTMODetector_skinterface",
|
67
|
-
TODSSubModels.KNN: ".KNN_skinterface",
|
68
|
-
}
|
69
|
-
|
70
|
-
TODS_MODEL_MAP = {
|
71
|
-
TODSSubModels.OCSVM: "OCSVMSKI",
|
72
|
-
TODSSubModels.DeepLog: "DeepLogSKI",
|
73
|
-
TODSSubModels.Telemanom: "TelemanomSKI",
|
74
|
-
TODSSubModels.IsolationForest: "IsolationForestSKI",
|
75
|
-
TODSSubModels.LSTMODetector: "LSTMODetectorSKI",
|
76
|
-
TODSSubModels.KNN: "KNNSKI",
|
77
|
-
}
|
78
|
-
|
79
|
-
|
80
|
-
class MerlionADModels(ExtendedEnum):
|
81
|
-
"""Supported Merlion AD sub models."""
|
82
|
-
|
83
|
-
# point anomaly
|
84
|
-
DAGMM = "dagmm"
|
85
|
-
DEEP_POINT_ANOMALY_DETECTOR = "deep_point_anomaly_detector"
|
86
|
-
LSTM_ED = "lstm_ed"
|
87
|
-
SPECTRAL_RESIDUAL = "spectral_residual"
|
88
|
-
VAE = "vae"
|
89
|
-
|
90
|
-
# forecast_based
|
91
|
-
ARIMA = "arima"
|
92
|
-
ETS = "ets"
|
93
|
-
PROPHET = "prophet"
|
94
|
-
SARIMA = "sarima"
|
95
|
-
|
96
|
-
# changepoint
|
97
|
-
BOCPD = "bocpd"
|
98
|
-
|
99
|
-
|
100
|
-
MERLIONAD_IMPORT_MODEL_MAP = {
|
101
|
-
MerlionADModels.DAGMM: ".dagmm",
|
102
|
-
MerlionADModels.DEEP_POINT_ANOMALY_DETECTOR: ".deep_point_anomaly_detector",
|
103
|
-
MerlionADModels.LSTM_ED: ".lstm_ed",
|
104
|
-
MerlionADModels.SPECTRAL_RESIDUAL: ".spectral_residual",
|
105
|
-
MerlionADModels.VAE: ".vae",
|
106
|
-
MerlionADModels.ARIMA: ".forecast_based.arima",
|
107
|
-
MerlionADModels.ETS: ".forecast_based.ets",
|
108
|
-
MerlionADModels.PROPHET: ".forecast_based.prophet",
|
109
|
-
MerlionADModels.SARIMA: ".forecast_based.sarima",
|
110
|
-
MerlionADModels.BOCPD: ".change_point.bocpd",
|
111
|
-
}
|
112
|
-
|
113
|
-
|
114
|
-
MERLIONAD_MODEL_MAP = {
|
115
|
-
MerlionADModels.DAGMM: "DAGMM",
|
116
|
-
MerlionADModels.DEEP_POINT_ANOMALY_DETECTOR: "DeepPointAnomalyDetector",
|
117
|
-
MerlionADModels.LSTM_ED: "LSTMED",
|
118
|
-
MerlionADModels.SPECTRAL_RESIDUAL: "SpectralResidual",
|
119
|
-
MerlionADModels.VAE: "VAE",
|
120
|
-
MerlionADModels.ARIMA: "ArimaDetector",
|
121
|
-
MerlionADModels.ETS: "ETSDetector",
|
122
|
-
MerlionADModels.PROPHET: "ProphetDetector",
|
123
|
-
MerlionADModels.SARIMA: "SarimaDetector",
|
124
|
-
MerlionADModels.BOCPD: "BOCPD",
|
125
|
-
}
|
126
|
-
|
127
|
-
|
128
|
-
class SupportedMetrics(ExtendedEnum):
|
129
|
-
UNSUPERVISED_UNIFY95 = "unsupervised_unify95"
|
130
|
-
UNSUPERVISED_UNIFY95_LOG_LOSS = "unsupervised_unify95_log_loss"
|
131
|
-
UNSUPERVISED_N1_EXPERTS = "unsupervised_n-1_experts"
|
132
|
-
RECALL = "Recall"
|
133
|
-
PRECISION = "Precision"
|
134
|
-
ACCURACY = "Accuracy"
|
135
|
-
F1_SCORE = "f1_score"
|
136
|
-
FP = "False Positive"
|
137
|
-
FN = "False Negative"
|
138
|
-
TP = "True Positive"
|
139
|
-
TN = "True Negative"
|
140
|
-
ROC_AUC = "ROC_AUC"
|
141
|
-
PRC_AUC = "PRC_AUC"
|
142
|
-
MCC = "MCC"
|
143
|
-
MEAN_RECALL = "Mean Recall"
|
144
|
-
MEAN_PRECISION = "Mean Precision"
|
145
|
-
MEAN_ACCURACY = "Mean Accuracy"
|
146
|
-
MEAN_F1_SCORE = "Mean f1_score"
|
147
|
-
MEAN_ROC_AUC = "Mean ROC_AUC"
|
148
|
-
MEAN_PRC_AUC = "Mean PRC_AUC"
|
149
|
-
MEAN_MCC = "Mean MCC"
|
150
|
-
MEDIAN_RECALL = "Median Recall"
|
151
|
-
MEDIAN_PRECISION = "Median Precision"
|
152
|
-
MEDIAN_ACCURACY = "Median Accuracy"
|
153
|
-
MEDIAN_F1_SCORE = "Median f1_score"
|
154
|
-
MEDIAN_ROC_AUC = "Median ROC_AUC"
|
155
|
-
MEDIAN_PRC_AUC = "Median PRC_AUC"
|
156
|
-
MEDIAN_MCC = "Median MCC"
|
157
|
-
ELAPSED_TIME = "Elapsed Time"
|
158
|
-
|
159
|
-
|
160
|
-
class OutputColumns(ExtendedEnum):
|
161
|
-
ANOMALY_COL = "anomaly"
|
162
|
-
SCORE_COL = "score"
|
163
|
-
Series = DataColumns.Series
|
164
|
-
|
165
|
-
|
166
|
-
TODS_DEFAULT_MODEL = "ocsvm"
|
167
|
-
SUBSAMPLE_THRESHOLD = 1000
|
@@ -1,146 +0,0 @@
|
|
1
|
-
#!/usr/bin/env python
|
2
|
-
# -*- coding: utf-8 -*--
|
3
|
-
|
4
|
-
# Copyright (c) 2023 Oracle and/or its affiliates.
|
5
|
-
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl/
|
6
|
-
|
7
|
-
import pandas as pd
|
8
|
-
|
9
|
-
from ads.opctl import logger
|
10
|
-
from ads.opctl.operator.lowcode.anomaly.const import OutputColumns
|
11
|
-
from ads.opctl.operator.lowcode.anomaly.utils import get_frequency_of_datetime
|
12
|
-
from ads.opctl.operator.lowcode.common.data import AbstractData
|
13
|
-
from ads.opctl.operator.lowcode.common.utils import (
|
14
|
-
default_signer,
|
15
|
-
merge_category_columns,
|
16
|
-
)
|
17
|
-
|
18
|
-
from ..operator_config import AnomalyOperatorSpec
|
19
|
-
|
20
|
-
|
21
|
-
class AnomalyData(AbstractData):
|
22
|
-
def __init__(self, spec: AnomalyOperatorSpec):
|
23
|
-
super().__init__(spec=spec, name="input_data")
|
24
|
-
|
25
|
-
|
26
|
-
class TestData(AbstractData):
|
27
|
-
def __init__(self, spec: AnomalyOperatorSpec):
|
28
|
-
super().__init__(spec=spec, name="test_data")
|
29
|
-
|
30
|
-
|
31
|
-
class ValidationData(AbstractData):
|
32
|
-
def __init__(self, spec: AnomalyOperatorSpec):
|
33
|
-
super().__init__(spec=spec, name="validation_data")
|
34
|
-
|
35
|
-
def _ingest_data(self, spec):
|
36
|
-
self.X_valid_dict = dict()
|
37
|
-
self.y_valid_dict = dict()
|
38
|
-
for s_id, df in self.get_dict_by_series().items():
|
39
|
-
self.X_valid_dict[s_id] = df.drop([OutputColumns.ANOMALY_COL], axis=1)
|
40
|
-
self.y_valid_dict[s_id] = df[OutputColumns.ANOMALY_COL]
|
41
|
-
|
42
|
-
|
43
|
-
class AnomalyDatasets:
|
44
|
-
def __init__(self, spec: AnomalyOperatorSpec):
|
45
|
-
"""Instantiates the DataIO instance.
|
46
|
-
|
47
|
-
Properties
|
48
|
-
----------
|
49
|
-
spec: AnomalyOperatorSpec
|
50
|
-
The anomaly operator spec.
|
51
|
-
"""
|
52
|
-
self._data = AnomalyData(spec)
|
53
|
-
self.data = self._data.get_data_long()
|
54
|
-
self.full_data_dict = self._data.get_dict_by_series()
|
55
|
-
if spec.validation_data is not None:
|
56
|
-
self.valid_data = ValidationData(spec)
|
57
|
-
self.X_valid_dict = self.valid_data.X_valid_dict
|
58
|
-
self.y_valid_dict = self.valid_data.y_valid_dict
|
59
|
-
|
60
|
-
# Returns raw data based on the series_id i.e; the merged target_category_column value
|
61
|
-
def get_raw_data_by_cat(self, category):
|
62
|
-
return self._data.get_raw_data_by_cat(category)
|
63
|
-
|
64
|
-
|
65
|
-
class AnomalyOutput:
|
66
|
-
def __init__(self, date_column):
|
67
|
-
self.category_map = dict()
|
68
|
-
self.date_column = date_column
|
69
|
-
|
70
|
-
def list_categories(self):
|
71
|
-
categories = list(self.category_map.keys())
|
72
|
-
categories.sort()
|
73
|
-
return categories
|
74
|
-
|
75
|
-
def add_output(self, category: str, anomalies: pd.DataFrame, scores: pd.DataFrame):
|
76
|
-
self.category_map[category] = (anomalies, scores)
|
77
|
-
|
78
|
-
def get_anomalies_by_cat(self, category: str):
|
79
|
-
return self.category_map[category][0]
|
80
|
-
|
81
|
-
def get_scores_by_cat(self, category: str):
|
82
|
-
return self.category_map[category][1]
|
83
|
-
|
84
|
-
def get_inliers_by_cat(self, category: str, data: pd.DataFrame):
|
85
|
-
anomaly = self.get_anomalies_by_cat(category)
|
86
|
-
scores = self.get_scores_by_cat(category)
|
87
|
-
inlier_indices = anomaly.index[anomaly[OutputColumns.ANOMALY_COL] == 0]
|
88
|
-
inliers = data.iloc[inlier_indices]
|
89
|
-
if scores is not None and not scores.empty and self.date_column != "index":
|
90
|
-
inliers = pd.merge(inliers, scores, on=self.date_column, how="inner")
|
91
|
-
else:
|
92
|
-
inliers = pd.merge(inliers, anomaly, left_index=True, right_index=True, how="inner")
|
93
|
-
return inliers
|
94
|
-
|
95
|
-
def get_outliers_by_cat(self, category: str, data: pd.DataFrame):
|
96
|
-
anomaly = self.get_anomalies_by_cat(category)
|
97
|
-
scores = self.get_scores_by_cat(category)
|
98
|
-
outliers_indices = anomaly.index[anomaly[OutputColumns.ANOMALY_COL] == 1]
|
99
|
-
outliers = data.iloc[outliers_indices]
|
100
|
-
if scores is not None and not scores.empty and self.date_column != "index":
|
101
|
-
outliers = pd.merge(outliers, scores, on=self.date_column, how="inner")
|
102
|
-
else:
|
103
|
-
outliers = pd.merge(outliers, anomaly, left_index=True, right_index=True, how="inner")
|
104
|
-
return outliers
|
105
|
-
|
106
|
-
def get_inliers(self, datasets):
|
107
|
-
inliers = pd.DataFrame()
|
108
|
-
|
109
|
-
for category in self.list_categories():
|
110
|
-
inliers = pd.concat(
|
111
|
-
[
|
112
|
-
inliers,
|
113
|
-
self.get_inliers_by_cat(category, datasets.get_raw_data_by_cat(category)),
|
114
|
-
],
|
115
|
-
axis=0,
|
116
|
-
ignore_index=True,
|
117
|
-
)
|
118
|
-
return inliers
|
119
|
-
|
120
|
-
def get_outliers(self, datasets):
|
121
|
-
outliers = pd.DataFrame()
|
122
|
-
|
123
|
-
for category in self.list_categories():
|
124
|
-
outliers = pd.concat(
|
125
|
-
[
|
126
|
-
outliers,
|
127
|
-
self.get_outliers_by_cat(category, datasets.get_raw_data_by_cat(category)),
|
128
|
-
],
|
129
|
-
axis=0,
|
130
|
-
ignore_index=True,
|
131
|
-
)
|
132
|
-
return outliers
|
133
|
-
|
134
|
-
def get_scores(self, target_category_columns):
|
135
|
-
if target_category_columns is None:
|
136
|
-
return self.get_scores_by_cat(self.list_categories()[0])
|
137
|
-
|
138
|
-
scores = pd.DataFrame()
|
139
|
-
for category in self.list_categories():
|
140
|
-
score = self.get_scores_by_cat(category)
|
141
|
-
score[target_category_columns[0]] = category
|
142
|
-
scores = pd.concat([scores, score], axis=0, ignore_index=True)
|
143
|
-
return scores
|
144
|
-
|
145
|
-
def get_num_anomalies_by_cat(self, category: str):
|
146
|
-
return (self.category_map[category][0][OutputColumns.ANOMALY_COL] == 1).sum()
|