TSModelInference¶
- class ibm_watsonx_ai.foundation_models.inference.TSModelInference(model_id=None, params=None, credentials=None, project_id=None, space_id=None, verify=None, api_client=None, deployment_id=None)[source]¶
- Bases: - WMLResource- Instantiate the time series model interface - Parameters:
- model_id (str, optional) – 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, - credentialsand- project_id/- space_idare not required.
- deployment_id (str, optional) – ID of tuned model’s deployment 
 
 - 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 ) - from ibm_watsonx_ai import Credentials from ibm_watsonx_ai.foundation_models import TSModelInference forecasting_params = { "prediction_length": 10 } ts_model = TSModelInference( deployment_id="<ID of deployed model>", params=forecasting_params, credentials=Credentials( api_key = IAM_API_KEY, url = "https://us-south.ml.cloud.ibm.com"), ) - forecast(data, params=None, future_data=None)[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. 
- future_data (dict, pd.DataFrame, optional) – Available only for deployment (BYOM). Exogenous or supporting features that extend into the forecasting horizon (e.g., a weather forecast or calendar of special promotions) which are known in advance. future_data would be in the same format as data except that all timestamps would be in the forecast horizon and it would not include previously specified target_columns. 
 
 - 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 ... ] } future_data = { "date": [ "2018-10-02T16:00:00", "2018-10-02T17:00:00", "2018-10-02T18:00:00" ... ], "HUFL": [ 10.10, 20.20, 30.30 ... ] } 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, future_data=future_data) # 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, )