TSModelInference¶
- class ibm_watsonx_ai.foundation_models.inference.TSModelInference(model_id, params=None, credentials=None, project_id=None, space_id=None, verify=None, api_client=None)[source]¶
Bases:
WMLResource
Instantiate the time series model interface
- Parameters:
model_id (str) – type of model to use
params (dict, TSForecastParameters, optional) – parameters to use during request generation
credentials (Credentials or dict, optional) – credentials for the Watson Machine Learning instance
project_id (str, optional) – ID of the Watson Studio project
space_id (str, optional) – ID of the Watson Studio space
verify (bool or str, optional) –
You can pass one of the following as verify:
the path to a CA_BUNDLE file
the path of directory with certificates of trusted CAs
True - default path to truststore will be taken
False - no verification will be made
api_client (APIClient, optional) – initialized APIClient object with a set project ID or space ID. If passed,
credentials
andproject_id
/space_id
are not required.
Example:
from ibm_watsonx_ai import Credentials from ibm_watsonx_ai.foundation_models import TSModelInference forecasting_params = { "prediction_length": 10 } ts_model = TSModelInference( model_id="<TIME SERIES MODEL>", params=forecasting_params, credentials=Credentials( api_key = IAM_API_KEY, url = "https://us-south.ml.cloud.ibm.com"), project_id=project_id )
- forecast(data, params=None, **kwargs)[source]¶
Generates a forecast based on the provided data and model parameters.
- Parameters:
data (dict, pd.DataFrame, required) – A payload of data matching the schema provided. For more information about the data limitation see the product documentation https://cloud.ibm.com/apidocs/watsonx-ai.
params (dict, TSForecastParameters, optional) – Contains basic metadata about your time series data input. These metadata are used by the server to understand which field represents a time stamp or which are unique identifiers for separating time series from different input channels.
Example:
# number of elements in the array for each field must be at least 512, 1024, or 1536 depending on the model; for example 512 for ibm/granite-ttm-512-96-r2 data = { "date": [ "2017-10-02T16:00:00", "2017-10-02T17:00:00", "2017-10-02T18:00:00" ... ], "HUFL": [ 1.1, 2.2, 3.3 ... ] } params = { "timestamp_column": "date", "target_columns": [ "HUFL", ], "prediction_length": 10 "freq": "1h" }, # The number of elements in the array for each field must be the prediction length of the model depending on the model; for example 96 for ibm/granite-ttm-512-96-r2, response = ts_model.forecast(data=data, params=params) # Print all response print(response)
Enums¶
- class TimeSeriesModels¶
Bases:
StrEnum
This represents a dynamically generated Enum for Time Series Foundation Models.
Example of getting TimeSeriesModels:
# GET TimeSeriesModels ENUM client.foundation_models.TimeSeriesModels # PRINT dict of Enums client.foundation_models.TimeSeriesModels.show()
Example Output:
{'GRANITE_TTM_1024_96_R2': 'ibm/granite-ttm-1024-96-r2', 'GRANITE_TTM_1536_96_R2': 'ibm/granite-ttm-1536-96-r2', 'GRANITE_TTM_512_96_R2': 'ibm/granite-ttm-512-96-r2'}
Example of initialising ModelInference with TimeSeriesModels Enum:
from ibm_watsonx_ai.foundation_models import TSModelInference model = TSModelInference( model_id=client.foundation_models.TimeSeriesModels.GRANITE_TTM_1024_96_R2, credentials=Credentials(...), project_id=project_id, )