Keywords

1 Introduction

Action anticipation (sometimes referred to as action prediction) is gaining a lot of attention due to its many real world applications such as human-computer interaction [2, 29, 32], sports analysis [3, 4, 55] and pedestrian movement prediction [5, 9, 18, 21, 45] especially in the autonomous driving scenarios.

In contrast to most widely studied human action recognition methods, in action anticipation, we aim to recognize human action as early as possible [22, 27, 38, 41, 48]. This is a challenging task due to the complex nature of video data. Although a video containing a human action consists of a large number of frames, many of them are not representative of the action being performed; large amount of visual data also tend to contain entangled information about variations in camera position, background, relative movements and occlusions. This results in cluttered temporal information and makes recognition of the human action a lot harder. The issue becomes even more significant for action anticipation methods, as the algorithm has to make a decision using only a fraction of the video at the very start. Therefore, finding a good video representation that extracts temporal information relevant to human action is crucial for the anticipation model.

To over come some of these issues, we resort to use deep convolutional neural networks (CNNs) and take the deep feature on the penultimate layer of CNN as video representation. Another motivation to use deep CNNs stems from the difficulty of generating visual appearances for future. Therefore, similar to Vondrick et al. [48], we propose a method to generate future features tailored for action anticipation task: given an observed sequence of deep CNN features, a novel Recurrent Neural Network (RNN) model is used to generate the most plausible future features and thereby predicting the action depicted in video data. An overview of this model can be found in Fig. 1.

The objective of our RNN is to map the feature vector at time t denoted by \(\varvec{x_t}\) to the future feature vector at \((t+k)\) denoted by \(\varvec{x_{t+k}}\). Because only a fraction of the frames are observed during inference, the future feature generator should be highly regularized to avoid over-fitting. Furthermore, feature generator needs to model complex dynamics of future frame features.

This can be resolved by parameter sharing. Parameter sharing is a strong machine learning concept that is being used by many modern leaning methods. Typically, CNNs share parameters in the spatial domain and RNNs in the temporal dimension. In our work, we propose to utilize parameter sharing in an unconventional way for RNN models by expanding it to the feature domain. This is based on the intuition that the CNN feature activations are correlated to each other.

By utilizing parameter sharing across feature activations, our proposed RNN is able to learn the temporal mapping from \(\varvec{x_t}\) to \(\varvec{x_{t+k}}\) with significantly fewer parameters. This greatly boosts the computational efficiency of the prediction model and correspondingly shortens the response time. We call our novel RNN architecture feature mapping RNN.

To model complex dynamic nature of video data, we make use of a novel mapping layer inside our RNN. In principle, the hidden state of the RNN captures the temporal information of observed sequence data. In our method, hidden state of the RNN is processed by a linear combination of Gaussian Radial Basis Function (RBF) kernels to produce the future feature vector. While a linear model defines a simple hyperplane as mapping functions, the kernelized mapping with RBF kernels can model complex surfaces and therefore has the potential of improving the prediction accuracy. In our work, we also implement RBF kernels on the action classification multi-layer perceptron to improve the performance of classifiers.

Ideally, we are interested in learning the probability distribution of future given the past features. To learn this conditional distribution, inspired by the of Generative Adversarial Networks [12], an adversarial approach is used to evaluate the cost of the feature mapping RNN. The RNN is trained with an adversarial loss and re-constrictive L2 loss. In this way, the model is optimized not only with the intention of reducing the Euclidean distance between the prediction and ground truth, but also taking probability distribution of the feature vector into consideration.

In a summary, our contributions are:

  • We propose a novel RNN architecture that share parameters across temporal domain as well as feature space.

  • We propose a novel RBF kernel to improve the prediction performance of RNNs.

  • We demonstrate the effectiveness of our method for action anticipation task beating state-of-the-art on standard benchmarks.

Fig. 1.
figure 1

Overview of Proposed feature mapping RNN: Given a frame extracted from video data, the algorithm first passes the RGB image I(t) through a deep CNN to acquire high level features of the image \(\varvec{x_t}\). The vector is then split into smaller segments \(\varvec{x_t^i}\) of equal length. Each scalar element in the segmented vector is used as input to a single LSTM cell that produces the prediction of corresponding feature element in frame \((t+k)\), where \(k\ge 1\). After all segments are processed with LSTMs, all the prediction segments \(\varvec{\hat{x}^i_{t+k}}\) are concatenated back together to form \(\varvec{\hat{x}_{t+k}}\), which contains high level features of \(I(t+k)\).

2 Related Work

The model proposed in this paper focuses on future video content generation for action prediction and action anticipation [10, 20, 22, 26, 28, 34, 35, 38, 41, 48, 49, 54]. In contrast to the widely studied action recognition problem, the action anticipation literature focuses on developing novel loss functions to reduce the predictive generalization error [16, 28, 38] or to improve the generalization capacity of future content such as future appearance [10] and future features [48]. The method propose in this paper also focuses on future content generation and therefore could further benefit from novel loss functions as proposed in [16, 28, 38].

In the early days, Yu et al. [54] make use of spatial temporal action matching to tackle early action prediction. Their method relies on spatial-temporal implicit shape models. By explicitly considering all history of observed features, temporal evolution of human actions is used to predict the class label as early as possible by Kong et al. [20]. Li et al.’s work [26] exploits sequence mining, where a series of actions and object co-occurrences are encoded as symbolic sequences. Soomro et al. [42] propose to use binary SVMs to localize and classify video snippets into sub-action categories, and obtain the final class label in an online manner using dynamic programming. In [49], action prediction is approached using still images with action-scene correlations. Different from the above mentioned methods, our work is focused on action anticipation from videos. We rely on deep CNNs along with a RNN that shares parameters across both feature and time dimensions to generate future features. To model complex dynamics of video data, we are the first to make use of effective RBF kernel functions inside RNNs for the action anticipation task.

On the other hand, feature generation has been studied with the aim of learning video representation, instead of specifically for action anticipation. Inspired by natural language processing technique [1], authors in [33] propose to predict the missing frame or extrapolate future frames from an input video sequence. However, they demonstrate this only for unsupervised video feature leaning. Other popular models include the unsupervised encoder-decoder scheme introduced by [44] for action classification, probabilistic distribution generation model by [24] as well as scene prediction learning using object location and attribute information introduced by [8]. Research in recent years on applications of Generative Adversarial Network on video generation have given rise to models such as MoCoGAN [47], TGAN [39] and Walker et al.’s work [52] on video generation using pose as a conditional information. The mechanisms of these GAN variations are all capable of exploiting both the spatial and temporal information in videos, and therefore have showed promising results in video generation.

Moreover, trajectory prediction [21], optical-flow prediction [51], path prediction [50, 53] and motion planning [11, 19], sports forecasting [7], activity forecasting of [30] are also related to our work. All these methods generate future aspects of the data. Our novel RNN model, however, focuses on generating future features for action anticipation.

3 Approach

3.1 Overview

Similar to methods adopted by other action anticipation algorithms, our algorithm makes predictions of action by only observing a fraction of video frames at the beginning of a long video. The overall pipeline of our method is shown in Fig. 1. First, we extract some CNN feature vectors from frames and predict the future features based on the past features. Subsequently, a multilayer perceptron (MLP) is used to classify generated features. We aggregate predictions from observed and generated features to recognize the action as early as possible.

3.2 Motivation

Denote observed sequence of feature vectors up to time t by \(X = \langle \varvec{x_1, x_2, x_3, \ldots x_t } \rangle \) and future feature vector we aim to produce by \(\varvec{\hat{x}_{t+k}}\), where \(k\ge 1\) and \(\varvec{x_t} \in \mathbb {R}^d\). We are interested in modeling the conditional probability distribution of \(P(\varvec{x_{t+k}} |\varvec{x_1,}\varvec{x_2,}\varvec{x_3,}\varvec{\cdots } \varvec{x_t};\varTheta )\), where \(\varTheta \) denotes the parameters of the probabilistic model.

It is natural to use RNNs or RNN variants such as Long Short Term Memory (LSTM) [14] to model the temporal evolution of the data. However, learning such a mapping could lead to over-fitting since these methods tend not to utilise the temporal coherence and the evolutionary nature of video data [31].

Furthermore, a naive CNN feature mapping using a LSTM from past to the future is also prone to over-fitting. A LSTM with hidden state of dimensionality H and takes feature vectors of dimensionality d as input uses parameters in the order of \(4 (dH+d^2)\). As an example, if we use the penultimate activations of Inception V3 [46] as feature vectors (\(d=2048\)), a typical LSTM (\(H=512\)) would require parameters in the order of \(10^7\). We believe that the effectiveness of such models can be largely improved by utilising the correlation of high level activations of modern CNN architectures [13, 46].

Motivated by these arguments, we propose to train a LSTM model where parameters are not only shared in the time domain, but also across feature activations. By doing so, we aim to self-regularize the feature generation of the algorithm. We name our novel architecture feature mapping RNN. Furthermore, to increase the functional capacity of RNNs, we make use of Radial Basis Functions (RBF) to model temporal dynamics of the conditional probability distribution \(P(\varvec{x_{t+k}} | \varvec{x_1,}\varvec{x_2,}\varvec{x_3,}\varvec{ \cdots }\varvec{x_t};\varTheta )\). These mechanisms will be introduced in details in the following subsection.

3.3 Feature Mapping RNN with RBF Kernel Mapping

A traditional feature generation RNN architecture takes a sequence of vectors up to time t as input and predicts the future feature vector \(\varvec{\hat{x}_{t+k}}\). Typically, the following recurrent formula is used to model the prediction:

$$\begin{aligned} \varvec{h_t} = f(\varvec{x_t},\varvec{h_{t-1}};\theta ) \end{aligned}$$
(1)

where \(\varvec{h_t}\) is the hidden state (\(\varvec{h_t} \in \mathbb {R}^{H}\)) which captures the temporal information of the sequence and \(\theta \) are the parameters of the recurrent formula. Then we utilize this hidden state to predict the future feature vector \(\varvec{x_{t+k}}\) using the following formula:

$$\begin{aligned} \varvec{\hat{x}_{t+k}} = \varvec{h_t} \times \varvec{W} \end{aligned}$$
(2)

where \(\varvec{W} \in \mathbb {R}^{H \times D}\) is the parameter that does the linear mapping to predict the future feature vector.

As introduced previously, in our feature mapping RNN the parameters \(\varTheta \) are shared across several groups of feature activations. This is achieved by segmenting the input feature vector of dimensionality d into equal size sub-vectors of dimensionality D, where D is referred to as feature step size.

Now let us denote the \(i^{th}\) sub-feature vector of size D by \(\varvec{x^{i}_t}\). Intuitively, if we concatenate all such sub-feature vectors in an end-to-end manner, we will be able to reconstruct the original feature vector \(\varvec{x_t}\). The time sequence of data for the \(i^{th}\) sub-feature vector is now denoted by \(X^{i}=\langle \varvec{x^{i}_1, x^{i}_2,}\varvec{x^{i}_3, \cdots x^{i}_t}\rangle \). If we process each sequence \(X^{i}\) in units of \(\varvec{x^{i}_t}\) with the RNN model in Eqs. 1 and 2, we will be able to predict \(\varvec{x^{i}_{t+k}}\) and by concatenating them end-to-end, generate \(\varvec{x_{t+k}}\). This approach reduces the number of parameters used in the RNN model from \(4 (dH+d^2)\) to \(4 (DH+D^2)\), which results in a considerable boost in computational efficiency especially when \(D\ll d\). However, the parameter complexity of the model would remain polynomial and is relevant to multiple hyperparameters.

To further improve the efficiency of our model, we adopt an even bolder approach: we propose to convert the sequence of vectors of \(X^{i}=\langle \varvec{x^{i}_1, x^{i}_2,}\varvec{x^{i}_3, \cdots x^{i}_t} \rangle \) to a sequence of scalars. Let us denote the j-th dimension of sub-vector \(\varvec{x^{i}_t}\) by \(x^{i(j)}_t\). Now instead processing sequence of vectors \(X^{i}\), we convert the sequence \(X^{i}\) to a new sequence of scalars \(X^{'}{^{i}} = \langle x^{i(1)}_1, x^{i(2)}_1, \cdots x^{i(D)}_1, x^{i(1)}_2, x^{i(2)}_2, \cdots , x^{i(k)}_t,\cdots x^{i(D)}_t \rangle \). Length of the sequence of scalars \(X^{'}{^{i}}\) is equal to \(t\times D\) and we generate \(\frac{d}{D}\) number of such sequences from each original sequence of feature vector X.

We then propose to process sequence of scalars using a RNN (LSTM) model. The computation complexity is now linear, with number of parameters used in the recurrent model (LSTM) reduced to \(4(H+1)\) and depends only on the hidden state size.

Again, given the current sequence of vectors X, we want to generate future feature vector \(\varvec{x_{t+k}}\). In the our RNN model, this is translated to predicting sequence of scalars \( \langle x^{i(1)}_{t+k}, \cdots x^{i(D)}_{t+k} \rangle \) from sequence \(X^{'}{^{i}}\) for all sub-feature vectors \(i=1\) to \(\frac{d}{D}\). Then we merge all predicted scalars for time \(t+k\) to obtain \(\varvec{x_{t+k}}\).

Therefore, mathematically our new RNN model that share the parameter over feature activations can be denoted by the following formula:

$$\begin{aligned} \varvec{h^{i(l)}_{t}} = f( x^{i(l)}_{t} , \varvec{h^{i(l)}}_{t-1} ;\varTheta ^{'}) \end{aligned}$$
(3)

where \(\varTheta ^{'}\) is the new parameter set of the RNN (LSTM) and the future l-th scalar of i-th sub-feature vector is given by:

(4)

To further improve the functional capacity of our feature mapping RNN, we make use of Radial Basis Functions (RBF). Instead of using a simple linear projection of the hidden state to the future feature vector, we propose to exploit the more capable Radial Basis Functional mapping. We call this novel RNN architecture the RBF kernelized feature mapping RNN, denoted by the following formula:

$$\begin{aligned} \hat{x}^{i(l)}_{t+k} = \displaystyle \sum _{j=1}^{n}\alpha _j^{l}\ \text {exp}\Big [-\frac{(\varvec{h^{i(l)}_t}-\varvec{\mu _j^{l}})^2}{{\sigma ^{l}_j}^{2}}\Big ] \end{aligned}$$
(5)

where \(\varvec{\mu _j^{l}}\), \(\sigma _j^{l}\) and \(\alpha _j^{l}\) are parameters learned during training and n the number of RBF kernels used. These parameters are shared across all sub-feature vectors. The future feature vector \(\varvec{\hat{x}^{i}_{t+k}}\) is calculated as the linear combination of RBF kernels outputs. Since the RBF kernels are better at modeling complex planes in the feature space, this functional mapping is able to accurately capture more complicated dynamics. Implementing the kernalised RBF on our feature mapping RNN enables the model to so with fewer parameters than classical RNNs.

Note that the method we have presented here only uses non-overlapping feature-sub-vectors, i.e. no overlapping exists between 2 consecutive sub-vectors. However, overlapping feature-sub-vectors can be used to improve the robustness of feature generation. Therefore, instead of using a non-overlapping feature stride of D, we use an overlapping stride of size S. In this case, we take the average between all overlapping parts of 2 consecutive sub-vectors to obtain \(\hat{x}^{i(l)}_{t+k}\).

3.4 Training of Feature Mapping RNN

Data generation, especially visual data generation with raw images, has remained a challenging problem for years mainly due to the absence of suitable loss function. The most commonly used function for this task is the \(\mathcal {L}_2\) loss. However, it works under the assumption that data is drawn from a Gaussian distribution, which makes the loss function ineffective when dealing with data that follows other distributions. As an example, if there exists only two equally possible value \(v_1\) and \(v_2\) for a pixel, the possibility for \(v_{avg}=(v_1+v_2)/2\) to be the true value for that pixel is minimal. However, \(v_{avg}\) will be assigned to the output in a neural network that uses \(\mathcal {L}_2\) loss to evaluate the cost. This property of the \(\mathcal {L}_2\) loss function causes a “blurry” effect on the generated output. Similar observations can be seen for feature vector generation.

Recent developments in Generative Adversarial Networks address this issue successfully [12]. Traditional GAN consists of 2 CNNs, one of them is named generator (denote as \(\mathcal {G}\)) and the other discriminator (denote as \(\mathcal {D}\)). The GAN effectively learns the probabilistic distribution of the original data, and therefore eliminates the “blockiness” effect caused by \(\mathcal {L}_2\) loss function. Here, we propose to train the feature mapping RNN algorithm using a combination of \(\mathcal {L}_2\) and adversarial loss, which is realized by implementing the feature mapping RNN as the generator denoted by \(\mathcal {G}: \varvec{x_t^{i}}\rightarrow \varvec{\hat{x}_{t+k}^{i}}\). By doing so, we are able to produce prediction that is both accurate and realistic.

\({\mathcal {L}_2}\,\,loss\): The \(\mathcal {L}_2\) loss is defined as the mean squared error between the generated feature and the real feature vector of the future frame given as follows:

$$\begin{aligned} \mathcal {L}_{2}^{\mathcal {G}}(\varvec{x_t}) = ||\varvec{x^{i}_{t+k}}-\varvec{\hat{x}^{i}_{t+k}}|| = ||\varvec{x^{i}_{t+k}}-\mathcal {G}(\varvec{x^{i}_{t}}) ||. \end{aligned}$$
(6)

Adversarial loss: We use generator adversarial loss proposed by [12] where we train \(\mathcal {G}\) so that \(\mathcal {D}\) believes \(\mathcal {G}(\varvec{x_t^{i}})\) comes from the dataset, at which point \(\mathcal {D}(\mathcal {G}(\varvec{x_t^i})) = 1\). The loss function is defined as:

$$\begin{aligned} \mathcal {L}^{\mathcal {G}}_{adv} = -\log (\mathcal {D}(\mathcal {G}(\varvec{x_{t}^{i}}))). \end{aligned}$$
(7)

By adding this loss to our objective function, the RNN is encouraged to generate feature prediction with probabilistic distribution similar to the original data. Finally, the loss function of our RNN generator \(\mathcal {G}\) is given by:

$$\begin{aligned} \mathcal {L}^{\mathcal {G}} = \lambda _1\mathcal {L}^{\mathcal {G}}_{2} + \lambda _2\mathcal {L}^{\mathcal {G}}_{adv}. \end{aligned}$$
(8)

The discriminator is trained to judge whether its inputs are real or synthetic. The objective is to output 1 when given input is the real data \(\varvec{x^{i}_{t+k}}\) and 0 when input is generated data \(\mathcal {G}(\varvec{x^{i}_{t}})\). Therefore, the discriminator loss is defined as:

$$\begin{aligned} \mathcal {L}^D = -log(\mathcal {D}(\varvec{x^{i}_{t+k}})) - log(1-\mathcal {D}(\mathcal {G}(\varvec{x^{i}_t})))\displaystyle . \end{aligned}$$
(9)

3.5 Action Classifier and Inference

To evaluate the authentication of predicted features generated by the feature matching RNN, we again use the frame features to train a 2-layer MLP appended with a RBF kernel layer (Eq. 5) to classify videos as early as possible. Illustration of our RBF kernelized MLP is shown in Fig. 2. The classification loss is evaluated using a cross-entropy loss. Feature mapping RNN and the action classification MLP is trained separately. One might consider training both MLP and the feature mapping RNN jointly. However, in terms of performance, we did not see that much of advantage.

Fig. 2.
figure 2

Illustration of RBF keneralized multilayer perceptron.

Fig. 3.
figure 3

Testing procedure of Feature Mapping RNN

During inference, we take advantage of all observed and generated features to increase the robustness of the results. Accuracy is calculated by performing temporal average pooling on all predictions (see Fig. 3).

4 Experiments

4.1 Datasets

Three datasets are used to evaluate the performance of our model, namely UT-Interaction [36], JHMDB-21 [17] and UCF101-24 [43]. We follow the standard protocols for each of the datasets in our experiments. We select these datasets because they are the most related to action anticipation task that has been used in prior work [34, 38].

UT-Interaction. The UT-Interaction dataset (UTI) is a popular human action recognition dataset with complicated dynamics. The dataset consists of 6 types of human interactions executed under different backgrounds, zoom rates and interference. It has a total of 20 video sequences split into 2 sets. Each video is of approximately 1 min long, depicting 8 interactions on average. The available action classes include handshaking, pointing, hugging, pushing, kicking and punching. The performance evaluation methodology requires the recognition accuracy to be measured using a 10-fold leave-one-out cross validation per set. The accuracy is evaluated for 20 times while changing the test sequence repeatedly and final result is yielded by taking the average of all measurements.

JHMDB-21. JHMDB-21 is another challenging dataset that contains 928 video clips of 21 types of human actions. Quite different from the UT-interaction where video clips of different actions are scripted and shot in relatively noise-free environments, all videos in JHMDB-21 are collected from either movies or online sources, which makes the dataset a lot more realistic. Each video contains an execution of an action and the dataset is split into 3 sets for training, validation and testing.

UCF101-24. UCF101-24 is a subset of UCF101. The dataset consists of more than 3000 videos from 24 action classes of UCF101. Since all the videos are collected from YouTube, the diversity of data in terms of action types, backgrounds, camera motions, lighting conditions etc are guaranteed. In addition, each video depicts up to 12 actions of the same category with different temporal and spatial features, which makes it one of the most challenging dataset to date.

4.2 Implementation Details

Feature Mapping RNN. The Feature Mapping RNN is trained with batch size of 128, using a hidden size (H) of 4 in all experiments unless otherwise specified. The default dimensionality of feature sub vector referred to as feature step size(D) is set to 128. We make use of six RBF kernels within the RBF kernelized feature mapping RNN. Feature stride is set to 64 and weight of the adversarial loss (\(\lambda _1\)) is set to 1 and the weight for \(\mathcal {L}_2\) loss is set to 10 (i.e. \(\lambda _2\)).

Action Classifier MLP. The a simple two layer MLP classifier consists of two hidden layers with 256 and 128 activation respectively. We also use RBF kernels along with the MLP where number of kernels set to 256. MLP is trained with batch size of 256.

Training and Testing Procedures. We use pre-trained Inception V3 [46] penultimate activation as the frame feature representation. The dimensions of each feature vector is 2048 (\(d=2048\)). The action classification MLP is trained on the feature vectors from the training split of the datasets. These features are also used to train our feature mapping RNN to generate future features. Both models are trained with learning rate 0.001 and exponential decay rate 0.9.

Protocols. Following the experimental protocol [34, 38], we used only the first \(r\%\) (\(50\%\) for UT-Interaction and \(20\%\) for JHMDB-21) of the video frames to predict action class for each video. To utilise our model, we generate extra \(p\%\) (referred to as prediction percentage) of the video features using our RBF kernalized feature mapping RNN. Therefore, we make use of \((r+p)\%\) feature vectors of the original video length to make the final prediction. To generate the next future feature at test time, we recursively apply our feature mapping RNN given all previous features (including the generated ones). We then use our action classification MLP to predict the action label using max pooling or simply average the predictions. This procedure is demonstrated more intuitively in Fig. 3.

4.3 Comparison to State-of-the-Art

We compare our model to the state-of-the-art algorithms for action anticipation task on the JHMDB-21 dataset. Results are shown in Table 1. Our best algorithm (denoted as fm+RBF+GAN+Inception V3 in the table) outperforms the state-of-the-art by \(18\%\), and we can clearly see that the implementation of kernel SVM and adversarial training improves the accuracy by around 3 to \(4\%\). In addition, to show the progression of how our method is able to outperform the baseline by such a large margin, we also implemented the Feature Mapping RNN on top of VGG16 so that the deep CNN pre-processing is consistent with other methods in Table 1. The fm+VGG16 entry in the table shows an \(8\%\) improvement from baseline ELSTM, which is purely influenced by the implementation of Feature Mapping RNN.

Experiments are also carried out on the two other mentioned datasets, where our best method outperforms the state-of-the-art by \(13\%\) on UT-Interaction and \(6\%\) on UCF101-24, as shown in Tables 2 and 3 respectively.

We believe these significant improvements suggests the effectiveness of two main principles, the parameter sharing and expressive capacity of RBF functionals. To further investigate the impact of each component, we perform a series of experiments in the following sections.

 

Table 1. Comparison of our model against state-of-the-arts on JHMDB-21 dataset for action anticipation. We follow the protocol of JHMDB-21 for action anticipation and predictions are made from using only \(20\%\) of video sequence.
Table 2. Comparison of our model against state-of-the-arts on UT-Interaction dataset for action anticipation. Following protocol of UT-Interaction, predictions are made from using only \(50\%\) of video sequence.
Table 3. Comparison of our model against state-of-the-arts on UCF101-24 dataset for action anticipation. Again, predictions are made from using only \(50\%\) of video sequence.

4.4 Analysis

In this section we compare the influence of different components of our RBF kernelized feature mapping RNN. As shown in Table 4, we compare following variants of our RNN model, including:

  1. (a)

    Feature Mapping RNN: use only \(\mathcal {L}_2\) loss to train the Feature Mapping RNN;

  2. (b)

    Feature Mapping RNN + RBF: our RNN with kernalised RBF, still only using \(\mathcal {L}_2\) loss;

  3. (c)

    Feature Mapping RNN + RBF + GAN: RBF kernelized feature mapping RNN with adversarial loss.

Apart from the Feature Mapping RNN-based models, we also conduct experiments on the following method as comparisons to our model:

  1. (d)

    Linear: a matrix of size \(D \times D\) is used for feature generation (D is dimension of input feature);

  2. (e)

    Vanilla LSTM: generate future action features with traditional vanilla LSTM. \(\mathcal {L}_2\) loss is used to train it;

  3. (f)

    Vanilla LSTM+RBF: vanilla LSTM with kernalised RBF, using only \(\mathcal {L}_2\) loss;

  4. (g)

    Vanilla LSTM+RBF+GAN: RBF kernalized vanilla LSTM with added adversarial loss.

Note that all the results are obtained using features extracted by Inception V3 network, and the accuracy are acquired using max pooling at prediction percentage \(p=50\%\).

Table 4. Comparison of different approach on JHMDB-21 dataset

The results in Table 4 shows the proposed scheme outperforms the linear model significantly while using fewer parameters. Most interestingly, the feature mapping RNN outperforms vanilla LSTM by almost 6% indicating the impact of parameter sharing in the feature space. We can also conclude from Table 4 that the application of adversarial loss as well as RBF kernel layers encourages the model to generate more realistic future features, which is reflected by the improvement in accuracy with Feature Mapping RNN+RBF and Feature Mapping RNN+RBF+GAN. It is also shown in the Table 4 that vanilla LSTM trained with RBF kernel yields almost \(2\%\) higher accuracy than plain vanilla LSTM, which proves further that the RBF layer is something the baseline can benefit from. Regrettably, the vanilla LSTM with adversarial training model failed to stabilise due to large number of parameters needed in the LSTM cells to reconstruct the original feature distribution.

The influence of RBF kernalized feature mapping RNN is quite distinctive. If we compare the red curve to the green one, we can see that the discrepancy between them becomes larger as the prediction percentage increases. This indicates that the RBF kernalized feature mapping RNN generate more accurate future features in the long term, and hence it is a more robust model than plain feature mapping RNN. Comparing the red and green curve to the orange and blue one, we can also conclude that the adversarial loss assist the RNN training in a similar way. Even without the assistance of GAN loss and RBF kernel, the feature mapping RNN still performs better than liner projection RNN (Fig. 4).

Fig. 4.
figure 4

Prediction accuracy without pooling for JHMDB-21 dataset at different video prediction percentages \(\varvec{p}\). RBF kernalized Feature mapping RNN is trained using adversarial loss is able to achieve the highest stable accuracy. (Color figure online)

Fig. 5.
figure 5

Prediction accuracy evaluated at different feature step sizes on JHMDB-21 dataset. The accuracy plotted in the image is found by implementing feature step size between \(D=8\) to 2048 with increment of 8 on the model and the rolling average is taken among every 16 measurements. No temporal pooling is used.

4.5 Influence of Hyper-parameters

Feature Step Size. The accuracy of the generated data indicates the existence of strong correlations between the D-dimensional segments of the feature vectors. By default, we resort to feature step size of 128 (\(D=128\)). In order to further explore this property, we experimented with different feature step sizes. In Fig. 5, we plot the recognition accuracy against feature step size. We observe that small feature step size guarantees effective feature generation. Specifically, the prediction remains above \(70\%\) when feature step size is smaller than 200. This phenomena can be explained by the intuition that when feature step size is large, the model tries to generalize a large set of features with mixed information at one time step, which results in degraded performance.

   

Table 5. Prediction accuracy at different feature stride size (\(\varvec{S}\))
Table 6. Prediction accuracy using LSTM cells with different state size (\(\varvec{H}\)).
Table 7. Prediction accuracy using different number of RBF kernels.

It is also interesting to note that the prediction accuracy oscillates drastically as the feature step size exceeds 250. This indicates that perhaps the feature vector summarizes information of the original image in fixed-size clusters, and when we attempt to break these clusters by setting different feature step size, the information within each time step lacks continuity and consistency, which subsequently compromises the prediction performance.

Although smaller feature step size builds a more robust model, the training time with feature step size 16 takes only half the amount of time of training with step size 4, with no compromise on prediction accuracy. Therefore, it might be beneficial sometimes to choose a larger feature step size to save computational time.

Interval Size. In this section we experiment the effect of overlapping sub-feature vectors on our RBF kernalized feature mapping RNN. Recall that the feature mapping RNN is denoted by \(\mathcal {G}: \varvec{x_t^{i}}\rightarrow \varvec{\hat{x}_{t+k}^{i:}}\). Instead of incriminating i by the multiple of feature step size D, in an attempt to improve the prediction accuracy, we define an feature stride S that is smaller than D. The prediction accuracy of Feature Mapping RNN with several different feature stride value is shown in Table 5.

LSTM State Size. This section aims at investigating the influence of LSTM cell’s hidden state size (H) on the model’s performance. Since the hidden state stores essential information of all the input sequence data, it is common to consider it as the “memory” of the RNN. It is intuitive to expect an improvement in performance when we increase the size of the hidden state up to some extent.

However, the results in Table 6 shows that increasing the LSTM state size does not have much effect on the prediction accuracy, especially when the state size becomes larger than 8. This is because in the proposed feature mapping RNN model, each LSTM cell takes only one scalar as input, as opposed to the traditional RNN cells that process entire vectors. As the hidden state size is always greater than the input size (equal to 1), it is not surprising that very large H does not have much influence on the model performance.

Number of RBF Kernels. In this section we study the influence of number of Gaussian surfaces used in feature mapping RNN. We calculate prediction accuracy while increasing the number of Gaussian kernels from \(2^1\) to \(2^8\). Results are as shown in Table 7. The results show a general trend of increasing prediction performance as we add more number of kernels, with the highest accuracy achieved at when \(k=128\). However, result obtained when \(k=256\) is worse than when \(k=4\). This phenomena could be explained by over-fitting, resulted from RBF kernel’s strong capability of modeling temporal dynamics of data with complex boundaries.

Conclusions for Hyper-parameters Tuning. The conclusion from these experiments is that the model is not too sensitive to the variation of these hyper-parameters in general, which demonstrates its robustness. Results further demonstrated the computational efficiency of our approach. Since it is possible to effectively train the model with very few parameters, it can be stored on mobile devices for fast future action anticipation.

5 Conclusions

The proposed RNN which uses a very few parameters outperforms state-of-the-art algorithms on action anticipation task. Our extensive experiments indicates the model’s ability to produce accurate prediction of future features only observing a fraction of the features. Furthermore, our RNN model is fast and consumes fraction of the memory which makes it suitable for real-time execution on mobile devices. Proposed feature mapping RNN can be trained with and without lables to generate future features. Our feature generator does not use class level annotations of video data. Therefore, in principle, we can increase the robustness of the model utilizing large amount of available unlabelled data. The fact that the model is able to generate valid results using very few parameters provides strong proofs for the existence of inner-correlation between deep features, which is a characteristic that can have implications on many related problems such as video tracking, image translation, and metric learning.

In addition, by appending a RBF layer to the RNN, we observe significant improvement in prediction accuracy. However, it was also noted that over-fitting occurs when the model is implemented with too many kernel RBFs. To fully explore functional capacity of RBF function, in future studies, we aim to implement kernel RBFs on fully connected layer of popular deep CNN models such as ResNet [13], AlexNet [23] and DenseNet [15].

In conclusion, proposed RBF kernalized feature mapping RNN demonstrates the power of parameter sharing and RBF functions in a challenging sequence learning task of video action anticipation.