abacusai.api_class.model
Classes
An abstract class for the training config options used to train the model. |
|
Training config for the PERSONALIZATION problem type |
|
Training config for the PREDICTIVE_MODELING problem type |
|
Training config for the FORECASTING problem type |
|
Training config for the NAMED_ENTITY_EXTRACTION problem type |
|
Training config for the NATURAL_LANGUAGE_SEARCH problem type |
|
Training config for the CHAT_LLM problem type |
|
Training config for the SENTENCE_BOUNDARY_DETECTION problem type |
|
Training config for the SENTIMENT_DETECTION problem type |
|
Training config for the DOCUMENT_CLASSIFICATION problem type |
|
Training config for the DOCUMENT_SUMMARIZATION problem type |
|
Training config for the DOCUMENT_VISUALIZATION problem type |
|
Training config for the CLUSTERING problem type |
|
Training config for the CLUSTERING_TIMESERIES problem type |
|
Training config for the EVENT_ANOMALY problem type |
|
Training config for the TS_ANOMALY problem type |
|
Training config for the CUMULATIVE_FORECASTING problem type |
|
Training config for the THEME ANALYSIS problem type |
|
Training config for the AI_AGENT problem type |
|
Training config for the CUSTOM_TRAINED_MODEL problem type |
|
Training config for the CUSTOM_ALGORITHM problem type |
|
Training config for the OPTIMIZATION problem type |
|
Helper class that provides a standard way to create an ABC using |
|
Algorithm that can be deployed to a model. |
Module Contents
- class abacusai.api_class.model.TrainingConfig
Bases:
abacusai.api_class.abstract.ApiClass
An abstract class for the training config options used to train the model.
- problem_type: abacusai.api_class.enums.ProblemType = None
- classmethod _get_builder()
- class abacusai.api_class.model.PersonalizationTrainingConfig
Bases:
TrainingConfig
Training config for the PERSONALIZATION problem type
- Parameters:
objective (PersonalizationObjective) – Ranking scheme used to select final best model.
sort_objective (PersonalizationObjective) – Ranking scheme used to sort models on the metrics page.
training_mode (PersonalizationTrainingMode) – whether to train in production or experimental mode. Defaults to EXP.
target_action_types (List[str]) – List of action types to use as targets for training.
target_action_weights (Dict[str, float]) – Dictionary of action types to weights for training.
session_event_types (List[str]) – List of event types to treat as occurrences of sessions.
test_split (int) – Percent of dataset to use for test data. We support using a range between 6% to 20% of your dataset to use as test data.
recent_days_for_training (int) – Limit training data to a certain latest number of days.
training_start_date (str) – Only consider training interaction data after this date. Specified in the timezone of the dataset.
test_on_user_split (bool) – Use user splits instead of using time splits, when validating and testing the model.
test_split_on_last_k_items (bool) – Use last k items instead of global timestamp splits, when validating and testing the model.
test_last_items_length (int) – Number of items to leave out for each user when using leave k out folds.
test_window_length_hours (int) – Duration (in hours) of most recent time window to use when validating and testing the model.
explicit_time_split (bool) – Sets an explicit time-based test boundary.
test_row_indicator (str) – Column indicating which rows to use for training (TRAIN), validation (VAL) and testing (TEST).
full_data_retraining (bool) – Train models separately with all the data.
sequential_training (bool) – Train a mode sequentially through time.
data_split_feature_group_table_name (str) – Specify the table name of the feature group to export training data with the fold column.
optimized_event_type (str) – The final event type to optimize for and compute metrics on.
dropout_rate (int) – Dropout rate for neural network.
batch_size (BatchSize) – Batch size for neural network.
disable_transformer (bool) – Disable training the transformer algorithm.
disable_gpu (boo) – Disable training on GPU.
filter_history (bool) – Do not recommend items the user has already interacted with.
action_types_exclusion_days (Dict[str, float]) – Mapping from action type to number of days for which we exclude previously interacted items from prediction
session_dedupe_mins (float) – Minimum number of minutes between two sessions for a user.
max_history_length (int) – Maximum length of user-item history to include user in training examples.
compute_rerank_metrics (bool) – Compute metrics based on rerank results.
add_time_features (bool) – Include interaction time as a feature.
disable_timestamp_scalar_features (bool) – Exclude timestamp scalar features.
compute_session_metrics (bool) – Evaluate models based on how well they are able to predict the next session of interactions.
max_user_history_len_percentile (int) – Filter out users with history length above this percentile.
downsample_item_popularity_percentile (float) – Downsample items more popular than this percentile.
use_user_id_feature (bool) – Use user id as a feature in CTR models.
min_item_history (int) – Minimum number of interactions an item must have to be included in training.
query_column (str) – Name of column in the interactions table that represents a natural language query, e.g. ‘blue t-shirt’.
item_query_column (str) – Name of column in the item catalog that will be matched to the query column in the interactions table.
include_item_id_feature (bool) – Add Item-Id to the input features of the model. Applicable for Embedding distance and CTR models.
- objective: abacusai.api_class.enums.PersonalizationObjective = None
- sort_objective: abacusai.api_class.enums.PersonalizationObjective = None
- training_mode: abacusai.api_class.enums.PersonalizationTrainingMode = None
- batch_size: abacusai.api_class.enums.BatchSize = None
- __post_init__()
- class abacusai.api_class.model.RegressionTrainingConfig
Bases:
TrainingConfig
Training config for the PREDICTIVE_MODELING problem type
- Parameters:
objective (RegressionObjective) – Ranking scheme used to select final best model.
sort_objective (RegressionObjective) – Ranking scheme used to sort models on the metrics page.
tree_hpo_mode – (RegressionTreeHPOMode): Turning off Rapid Experimentation will take longer to train.
type_of_split (RegressionTypeOfSplit) – Type of data splitting into train/test (validation also).
test_split (int) – Percent of dataset to use for test data. We support using a range between 5% to 20% of your dataset to use as test data.
disable_test_val_fold (bool) – Do not create a TEST_VAL set. All records which would be part of the TEST_VAL fold otherwise, remain in the TEST fold.
k_fold_cross_validation (bool) – Use this to force k-fold cross validation bagging on or off.
num_cv_folds (int) – Specify the value of k in k-fold cross validation.
timestamp_based_splitting_column (str) – Timestamp column selected for splitting into test and train.
timestamp_based_splitting_method (RegressionTimeSplitMethod) – Method of selecting TEST set, top percentile wise or after a given timestamp.
test_splitting_timestamp (str) – Rows with timestamp greater than this will be considered to be in the test set.
sampling_unit_keys (List[str]) – Constrain train/test separation to partition a column.
test_row_indicator (str) – Column indicating which rows to use for training (TRAIN) and testing (TEST). Validation (VAL) can also be specified.
full_data_retraining (bool) – Train models separately with all the data.
rebalance_classes (bool) – Class weights are computed as the inverse of the class frequency from the training dataset when this option is selected as “Yes”. It is useful when the classes in the dataset are unbalanced. Re-balancing classes generally boosts recall at the cost of precision on rare classes.
rare_class_augmentation_threshold (float) – Augments any rare class whose relative frequency with respect to the most frequent class is less than this threshold. Default = 0.1 for classification problems with rare classes.
augmentation_strategy (RegressionAugmentationStrategy) – Strategy to deal with class imbalance and data augmentation.
training_rows_downsample_ratio (float) – Uses this ratio to train on a sample of the dataset provided.
active_labels_column (str) – Specify a column to use as the active columns in a multi label setting.
min_categorical_count (int) – Minimum threshold to consider a value different from the unknown placeholder.
sample_weight (str) – Specify a column to use as the weight of a sample for training and eval.
numeric_clipping_percentile (float) – Uses this option to clip the top and bottom x percentile of numeric feature columns where x is the value of this option.
target_transform (RegressionTargetTransform) – Specify a transform (e.g. log, quantile) to apply to the target variable.
ignore_datetime_features (bool) – Remove all datetime features from the model. Useful while generalizing to different time periods.
max_text_words (int) – Maximum number of words to use from text fields.
perform_feature_selection (bool) – If enabled, additional algorithms which support feature selection as a pretraining step will be trained separately with the selected subset of features. The details about their selected features can be found in their respective logs.
feature_selection_intensity (int) – This determines the strictness with which features will be filtered out. 1 being very lenient (more features kept), 100 being very strict.
batch_size (BatchSize) – Batch size.
dropout_rate (int) – Dropout percentage rate.
pretrained_model_name (str) – Enable algorithms which process text using pretrained multilingual NLP models.
pretrained_llm_name (str) – Enable algorithms which process text using pretrained large language models.
is_multilingual (bool) – Enable algorithms which process text using pretrained multilingual NLP models.
loss_function (RegressionLossFunction) – Loss function to be used as objective for model training.
loss_parameters (str) – Loss function params in format <key>=<value>;<key>=<value>;…..
target_encode_categoricals (bool) – Use this to turn target encoding on categorical features on or off.
drop_original_categoricals (bool) – This option helps us choose whether to also feed the original label encoded categorical columns to the mdoels along with their target encoded versions.
monotonically_increasing_features (List[str]) – Constrain the model such that it behaves as if the target feature is monotonically increasing with the selected features
monotonically_decreasing_features (List[str]) – Constrain the model such that it behaves as if the target feature is monotonically decreasing with the selected features
data_split_feature_group_table_name (str) – Specify the table name of the feature group to export training data with the fold column.
custom_loss_functions (List[str]) – Registered custom losses available for selection.
custom_metrics (List[str]) – Registered custom metrics available for selection.
partial_dependence_analysis (PartialDependenceAnalysis) – Specify whether to run partial dependence plots for all features or only some features.
do_masked_language_model_pretraining (bool) – Specify whether to run a masked language model unsupervised pretraining step before supervized training in certain supported algorithms which use BERT-like backbones.
max_tokens_in_sentence (int) – Specify the max tokens to be kept in a sentence based on the truncation strategy.
truncation_strategy (str) – What strategy to use to deal with text rows with more than a given number of tokens (if num of tokens is more than “max_tokens_in_sentence”).
- objective: abacusai.api_class.enums.RegressionObjective = None
- sort_objective: abacusai.api_class.enums.RegressionObjective = None
- tree_hpo_mode: abacusai.api_class.enums.RegressionTreeHPOMode = None
- partial_dependence_analysis: abacusai.api_class.enums.PartialDependenceAnalysis = None
- type_of_split: abacusai.api_class.enums.RegressionTypeOfSplit = None
- timestamp_based_splitting_method: abacusai.api_class.enums.RegressionTimeSplitMethod = None
- augmentation_strategy: abacusai.api_class.enums.RegressionAugmentationStrategy = None
- target_transform: abacusai.api_class.enums.RegressionTargetTransform = None
- batch_size: abacusai.api_class.enums.BatchSize = None
- loss_function: abacusai.api_class.enums.RegressionLossFunction = None
- __post_init__()
- class abacusai.api_class.model.ForecastingTrainingConfig
Bases:
TrainingConfig
Training config for the FORECASTING problem type
- Parameters:
prediction_length (int) – How many timesteps in the future to predict.
objective (ForecastingObjective) – Ranking scheme used to select final best model.
sort_objective (ForecastingObjective) – Ranking scheme used to sort models on the metrics page.
forecast_frequency (ForecastingFrequency) – Forecast frequency.
probability_quantiles (List[float]) – Prediction quantiles.
force_prediction_length (int) – Force length of test window to be the same as prediction length.
filter_items (bool) – Filter items with small history and volume.
enable_feature_selection (bool) – Enable feature selection.
enable_padding (bool) – Pad series to the max_date of the dataset
enable_cold_start (bool) – Enable cold start forecasting by training/predicting for zero history items.
enable_multiple_backtests (bool) – Whether to enable multiple backtesting or not.
num_backtesting_windows (int) – Total backtesting windows to use for the training.
backtesting_window_step_size (int) – Use this step size to shift backtesting windows for model training.
full_data_retraining (bool) – Train models separately with all the data.
additional_forecast_keys – List[str]: List of categoricals in timeseries that can act as multi-identifier.
experimentation_mode (ExperimentationMode) – Selecting Thorough Experimentation will take longer to train.
type_of_split (ForecastingDataSplitType) – Type of data splitting into train/test.
test_by_item (bool) – Partition train/test data by item rather than time if true.
test_start (str) – Limit training data to dates before the given test start.
test_split (int) – Percent of dataset to use for test data. We support using a range between 5% to 20% of your dataset to use as test data.
loss_function (ForecastingLossFunction) – Loss function for training neural network.
underprediction_weight (float) – Weight for underpredictions
disable_networks_without_analytic_quantiles (bool) – Disable neural networks, which quantile functions do not have analytic expressions (e.g, mixture models)
initial_learning_rate (float) – Initial learning rate.
l2_regularization_factor (float) – L2 regularization factor.
dropout_rate (int) – Dropout percentage rate.
recurrent_layers (int) – Number of recurrent layers to stack in network.
recurrent_units (int) – Number of units in each recurrent layer.
convolutional_layers (int) – Number of convolutional layers to stack on top of recurrent layers in network.
convolution_filters (int) – Number of filters in each convolution.
local_scaling_mode (ForecastingLocalScaling) – Options to make NN inputs stationary in high dynamic range datasets.
zero_predictor (bool) – Include subnetwork to classify points where target equals zero.
skip_missing (bool) – Make the RNN ignore missing entries rather instead of processing them.
batch_size (ForecastingBatchSize) – Batch size.
batch_renormalization (bool) – Enable batch renormalization between layers.
history_length (int) – While training, how much history to consider.
prediction_step_size (int) – Number of future periods to include in objective for each training sample.
training_point_overlap (float) – Amount of overlap to allow between training samples.
max_scale_context (int) – Maximum context to use for local scaling.
quantiles_extension_method (ForecastingQuanitlesExtensionMethod) – Quantile extension method
number_of_samples (int) – Number of samples for ancestral simulation
symmetrize_quantiles (bool) – Force symmetric quantiles (like in Gaussian distribution)
use_log_transforms (bool) – Apply logarithmic transformations to input data.
smooth_history (float) – Smooth (low pass filter) the timeseries.
local_scale_target (bool) – Using per training/prediction window target scaling.
use_clipping (bool) – Apply clipping to input data to stabilize the training.
timeseries_weight_column (str) – If set, we use the values in this column from timeseries data to assign time dependent item weights during training and evaluation.
item_attributes_weight_column (str) – If set, we use the values in this column from item attributes data to assign weights to items during training and evaluation.
use_timeseries_weights_in_objective (bool) – If True, we include weights from column set as “TIMESERIES WEIGHT COLUMN” in objective functions.
use_item_weights_in_objective (bool) – If True, we include weights from column set as “ITEM ATTRIBUTES WEIGHT COLUMN” in objective functions.
skip_timeseries_weight_scaling (bool) – If True, we will avoid normalizing the weights.
timeseries_loss_weight_column (str) – Use value in this column to weight the loss while training.
use_item_id (bool) – Include a feature to indicate the item being forecast.
use_all_item_totals (bool) – Include as input total target across items.
handle_zeros_as_missing_values (bool) – If True, handle zero values in demand as missing data.
datetime_holiday_calendars (List[HolidayCalendars]) – Holiday calendars to augment training with.
fill_missing_values (List[List[dict]]) – Strategy for filling in missing values.
enable_clustering (bool) – Enable clustering in forecasting.
data_split_feature_group_table_name (str) – Specify the table name of the feature group to export training data with the fold column.
custom_loss_functions (List[str]) – Registered custom losses available for selection.
custom_metrics (List[str]) – Registered custom metrics available for selection.
return_fractional_forecasts – Use this to return fractional forecast values while prediction
allow_training_with_small_history – Allows training with fewer than 100 rows in the dataset
- objective: abacusai.api_class.enums.ForecastingObjective = None
- sort_objective: abacusai.api_class.enums.ForecastingObjective = None
- forecast_frequency: abacusai.api_class.enums.ForecastingFrequency = None
- experimentation_mode: abacusai.api_class.enums.ExperimentationMode = None
- type_of_split: abacusai.api_class.enums.ForecastingDataSplitType = None
- loss_function: abacusai.api_class.enums.ForecastingLossFunction = None
- local_scaling_mode: abacusai.api_class.enums.ForecastingLocalScaling = None
- batch_size: abacusai.api_class.enums.BatchSize = None
- quantiles_extension_method: abacusai.api_class.enums.ForecastingQuanitlesExtensionMethod = None
- datetime_holiday_calendars: List[abacusai.api_class.enums.HolidayCalendars] = None
- __post_init__()
- class abacusai.api_class.model.NamedEntityExtractionTrainingConfig
Bases:
TrainingConfig
Training config for the NAMED_ENTITY_EXTRACTION problem type
- Parameters:
llm_for_ner (NERForLLM) – LLM to use for NER from among available LLM
test_split (int) – Percent of dataset to use for test data. We support using a range between 5 ( i.e. 5% ) to 20 ( i.e. 20% ) of your dataset.
test_row_indicator (str) – Column indicating which rows to use for training (TRAIN) and testing (TEST).
active_labels_column (str) – Entities that have been marked in a particular text
document_format (NLPDocumentFormat) – Format of the input documents.
minimum_bounding_box_overlap_ratio (float) – Tokens are considered to belong to annotation if the user bounding box is provided and ratio of (token_bounding_box ∩ annotation_bounding_box) / token_bounding_area is greater than the provided value.
save_predicted_pdf (bool) – Whether to save predicted PDF documents
enhanced_ocr (bool) – Enhanced text extraction from predicted digital documents
additional_extraction_instructions (str) – Additional instructions to guide the LLM in extracting the entities. Only used with LLM algorithms.
- llm_for_ner: abacusai.api_class.enums.LLMName = None
- document_format: abacusai.api_class.enums.NLPDocumentFormat = None
- __post_init__()
- class abacusai.api_class.model.NaturalLanguageSearchTrainingConfig
Bases:
TrainingConfig
Training config for the NATURAL_LANGUAGE_SEARCH problem type
- Parameters:
abacus_internal_model (bool) – Use a Abacus.AI LLM to answer questions about your data without using any external APIs
num_completion_tokens (int) – Default for maximum number of tokens for chat answers. Reducing this will get faster responses which are more succinct
larger_embeddings (bool) – Use a higher dimension embedding model.
search_chunk_size (int) – Chunk size for indexing the documents.
chunk_overlap_fraction (float) – Overlap in chunks while indexing the documents.
index_fraction (float) – Fraction of the chunk to use for indexing.
- __post_init__()
- class abacusai.api_class.model.ChatLLMTrainingConfig
Bases:
TrainingConfig
Training config for the CHAT_LLM problem type
- Parameters:
document_retrievers (List[str]) – List of names or IDs of document retrievers to use as vector stores of information for RAG responses.
num_completion_tokens (int) – Default for maximum number of tokens for chat answers. Reducing this will get faster responses which are more succinct.
temperature (float) – The generative LLM temperature.
retrieval_columns (list) – Include the metadata column values in the retrieved search results.
filter_columns (list) – Allow users to filter the document retrievers on these metadata columns.
include_general_knowledge (bool) – Allow the LLM to rely not just on RAG search results, but to fall back on general knowledge. Disabled by default.
enable_web_search (bool) – Allow the LLM to use Web Search Engines to retrieve information for better results.
behavior_instructions (str) – Customize the overall behaviour of the model. This controls things like - when to execute code (if enabled), write sql query, search web (if enabled), etc.
response_instructions (str) – Customized instructions for how the model should respond inlcuding the format, persona and tone of the answers.
enable_llm_rewrite (bool) – If enabled, an LLM will rewrite the RAG queries sent to document retriever. Disabled by default.
column_filtering_instructions (str) – Instructions for a LLM call to automatically generate filter expressions on document metadata to retrieve relevant documents for the conversation.
keyword_requirement_instructions (str) – Instructions for a LLM call to automatically generate keyword requirements to retrieve relevant documents for the conversation.
query_rewrite_instructions (str) – Special instructions for the LLM which rewrites the RAG query.
max_search_results (int) – Maximum number of search results in the retrieval augmentation step. If we know that the questions are likely to have snippets which are easily matched in the documents, then a lower number will help with accuracy.
data_feature_group_ids – (List[str]): List of feature group IDs to use to possibly query for the ChatLLM. The created ChatLLM is commonly referred to as DataLLM.
data_prompt_context (str) – Prompt context for the data feature group IDs.
data_prompt_table_context (Dict[str, str]) – Dict of table name and table context pairs to provide table wise context for each structured data table.
data_prompt_column_context (Dict[str, str]) – Dict of ‘table_name.column_name’ and ‘column_context’ pairs to provide column context for some selected columns in the selected structured data table. This replaces the default auto-generated information about the column data.
hide_sql_and_code (bool) – When running data queries, this will hide the generated SQL and Code in the response.
disable_data_summarization (bool) – After executing a query summarize the reponse and reply back with only the table and query run.
data_columns_to_ignore (List[str]) – Columns to ignore while encoding information about structured data tables in context for the LLM. A list of strings of format “<table_name>.<column_name>”
search_score_cutoff (float) – Minimum search score to consider a document as a valid search result.
include_bm25_retrieval (bool) – Combine BM25 search score with vector search using reciprocal rank fusion.
database_connector_id (str) – Database connector ID to use for connecting external database that gives access to structured data to the LLM.
database_connector_tables (List[str]) – List of tables to use from the database connector for the ChatLLM.
enable_code_execution (bool) – Enable python code execution in the ChatLLM. This equips the LLM with a python kernel in which all its code is executed.
enable_response_caching (bool) – Enable caching of LLM responses to speed up response times and improve reproducibility.
unknown_answer_phrase (str) – Fallback response when the LLM can’t find an answer.
enable_tool_bar (bool) – Enable the tool bar in Enterprise ChatLLM to provide additional functionalities like tool_use, web_search, image_gen, etc.
enable_inline_source_citations (bool) – Enable inline citations of the sources in the response.
response_format – (str): When set to ‘JSON’, the LLM will generate a JSON formatted string.
json_response_instructions (str) – Instructions to be followed while generating the json_response if response_format is set to “JSON”. This can include the schema information if the schema is dynamic and its keys cannot be pre-determined.
json_response_schema (str) – Specifies the JSON schema that the model should adhere to if response_format is set to “JSON”. This should be a json-formatted string where each field of the expected schema is mapped to a dictionary containing the fields ‘type’, ‘required’ and ‘description’. For example - ‘{“sample_field”: {“type”: “integer”, “required”: true, “description”: “Sample Field”}}’
- __post_init__()
- class abacusai.api_class.model.SentenceBoundaryDetectionTrainingConfig
Bases:
TrainingConfig
Training config for the SENTENCE_BOUNDARY_DETECTION problem type
- Parameters:
- batch_size: abacusai.api_class.enums.BatchSize = None
- __post_init__()
- class abacusai.api_class.model.SentimentDetectionTrainingConfig
Bases:
TrainingConfig
Training config for the SENTIMENT_DETECTION problem type
- Parameters:
sentiment_type (SentimentType) – Type of sentiment to detect.
test_split (int) – Percent of dataset to use for test data. We support using a range between 5 ( i.e. 5% ) to 20 ( i.e. 20% ) of your dataset.
- sentiment_type: abacusai.api_class.enums.SentimentType = None
- __post_init__()
- class abacusai.api_class.model.DocumentClassificationTrainingConfig
Bases:
TrainingConfig
Training config for the DOCUMENT_CLASSIFICATION problem type
- Parameters:
- __post_init__()
- class abacusai.api_class.model.DocumentSummarizationTrainingConfig
Bases:
TrainingConfig
Training config for the DOCUMENT_SUMMARIZATION problem type
- Parameters:
- batch_size: abacusai.api_class.enums.BatchSize = None
- __post_init__()
- class abacusai.api_class.model.DocumentVisualizationTrainingConfig
Bases:
TrainingConfig
Training config for the DOCUMENT_VISUALIZATION problem type
- Parameters:
- batch_size: abacusai.api_class.enums.BatchSize = None
- __post_init__()
- class abacusai.api_class.model.ClusteringTrainingConfig
Bases:
TrainingConfig
Training config for the CLUSTERING problem type
- Parameters:
num_clusters_selection (int) – Number of clusters. If None, will be selected automatically.
- __post_init__()
- class abacusai.api_class.model.ClusteringTimeseriesTrainingConfig
Bases:
TrainingConfig
Training config for the CLUSTERING_TIMESERIES problem type
- Parameters:
num_clusters_selection (int) – Number of clusters. If None, will be selected automatically.
imputation (ClusteringImputationMethod) – Imputation method for missing values.
- imputation: abacusai.api_class.enums.ClusteringImputationMethod = None
- __post_init__()
- class abacusai.api_class.model.EventAnomalyTrainingConfig
Bases:
TrainingConfig
Training config for the EVENT_ANOMALY problem type
- Parameters:
anomaly_fraction (float) – The fraction of the dataset to classify as anomalous, between 0 and 0.5
- __post_init__()
- class abacusai.api_class.model.TimeseriesAnomalyTrainingConfig
Bases:
TrainingConfig
Training config for the TS_ANOMALY problem type
- Parameters:
type_of_split (TimeseriesAnomalyDataSplitType) – Type of data splitting into train/test.
test_start (str) – Limit training data to dates before the given test start.
test_split (int) – Percent of dataset to use for test data. We support using a range between 5 ( i.e. 5% ) to 20 ( i.e. 20% ) of your dataset.
fill_missing_values (List[List[dict]]) – strategies to fill missing values and missing timestamps
handle_zeros_as_missing_values (bool) – If True, handle zero values in numeric columns as missing data
timeseries_frequency (str) – set this to control frequency of filling missing values
min_samples_in_normal_region (int) – Adjust this to fine-tune the number of anomalies to be identified.
anomaly_type (TimeseriesAnomalyTypeOfAnomaly) – select what kind of peaks to detect as anomalies
hyperparameter_calculation_with_heuristics (TimeseriesAnomalyUseHeuristic) – Enable heuristic calculation to get hyperparameters for the model
threshold_score (float) – Threshold score for anomaly detection
additional_anomaly_ids (List[str]) – List of categorical columns that can act as multi-identifier
- type_of_split: abacusai.api_class.enums.TimeseriesAnomalyDataSplitType = None
- anomaly_type: abacusai.api_class.enums.TimeseriesAnomalyTypeOfAnomaly = None
- hyperparameter_calculation_with_heuristics: abacusai.api_class.enums.TimeseriesAnomalyUseHeuristic = None
- __post_init__()
- class abacusai.api_class.model.CumulativeForecastingTrainingConfig
Bases:
TrainingConfig
Training config for the CUMULATIVE_FORECASTING problem type
- Parameters:
test_split (int) – Percent of dataset to use for test data. We support using a range between 5 ( i.e. 5% ) to 20 ( i.e. 20% ) of your dataset.
historical_frequency (str) – Forecast frequency
cumulative_prediction_lengths (List[int]) – List of Cumulative Prediction Frequencies. Each prediction length must be between 1 and 365.
skip_input_transform (bool) – Avoid doing numeric scaling transformations on the input.
skip_target_transform (bool) – Avoid doing numeric scaling transformations on the target.
predict_residuals (bool) – Predict residuals instead of totals at each prediction step.
- __post_init__()
- class abacusai.api_class.model.ThemeAnalysisTrainingConfig
Bases:
TrainingConfig
Training config for the THEME ANALYSIS problem type
- __post_init__()
- class abacusai.api_class.model.AIAgentTrainingConfig
Bases:
TrainingConfig
Training config for the AI_AGENT problem type
- Parameters:
description (str) – Description of the agent function.
agent_interface (AgentInterface) – The interface that the agent will be deployed with.
agent_connectors – (List[enums.ApplicationConnectorType]): The connectors needed for the agent to function.
- agent_interface: abacusai.api_class.enums.AgentInterface = None
- agent_connectors: List[abacusai.api_class.enums.ApplicationConnectorType] = None
- __post_init__()
- class abacusai.api_class.model.CustomTrainedModelTrainingConfig
Bases:
TrainingConfig
Training config for the CUSTOM_TRAINED_MODEL problem type
- Parameters:
max_catalog_size (int) – Maximum expected catalog size.
max_dimension (int) – Maximum expected dimension of the catalog.
index_output_path (str) – Fully qualified cloud location (GCS, S3, etc) to export snapshots of the embedding to.
docker_image_uri (str) – Docker image URI.
service_port (int) – Service port.
streaming_embeddings (bool) – Flag to enable streaming embeddings.
- __post_init__()
- class abacusai.api_class.model.CustomAlgorithmTrainingConfig
Bases:
TrainingConfig
Training config for the CUSTOM_ALGORITHM problem type
- Parameters:
timeout_minutes (int) – Timeout for the model training in minutes.
- __post_init__()
- class abacusai.api_class.model.OptimizationTrainingConfig
Bases:
TrainingConfig
Training config for the OPTIMIZATION problem type
- Parameters:
solve_time_limit (float) – The maximum time in seconds to spend solving the problem. Accepts values between 0 and 86400.
optimality_gap_limit (float) – The stopping optimality gap limit. Optimality gap is fractional difference between the best known solution and the best possible solution. Accepts values between 0 and 1.
include_all_partitions (bool) – Include all partitions in the model training. Default is False.
include_specific_partitions (List[str]) – Include specific partitions in partitioned model training. Default is empty list.
- __post_init__()
- class abacusai.api_class.model._TrainingConfigFactory
Bases:
abacusai.api_class.abstract._ApiClassFactory
Helper class that provides a standard way to create an ABC using inheritance.
- config_abstract_class
- config_class_key = 'problem_type'
- config_class_map
- class abacusai.api_class.model.DeployableAlgorithm
Bases:
abacusai.api_class.abstract.ApiClass
Algorithm that can be deployed to a model.
- Parameters: