Skip to main content
Sensors (Basel, Switzerland) logoLink to Sensors (Basel, Switzerland)
. 2020 Apr 15;20(8):2226. doi: 10.3390/s20082226

Keys for Action: An Efficient Keyframe-Based Approach for 3D Action Recognition Using a Deep Neural Network

Hashim Yasin 1,*, Mazhar Hussain 1, Andreas Weber 2,
PMCID: PMC7218879  PMID: 32326468

Abstract

In this paper, we propose a novel and efficient framework for 3D action recognition using a deep learning architecture. First, we develop a 3D normalized pose space that consists of only 3D normalized poses, which are generated by discarding translation and orientation information. From these poses, we extract joint features and employ them further in a Deep Neural Network (DNN) in order to learn the action model. The architecture of our DNN consists of two hidden layers with the sigmoid activation function and an output layer with the softmax function. Furthermore, we propose a keyframe extraction methodology through which, from a motion sequence of 3D frames, we efficiently extract the keyframes that contribute substantially to the performance of the action. In this way, we eliminate redundant frames and reduce the length of the motion. More precisely, we ultimately summarize the motion sequence, while preserving the original motion semantics. We only consider the remaining essential informative frames in the process of action recognition, and the proposed pipeline is sufficiently fast and robust as a result. Finally, we evaluate our proposed framework intensively on publicly available benchmark Motion Capture (MoCap) datasets, namely HDM05 and CMU. From our experiments, we reveal that our proposed scheme significantly outperforms other state-of-the-art approaches.

Keywords: action recognition, deep neural network (DNN), motion capture (MoCap) datasets, keyframe extraction

1. Introduction

Human action recognition and behavior analysis has been an active research area in recent decades because of its wide range of potential applications, including human–computer interaction applications, e.g., sport annotations and fitness training, game and film industries, computer animations, robotics, content-based data retrieval, health monitoring, and medical rehabilitation. For this reason, the demand for capturing and rendering 3D human motion is continually increasing. In general, studio-like environments with well-developed motion capture systems are used to capture the dynamic movements of an actor or object. The motion capture data basically represent human motions in the form of the spatiotemporal trajectories of the specified human skeleton joints [1]. The motivation behind motion capturing is to record the motion and then re-utilize it to perform different kinds of tasks rather than generate the motion synthetically. In order to capture human motion, a variety of sources are utilized, such as mechanical systems in which potentiometer and fiber optics are used; magnetic-/acoustic-based systems [2]; camera-based systems [3,4,5] in which expensive, high-speed and high-definition cameras are used; high-speed optical motion capture systems using photosensors [6]; inertial sensor- and accelerometer-based systems [7,8]; and hybrid systems [9]. As another domain, 3D motions are reconstructed from different sources, e.g., reconstruction from video or image data [10,11,12,13,14] and reconstruction from accelerometer data [15,16]. In short, motions captured or generated by different sources of means are abundant and contain a lot of hidden knowledge and information that may be exploited further in different types of applications, such as those mentioned above.

There exists a variety of action classification methods that are based on different input data; the input may be in the form of simple RGB videos or spatiotemporal joint trajectories acquired by means of a sensor system (e.g., mechanical, magnetic, optic, inertial, non-optic wearable sensors and RGB-D sensors, such as Kinect) or an estimated 3D skeleton from image data or a hybrid system. Although a lot of research has been done in the domain of action recognition, there still exist numerous challenges, such as viewpoint variations, different human body sizes and appearances, and illumination factors that may influence the efficiency and performance of existing algorithms [17]. Moreover, each performing actor has his or her own way and style of executing the same action. The actions may also have many variations in terms of speed and length. In addition to these inter-class variations, extensive intra-class variations make the task more difficult. For example, it is not an easy task to differentiate between jogging and running, walkForward and walkBackward, sitDownChair and sitDownFloor, standUpSitChair and standUpSitFloor, rotateArmBackward and rotateArmForward, etc. The example actions described in this paper are presented with the labels as it is used in [1,18,19]. In order to deal with all these challenges, a number of techniques have been proposed. One of these techniques is the skeleton-based approach, which has become very popular because it provides very comprehensive information as compared with approaches based upon 2D RGB images or depth sensor data [20]. It is comparatively more resilient to variations in illumination, occlusion factors, a complex and continuously changing background environment, etc. [21]. Skeleton-based features are more vigorous and robust as compared with depth-based features for both cross-subject as well as cross-view action recognition [17]. Action recognition based on 3D human skeleton joints is basically a problem of time-series analysis, where the action is recognized from sequences of articulated body poses over time [22,23,24]. Generally, the skeleton-based approach can be categorized into two major classes: (i) the human body posture comprising different body joints has been employed to recognize actions [20,25,26,27,28], and (ii) human body parts in the form of a cylinder have been utilized in the process of action classification [29,30,31]. In this context, this paper deals with the skeleton-based action recognition technique using human MoCap datasets, where the human body posture comprises different body joints.

In this paper, we propose a novel and efficient approach for 3D action recognition based on the human body skeleton with 3D articulated joint trajectories. We first design a framework in order to learn the action model during the training phase, and we start by normalizing the sequence of poses to reduce the impact of orientation, as well as translation. Having obtained the normalized poses, we then successfully extract the joint features, which further contribute as input to the deep neural network in order to classify the 3D action in a supervised learning fashion. We empirically adjust the number of hidden layers and the number of neuron units within a hidden layer in order to come up with the final deep network architecture. We report all the particulars of experiments for the configuration of the deep neural network architecture in Section 4. We also propose and design a strategy that enables us to extract keyframes from a sequence of motion. As a result, we summarize the motion by discarding redundant frames and keep only the frames that have essential and comprehensive information about the action in the motion. The proposed keyframe extraction method reduces the latency, as the online system generally requires short latency for decision-making in human–machine interactions. In our experiments, we reveal and verify that a few informative keyframes, rather than all of the frames of a motion sequence, are sufficient to recognize the action accurately. The details about the proposed framework can be seen in Figure 1.

Figure 1.

Figure 1

System overview. The first phase is the training phase, while the second phase represents the testing phase. In the training phase, 3D poses are normalized first by removing orientation and translational information from each pose, thus developing the normalized pose space. The joint features are extracted from these normalized poses and are given as input to the deep neural network in order to learn the model. The testing phase includes normalization, keyframe extraction and then the extraction of joint features, on the basis of which the action is recognized with the help of the learned model.

We evaluate our proposed approach thoroughly on popular benchmark MoCap datasets, namely HDM05 [32] and CMU [33]. We categorize these datasets further into four groups according to the motion classes, e.g., HDM05-65, HDM05-14, CMU-30, and CMU-14. We conducted several experiments in order to analyze our proposed scheme, and we describe them step by step. In particular, we analyze (i) the impact of essential keyframes on the overall process of action recognition in terms of accuracy and time complexity, (ii) the impact of the training MoCap datasets and, ultimately, and (iii) the impact of a variety of deep neural network architectures. We compare our approach with other existing state-of-the-art approaches and conclude that our proposed pipeline is not only computationally fast enough but also achieves comparatively better performance in terms of accuracy.

This paper is organized as follows: we first discuss the related methods and techniques in Section 2. In Section 3, we describe our proposed methodology step by step, including the process of normalization, the proposed keyframe extraction algorithm, and the details about the proposed deep neural network architecture. The experiments and the discussion on the obtained results are presented in Section 4. A comparison of our approach with other techniques is also available in Section 4. Finally, we conclude our work in Section 5.

2. Related Work

In this section, we discuss the background research work in the field of action recognition using motion capture datasets. There exists a variety of techniques to recognize 3D human action from a motion capture dataset. We categorize these techniques into two major classes, i.e., conventional machine-learning-based approaches and deep-learning-based algorithms.

2.1. Conventional Learning-Based Approaches

An abundance of research has been done on human action recognition based on conventional machine learning techniques, such as K Nearest Neighbor (KNN) classifiers [34,35], Support Vector Machine (SVM) [18,35,36,37,38,39,40], Hidden Markov Models (HMM) [41,42], clustering strategies [42,43,44], and Bayesian learning [45,46]. Most of these techniques first extract hand-crafted features [34,36,38,39,46,47] and then apply a learning algorithm in order to classify the action. Wu et al., in [34], propose action descriptors with a sliding temporal window of size 5, which includes joint position, angular velocity, and angular acceleration. They exploit three different modified K Nearest Neighbor (KNN) classifiers for the confidence of each frame, for the prediction of frame-wise labels, and, ultimately, for the final action classifications. In [18], Cho et al. propose a method that classifies the action while simultaneously reconstructing the given input motion sequences. This approach utilizes two sets of features: the first feature set consists of the relative positions of joints (PO) with temporal differences (TD), represented as (PO+TD); and the second set includes the relative positions of joints (PO) with temporal differences (TD) and normalized trajectories (NT) of motion, represented as (PO+TD+NT). A Hybrid Multi-Layer Perception with a deep autoencoder, a symmetric feedforward neural network, is then trained on this extracted feature set to perform the classification and reconstruction tasks simultaneously. The experiments were performed on the HDM05 MoCap dataset. For the evaluation, they also employed other classification techniques, such as Multi-Layer Perception (MLP), SVM, Extreme Learning Machines (ELM), and Hybrid Multi-Layer Perception (Hybrid MLP), with different learning rates λ={0,0.1,0.5,0.9}. Yang and Tian, in [46], propose a new action feature descriptor, e.g., eigenJoints, for action recognition, which is basically the combination of multiple action-related information types, such as the static posture of the actor, how the motion is performed, and the ultimate overall dynamics. For the selection of the most informative frame, they employ Accumulated Motion Energy (AME), which measures the dissimilarity between the frames. For the final action classification task, they deploy a non-parametric Naïve-Bayes-Nearest-Neighbor (NBNN) classifier. Vantigodi et al. [39] propose a method for action recognition that is based on two feature sets, the variance of skeleton joints and the time-weighted variance of the skeleton points, which incorporates the temporal information of the performed action. Both feature sets are embedded together for further model training. For action classification, a linear SVM and a correlation-based metric are employed. Liang et al. [42] introduce a local joint structure and 3D histogram-based local and global features in order to represent 3D actions. Linear Discriminant Analysis (LDA) is employed to reduce feature dimensionality, the k-means clustering algorithm is utilized to generate codewords, and Hidden Markov Models are deployed for action recognition on the basis of the codewords. Moussa et al. [38] propose a methodology that depends on high-level features that carry information about changes in human body dimensions during the performance of the action. Their proposed system comprises four stages: the extraction of skeleton details, parameter calculation, parameter encoding, and, finally, a classification module, in which a multi-class linear SVM classifier is employed.

Slama et al. [36] present a method in which 3D human skeleton motion is represented as geometric formulations, and an action is represented as a component of a Grassmann manifold. For classification, they employ a wrapped Gaussian model and a linear Support Vector Machine (SVM). Kovar and Gleicher, in their paper [47], propose a method to logically identify similar motion segments by employing a novel distance metric with which they numerically find similarity and closeness between motion segments from a large MoCap dataset. They further utilize these similar segments for automated motion registration, as well as for blending the continuous and parameterized space of 3D motions. Xiao and Song [45] propose a technique of Statistical Learning and Bayesian Fusion (SLBF) for motion clip similarity in which a motion feature database is developed by representative frames extracted through a fuzzy clustering strategy and gesture features. They basically combine category-based motion similarity distances and Canonical Correlation Analysis (CCA)-based distances through Bayesian estimation in order to find similar segments from a MoCap dataset. Kadu and Kuo [37] propose a multi-resolution string representation method using Tree Structure Vector Quantized (TSVQ) in order to generate a codeword for action classification. For final action recognition and classification, they considered a number of methods, such as (i) Method A: Motion-String Similarity including Sim-parameter with Level-n (SLn) and Max-parameter with Level-n (MLn), where n=10,11,12,13; (ii) Method B: a Pose-Histogram Classifier with Level-n (SLn), where n={3,4,5,6}; (iii) Method C: Two-Step Score Fusion with TSVQ; and (iv) Method D: Two-Step Support Vector Machine (SVM) Fusion with TSVQ. Overall, they achieved very good results with Two-Step (SVM) Fusion with the TSVQ method. Ko et al., in [43], deploy Principle Component Analysis (PCA) for dimensionality reduction, motion saliency and the k-means clustering algorithm in order to first extract informative and significant keyframes from human motion input sequences; then, they reconstruct these motion sequences to compare them with the input motion clip. In [48], Wu et al. employ a Self Organizing Map (SOM) and the Smith–Waterman algorithm to achieve efficient retrieval and, ultimately, indexing of the human motion capture data. For indexing, the SOM is utilized, while the local similarities between motion clips are computed with the help of the Smith–Waterman algorithm. They basically propose an unsupervised method for the indexing and clustering of motion clips, which are deployed further to classify the actions, as well. They enhanced their strategy of the motion map, as described in [44], where they present a cluster-based scheme for the indexing and retrieval of motion clips. They partition the human skeleton model into three body parts: the torso, the arms and the legs. They then measure temporal similarity information for each body part by the SOM and Smith–Waterman algorithm. In the end, a hierarchical clustering method is implemented to cluster similar data, as well as to find relationships between them. The authors of [41] propose a novel frame-by-frame action recognition approach by considering the algebraic velocity generated by different body parts of the 3D skeleton. For the classification of different action categories, a real-time Hidden Markov Model algorithm with Gaussian Mixture Models (GMM) is deployed. Barnachon et al. [49] propose an action recognition technique for ongoing action sequences. They compute the histogram of the action and then the Hausdorff distances accordingly, which are further warped by Dynamic Time Warping (DTW). For that purpose, they deploy dynamic programming in order to compute the final recognition score. Baumann et al. [50] propose an action graph, for which a kd tree is developed. The neighborhood of a query is fetched, which is further utilized in the action graph. Finally, action recognition is transformed into the shortest-path-finding problem, where the target is to find the shortest path through the action graph. This shortest path represents the final action. Laraba et al. [35] first represent 3D human motions as 2D RGB images, and then they employ classical machine learning algorithms, including KNN, SVM, Random Forest, and Convolutional Neural Network (CNN), for action classification. On the basis of their experiments, they claim that because the images of the motion sequences are represented in the RGB domain, the CNN outperforms all other competing techniques. Plenty of methods exist that employ key pose-based features or descriptors in order to classify actions [49,51,52,53].

2.2. Deep-Learning-Based Approaches

Hinton et al. [54] define a DNN as a neural network that consists of two or more hidden layers between the input layer and the output layer. The literature contains a number of techniques that employ deep-learning-based approaches; for example, [1,55,56,57] rely on a Convolutional Neural Network (CNN), [19,58,59,60] utilize a Recurrent Neural Network (RNN), as well as Long-Short Term Memory (LSTM), and [61] uses Deep Progress Reinforcement Learning (DPRL). Sedmidubsky et al. [1] propose a method for action recognition and segmentation in which the motions are mapped onto encoded RGB images. They first normalize the poses, and then the x-, y-, and z-coordinates of the poses are translated into red, blue, and green channels of the colors. They combine distance-based functions with a CNN classifier. In this way, they generate fixed-sized, highly descriptive feature vectors with 4096 dimensions. They learn motion characteristics by employing a CNN while performing indexing by a distance-based comparison. They further enhanced this approach towards the process of segmentation. Zhang et al. [59] extended an RNN model to the spatial domain by adding up simple geometric relational features that are based on the distances between skeleton joints. They use a three-layer-deep LSTM model in which they drop the in-cell connections. The geometric features are given as input to the first layer of the LSTM network, and the output of the first layer is provided as the input to the upper layer. A softmax layer is ultimately used on top of the highest LSTM layer. Liu et al. [55] propose a skepxel in which they combine spatial and spatiotemporal information in order to represent the skeleton joint sequences. Furthermore, they also add up relative joint velocities. In this way, the authors provide a more detailed hierarchical representation with micro-temporal relation and macro-temporal relation for learning through a CNN. They extended the Inception-ResNN CNN with their proposed scheme and obtained outstanding results. Tang et al. [61] recognize action by proposing Deep Progress Reinforcement Learning (DPRL) with a graph-based CNN. They extract the most informative frames from the input action video sequences through DPRL and employ a graph-based CNN in order to exploit the extrinsic, as well as intrinsic, human joint dependencies. Pham et al. [57] propose an SPMF (Skeleton Posture-Motion Feature) based on necessary spatiotemporal information extracted from skeleton poses and their motions in order to represent unique patterns that exist in skeletal movements. It is further enhanced by exploiting the Adaptive Histogram Equalization (AHE) method to build the action map. In the end, Deep CNNs (DCNN) based on the already-proposed DenseNet architecture are utilized for the purpose of final learning and action classification. In [19], the authors propose different Recurrent Neural Network (RNN) architectures for action recognition. Rather than use the whole skeleton, this approach divides the skeleton into five subparts (two legs, two arms, and one trunk) according to the skeleton structure in order to feed different recurrent network architectures, such as a Hierarchically Bidirectional Recurrent Neural Network (HBRNN-L) with Long-Short Term Memory (LSTM) architecture in the last network layer, a Hierarchically Unidirectional Recurrent Neural Network (HURNN-L) with LSTM, a Deep Bidirectional Recurrent Neural Network (DBRNN-L) with LSTM and Deep Unidirectional Recurrent Neural Network (DURNN-L) with LSTM, a Deep Bidirectional Recurrent Neural Network (DBRNN-T) with a tanh activation function, and a Deep Unidirectional Recurrent Neural Network (DBRNN-T) with a tanh activation function. Veeriah et al. [60] added a new gating strategy in LSTM to develop a differential RNN that depends on information obtained through the changes that occur in successive frames. Ijjina et al. [56] propose a fuzzy CNN to recognize action using human 3D skeleton data. They measure the temporal variation between the skeleton joints during action sequences and recognize local patterns.

3. Methodology

The detailed pipeline and framework of our proposed methodology can be seen in Figure 1. We discuss all the steps involved in our proposed methodology, one by one, as follows.

3.1. Normalization

The first step of the proposed pipeline is the process of normalization. We normalize each 3D pose X with 31 joints J that exist in the motion M. In fact, we eliminate the translational, as well as the orientation, information from the 3D pose so that we can avoid ambiguities and complexities that may arise because of such information. In the case of translational normalization, we translate the 3D pose in such a way that the pose must have its center of mass (the root joint) at the coordinates (0,0,0). We basically subtract the root joint coordinates from all other joint coordinates in order to shift the pose at the position (0,0,0). For orientation normalization, we rotate the joint trajectories along the y-axis (facing upward) so that the subject becomes just the frontal view: the skeleton faces towards the x-axis, and the hip joints are aligned to the z-axis. We first estimate the angle and then rotate all the joints of a pose with this angle about the y-axis. As a result, each pose has only the information about how the motion is performed, rather than where and from what viewpoint it is executed. An example of the normalization of different poses is shown in Figure 2.

Figure 2.

Figure 2

The process of normalization. (a) A representation of a few poses taken from different motion classes of the CMU-30 dataset. (b) The orientation information is removed from the poses. (c) The translational information is also removed to generate the final poses, which are ultimately normalized rotationally, as well as translationally.

3.2. Keyframes

In this paper, we propose a keyframe extraction technique to extract the most informative frames and to remove pose redundancy. As a result, human motion is effectively compressed and summarized. Moreover, in this way, we increase efficiency in terms of time and accuracy for action recognition, as well. In fact, the extraction of keyframes may be considered an indispensable step in an online recognition system that demands short latency for a quick response.

Implementation Details

Our proposed keyframe extraction strategy is iterative in nature. In each iteration, a new suitable keyframe is selected from the remaining frames of the input motion according to the similarity measure. For example, in the first iteration, we find k nearest neighbors of the first frame of the given input motion of size n within that input motion. In order to find the nearest neighbors in the J×3×n-dimensional space defined by the skeleton joints, we measure the average 3D Euclidean distance. We fix the size of k=n2 so that the size of the nearest neighbors do not exceed the size of the motion. We further purify the nearest neighbors N in hand to select suitable candidate keyframes Φ by means of a threshold; a threshold is used to control the compression ratio for the number of frames that should be reduced. We report the details about the selection of the threshold in Section 4. To this end, we have candidate keyframes Φ from which we have to extract the final keyframes Ψ. We sort these candidate keyframes and then find the median frame, which is finally considered to be the keyframe. All the candidate keyframes are discarded from the input motion so that these frames do not participate again in subsequent iterations. The complete process is repeated until there are no input frames left. The details about the algorithm are presented in Algorithm 1.

Algorithm 1 Keyframe Extraction Algorithm
  • 1:

    procedureKeyframesExtraction(M)

  • 2:

       inputs: M={X1,X2,X3,,Xn}, given input sequence of frames

  • 3:

       persistent: n, total number of frames

       k, total number of nearest neighbors

       N={X^1,X^2,X^3,,X^k}, retrieved nearest neighbors

       D={d1,d2,d3,,dk}, distances computed for each nearest neighbor

       Φ={ϕ1,ϕ2,ϕ3,,ϕc}, candidate keyframes

       Ψ={ψ1,ψ2,ψ3,,ψs}, final selected keyframes

       t, threshold value

  • 4:

       kn2

  • 5:

       s1

  • 6:

       while (length(M)0) do

  • 7:

        X1extractFrame(M)

  • 8:

        [N,D]findNearestNeighbours(M,X1,k)

  • 9:

        i1

  • 10:

        while (i<k) do

  • 11:

         if (di<t) then

  • 12:

            ϕiX^i

  • 13:

            ii+1

  • 14:

         end if

  • 15:

        end while

  • 16:

        Φsort(Φ)

  • 17:

        ψsmedian(Φ)

  • 18:

        MMΦ

  • 19:

        ss+1

  • 20:

       end while

  • 21:

    end procedure

3.3. Deep Network

Our proposed deep neural network architecture consists of an input layer, two hidden layers (h and h) and an output layer; all these layers are fully connected to each other. To design the deep neural network architecture, we conducted several experiments with varying numbers of hidden layers, as well as varying numbers of neuron units within each hidden layer. We empirically concluded that when we increase the number of hidden layers beyond two, the performance decreases. We report and discuss all these results in detail in Section 4.

Implementation Details

We input the joint features extracted from motion sequences to our neural network. Each node of the first hidden layer h takes real-valued numbers, computes the weighted sum, and applies a non-linear activation function (sigmoid function) in order to execute the output as

hp=11+ej=0J×3xjwj,pwithp{1,2,3,,P}, (1)

where P is the total number of nodes for the first hidden layer. Similarly, at each unit of the second hidden layer h, we compute the output as

hq=11+ep=0Phpwp,qwithq{1,2,3,,Q}, (2)

where Q is the number of units for the second hidden layer. Finally, for this multi-class classification problem, we employ the softmax function in the output layer in order to yield the probability of each class at each unit of the output layer:

or=erq=0Qhqwq,rr·erq=0Qhqwq,rwithr{1,2,3,,R}, (3)

where R is the number of units for the output layer. The softmax function basically squashes a vector into the range of 0–1, and the sum of all the resulting elements is necessarily equivalent to 1. We exploit a cross-entropy cost function with the predicted value or and the target value tr for this multi-nominal classification problem, e.g., the one-hot encoded vector tr=[0,0,0,1,0,,R] contains just a single 1 at the 4th position. This cross-entropy cost,

E=rtrln(or), (4)

is computed at the output layer, and the errors are back-propagated towards the hidden layers in order to update the weight vectors w, w, and w with a gradient descent algorithm. For the implementation of the gradient descent, the derivative of the error E is computed with respect to each weight wq,r that connects the hidden layer h to the output layer with the softmax function,

Ewq,r=Eor·orwq,r. (5)

For each unit in the output layer o indexed by r, the gradients are

δr=Eor=(ortr), (6)

and the gradient with respect to wq,r becomes

Ewq,r=hq(ortr). (7)

Similarly, the derivative of the error E with respect to each weight wp,q that connects the first hidden layer h to the second hidden layer h with the sigmoid function is

Ewp,q=Ehq·hqwp,q. (8)

For each unit in the hidden layer h indexed by q, the gradients of the loss function are

δq=Ehq=hq(1hq)·r(ortr)·(wq,r) (9)

and, with respect to weight wp,q,

Ewp,q=hq(1hq)·r(ortr)·(wq,r)·(hp). (10)

The derivative of the error E with respect to each weight wj,p that connects the input layer to the first hidden layer h with the sigmoid function is

Ewj,p=Ehp·hpwj,p. (11)

For each unit in the first hidden layer h indexed by p, the gradients are

δp=Ehp=hp(1hp)·qδq·(wp,q) (12)

and, with respect to weight wj,p,

Ewj,p=hp(1hp)·qδq·(wp,q)·(xj). (13)

Weight Updates: The weights wj,p that establish the connection between the input and first hidden layers are updated as

wj,p=wj,p+ηδpxj, (14)

and similarly, the weights wp,q and weights wq,r are updated as

wp,q=wp,q+ηδqhp, (15)
wq,r=wq,r+ηδrhq, (16)

where η is the learning rate, which is kept equal to 0.01. We fix the maximum number of epochs to 1000, and the minimum performance gradient is kept at 1e6. The training process stops if the validation performance deteriorates continuously for 5 consecutive epochs.

3.4. Action Score

To this end, we define the deep network architecture, and as an input, we provide the extracted features from the keyframe sequences of the motion in the form of joint positions to the network. Finally, in the last step, similar to [51,52], we calculate the action score frame by frame of the given keyframe sequence of the motion. On the basis of the probability determined through the deep network, we assign a vote to each keyframe involved in the given action sequences. We exploit the majority function here, where the majority count of the votes ultimately leads us to the prediction of the final action class.

4. Experiments

We evaluated our proposed approach extensively on a pool of benchmark MoCap datasets, namely CMU [33] and HDM05 [32], both of which are publicly available. We further categorized these datasets into four different types of datasets on the basis of action categories. The details about these datasets can be found in Section 4.1. We adopted a 5-fold cross-validation method in order to evaluate the performance of our proposed pipeline for classification. We performed a number of experiments in this context on these datasets. We first tuned the parameters that we utilized in our keyframe extraction algorithm and the deep network architecture for action recognition. We then started with the evaluation of our proposed keyframe extraction algorithm, as mentioned in Algorithm 1. Finally, we thoroughly evaluated the performance of our proposed framework by comparing it with other existing approaches.

4.1. Datasets

4.1.1. HDM05 Dataset

HDM05 [32] is a well-defined popular dataset that contains almost 2337 sequences with 130 motion classes performed by 5 different actors. The Vicon MX system with 12 high-resolution cameras was used to capture the motions at a sampling rate of 120 Hz. The ultimate 3D skeleton consists of 31 joints in total. We categorized the HDM05 dataset [32] into two groups according to the number of classes, as found in the literature, as follows.

HDM05-65: As stated in [18], most motion classes can be combined into one distinctive major motion class; e.g., shuffle2StepsLStart, shuffle2StepsRStart, shuffle4StepsLStart, shuffle4StepsRStart belong to the motion category shuffle; thus, they are represented as one motion class, i.e., shuffle. As a result, we came up with 65 motion classes, which are the same as those described in [18,19].

HDM05-14: This dataset, extracted from HDM05, consists of 14 motion classes: runOnPlace, shuffle, sneak, sitDownFloor, sitDownKnee, sitDownTable, skier, sitDownChair, squat, staircaseDown, staircaseUp, standUpSitChair, standUpLie.

4.1.2. CMU Dataset

Our second dataset is CMU [33], which is also considered a very popular dataset in the research community. The Vicon motion capture system, consisting of 12 infrared MX-40 cameras, recorded motions with a sampling rate of 120 Hz [33]. In the CMU dataset, the 3D skeleton also consists of 31 joints in total. We again categorized this dataset into two groups according to the number of classes as follows.

CMU-30: The dataset CMU-30 consists of 30 distinctive motion classes. It contains 278 labeled motion clips belonging to 30 different motion categories. A total of 33 different subjects participated in the recording of these motion clips, as mentioned in [37].

CMU-14: The dataset CMU-14 contains 14 motion classes: cartwheel, jump, pick, swing, balanceWalk, walkBackwardOnToes, run, hopOnLeftFoot, boxing, walk, getUpFromFloor, breastStroke, getUpFromChair, mickeyWalk.

4.2. Parameters

We evaluated the impact of the parameters involved in our proposed framework on the overall performance of our approach. We first tuned these parameters and ultimately fixed their values for the other experiments.

4.2.1. Threshold

For the performance assessment of our proposed keyframe extraction technique, we first adjusted the threshold value empirically. From the experiments, we observed that as we increased the threshold value, the error decreased up to a certain point and then started increasing again. We fixed the threshold value to t=30 for all other experiments; at this threshold, the system obtained the best results, as is quite obvious in Figure 3a. We also conducted another experiment to see the impact of the threshold value on the selection of the keyframes, i.e., how many frames can be eliminated from the motion by the selection of the threshold. The compression ratio increased with the increase in the threshold. More precisely, the number of selected keyframes was reduced when the threshold had higher values, as shown in Figure 3b.

Figure 3.

Figure 3

(a) Threshold tuning on different datasets. (b) The number of keyframes extracted through different threshold values for a variety of motions.

4.2.2. Deep Network

We developed and compared various deep neural network configurations in order to tune the number of hidden layers, as well as the number of neurons within a hidden layer. We performed experiments with one, two and three hidden layers and with varying numbers of neurons within a hidden layer in the deep neural network architecture. The overall impact of using a different number of layers with a different number of neurons can be seen in Table 1. Although the results obtained with just one hidden layer are significant, with an accuracy of 93.53%, the highest accuracy (95.14%) was achieved by employing two hidden layers in the deep network for the process of action recognition. From the experiments, we empirically concluded that the performance in terms of accuracy decreased when more than two hidden layers were exploited in the deep neural network. Similarly, increasing or decreasing the number of neurons beyond 85 for the first hidden layer and 80 for the second hidden layer diminished the performance of the network, as well. As a result, we stopped going deeper and fixed the two hidden layers with 85 and 80 neurons, respectively, with the sigmoid activation function. For the output layer, we employed the softmax activation function in our proposed deep neural network architecture. The input provided to our deep network almost has low dimensionality (31×3), and the maximum action classes are just only 65 in total in case of HDM05 dataset; as a result, we obtained promising results with two hidden layers only.

Table 1.

Deep neural network performance with varying numbers of neurons within a hidden layer, as well as with different numbers of hidden layers.

Input Layer Hidden Layer 1 Hidden Layer 2 Hidden Layer 3 Output Layer Accuracy (%)
93 75 - - 65 89.55%
93 100 - - 65 90.54%
93 125 - - 65 91.04%
93 150 - - 65 92.53%
93 175 - - 65 92.53%
93 200 - - 65 93.03%
93 225 - - 65 93.53%
93 250 - - 65 93.53%
93 275 - - 65 93.03%
93 300 - - 65 93.03%
93 75 75 - 65 91.54%
93 75 80 - 65 91.54%
93 75 85 - 65 92.04%
93 75 90 - 65 92.04%
93 80 75 - 65 92.04%
93 80 80 - 65 93.53%
93 80 85 - 65 93.53%
93 80 90 - 65 93.03%
93 85 75 - 65 92.53%
93 85 80 - 65 95.14%
93 85 85 - 65 93.53%
93 85 90 - 65 93.53%
93 90 75 - 65 92.04%
93 90 80 - 65 94.53%
93 90 85 - 65 92.53%
93 90 90 - 65 92.04%
93 85 80 75 65 93.53%
93 85 80 80 65 94.03%
93 85 80 85 65 94.03%
93 85 80 90 65 93.53%

4.3. Comparison with State-of-the-Art Methods

4.3.1. Keyframes

We evaluated our proposed keyframe extraction approach by carrying out different types of experiments. We first examined how the keyframes affected the accuracy of action recognition. We performed a comparison between scenarios in which (i) we employed all the frames available in the motion category for the process of action recognition; (ii) only the keyframes extracted through our proposed Algorithm 1 were used in the process of action recognition; and (iii)–(iv) the keyframes were selected randomly with varying sizes: i.e., ξf, the number of keyframes with a size equal to the number of keyframes extracted through Algorithm 1, and ξf, the number of keyframes with a size that was double the number of keyframes extracted through Algorithm 1. Moreover, we adapted a 10-fold cross-validation procedure for the random selection of the keyframes. The results presented in Table 2 demonstrate that our proposed Algorithm 1 obtained the best results in terms of accuracy as compared with the other models mentioned above for different motion categories.

Table 2.

A comparison between scenarios in which (i) all the original frames in the specified motion are utilized in the process of action recognition, (ii) only the keyframes extracted through Algorithm 1 are employed in the process of action recognition, (iii) ξf keyframes selected randomly are used, and (iv) ξf keyframes selected randomly are used.

Motions (i) All Frames (ii) Keyframes (iii) (ξf) (iv) (ξf)
Frames Acc. Frames Acc. Frames Acc. Frames Acc.
standUpLie 327 50% 93 100% 93 40% 186 50%
lieDownFloor 277 50% 81 100% 81 50% 162 50%
throwStandingHighR 239 66.66% 98 100% 98 69.97% 196 66.66%
standUpSitChair 172 50% 31 100% 31 55% 62 50%
grabMiddleR 151 66.66% 35 100% 35 59.99% 70 69.94%
depositMiddleR 142 100% 20 100% 20 70% 40 100%
sitDownTable 117 50% 11 100% 11 55% 22 40%
standUpSitTable 177 100% 24 100% 24 90% 48 80%
grabLowR 186 66.66% 47 66.66% 47 43.32% 94 39.97%
turnLeft 145 100% 29 100% 29 79.99% 58 100%
punchLFront 226 100% 77 100% 77 85% 154 97.75%
sitDownFloor 159 100% 54 100% 54 75% 108 100%
depositLowR 224 33.33% 52 33.33% 52 33.33% 104 33.33%
squat 536 100% 89 100% 89 98.57% 178 100%
elbowToKnee 409 100% 162 100% 162 100% 324 100%

Our next experiment determined how many keyframes were extracted for a variety of motion categories and how much processing time was required for the extraction of these frames. The overall results for different motion categories are shown in Figure 4. For example, for the walk motion class, the number of frames was reduced from 82 to 13; similarly, for the motion class sitDownFloor, the number of frames was reduced from 115 to 32, etc. The processing time required for the extraction of each keyframe was approximately 0.062 seconds. Further details about the processing time are available in Section 4.3.3.

Figure 4.

Figure 4

A comparison in terms of the number of frames between the keyframes extracted through Algorithm 1 against the original total number of frames for different types of motions. The processing time for the extraction of keyframes (seconds/frame) is also reported.

We also assessed our keyframe extraction approach qualitatively, and we show the results in Figure 5, where the actual frames in the motion class and the keyframes extracted through our proposed Algorithm 1 are visualized. For example, there are 31 original frames in the motion category jogOnPlace and 32 frames in the jumpingJack motion; for the two motion classes, 11 and 12 keyframes were extracted, respectively, which have most of the information about the motion, as evident in Figure 5.

Figure 5.

Figure 5

Qualitative results for our proposed keyframe extraction Algorithm 1 for the motion categories (a) jogOnPlace and (b) jumpingJack. The extracted keyframes are shown in boxes and also visualized separately to show a clear view.

From these experimental results, we conclude that extracting a few informative frames through the proposed keyframe method, rather than using all the frames of a motion sequence, is sufficient to recognize the action accurately. Moreover, our keyframe extraction approach improves the accuracy of action recognition by using a few informative frames rather than exhausting all the existing frames of the motions.

4.3.2. Action Recognition

We finally evaluated our proposed framework for action recognition and performed extensive experiments on the benchmark MoCap datasets CMU [33] and HDM05 [32], which were further categorized into four groups of datasets, HDM05-65, HDM05-14, CMU-30, and CMU-14, as mentioned in Section 4.1. We discuss all the results separately in detail as follows.

Evaluation on HDM05-65

In the case of the HDM05-65 dataset with 65 motion classes, we followed the same experimental protocol as that proposed in [18,19]. For this dataset, our approach achieved competitive results, with 95.14% accuracy, in comparison with other techniques. Although our approach did not outperform comparatively, it still produced competitive and very promising results. Our approach with deep neural network architecture performed better as compared with other popular classifiers, including Support Vector Machine (SVM), Multi-layer perceptron (MLP), Extreme Learning Machine [18], Convolutional Neural Network (CNN) [1], Deep Bidirectional Recurrent Neural Network (DBRNN-T) [19] with the tanh activation function, and Deep Unidirectional Recurrent Neural Network (DBRNN-T) [19] with the tanh activation function on the same HDM05-65 dataset. The Hierarchical Bidirectional Recurrent Neural Network (HBRNN-L) [19] with Long-Short Term Memory (LSTM) had the highest accuracy. Other RNN variants, such as the Hierarchical Unidirectional Recurrent Neural Network (HURNN-L) [19] with LSTM, Deep Bidirectional Recurrent Neural Network (DBRNN-L) [19] with LSTM, and Deep Unidirectional Recurrent Neural Network (DURNN-L) [19] with LSTM, also produced results with high accuracies, but there was very little marginal difference in accuracy in comparison with our proposed approach, as observed in Table 3. Moreover, our proposed deep neural network architecture is a comparatively simple architecture with less complexity. On the other hand, all the different categories of recurrent neural networks proposed in [19] consist of a large network structure with feedback connections, where the previous layer with a node influences itself to form a loop and ultimately leads towards high complexity.

Table 3.

Comparison with other state-of-the-art methods on the datasets HDM05-65, HDM05-14, CMU-30, and CMU-14. The results are presented in top-down order. The results using our approach are shown in bold text. * The CMU dataset with 14 classes was used, as well as the dataset recorded with their own Vicon (http://www.vicon.com/) motion capture device. Note: Normalized Trajectories (NT), relative positions of joints (PO), Temporal Differences (TD), Tree Structure Vector Quantized (TSVQ), Hierarchically Bidirectional Recurrent Neural Network with Long-Short Term Memory (LSTM) (HBRNN-L). For more details, see Section 2 and Section 4.3.2.

Dataset Approach Algorithm Features Training Accuracy
HDM05-65 Du et al. [19] HBRNN-L NT 90% 96.90%
HURNN-L NT 96.70%
DBRNN-L NT 96.70%
DURNN-L NT 96.62%
Cho et al. [18] Hybrid MLP (λ=0.5) PO+TD 95.59%
Hybrid MLP (λ=0.9) PO+TD 95.55%
Hybrid MLP (λ=0.1) PO+TD 95.46%
Hybrid MLP (λ=0.1) PO+TD+NT 95.21%
MLP PO+TD 95.20%
Our approach DNN NT+Keyframes 95.14%
Cho et al. [18] SVM PO+TD+NT 95.12%
Hybrid MLP (λ=0.9) PO+TD+NT 95.04%
SVM PO+TD 94.95%
MLP PO+TD+NT 94.86%
Hybrid MLP (λ=0.5) PO+TD+NT 94.82%
Du et al. [19] DBRNN-T NT 94.79%
DURNN-T NT 94.63%
Sedmidubsky et al. [1] CNN+KNN NT 93.9%
Cho et al. [18] ELM PO+TD+NT 92.76%
ELM PO+TD 91.57%
HDM05-14 Our approach DNN NT+Keyframes 50% 98.6%
Sedmidubsky et al. [1] CNN+KNN NT 94.3%
Elias et al. [62] CNN+KNN NT 87.4%
CMU-30 Kadu and Kuo [37] Two-Step SVM Fusion TSVQ 80% 99.6%
Our approach DNN NT+Keyframes 99.3%
Kadu and Kuo [37] Two-Step Score Fusion TSVQ 98.2%
Pose-Histogram Classifier B-PL04 95.6%
B-PL06 95.6%
Motion-String Similarity A-SL12 95.6%
A-SL13 95.6%
Pose-Histogram Classifier B-PL05 95.3%
B-PL03 92.8%
Motion-String Similarity A-ML12 82.3%
A-ML13 80.5%
CMU-14 Our approach DNN NT+Keyframes 85% 98.5%
Wu et al. [44]* Hierarchical Tree 3D Trajectories 98.1%
Wu et al. [48]* Smith–Waterman 3D Trajectories 97.0%

The confusion matrix for HDM05-65, presented in Figure 6, shows that our proposed framework performed well on almost all types of motion. The few motion categories for which our approach did not perform significantly well are the depositLow and grabLow motions. Since both of these motion categories are very similar to each other, our approach misclassified them: e.g., the motion class grabLow was 33% misclassified as the motion depositLow, and alternatively, depositLow was 66% misclassified as the grabLow motion. As a result, the overall performance of our scheme decreased to 95.14% accuracy.

Figure 6.

Figure 6

Confusion matrix of our proposed approach on the HDM05-65 dataset.

Evaluation on HDM05-14

On the dataset HDM05-14 with 14 motion classes, our proposed scheme outperformed the other existing state-of-the-art approaches [1,62], and it achieved 98.6% accuracy. The addition of keyframes with Normalized Trajectories (NT) substantially contributed to the improved performance of our proposed framework, as is obvious in Table 3. The detailed version of the results of our approach on the HDM05-14 dataset in the form of a confusion matrix is presented in Figure 7. Although some of the actions were misclassified by our approach (sitDownFloor and standUpSitChair were misclassified; staircaseUp was misclassified as steak), our approach still performed significantly well.

Figure 7.

Figure 7

Confusion matrix of our proposed approach on the HDM05-14 dataset.

Evaluation on CMU-30

On the CMU-30 dataset, the results of our approach are outstanding as compared with other state-of-the-art methods (see Table 3). Although the method of two-step Support Vector Machine (SVM) fusion with Tree Structure Vector Quantized (TSVQ) [37] had the best results, our approach provided competitive results with an accuracy of 99.3% and outperformed other approaches, such as the Similarity Suffix Array, Pose-Histogram Classifier, and Two-Step Score Fusion [37]. All these results can be seen in detail in Table 4, where it is quite obvious that our approach only misclassified the bouncyWalk motion and achieved 99.3% accuracy, while the method of two-step SVM fusion with TSVQ [37] also misclassified the motion rhymeTeaPot and achieved 99.6% accuracy.

Table 4.

A detailed comparison between our approach and other state-of-the-art methods for all 30 motion classes on the CMU-30 dataset. Methods A-ML12 and A-ML13 refer to Max-parameter with Levels 12 and 13, while methods A-SL12 and A-SL13 refer to Sim-parameter with Levels 12 and 13 [37]. Methods B-PL03, B-PL04, B-PL05, and B-PL06 are the Pose histogram with Levels 03, 04, 05, and 06, respectively [37]. Methods C and D refer to Two-Step Score Fusion and Two-Step Support Vector Machine (SVM) Fusion, respectively [37].

Motion Categories A-ML12 A-ML13 A-SL12 A-SL13 B-PL03 B-PL04 B-PL05 B-PL06 (C) (D) Ours
run(27) 96% 96% 100% 96% 96% 100% 96% 96% 100% 100% 100%
walk(47) 85% 85% 97% 100% 97% 97% 97% 97% 100% 100% 100%
forwardJump(9) 88% 88% 88% 100% 88% 88% 77% 100% 100% 100% 100%
forwardDribble(5) 100% 100% 100% 100% 100% 100% 100% 100% 100% 100% 100%
cartWheel(5) 100% 100% 100% 100% 100% 100% 100% 100% 100% 100% 100%
kickball(6) 100% 100% 100% 100% 83% 83% 83% 83% 100% 100% 100%
boxing(7) 0% 0% 85% 100% 100% 100% 100% 100% 100% 100% 100%
mickeyWalk(7) 100% 100% 100% 100% 85% 100% 100% 100% 100% 100% 100%
sitAndStandUp(5) 80% 80% 100% 100% 100% 100% 100% 80% 100% 100% 100%
laugh(6) 66% 100% 100% 100% 100% 100% 100% 100% 100% 100% 100%
sweepFloor(5) 40% 40% 100% 100% 80% 100% 100% 100% 100% 100% 100%
washWindows(5) 640% 60% 100% 100% 100% 100% 100% 100% 100% 100% 100%
climbLadder(5) 100% 100% 100% 100% 100% 100% 100% 100% 100% 100% 100%
steps(7) 57% 85% 100% 100% 100% 100% 100% 100% 100% 100% 100%
eating(5) 100% 100% 100% 100% 100% 100% 100% 100% 100% 100% 100%
tiptoe(5) 100% 60% 100% 100% 100% 100% 100% 100% 100% 100% 100%
pickBoxBendWaist(6) 100% 100% 83% 100% 83% 83% 100% 100% 100% 100% 100%
limp(5) 100% 80% 100% 100% 100% 100% 100% 100% 100% 100% 100%
balancingWalk(12) 83% 75% 100% 100% 83% 100% 91% 91% 100% 100% 100%
getUpFromChair(5) 80% 80% 100% 80% 80% 100% 100% 60% 100% 100% 100%
breastStroke(6) 50% 16% 83% 83% 100% 100% 83% 83% 83% 100% 100%
hopOnLeftFoot(6) 66% 100% 100% 100% 100% 83% 100% 100% 100% 100% 100%
bouncyWalk(6) 66% 66% 100% 100% 50% 66% 83% 100% 100% 100% 75%
marching(10) 100% 100% 100% 90% 100% 100% 100% 100% 100% 100% 100%
rhymeTeaPot(16) 81% 81% 75% 75% 75% 87% 87% 87% 75% 93% 100%
rhymeCockRobin(10) 60% 40% 86% 86% 93% 86% 80% 100% 100% 100% 100%
swing(10) 100% 100% 90% 100% 100% 100% 100% 100% 100% 100% 100%
placingTee(5) 100% 100% 100% 80% 80% 80% 100% 80% 100% 100% 100%
salsaDance(15) 86% 73% 100% 95% 100% 100% 100% 100% 100% 100% 100%
getUpFromFloor(10) 80% 80% 100% 100% 80% 100% 100% 80% 100% 100% 100%
Total(278) 82.3% 80.5% 95.6% 95.6% 92.8% 95.6% 95.3% 95.6% 98.2% 99.6% 99.3%

The confusion matrix in Figure 8 provides a detailed description of the results of our approach on the CMU-30 dataset. All the motion classes were correctly classified except bouncyWalk, which was misclassified as the motion boxing.

Figure 8.

Figure 8

Confusion matrix of our proposed approach on the CMU-30 dataset.

Evaluation on CMU-14

On the CMU-14 MoCap dataset, we compared our approach with [44,48]. These methods use the CMU MoCap dataset, as well as their own dataset with 14 classes, recorded by utilizing a Vicon (http://www.vicon.com/) motion capture device, while we conducted experiments on only the CMU-14 MoCap dataset. Our proposed scheme outperformed both approaches in [44,48] and obtained 98.5% accuracy on the CMU-14 dataset. In this case, we employed 85% of the training data for training purposes. From the detailed analysis presented in Table 3 and in Figure 9, we observe that out of 14 motion classes, only one motion class, walkBackwardsOnToes, was misclassified as the walk motion category.

Figure 9.

Figure 9

Confusion matrix of our proposed approach on the CMU-14 dataset.

4.3.3. Processing Time

We conducted our experiments on a Core I7 with 8GB RAM and a Windows operating system. The proposed keyframe extraction methods took approximately 0.062 seconds to extract keyframes from a motion of 60 frames. The input query motion took roughly 0.0085 seconds per frame for action recognition. More precisely, the overall time for feature extraction, as well as action recognition, was ∼0.0095 seconds per frame.

4.4. Discussion

We evaluated our proposed method extensively on different types and sizes of MoCap datasets. From the experimental results described in Table 3 and Table 4, our proposed algorithm performs comparatively well. We observe that our approach not only classifies the distinct action classes very accurately, e.g., cartwheel, walk, jumpingJack, and clap, but also correctly classifies most of the similar action classes, e.g., turnLeft vs. turnRight, jogLeftCircle vs. jogRightCircle, jogOnPlace vs. runOnPlace, walkLeftCircle vs. walkRightCircle, kickLSide vs. kickRSide and punchLFront vs. punchRFront. The few motion categories that are misclassified are immensely similar to each other: depositHighR is misclassified as grabHighR, and depositLowR is misclassified as grabLowR. In a few cases in which the action is the combination of a sequence of atomic movements that are further shared among different classes, our keyframe-based approach might mislead: e.g., sitDownTable is misclassified as standUpSitTable, and the majority of the keyframes extracted from standUpSitTable belong to the subclass SitTable, and, as a result, the sitDownTable class is predicted. Short, single actions with multiple classes, such as standUpSitTable, may create ambiguity for our proposed method.

Our proposed approach is data-driven, and it performs well enough when at least a few similar action poses of the input action are available in the MoCap dataset; the performance may deteriorate when a similar input motion is not available in the MoCap dataset. Our proposed method is fast enough with a short latency (∼0.0095 seconds per frame), which is a crucial requirement for real-time online systems. Because our approach is keyframe-dependent, it has the capacity to compensate for missing information, as well.

5. Conclusions

In this paper, we present a novel action recognition schema that relies on keyframes extracted from action sequences. The extracted keyframes enhance the process by providing information that is free from redundancy but carries the most relevant details about the action that exists in the motion. We conducted a variety of experiments to evaluate the keyframe extraction results, and we concluded that a few but significant information-carrying frames, rather than all frames with redundant information, are sufficient. We started with the normalization of 3D poses and extract joint features, on the basis of which we constituted our proposed deep neural network. We empirically configured the number of hidden layers, as well as the number of units within a hidden layer, by carrying out several experiments. We conclude from these experiments that, in our case, two hidden layers with 85 and 80 neurons are adequate to get substantial results. Finally, for thorough and detailed performance evaluations, we worked on four different datasets with varying numbers of motion categories, i.e., HDM05-65, HDM05-14, CMU-30, and CMU-14. On the HDM05 dataset, our proposed framework comparatively produced very competitive results, with 95.14% accuracy on HDM05-65 and 98.6% accuracy on the HDM05-14 dataset. On the CMU dataset, our proposed approach outperformed other techniques, with 98.5% accuracy on the CMU-14 dataset and 99.3% accuracy on the CMU-30 dataset. Furthermore, our approach has satisfactory efficiency in terms of time, as well. It takes roughly 0.0095 seconds per frame to recognize the action.

In future work, the proposed framework may be extended to perform action recognition and motion segmentation simultaneously. Furthermore, the proposed method for action classification can be coupled with gait analysis and person identification. Another important direction might be the integration of action recognition and pose estimation together in 3D-3D, 2D-3D, and 3D-2D scenarios. To date, we have worked only with action classes that are performed by a single person, and this approach can be extended to multiple persons interacting with each other.

Author Contributions

Conceptualization, H.Y.; data normalization and annotation, H.Y.; methodology—design and implementation, H.Y. and M.H.; experiments—design, evaluation and investigation, H.Y. and M.H.; writing—original draft preparation, H.Y., M.H. and A.W.; writing—review and editing, H.Y and A.W. All authors have read and agreed to the published version of the manuscript.

Funding

This research received no external funding.

Conflicts of Interest

The authors declare no conflict of interest.

References

  • 1.Sedmidubsky J., Elias P., Zezula P. Effective and efficient similarity searching in motion capture data. Multimed. Tools Appl. 2018;77:12073–12094. doi: 10.1007/s11042-017-4859-7. [DOI] [Google Scholar]
  • 2.An K.N., Jacobsen M., Berglund L., Chao E. Application of a magnetic tracking device to kinesiologic studies. J. Biomech. 1988;21:613–620. doi: 10.1016/0021-9290(88)90225-4. [DOI] [PubMed] [Google Scholar]
  • 3.VICONPEAK Camera MX 40. [(accessed on 27 January 2020)]; Available online: http://www.vicon.com/products/mx40.html.
  • 4.PHASE SPACE INC Impulse Camera. [(accessed on 27 January 2020)]; Available online: http://www.phasespace.com.
  • 5.Liu Y., Zhang X., Cui J., Wu C., Aghajan H., Zha H. Visual analysis of child-adult interactive behaviors in video sequences; Proceedings of the 2010 16th International Conference on Virtual Systems and Multimedia; Seoul, Korea. 20–23 October 2010; pp. 26–33. [Google Scholar]
  • 6.Raskar R., Nii H., deDecker B., Hashimoto Y., Summet J., Moore D., Zhao Y., Westhues J., Dietz P., Barnwell J., et al. Prakash: Lighting Aware Motion Capture Using Photosensing Markers and Multiplexed Illuminators. ACM Trans. Graph. 2007;26:36. doi: 10.1145/1276377.1276422. [DOI] [Google Scholar]
  • 7.XSENS Inertial Sensors. [(accessed on 25 November 2019)]; Available online: http://www.xsens.com.
  • 8.Lu Y., Wei Y., Liu L., Zhong J., Sun L., Liu Y. Towards unsupervised physical activity recognition using smartphone accelerometers. Multimed. Tools Appl. 2017;76:10701–10719. doi: 10.1007/s11042-015-3188-y. [DOI] [Google Scholar]
  • 9.Vlasic D., Adelsberger R., Vannucci G., Barnwell J., Gross M., Matusik W., Popović J. Practical Motion Capture in Everyday Surroundings. ACM Trans. Graph. 2007;26:35. doi: 10.1145/1276377.1276421. [DOI] [Google Scholar]
  • 10.Yasin H., Iqbal U., Krüger B., Weber A., Gall J. A Dual-Source Approach for 3D Pose Estimation from a Single Image; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Las Vegas, NV, USA. 26 June–1 July 2016. [Google Scholar]
  • 11.Wang C., Wang Y., Lin Z., Yuille A.L., Gao W. Robust Estimation of 3D Human Poses from a Single Image; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Columbus, OH, USA. 24–27 June 2014. [Google Scholar]
  • 12.Dantone M., Leistner C., Gall J., Van Gool L. Body Parts Dependent Joint Regressors for Human Pose Estimation in Still Images. IEEE Trans. Pattern Anal. Mach. Intell. 2014;36:2131–2143. doi: 10.1109/TPAMI.2014.2318702. [DOI] [PubMed] [Google Scholar]
  • 13.Yasin H., Krüger B., Weber A. Model based Full Body Human Motion Reconstruction from Video Data; Proceedings of the 6th International Conference on Computer Vision/Computer Graphics Collaboration Techniques and Applications; Berlin, Germany. 6–7 June 2013. [Google Scholar]
  • 14.Simo-Serra E., Ramisa A., Alenyà G., Torras C., Moreno-Noguer F. Single Image 3D Human Pose Estimation from Noisy Observations; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Rhode Island, RI, USA. 18–20 June 2012. [Google Scholar]
  • 15.Tautges J., Zinke A., Krüger B., Baumann J., Weber A., Helten T., Müller M., Seidel H.P., Eberhardt B. Motion reconstruction using sparse accelerometer data. ACM Trans. Graph. 2011;30:1–12. doi: 10.1145/1966394.1966397. [DOI] [Google Scholar]
  • 16.Riaz Q., Guanhong T., Krüger B., Weber A. Motion Reconstruction Using Very Few Accelerometers and Ground Contacts. Graph. Models. 2015;79:23–38. doi: 10.1016/j.gmod.2015.04.001. [DOI] [Google Scholar]
  • 17.Wang L., Huynh D.Q., Koniusz P. A Comparative Review of Recent Kinect-Based Action Recognition Algorithms. IEEE Trans. Image Process. 2020;29:15–28. doi: 10.1109/TIP.2019.2925285. [DOI] [PubMed] [Google Scholar]
  • 18.Cho K., Chen X. Classifying and visualizing motion capture sequences using deep neural networks; Proceedings of the 2014 International Conference on Computer Vision Theory and Applications (VISAPP); Lisbon, Portugal. 5–8 January 2014; pp. 122–130. [Google Scholar]
  • 19.Du Y., Wang W., Wang L. Hierarchical recurrent neural network for skeleton based action recognition; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Boston, MA, USA. 7–12 June 2015; pp. 1110–1118. [Google Scholar]
  • 20.Ke Q., An S., Bennamoun M., Sohel F.A., Boussaïd F. SkeletonNet: Mining Deep Part Features for 3-D Action Recognition. IEEE Signal Process. Lett. 2017;24:731–735. doi: 10.1109/LSP.2017.2690339. [DOI] [Google Scholar]
  • 21.Lv N., Feng Z., Ran L., Zhao X. Action recognition of motion capture data; Proceedings of the 2014 7th International Congress on Image and Signal Processing; Dalian, China. 14–16 October 2014; pp. 22–26. [Google Scholar]
  • 22.Gong D., Medioni G., Zhao X. Structured Time Series Analysis for Human Action Segmentation and Recognition. IEEE Trans. Pattern Anal. Mach. Intell. 2014;36:1414–1427. doi: 10.1109/TPAMI.2013.244. [DOI] [PubMed] [Google Scholar]
  • 23.Kim H., Kim I. Human Activity Recognition as Time-Series Analysis. Math. Probl. Eng. 2015;2015:1–9. doi: 10.1155/2015/676090. [DOI] [Google Scholar]
  • 24.Li K., Fu Y. Prediction of Human Activity by Discovering Temporal Sequence Patterns. IEEE Trans. Pattern Anal. Mach. Intell. 2014;36:1644–1657. doi: 10.1109/TPAMI.2013.2297321. [DOI] [PubMed] [Google Scholar]
  • 25.Yang X., Tian Y. EigenJoints-based action recognition using Naïve-Bayes-Nearest-Neighbor; Proceedings of the 2012 IEEE Computer Society Conference on Computer Vision and Pattern Recognition Workshops; Providence, RI, USA. 16–21 June 2012; pp. 14–19. [Google Scholar]
  • 26.Vemulapalli R., Arrate F., Chellappa R. Human Action Recognition by Representing 3D Skeletons as Points in a Lie Group; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Columbus, OH, USA. 24–27 June 2014; pp. 588–595. [Google Scholar]
  • 27.Ke Q., Bennamoun M., An S., Sohel F., Boussaid F. A new representation of skeleton sequences for 3D action recognition; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Honolulu, HI, USA. 22–25 July 2017; pp. 4570–4579. [Google Scholar]
  • 28.Kapsouras I., Nikolaidis N. Action recognition on motion capture data using a dynemes and forward differences representation. J. Vis. Commun. Image Represent. 2014;25:1432–1445. doi: 10.1016/j.jvcir.2014.04.007. [DOI] [Google Scholar]
  • 29.Koniusz P., Cherian A., Porikli F. Tensor Representations via Kernel Linearization for Action Recognition from 3D Skeletons; Proceedings of the European Conference on Computer Vision; Amsterdam, The Netherlands. 11–14 October 2016; pp. 37–53. [Google Scholar]
  • 30.Yan S., Xiong Y., Lin D. Spatial Temporal Graph Convolutional Networks for Skeleton-Based Action Recognition; Proceedings of the Thirty-Second AAAI Conference on Artificial Intelligence; New Orleans, LA, USA. 2–7 February 2018; pp. 7444–7452. [Google Scholar]
  • 31.Amor B.B., Su J., Srivastava A. Action Recognition Using Rate-Invariant Analysis of Skeletal Shape Trajectories. IEEE Trans. Pattern Anal. Mach. Intell. 2016;38:1–13. doi: 10.1109/TPAMI.2015.2439257. [DOI] [PubMed] [Google Scholar]
  • 32.Müller M., Röder T., Clausen M., Eberhardt B., Krüger B., Weber A. Documentation Mocap Database HDM05. Universität Bonn; Bonn, Germany: 2007. Technical Report CG-2007-2. [Google Scholar]
  • 33.CMU CMU Motion Capture Database. [(accessed on 20 September 2019)]; Available online: http://mocap.cs.cmu.edu/
  • 34.Wu Q., Xu G., Chen L., Luo A., Zhang S. Human action recognition based on kinematic similarity in real time. PLoS ONE. 2017;12:e0185719. doi: 10.1371/journal.pone.0185719. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 35.Laraba S., Brahimi M., Tilmanne J., Dutoit T. 3D skeleton-based action recognition by representing motion capture sequences as 2D-RGB images. Comput. Animat. Virtual Worlds. 2017;28:e1782. doi: 10.1002/cav.1782. [DOI] [Google Scholar]
  • 36.Slama R., Wannous H., Daoudi M., Srivastava A. Accurate 3D Action Recognition Using Learning on the Grassmann Manifold. Pattern Recogn. 2015;48:556–567. doi: 10.1016/j.patcog.2014.08.011. [DOI] [Google Scholar]
  • 37.Kadu H., Kuo C.C.J. Automatic human mocap data classification. IEEE Trans. Multimed. 2014;16:2191–2202. doi: 10.1109/TMM.2014.2360793. [DOI] [Google Scholar]
  • 38.Moussa M.M., Hemayed E.E., El Nemr H.A., Fayek M.B. Human action recognition utilizing variations in skeleton dimensions. Arab. J. Sci. Eng. 2018;43:597–610. doi: 10.1007/s13369-017-2694-9. [DOI] [Google Scholar]
  • 39.Vantigodi S., Babu R.V. Real-time human action recognition from motion capture data; Proceedings of the Fourth National Conference on Computer Vision, Pattern Recognition, Image Processing and Graphics (NCVPRIPG); Jodhpur, India. 18–21 December 2013; pp. 1–4. [Google Scholar]
  • 40.Hussein M.E., Torki M., Gowayyed M.A., El-Saban M. Human Action Recognition Using a Temporal Hierarchy of Covariance Descriptors on 3D Joint Locations; Proceedings of the Twenty-Third International Joint Conference on Artificial Intelligence; Beijing, China. 3–9 August 2013; pp. 2466–2472. [Google Scholar]
  • 41.Talha S.A.W., Fleury A., Ambellouis S. Human Action Recognition from Body-Part Directional Velocity Using Hidden Markov Models; Proceedings of the 16th IEEE International Conference on Machine Learning and Applications (ICMLA); Cancun, Mexico. 18–21 December 2017; pp. 1035–1040. [Google Scholar]
  • 42.Liang Y., Lu W., Liang W., Wang Y. Action recognition using local joints structure and histograms of 3d joints; Proceedings of the Tenth International Conference on Computational Intelligence and Security; Kunming, China. 15–16 November 2014; pp. 185–188. [Google Scholar]
  • 43.Ko C.H., Li J.Y., Lu T.C. Automatic Key-frames Extraction of Humanoid Motions. J. Technol. 2017;32:39–47. [Google Scholar]
  • 44.Wu S., Wang Z., Xia S. Indexing and retrieval of human motion data by a hierarchical tree; Proceedings of the 16th ACM Symposium on Virtual Reality Software and Technology; Kyoto, Japan. 18–20 November 2009; pp. 207–214. [Google Scholar]
  • 45.Xiao Q., Song R. Human motion retrieval based on statistical learning and bayesian fusion. PLoS ONE. 2016;11:e0164610. doi: 10.1371/journal.pone.0164610. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 46.Yang X., Tian Y. Effective 3d action recognition using eigenjoints. J. Visual Commun. Image Represent. 2014;25:2–11. doi: 10.1016/j.jvcir.2013.03.001. [DOI] [Google Scholar]
  • 47.Kovar L., Gleicher M. Automated extraction and parameterization of motions in large data sets. ACM Trans. Graph. 2004;23:559–568. doi: 10.1145/1015706.1015760. [DOI] [Google Scholar]
  • 48.Wu S., Xia S., Wang Z., Li C. Efficient motion data indexing and retrieval with local similarity measure of motion strings. Vis. Comput. 2009;25:499–508. doi: 10.1007/s00371-009-0345-1. [DOI] [Google Scholar]
  • 49.Barnachon M., Bouakaz S., Boufama B., Guillou E. Ongoing human action recognition with motion capture. Pattern Recognit. 2014;47:238–247. doi: 10.1016/j.patcog.2013.06.020. [DOI] [Google Scholar]
  • 50.Baumann J., Wessel R., Krüger B., Weber A. Action graph a versatile data structure for action recognition; Proceedings of the 2014 International Conference on Computer Graphics Theory and Applications (GRAPP); Lisbon, Portugal. 5–8 January 2014; pp. 1–10. [Google Scholar]
  • 51.Xia L., Chen C., Aggarwal J.K. View invariant human action recognition using histograms of 3D joints; Proceedings of the 2012 IEEE Computer Society Conference on Computer Vision and Pattern Recognition Workshops; Providence, RI, USA. 16–21 June 2012; pp. 20–27. [Google Scholar]
  • 52.Ofli F., Chaudhry R., Kurillo G., Vidal R., Bajcsy R. Sequence of the Most Informative Joints (SMIJ) J. Vis. Commun. Image Represent. 2014;25:24–38. doi: 10.1016/j.jvcir.2013.04.007. [DOI] [Google Scholar]
  • 53.Lillo I., Soto A., Niebles J.C. Discriminative Hierarchical Modeling of Spatio-Temporally Composable Human Activities; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Columbus, OH, USA. 24–27 June 2014; pp. 812–819. [Google Scholar]
  • 54.Hinton G., Deng L., Yu D., Dahl G.E., Mohamed A.r., Jaitly N., Senior A., Vanhoucke V., Nguyen P., Sainath T.N., et al. Deep neural networks for acoustic modeling in speech recognition. IEEE Signal Process Mag. 2012;29:82–97. doi: 10.1109/MSP.2012.2205597. [DOI] [Google Scholar]
  • 55.Liu J., Akhtar N., Mian A. Skepxels: Spatio-temporal Image Representation of Human Skeleton Joints for Action Recognition; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR) Workshops; Long Beach, CA, USA. 16–20 June 2019. [Google Scholar]
  • 56.Ijjina E.P., Mohan C.K. Human action recognition based on motion capture information using fuzzy convolution neural networks; Proceedings of the Eighth International Conference on Advances in Pattern Recognition (ICAPR); Kolkata, India. 4–7 January 2015; pp. 1–6. [Google Scholar]
  • 57.Pham H.H., Salmane H., Khoudour L., Crouzil A., Zegers P., Velastin S.A. Spatio-Temporal Image Representation of 3D Skeletal Movements for View-Invariant Action Recognition with Deep Convolutional Neural Networks. Sensors. 2019;19:1932. doi: 10.3390/s19081932. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 58.Liu J., Shahroudy A., Xu D., Wang G. Spatio-Temporal LSTM with Trust Gates for 3D Human Action Recognition; Proceedings of the 14th European Conference on Computer Vision; Amsterdam, The Netherlands. 11–14 October 2016. [Google Scholar]
  • 59.Zhang S., Liu X., Xiao J. On Geometric Features for Skeleton-Based Action Recognition Using Multilayer LSTM Networks; Proceedings of the 2017 IEEE Winter Conference on Applications of Computer Vision (WACV); Santa Rosa, CA, USA. 24–31 March 2017; pp. 148–157. [Google Scholar]
  • 60.Veeriah V., Zhuang N., Qi G.J. Differential Recurrent Neural Networks for Action Recognition; Proceedings of the 2015 IEEE International Conference on Computer Vision (ICCV); Santiago, Chile. 13–16 December 2015; pp. 4041–4049. [Google Scholar]
  • 61.Tang Y., Tian Y., Lu J., Li P., Zhou J. Deep Progressive Reinforcement Learning for Skeleton-Based Action Recognition; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR); Salt Lake City, UT, USA. 18–22 June 2018. [Google Scholar]
  • 62.Elias P., Sedmidubsky J., Zezula P. Motion images: An effective representation of motion capture data for similarity search; Proceedings of the International Conference on Similarity Search and Applications; Glasgow, UK. 12–14 October 2015; pp. 250–255. [Google Scholar]

Articles from Sensors (Basel, Switzerland) are provided here courtesy of Multidisciplinary Digital Publishing Institute (MDPI)

RESOURCES