Informer
Last updated
Last updated
The Informer model was proposed in by Haoyi Zhou, Shanghang Zhang, Jieqi Peng, Shuai Zhang, Jianxin Li, Hui Xiong, and Wancai Zhang.
This method introduces a Probabilistic Attention mechanism to select the βactiveβ queries rather than the βlazyβ queries and provides a sparse Transformer thus mitigating the quadratic compute and memory requirements of vanilla attention.
The abstract from the paper is the following:
Many real-world applications require the prediction of long sequence time-series, such as electricity consumption planning. Long sequence time-series forecasting (LSTF) demands a high prediction capacity of the model, which is the ability to capture precise long-range dependency coupling between output and input efficiently. Recent studies have shown the potential of Transformer to increase the prediction capacity. However, there are several severe issues with Transformer that prevent it from being directly applicable to LSTF, including quadratic time complexity, high memory usage, and inherent limitation of the encoder-decoder architecture. To address these issues, we design an efficient transformer-based model for LSTF, named Informer, with three distinctive characteristics: (i) a ProbSparse self-attention mechanism, which achieves O(L logL) in time complexity and memory usage, and has comparable performance on sequencesβ dependency alignment. (ii) the self-attention distilling highlights dominating attention by halving cascading layer input, and efficiently handles extreme long input sequences. (iii) the generative style decoder, while conceptually simple, predicts the long time-series sequences at one forward operation rather than a step-by-step way, which drastically improves the inference speed of long-sequence predictions. Extensive experiments on four large-scale datasets demonstrate that Informer significantly outperforms existing methods and provides a new solution to the LSTF problem.
This model was contributed by and . The original code can be found .
A list of official BOINC AI and community (indicated by π) resources to help you get started. If youβre interested in submitting a resource to be included here, please feel free to open a Pull Request and weβll review it! The resource should ideally demonstrate something new instead of duplicating an existing resource.
Check out the Informer blog-post in HuggingFace blog:
( prediction_length: typing.Optional[int] = Nonecontext_length: typing.Optional[int] = Nonedistribution_output: str = 'student_t'loss: str = 'nll'input_size: int = 1lags_sequence: typing.List[int] = Nonescaling: typing.Union[str, bool, NoneType] = 'mean'num_dynamic_real_features: int = 0num_static_real_features: int = 0num_static_categorical_features: int = 0num_time_features: int = 0cardinality: typing.Optional[typing.List[int]] = Noneembedding_dimension: typing.Optional[typing.List[int]] = Noned_model: int = 64encoder_ffn_dim: int = 32decoder_ffn_dim: int = 32encoder_attention_heads: int = 2decoder_attention_heads: int = 2encoder_layers: int = 2decoder_layers: int = 2is_encoder_decoder: bool = Trueactivation_function: str = 'gelu'dropout: float = 0.05encoder_layerdrop: float = 0.1decoder_layerdrop: float = 0.1attention_dropout: float = 0.1activation_dropout: float = 0.1num_parallel_samples: int = 100init_std: float = 0.02use_cache = Trueattention_type: str = 'prob'sampling_factor: int = 5distil: bool = True**kwargs )
Parameters
prediction_length (int
) β The prediction length for the decoder. In other words, the prediction horizon of the model. This value is typically dictated by the dataset and we recommend to set it appropriately.
context_length (int
, optional, defaults to prediction_length
) β The context length for the encoder. If None
, the context length will be the same as the prediction_length
.
distribution_output (string
, optional, defaults to "student_t"
) β The distribution emission head for the model. Could be either βstudent_tβ, βnormalβ or βnegative_binomialβ.
loss (string
, optional, defaults to "nll"
) β The loss function for the model corresponding to the distribution_output
head. For parametric distributions it is the negative log likelihood (nll) - which currently is the only supported one.
input_size (int
, optional, defaults to 1) β The size of the target variable which by default is 1 for univariate targets. Would be > 1 in case of multivariate targets.
scaling (string
or bool
, optional defaults to "mean"
) β Whether to scale the input targets via βmeanβ scaler, βstdβ scaler or no scaler if None
. If True
, the scaler is set to βmeanβ.
lags_sequence (list[int]
, optional, defaults to [1, 2, 3, 4, 5, 6, 7]
) β The lags of the input time series as covariates often dictated by the frequency of the data. Default is [1, 2, 3, 4, 5, 6, 7]
but we recommend to change it based on the dataset appropriately.
num_time_features (int
, optional, defaults to 0) β The number of time features in the input time series.
num_dynamic_real_features (int
, optional, defaults to 0) β The number of dynamic real valued features.
num_static_categorical_features (int
, optional, defaults to 0) β The number of static categorical features.
num_static_real_features (int
, optional, defaults to 0) β The number of static real valued features.
cardinality (list[int]
, optional) β The cardinality (number of different values) for each of the static categorical features. Should be a list of integers, having the same length as num_static_categorical_features
. Cannot be None
if num_static_categorical_features
is > 0.
embedding_dimension (list[int]
, optional) β The dimension of the embedding for each of the static categorical features. Should be a list of integers, having the same length as num_static_categorical_features
. Cannot be None
if num_static_categorical_features
is > 0.
d_model (int
, optional, defaults to 64) β Dimensionality of the transformer layers.
encoder_layers (int
, optional, defaults to 2) β Number of encoder layers.
decoder_layers (int
, optional, defaults to 2) β Number of decoder layers.
encoder_attention_heads (int
, optional, defaults to 2) β Number of attention heads for each attention layer in the Transformer encoder.
decoder_attention_heads (int
, optional, defaults to 2) β Number of attention heads for each attention layer in the Transformer decoder.
encoder_ffn_dim (int
, optional, defaults to 32) β Dimension of the βintermediateβ (often named feed-forward) layer in encoder.
decoder_ffn_dim (int
, optional, defaults to 32) β Dimension of the βintermediateβ (often named feed-forward) layer in decoder.
activation_function (str
or function
, optional, defaults to "gelu"
) β The non-linear activation function (function or string) in the encoder and decoder. If string, "gelu"
and "relu"
are supported.
dropout (float
, optional, defaults to 0.1) β The dropout probability for all fully connected layers in the encoder, and decoder.
encoder_layerdrop (float
, optional, defaults to 0.1) β The dropout probability for the attention and fully connected layers for each encoder layer.
decoder_layerdrop (float
, optional, defaults to 0.1) β The dropout probability for the attention and fully connected layers for each decoder layer.
attention_dropout (float
, optional, defaults to 0.1) β The dropout probability for the attention probabilities.
activation_dropout (float
, optional, defaults to 0.1) β The dropout probability used between the two layers of the feed-forward networks.
num_parallel_samples (int
, optional, defaults to 100) β The number of samples to generate in parallel for each time step of inference.
init_std (float
, optional, defaults to 0.02) β The standard deviation of the truncated normal weight initialization distribution.
use_cache (bool
, optional, defaults to True
) β Whether to use the past key/values attentions (if applicable to the model) to speed up decoding.
attention_type (str
, optional, defaults to βprobβ) β Attention used in encoder. This can be set to βprobβ (Informerβs ProbAttention) or βfullβ (vanilla transformerβs canonical self-attention).
sampling_factor (int
, optional, defaults to 5) β ProbSparse sampling factor (only makes affect when attention_type
=βprobβ). It is used to control the reduced query matrix (Q_reduce) input length.
distil (bool
, optional, defaults to True
) β Whether to use distilling in encoder.
Example:
Copied
( config: InformerConfig )
Parameters
forward
Parameters
past_values (torch.FloatTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
) β Past values of the time series, that serve as context in order to predict the future. The sequence size of this tensor must be larger than the context_length
of the model, since the model will use the larger size to construct lag features, i.e. additional values from the past which are added in order to serve as βextra contextβ.
The sequence_length
here is equal to config.context_length
+ max(config.lags_sequence)
, which if no lags_sequence
is configured, is equal to config.context_length
+ 7 (as by default, the largest look-back index in config.lags_sequence
is 7). The property _past_length
returns the actual length of the past.
The past_values
is what the Transformer encoder gets as input (with optional additional features, such as static_categorical_features
, static_real_features
, past_time_features
and lags).
Optionally, missing values need to be replaced with zeros and indicated via the past_observed_mask
.
For multivariate time series, the input_size
> 1 dimension is required and corresponds to the number of variates in the time series per time step.
past_time_features (torch.FloatTensor
of shape (batch_size, sequence_length, num_features)
) β Required time features, which the model internally will add to past_values
. These could be things like βmonth of yearβ, βday of the monthβ, etc. encoded as vectors (for instance as Fourier features). These could also be so-called βageβ features, which basically help the model know βat which point in lifeβ a time-series is. Age features have small values for distant past time steps and increase monotonically the more we approach the current time step. Holiday features are also a good example of time features.
These features serve as the βpositional encodingsβ of the inputs. So contrary to a model like BERT, where the position encodings are learned from scratch internally as parameters of the model, the Time Series Transformer requires to provide additional time features. The Time Series Transformer only learns additional embeddings for static_categorical_features
.
Additional dynamic real covariates can be concatenated to this tensor, with the caveat that these features must but known at prediction time.
The num_features
here is equal to config.
num_time_features+
config.num_dynamic_real_features`.
past_observed_mask (torch.BoolTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
, optional) β Boolean mask to indicate which past_values
were observed and which were missing. Mask values selected in [0, 1]
:
1 for values that are observed,
0 for values that are missing (i.e. NaNs that were replaced by zeros).
static_categorical_features (torch.LongTensor
of shape (batch_size, number of static categorical features)
, optional) β Optional static categorical features for which the model will learn an embedding, which it will add to the values of the time series.
Static categorical features are features which have the same value for all time steps (static over time).
A typical example of a static categorical feature is a time series ID.
static_real_features (torch.FloatTensor
of shape (batch_size, number of static real features)
, optional) β Optional static real features which the model will add to the values of the time series.
Static real features are features which have the same value for all time steps (static over time).
A typical example of a static real feature is promotion information.
future_values (torch.FloatTensor
of shape (batch_size, prediction_length)
or (batch_size, prediction_length, input_size)
, optional) β Future values of the time series, that serve as labels for the model. The future_values
is what the Transformer needs during training to learn to output, given the past_values
.
The sequence length here is equal to prediction_length
.
See the demo notebook and code snippets for details.
Optionally, during training any missing values need to be replaced with zeros and indicated via the future_observed_mask
.
For multivariate time series, the input_size
> 1 dimension is required and corresponds to the number of variates in the time series per time step.
future_time_features (torch.FloatTensor
of shape (batch_size, prediction_length, num_features)
) β Required time features for the prediction window, which the model internally will add to future_values
. These could be things like βmonth of yearβ, βday of the monthβ, etc. encoded as vectors (for instance as Fourier features). These could also be so-called βageβ features, which basically help the model know βat which point in lifeβ a time-series is. Age features have small values for distant past time steps and increase monotonically the more we approach the current time step. Holiday features are also a good example of time features.
These features serve as the βpositional encodingsβ of the inputs. So contrary to a model like BERT, where the position encodings are learned from scratch internally as parameters of the model, the Time Series Transformer requires to provide additional time features. The Time Series Transformer only learns additional embeddings for static_categorical_features
.
Additional dynamic real covariates can be concatenated to this tensor, with the caveat that these features must but known at prediction time.
The num_features
here is equal to config.
num_time_features+
config.num_dynamic_real_features`.
future_observed_mask (torch.BoolTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
, optional) β Boolean mask to indicate which future_values
were observed and which were missing. Mask values selected in [0, 1]
:
1 for values that are observed,
0 for values that are missing (i.e. NaNs that were replaced by zeros).
This mask is used to filter out missing values for the final loss calculation.
attention_mask (torch.Tensor
of shape (batch_size, sequence_length)
, optional) β Mask to avoid performing attention on certain token indices. Mask values selected in [0, 1]
:
1 for tokens that are not masked,
0 for tokens that are masked.
decoder_attention_mask (torch.LongTensor
of shape (batch_size, target_sequence_length)
, optional) β Mask to avoid performing attention on certain token indices. By default, a causal mask will be used, to make sure the model can only look at previous inputs in order to predict the future.
head_mask (torch.Tensor
of shape (encoder_layers, encoder_attention_heads)
, optional) β Mask to nullify selected heads of the attention modules in the encoder. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
decoder_head_mask (torch.Tensor
of shape (decoder_layers, decoder_attention_heads)
, optional) β Mask to nullify selected heads of the attention modules in the decoder. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
cross_attn_head_mask (torch.Tensor
of shape (decoder_layers, decoder_attention_heads)
, optional) β Mask to nullify selected heads of the cross-attention modules. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
encoder_outputs (tuple(tuple(torch.FloatTensor)
, optional) β Tuple consists of last_hidden_state
, hidden_states
(optional) and attentions
(optional) last_hidden_state
of shape (batch_size, sequence_length, hidden_size)
(optional) is a sequence of hidden-states at the output of the last layer of the encoder. Used in the cross-attention of the decoder.
past_key_values (tuple(tuple(torch.FloatTensor))
, optional, returned when use_cache=True
is passed or when config.use_cache=True
) β Tuple of tuple(torch.FloatTensor)
of length config.n_layers
, with each tuple having 2 tensors of shape (batch_size, num_heads, sequence_length, embed_size_per_head)
) and 2 additional tensors of shape (batch_size, num_heads, encoder_sequence_length, embed_size_per_head)
.
Contains pre-computed hidden-states (key and values in the self-attention blocks and in the cross-attention blocks) that can be used (see past_key_values
input) to speed up sequential decoding.
If past_key_values
are used, the user can optionally input only the last decoder_input_ids
(those that donβt have their past key value states given to this model) of shape (batch_size, 1)
instead of all decoder_input_ids
of shape (batch_size, sequence_length)
.
inputs_embeds (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
, optional) β Optionally, instead of passing input_ids
you can choose to directly pass an embedded representation. This is useful if you want more control over how to convert input_ids
indices into associated vectors than the modelβs internal embedding lookup matrix.
use_cache (bool
, optional) β If set to True
, past_key_values
key value states are returned and can be used to speed up decoding (see past_key_values
).
output_attentions (bool
, optional) β Whether or not to return the attentions tensors of all attention layers. See attentions
under returned tensors for more detail.
output_hidden_states (bool
, optional) β Whether or not to return the hidden states of all layers. See hidden_states
under returned tensors for more detail.
Returns
last_hidden_state (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
) β Sequence of hidden-states at the output of the last layer of the decoder of the model.
If past_key_values
is used only the last hidden-state of the sequences of shape (batch_size, 1, hidden_size)
is output.
past_key_values (tuple(tuple(torch.FloatTensor))
, optional, returned when use_cache=True
is passed or when config.use_cache=True
) β Tuple of tuple(torch.FloatTensor)
of length config.n_layers
, with each tuple having 2 tensors of shape (batch_size, num_heads, sequence_length, embed_size_per_head)
) and 2 additional tensors of shape (batch_size, num_heads, encoder_sequence_length, embed_size_per_head)
.
Contains pre-computed hidden-states (key and values in the self-attention blocks and in the cross-attention blocks) that can be used (see past_key_values
input) to speed up sequential decoding.
decoder_hidden_states (tuple(torch.FloatTensor)
, optional, returned when output_hidden_states=True
is passed or when config.output_hidden_states=True
) β Tuple of torch.FloatTensor
(one for the output of the embeddings, if the model has an embedding layer, + one for the output of each layer) of shape (batch_size, sequence_length, hidden_size)
.
Hidden-states of the decoder at the output of each layer plus the optional initial embedding outputs.
decoder_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the decoder, after the attention softmax, used to compute the weighted average in the self-attention heads.
cross_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the decoderβs cross-attention layer, after the attention softmax, used to compute the weighted average in the cross-attention heads.
encoder_last_hidden_state (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
, optional) β Sequence of hidden-states at the output of the last layer of the encoder of the model.
encoder_hidden_states (tuple(torch.FloatTensor)
, optional, returned when output_hidden_states=True
is passed or when config.output_hidden_states=True
) β Tuple of torch.FloatTensor
(one for the output of the embeddings, if the model has an embedding layer, + one for the output of each layer) of shape (batch_size, sequence_length, hidden_size)
.
Hidden-states of the encoder at the output of each layer plus the optional initial embedding outputs.
encoder_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the encoder, after the attention softmax, used to compute the weighted average in the self-attention heads.
loc (torch.FloatTensor
of shape (batch_size,)
or (batch_size, input_size)
, optional) β Shift values of each time seriesβ context window which is used to give the model inputs of the same magnitude and then used to shift back to the original magnitude.
scale (torch.FloatTensor
of shape (batch_size,)
or (batch_size, input_size)
, optional) β Scaling values of each time seriesβ context window which is used to give the model inputs of the same magnitude and then used to rescale back to the original magnitude.
static_features (torch.FloatTensor
of shape (batch_size, feature size)
, optional) β Static features of each time seriesβ in a batch which are copied to the covariates at inference time.
Although the recipe for forward pass needs to be defined within this function, one should call the Module
instance afterwards instead of this since the former takes care of running the pre and post processing steps while the latter silently ignores them.
Examples:
Copied
( config: InformerConfig )
Parameters
forward
Parameters
past_values (torch.FloatTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
) β Past values of the time series, that serve as context in order to predict the future. The sequence size of this tensor must be larger than the context_length
of the model, since the model will use the larger size to construct lag features, i.e. additional values from the past which are added in order to serve as βextra contextβ.
The sequence_length
here is equal to config.context_length
+ max(config.lags_sequence)
, which if no lags_sequence
is configured, is equal to config.context_length
+ 7 (as by default, the largest look-back index in config.lags_sequence
is 7). The property _past_length
returns the actual length of the past.
The past_values
is what the Transformer encoder gets as input (with optional additional features, such as static_categorical_features
, static_real_features
, past_time_features
and lags).
Optionally, missing values need to be replaced with zeros and indicated via the past_observed_mask
.
For multivariate time series, the input_size
> 1 dimension is required and corresponds to the number of variates in the time series per time step.
past_time_features (torch.FloatTensor
of shape (batch_size, sequence_length, num_features)
) β Required time features, which the model internally will add to past_values
. These could be things like βmonth of yearβ, βday of the monthβ, etc. encoded as vectors (for instance as Fourier features). These could also be so-called βageβ features, which basically help the model know βat which point in lifeβ a time-series is. Age features have small values for distant past time steps and increase monotonically the more we approach the current time step. Holiday features are also a good example of time features.
These features serve as the βpositional encodingsβ of the inputs. So contrary to a model like BERT, where the position encodings are learned from scratch internally as parameters of the model, the Time Series Transformer requires to provide additional time features. The Time Series Transformer only learns additional embeddings for static_categorical_features
.
Additional dynamic real covariates can be concatenated to this tensor, with the caveat that these features must but known at prediction time.
The num_features
here is equal to config.
num_time_features+
config.num_dynamic_real_features`.
past_observed_mask (torch.BoolTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
, optional) β Boolean mask to indicate which past_values
were observed and which were missing. Mask values selected in [0, 1]
:
1 for values that are observed,
0 for values that are missing (i.e. NaNs that were replaced by zeros).
static_categorical_features (torch.LongTensor
of shape (batch_size, number of static categorical features)
, optional) β Optional static categorical features for which the model will learn an embedding, which it will add to the values of the time series.
Static categorical features are features which have the same value for all time steps (static over time).
A typical example of a static categorical feature is a time series ID.
static_real_features (torch.FloatTensor
of shape (batch_size, number of static real features)
, optional) β Optional static real features which the model will add to the values of the time series.
Static real features are features which have the same value for all time steps (static over time).
A typical example of a static real feature is promotion information.
future_values (torch.FloatTensor
of shape (batch_size, prediction_length)
or (batch_size, prediction_length, input_size)
, optional) β Future values of the time series, that serve as labels for the model. The future_values
is what the Transformer needs during training to learn to output, given the past_values
.
The sequence length here is equal to prediction_length
.
See the demo notebook and code snippets for details.
Optionally, during training any missing values need to be replaced with zeros and indicated via the future_observed_mask
.
For multivariate time series, the input_size
> 1 dimension is required and corresponds to the number of variates in the time series per time step.
future_time_features (torch.FloatTensor
of shape (batch_size, prediction_length, num_features)
) β Required time features for the prediction window, which the model internally will add to future_values
. These could be things like βmonth of yearβ, βday of the monthβ, etc. encoded as vectors (for instance as Fourier features). These could also be so-called βageβ features, which basically help the model know βat which point in lifeβ a time-series is. Age features have small values for distant past time steps and increase monotonically the more we approach the current time step. Holiday features are also a good example of time features.
These features serve as the βpositional encodingsβ of the inputs. So contrary to a model like BERT, where the position encodings are learned from scratch internally as parameters of the model, the Time Series Transformer requires to provide additional time features. The Time Series Transformer only learns additional embeddings for static_categorical_features
.
Additional dynamic real covariates can be concatenated to this tensor, with the caveat that these features must but known at prediction time.
The num_features
here is equal to config.
num_time_features+
config.num_dynamic_real_features`.
future_observed_mask (torch.BoolTensor
of shape (batch_size, sequence_length)
or (batch_size, sequence_length, input_size)
, optional) β Boolean mask to indicate which future_values
were observed and which were missing. Mask values selected in [0, 1]
:
1 for values that are observed,
0 for values that are missing (i.e. NaNs that were replaced by zeros).
This mask is used to filter out missing values for the final loss calculation.
attention_mask (torch.Tensor
of shape (batch_size, sequence_length)
, optional) β Mask to avoid performing attention on certain token indices. Mask values selected in [0, 1]
:
1 for tokens that are not masked,
0 for tokens that are masked.
decoder_attention_mask (torch.LongTensor
of shape (batch_size, target_sequence_length)
, optional) β Mask to avoid performing attention on certain token indices. By default, a causal mask will be used, to make sure the model can only look at previous inputs in order to predict the future.
head_mask (torch.Tensor
of shape (encoder_layers, encoder_attention_heads)
, optional) β Mask to nullify selected heads of the attention modules in the encoder. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
decoder_head_mask (torch.Tensor
of shape (decoder_layers, decoder_attention_heads)
, optional) β Mask to nullify selected heads of the attention modules in the decoder. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
cross_attn_head_mask (torch.Tensor
of shape (decoder_layers, decoder_attention_heads)
, optional) β Mask to nullify selected heads of the cross-attention modules. Mask values selected in [0, 1]
:
1 indicates the head is not masked,
0 indicates the head is masked.
encoder_outputs (tuple(tuple(torch.FloatTensor)
, optional) β Tuple consists of last_hidden_state
, hidden_states
(optional) and attentions
(optional) last_hidden_state
of shape (batch_size, sequence_length, hidden_size)
(optional) is a sequence of hidden-states at the output of the last layer of the encoder. Used in the cross-attention of the decoder.
past_key_values (tuple(tuple(torch.FloatTensor))
, optional, returned when use_cache=True
is passed or when config.use_cache=True
) β Tuple of tuple(torch.FloatTensor)
of length config.n_layers
, with each tuple having 2 tensors of shape (batch_size, num_heads, sequence_length, embed_size_per_head)
) and 2 additional tensors of shape (batch_size, num_heads, encoder_sequence_length, embed_size_per_head)
.
Contains pre-computed hidden-states (key and values in the self-attention blocks and in the cross-attention blocks) that can be used (see past_key_values
input) to speed up sequential decoding.
If past_key_values
are used, the user can optionally input only the last decoder_input_ids
(those that donβt have their past key value states given to this model) of shape (batch_size, 1)
instead of all decoder_input_ids
of shape (batch_size, sequence_length)
.
inputs_embeds (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
, optional) β Optionally, instead of passing input_ids
you can choose to directly pass an embedded representation. This is useful if you want more control over how to convert input_ids
indices into associated vectors than the modelβs internal embedding lookup matrix.
use_cache (bool
, optional) β If set to True
, past_key_values
key value states are returned and can be used to speed up decoding (see past_key_values
).
output_attentions (bool
, optional) β Whether or not to return the attentions tensors of all attention layers. See attentions
under returned tensors for more detail.
output_hidden_states (bool
, optional) β Whether or not to return the hidden states of all layers. See hidden_states
under returned tensors for more detail.
Returns
last_hidden_state (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
) β Sequence of hidden-states at the output of the last layer of the decoder of the model.
If past_key_values
is used only the last hidden-state of the sequences of shape (batch_size, 1, hidden_size)
is output.
past_key_values (tuple(tuple(torch.FloatTensor))
, optional, returned when use_cache=True
is passed or when config.use_cache=True
) β Tuple of tuple(torch.FloatTensor)
of length config.n_layers
, with each tuple having 2 tensors of shape (batch_size, num_heads, sequence_length, embed_size_per_head)
) and 2 additional tensors of shape (batch_size, num_heads, encoder_sequence_length, embed_size_per_head)
.
Contains pre-computed hidden-states (key and values in the self-attention blocks and in the cross-attention blocks) that can be used (see past_key_values
input) to speed up sequential decoding.
decoder_hidden_states (tuple(torch.FloatTensor)
, optional, returned when output_hidden_states=True
is passed or when config.output_hidden_states=True
) β Tuple of torch.FloatTensor
(one for the output of the embeddings, if the model has an embedding layer, + one for the output of each layer) of shape (batch_size, sequence_length, hidden_size)
.
Hidden-states of the decoder at the output of each layer plus the optional initial embedding outputs.
decoder_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the decoder, after the attention softmax, used to compute the weighted average in the self-attention heads.
cross_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the decoderβs cross-attention layer, after the attention softmax, used to compute the weighted average in the cross-attention heads.
encoder_last_hidden_state (torch.FloatTensor
of shape (batch_size, sequence_length, hidden_size)
, optional) β Sequence of hidden-states at the output of the last layer of the encoder of the model.
encoder_hidden_states (tuple(torch.FloatTensor)
, optional, returned when output_hidden_states=True
is passed or when config.output_hidden_states=True
) β Tuple of torch.FloatTensor
(one for the output of the embeddings, if the model has an embedding layer, + one for the output of each layer) of shape (batch_size, sequence_length, hidden_size)
.
Hidden-states of the encoder at the output of each layer plus the optional initial embedding outputs.
encoder_attentions (tuple(torch.FloatTensor)
, optional, returned when output_attentions=True
is passed or when config.output_attentions=True
) β Tuple of torch.FloatTensor
(one for each layer) of shape (batch_size, num_heads, sequence_length, sequence_length)
.
Attentions weights of the encoder, after the attention softmax, used to compute the weighted average in the self-attention heads.
loc (torch.FloatTensor
of shape (batch_size,)
or (batch_size, input_size)
, optional) β Shift values of each time seriesβ context window which is used to give the model inputs of the same magnitude and then used to shift back to the original magnitude.
scale (torch.FloatTensor
of shape (batch_size,)
or (batch_size, input_size)
, optional) β Scaling values of each time seriesβ context window which is used to give the model inputs of the same magnitude and then used to rescale back to the original magnitude.
static_features (torch.FloatTensor
of shape (batch_size, feature size)
, optional) β Static features of each time seriesβ in a batch which are copied to the covariates at inference time.
Although the recipe for forward pass needs to be defined within this function, one should call the Module
instance afterwards instead of this since the former takes care of running the pre and post processing steps while the latter silently ignores them.
Examples:
Copied
This is the configuration class to store the configuration of an . It is used to instantiate an Informer model according to the specified arguments, defining the model architecture. Instantiating a configuration with the defaults will yield a similar configuration to that of the Informer architecture.
Configuration objects inherit from can be used to control the model outputs. Read the documentation from for more information.
config () β Model configuration class with all the parameters of the model. Initializing with a config file does not load the weights associated with the model, only the configuration. Check out the method to load the model weights.
The bare Informer Model outputting raw hidden-states without any specific head on top. This model inherits from . Check the superclass documentation for the generic methods the library implements for all its model (such as downloading or saving, resizing the input embeddings, pruning heads etc.)
This model is also a PyTorch subclass. Use it as a regular PyTorch Module and refer to the PyTorch documentation for all matter related to general usage and behavior.
( past_values: Tensorpast_time_features: Tensorpast_observed_mask: Tensorstatic_categorical_features: typing.Optional[torch.Tensor] = Nonestatic_real_features: typing.Optional[torch.Tensor] = Nonefuture_values: typing.Optional[torch.Tensor] = Nonefuture_time_features: typing.Optional[torch.Tensor] = Nonedecoder_attention_mask: typing.Optional[torch.LongTensor] = Nonehead_mask: typing.Optional[torch.Tensor] = Nonedecoder_head_mask: typing.Optional[torch.Tensor] = Nonecross_attn_head_mask: typing.Optional[torch.Tensor] = Noneencoder_outputs: typing.Optional[typing.List[torch.FloatTensor]] = Nonepast_key_values: typing.Optional[typing.List[torch.FloatTensor]] = Noneoutput_hidden_states: typing.Optional[bool] = Noneoutput_attentions: typing.Optional[bool] = Noneuse_cache: typing.Optional[bool] = Nonereturn_dict: typing.Optional[bool] = None ) β or tuple(torch.FloatTensor)
return_dict (bool
, optional) β Whether or not to return a instead of a plain tuple.
or tuple(torch.FloatTensor)
A or a tuple of torch.FloatTensor
(if return_dict=False
is passed or when config.return_dict=False
) comprising various elements depending on the configuration () and inputs.
The forward method, overrides the __call__
special method.
config () β Model configuration class with all the parameters of the model. Initializing with a config file does not load the weights associated with the model, only the configuration. Check out the method to load the model weights.
The Informer Model with a distribution head on top for time-series forecasting. This model inherits from . Check the superclass documentation for the generic methods the library implements for all its model (such as downloading or saving, resizing the input embeddings, pruning heads etc.)
This model is also a PyTorch subclass. Use it as a regular PyTorch Module and refer to the PyTorch documentation for all matter related to general usage and behavior.
( past_values: Tensorpast_time_features: Tensorpast_observed_mask: Tensorstatic_categorical_features: typing.Optional[torch.Tensor] = Nonestatic_real_features: typing.Optional[torch.Tensor] = Nonefuture_values: typing.Optional[torch.Tensor] = Nonefuture_time_features: typing.Optional[torch.Tensor] = Nonefuture_observed_mask: typing.Optional[torch.Tensor] = Nonedecoder_attention_mask: typing.Optional[torch.LongTensor] = Nonehead_mask: typing.Optional[torch.Tensor] = Nonedecoder_head_mask: typing.Optional[torch.Tensor] = Nonecross_attn_head_mask: typing.Optional[torch.Tensor] = Noneencoder_outputs: typing.Optional[typing.List[torch.FloatTensor]] = Nonepast_key_values: typing.Optional[typing.List[torch.FloatTensor]] = Noneoutput_hidden_states: typing.Optional[bool] = Noneoutput_attentions: typing.Optional[bool] = Noneuse_cache: typing.Optional[bool] = Nonereturn_dict: typing.Optional[bool] = None ) β or tuple(torch.FloatTensor)
return_dict (bool
, optional) β Whether or not to return a instead of a plain tuple.
or tuple(torch.FloatTensor)
A or a tuple of torch.FloatTensor
(if return_dict=False
is passed or when config.return_dict=False
) comprising various elements depending on the configuration () and inputs.
The forward method, overrides the __call__
special method.