Next Article in Journal
Energy Efficient Real-Time Scheduling Using DPM on Mobile Sensors with a Uniform Multi-Cores
Previous Article in Journal
Optimal Multi-Type Sensor Placement for Structural Identification by Static-Load Testing
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Centralized Networks to Generate Human Body Motions

1
Institute for Mechanical Engineering Problems, 195251 Saint Petersburg, Russia
2
Mechanics and Optics, Saint Petersburg National Research University of Information Technologies, 191119 Saint Petersburg, Russia
3
DIMNP-UMR 5235 CNRS/UM, University of Montpellier, 34095 Montpellier, France
4
Computer Science Department, University of Bonn, 53113 Bonn, Germany
*
Author to whom correspondence should be addressed.
Sensors 2017, 17(12), 2907; https://doi.org/10.3390/s17122907
Submission received: 15 September 2017 / Revised: 10 December 2017 / Accepted: 11 December 2017 / Published: 14 December 2017
(This article belongs to the Section Sensor Networks)

Abstract

:
We consider continuous-time recurrent neural networks as dynamical models for the simulation of human body motions. These networks consist of a few centers and many satellites connected to them. The centers evolve in time as periodical oscillators with different frequencies. The center states define the satellite neurons’ states by a radial basis function (RBF) network. To simulate different motions, we adjust the parameters of the RBF networks. Our network includes a switching module that allows for turning from one motion to another. Simulations show that this model allows us to simulate complicated motions consisting of many different dynamical primitives. We also use the model for learning human body motion from markers’ trajectories. We find that center frequencies can be learned from a small number of markers and can be transferred to other markers, such that our technique seems to be capable of correcting for missing information resulting from sparse control marker settings.

1. Introduction

In recent years, various neural network topologies have been used for recognizing and representing human body motions. In particular, the use of deep networks has been proposed [1,2] or of Long Short-Term Memory (LSTM) networks and their extensions [1,3,4]. Additionally, specialized architectures for human motions such as so-called “phase-functional networks” [5] have recently been proposed.
In this paper we advocate the use of another kind of network—the so-called centralized network [6]. Inspired by the success of these networks in neuroscience, genetics, and ecology [7,8,9,10,11,12,13], we consider centralized, continuous-time recurrent networks of an analogous topological structure as dynamical models for the simulation of human body motions.
Our method combines nonlinear oscillators, centralized architectures, and approximation by radial basis functions. All these ingredients are present in different fields in neuroscience, robotics, and machine learning, but to the best of our knowledge they have not yet been put together. Nonlinear oscillators were discovered as building blocks of locomotor neural circuits in animals, and similar designs were mimicked to control the movements of robots [14,15,16]. Although the idea of coupling oscillators to neural networks was successfully used to model gait transitions in cybernetic models [15,17], there is no systematic approach for learning complicated body movements from sensors data based on this idea. In order to do so, we use radial basis function networks—a popular general-purpose approximation method used in signal processing and system identification [18,19]. This machine learning technique has already been used in the context of locomotion, but for models different from ours [20]. The interest of our centralized architecture relating a few pacemaker hubs to satellite effectors is manifold. Beyond realism, it allows a robust control of body motions. The learning of the model can be decomposed into two parts. The first part is estimation of the pacemaker frequencies, which can be done using the signal from any effector or from a small group of randomly chosen effectors. The second part is also robust, being based on simple, two-layer, feed-forward radial basis function networks. Several extensions of this basic approach imply recursive networks. One of these extensions, based on a switching module with feedback, is discussed in the paper. Other extensions could consider couplings between oscillating nodes, directly or via satellite nodes. The interest in coupling lies in the possibility of synchronization, which has been shown to characterize gaits defined as collective nonlinear modes in the entire body [15,17].
Although to the best of our knowledge centralized networks have not directly been used in the context of human body motions, the widely considered dynamical movement primitives (DMPs) [21,22,23,24,25] share common grounds on a technical basis in several respects.
Our proposal not only relates the concept of DMPs to neural networks, but also generalizes and enhances their construction—for example, by transparently allowing more than one central oscillator and also incorporating switching while staying in the topological realm of centralized networks.
Our model allows us to sufficiently simulate long motions by only two oscillators. However, in some difficult cases (for example, if a motion consists of walking, running, kicking, punching, and knee kicking), we also decompose the whole motion into 2–4 segments and then for each segment we adjust the corresponding oscillator frequency. Then, the application of our approximation algorithm allows us to automatically obtain a uniform and smooth approximation of the whole motion. The use of 2–3 oscillators and 20–200 satellites has proven to be sufficient in our experiments.
Due to the network switching module we can use nonlinear oscillators and obtain a global network that can simulate a large class of different motions.
Our approach is trajectory-based, and works in principle on single marker trajectories independently of others. In this respect, our approach is similar to the DMP, but is in contrast to the Bayesian approaches presented in the literature, in which prior information has to be collected on the level of pose similarity using correlations of the positions of different body parts [26,27,28]. Our approach can be applied on the basis of a single motion and single trajectory, not requiring a database of collected motions as a priori knowledge.
The paper is organized as follows: In Section 2.1, we first give background on scale-free networks and centralized networks in Section 2.1.1. We define the centralized networks for elementary human motion in Section 2.1.2, and describe our approach to change frequencies, hence building centralized networks generating a large class of human body motions in Section 2.1.3. The idea of a switching module is detailed in Section 2.2. Algorithms to construct such networks to generate human body motions are given in Section 2.3—first for the case of non-segmented motions in Section 2.3.1, and then for the case of segmented motions in Section 2.3.2. A comparison of our approach with the DMPs is given in Section 2.4. Experimental results are presented in Section 3. In Section 4, we not only discuss the results in relation to previous and state-of-the-art methods, but we also give some directions for possible future works.

2. Materials and Methods

2.1. Network Structure

2.1.1. Background on Scale-Free Networks and Centralized Networks

Networks of dynamically coupled elements have imposed themselves as models of complex systems in physics, chemistry, biology, and engineering. An important structure-related property of networks is their scale-freeness [8,9,29,30], often invoked as a paradigm of self-organization, and the spontaneous emergence of complex collective behavior. In scale-free networks, the fraction P ( k ) of nodes in the network having k connections to other nodes (i.e., having degree k) can be estimated for large values of k as P ( k ) k γ , where γ is a parameter whose value is typically in the range 2 < γ < 3 [29]. In such networks, the degree is extremely heterogeneous. In particular, there are strongly connected nodes that can be named hubs, or centers. The hubs communicate to each other directly, or via a number of weakly connected nodes. The weakly connected nodes that interact mainly with hubs can be called satellites. Scale-free networks also have nodes of intermediate connectivity. Networks that have only two types of nodes—strongly connected hubs and weakly connected satellites—are known as bimodal degree networks [31]. Because of the presence of a large number of hubs, scale-free or bimodal degree networks can be called centralized.
It has been shown that centralized networks show a good compromise between robustness and flexibility. They are resilient with respect to external perturbations and are insensitive to noise, while remaining totally controllable [32,33,34]. Furthermore, centralized networks are universal approximate models, and can simulate any structurally stable dynamics [6,35,36]. Other interesting dynamical properties of centralized networks are related to their ability to switch, activating on turning the coordinated evolution of different sets of nodes. On one hand, this capacity is responsible for the “stable yet switchable” property, meaning that the network remains stable in a given context and is able to reach another stable state when a stimulus indicates a change in the context [6]. On the other hand, centralized networks can be itinerant; i.e., spontaneously changing their functioning mode [10].
The above dynamical properties of centralized networks have received particular attention in neuroscience, genetics, and ecology. Centralized connectivity has been found by functional imaging of brain activity in neuroscience [7], and also by large-scale studies of protein–protein interactions or of metabolic networks in functional genetics [8,9]. Itinerant and switching behavior was observed in the transient activity of antennal lobe neurons involved in insect olfaction or in the activity of high vocal centers controlling songbird patterns [10]. The robustness of scale-free networks was emphasized in relation to food-webs and ecosystems [11,12], epidemics [13], etc.
Motivated by the success of centralized networks in neuroscience, genetics, and ecology, we consider centralized, continuous-time recurrent networks of an analogous topological structure as dynamical models for simulation of human body motions. From the general setting, we take the idea that these networks consist of a few centers and many satellites. As human motions are very often cyclical but with varying frequencies, the centers may evolve in time as oscillators with different frequencies. We take the idea of radial basis function (RBF) networks to define the center states. An additional switching module allows us to turn from one particular motion to another. Due to this structure, the network can simulate a large class of different motions with good accuracies, which depend on the oscillator frequencies.

2.1.2. Centralized Networks for Elementary Human Motions

The networks consist of n centers with the states q i , and a number of satellites with states X j , Y j , Z j , where j = 1 , , N n . In the simplest case, when we approximate a single relatively simple motion, the time evolutions of the center states are governed by harmonic oscillator equation:
d 2 q i d t 2 + ω i 2 q i = 0 , i = 1 , , n ,
where q i is the coordinate of the i-th oscillator, ω i is the frequency of that oscillator, and n is the number of oscillators. Often even two oscillators ( n = 2 ) provide a good accuracy, but for more complicated motions one can take n { 3 , 4 , 5 } . Let q ( t ) = ( q 1 , , q n ) be the vector of the oscillator states, depending on time t, and x k ( t ) are output coordinates (here x 1 ( t ) = X ( t ) , x 2 ( T ) = Y ( t ) , x 3 ( t ) = Z ( t ) ).
The centers are connected with N output coordinates x k by a network:
x k = j = 1 N m W k j Φ j ( q , b ) ,
where x k is the k-th coordinate on the body, k = 1 , , N . The functions Φ j form a basis in the space L 2 ( [ X 0 , X 0 ] , where x 0 is characteristic maximal amplitude of motion for the j-th point, b is a parameter, and N m is the number of basis functions. The matrix entry W k j describes the action of the node j on x k . Note that (2) defines a straight-forward network that maps the center states q i into the output coordinate x k by N m hidden neurons (satellites), and therefore, there are no interactions between satellites.
There are possible different choices of Φ j . For example, we can consider the following cases.
A 
Harmonic basis. Here we assume that
Φ j ( q , b ) = cos ( b j q ) ,
where b is a frequency.
B 
System of radial basis functions.
For the case where a motion consists of many segments and we observe sharp transitions between those segments, we can use radial basis functions
Φ j = ϕ ( b | q q ¯ ( j ) | ) , j = 1 , , N m ,
where ϕ is a fixed function, b is a sharpness parameter, and q ¯ ( j ) is the vector of centers of radial basis functions with components q ¯ ( j ) = ( q ¯ 1 ( j ) , , q ¯ n ( j ) ) , where the latter are parameters of the system, and | z | denotes the Euclidian norm of the vector z: | z | = i = 1 n z i 2 . We assume that the radial basis function ϕ ( | z | ) is well localized at z = 0 and is smooth. For example, we can take the Gaussian
ϕ ( | z | ) = exp ( | z | 2 / 2 ) .
C 
Polynomial basis.
Here we take
Φ j ( q ) = q j 1 , j = 1 , , N m .
The basis B has an important advantage: the radial basis functions provide local approximations that are important to approximate complicated motions with sharp transitions.
To perform switching in the network, we will also use the sigmoidal functions σ . They are increasing and smooth (at least twice differentiable) functions such that
σ ( ) = 0 , σ ( + ) = 1 , σ ( z ) > 0 .
Typical examples can be given by
σ ( h ) = 1 1 + exp ( h ) , σ ( h ) = 1 2 h 1 + h 2 + 1 .
The structure of interactions between centers and coordinates x i can be described by Figure 1.

2.1.3. Centralized Networks Generating a Large Class of Human Body Motions

To approximate different motions by a single network, we should have the possibility of changing the frequencies and coefficients W k j .
The main idea is as follows. Each motion can be approximated by a network described in the previous subsection, with adjusted frequencies ω i and appropriated coefficients W k j . We can use nonlinear oscillators to obtain all possible frequencies. For example, one can use the model described below. Consider networks consisting of n centers, which evolve as nonlinear oscillators:
d 2 q i d t 2 + z c f ( q i ) = 0 , i = 1 , , n ,
where q i is the coordinate of the i-th oscillator, f ( q ) is a nonlinear function, and z c is a control paremeter (one can take, for instance, f = sin ( q ) or f = a q b q 3 ). We assume that
q i ( 0 ) = 0 , p i ( 0 ) = p 0 , p ( t ) = d q d t ,
where p 0 is a fixed number. Solutions of Equation (9) are periodic functions of time, with the period T ( z i ) and the frequency ω ( z i ) = 2 π / T . It can be found by the motion integral of Equation (9) that:
E i = 1 2 ( d q i d t ) 2 + F ( q i , z i ) ,
where F is the antiderivative of f: f ( q ) = d F d q .
Notice that Equations (2)–(9) are “standard” (see e.g., [19]).
Consider a set of human motions characterized by a set of coordinates x 1 ( j ) , , x N ( j ) , where the upper index j corresponds to a particular motion. Each motion can be described by the model (1) and (2) with the corresponding frequencies ω i ( j ) and coefficients W k l ( j ) .
A switching between the different motions can be performed by a choice of the control parameters z i .
By the switching module (described in the next subsection), we find a network subsystem which has z c ( j ) as local attractors. Then, we can construct maps z c ω 1 ( z ) , , ω n ( z ) and z c W k l ( z c ) such that
ω l ( z l ( i ) ) = ω ( z l ( i ) ) , l = 1 , , n
W l i ( j ) = W k i ( z ( j ) ) .
Hence, our global model for human motion consists of
  • a system of n nonlinear oscillators (9) with the control parameters z i , i = 1 , , n ;
  • an RBF network defined by (2);
  • maps obeying Equations (12) and (13); and
  • a switching module that is a network with M + 1 nodes, where M is the number of different motions.
In the next section, we describe the switching module.

2.2. Switching Module

Ideas behind construction. Before stating a formal statement, we present a brief outline which describes the main ideas of the proof and the architecture of the switchable network. The network consists of two modules. The first module is a generating one and it is a centralized neural network with n centers q 1 , , q n and satellites x 1 , , x N . The second module consists of a center v n + 1 = z and m satellites w ˜ 1 , , w ˜ m . The satellites from this module interact only with the module center z; i.e., in this module the interactions can be described by a distar graph [6]. Only the center of the second module interacts with the neurons of the first (generating) module. We refer to the second module as a switching one. This architecture is shown in Figure 2.
For the switching module, the corresponding differential equations have the following form. Let us consider a distar interaction motif, where a node z is connected in both directions with m nodes w ˜ 1 , , w ˜ m . By this notation, the equations for the switching module can be written down in the form
d w ˜ i d t = σ b ˜ i z h ˜ i κ 1 w ˜ i ,
d z d t = σ κ 1 j = 1 m a ˜ j w ˜ j h ξ λ ¯ z ,
where i = 1 , , m and b ˜ i , a ˜ j , λ ¯ > 0 .
In order to come up with a mathematical description of the way in which switching module works, let us consider the system of differential equations
d v d t = Q ( v , z ) , v = ( v 1 , , v 2 n ) ,
where z is a real control parameter. Let z 1 , , z m + 1 be some values of this parameter. We find a vector field Q such that for z = z l , where l = 1 , , m , the dynamics defined by (16) have the prescribed dynamics. For example, we can set n = 2 and
v 1 = q , v 2 = p = d q d t ,
and
Q = v 2 , d v 2 d t = z c f ( v 1 ) ,
which gives (9).
For the switching module, we adjust the center–satellite interactions and the center response time parameter ξ in such a way that for a set of values ξ the switching module has the dynamics of the system shown in (14) and (15), with m different rest points z = z 1 , z 2 , , z m + 1 , and for sufficiently large ξ the system shown in (14) and (15) has a single equilibrium close to z 1 = 0 . The existence of such a choice will be shown in Lemma 1. This lemma has been stated and proven in the generic context ([6] Lemma 8.2). Due to its importance, we restate it here.
Lemma 1.
Let β ( 0 , 1 ) and let m be a positive integer. For sufficiently small κ > 0 , there exist a ¯ j , b i , h ˜ i , h such that
(i) 
for an open interval of values ξ the system in (14) and (15) has m stable hyperbolic rest points
z j ( j 1 + β , j + β ) ,
where j = 1 , , m ;
(ii) 
for ξ > ξ 0 > 0 the system in (14) and (15) has a single stable hyperbolic rest point.
For the proof of this lemma we refer to [6].

2.3. Algorithm of Construction of the RBF Network to Generate Human Body Motions

2.3.1. Non-Segmented Motions

Simple motions can be handled as a whole (i.e., without any segmentation). Let us fix the index j (i.e., consider a particular motion). Let t 1 , , t K be time moments where we have data on human body coordinates X j ( t ) , Y j ( t ) , Z j ( t ) , where j is the index of an optical marker on the body and the number of the markers is N, j = 1 , , N . All X , Y , and Z are thus vectors with N components. Let ε ( k , ω ) be the L 2 - approximation accuracy for the x-component and k-th marker defined by
ε X 2 ( k , ω ) = m = 1 K ( X k ( t m ) x k ( q ( t m ) , ω ) ) 2 ,
where x k ( q ) are defined by (2). Similarly,
ε Y 2 ( k , ω ) = m = 1 K ( Y k ( t m ) y k ( q ( t m ) , ω ) ) 2 ,
ε Z 2 ( k , ω ) = m = 1 K ( Z k ( t m ) z k ( q ( t m ) , ω ) ) 2 .
The relative accuracies for X , Y , Z components are given by
ε r , X , ω 2 ( k ) = ε X 2 ( k , ω ) / m = 1 K X k ( t m ) 2 ,
ε r , Y , ω 2 ( k ) = ε Y 2 ( k , ω ) / m = 1 K Y k ( t m ) 2 ,
ε r , Z , ω 2 ( k ) = ε Z 2 ( k , ω ) / m = 1 K Z k ( t m ) 2 ,
respectively. Let us fix a k { 1 , 2 , , N } (i.e., a marker on the human body). For a set of frequency vectors ω , we compute the integral relative accuracy
ε r , k ( ω ) = ( ε r , X , ω 2 ( k ) + ε r , Y , ω 2 ( k ) + ε r , Z , ω 2 ( k ) ) / 3 .
Then, we find a ω * such that ε ( ω * ) is minimal:
ω * = argmin ε r , k ( ω ) .
The corresponding coefficients W k l can be found by the standard Matlab programs, which approximate a target function by RBF networks. Here we use standard radial basis functions of Gaussian type, where the sharpness parameter b can be adjusted by trial and error to minimize ε .
Numerical results show that the frequencies found for a particular motion by a value of k (a specific marker choice) and giving a small ε r , k can be applied to find good approximations for all rest values of k (i.e., for all other markers). An alternative method is to take the average of all markers, and then
ω * = argmin k ε r , k ( ω ) .
However, in this case the running time of the algorithm sharply increases.

2.3.2. Segmented Motions

For complex motions it is difficult to uniformly approximate a whole motion using a few neurons; sometimes such approximation is good anywhere except for a certain interval. In fact, it is difficult to expect that all parts of complicated motions consisting of quite different elementary submotions can be handled with the same frequencies. However, we can use the segmentation. We then decompose the motion in segments [ T i , T i + 1 ] , where i = 1 , , N seg . For each segment we can determine optimal frequencies as described above and compute the accuracies. The frequency optimization can be done in two ways. If the number of oscillators is small (say, n = 1 , 2 ), we can perform an exhaustive search over a uniform grid. For larger n, one can use a random search.

2.4. Comparison with DMPs

Let us compare the approach based on centralized networks, proposed in this present paper, and the classical method of dynamic movement primitives (DMPs). Both approaches use the same general representation, which, following [24], we write down as follows (see Equations (1) and (2) in [24]):
d s d t = Canonical ( t , s ) ,
d y d t = Transform ( t , y ) + Perturbation ( s ) .
The first equation is a time-dependent dynamical system, and the second one describes a transformation of trajectories of that dynamical system to desired trajectories y ( t ) . Note that the term P ( s ) = Perturbation ( s ) should be adapted to induce a desired behaviour in the system; i.e., to reproduce a given trajectory [24]. So, a DMP consists of two parts, as described by Ernesti et al. [24]: “the canonical system and the transformation system. While the canonical system defines the state of the DMP in time, the transformation system is the link between this DMP state and the robot. The transformation system can be easily adapted to a desired trajectory; i.e., by solving a standard regression problem. The canonical system determines the type of attractor which can be either discrete or periodic”.
The DMP method uses P ( s ) to attain the twofold goal: to represent trajectories tending to rest points and periodic trajectories. In fact, roughly speaking, the dynamics of any dissipative systems reduce to some transient trajectories and motions on local attractors. However, it is not so simple to represent simultaneously transient dynamics, as was mentioned in [22]. To attain this goal, we must use sufficiently sophisticated formulas for P ( s ) , which are based mainly on radial basis functions and the fact that RBFs are universal approximators.
In our centralized network approach, we use the same transformation system (29). However, we add a new idea in the representation of canonical part (28). It is well known that many motions generated by dissipative systems consist of slow and fast components. Fast components can describe, for example, transient trajectories, while slow components correspond to motions on local attractors. To represent such complex dynamics, we can nonetheless use systems of oscillators [37].
In particular, in our approach we usually use two oscillators, one of higher frequency and another of low frequency, although one can take three or more oscillators for complicated target motions. This idea works well: we greatly simplify the complicated formulas suggested in [22], and all transformation systems take the feed-forward form:
y = Perturbation ( s ) .

3. Results

For empiric tests we use the CMU Motion Capture Database [38]. We use two motions from family number 86, as these consist of sequences of several different motions performed by one actor subsequently, and hence have also been used as a test suite for different motion segmentation algorithms (e.g., [39] and references therein).
We use markers on left and right heels and left and right wrists, as in general from the position of these four markers even the full body motion can be reconstructed quite well [40,41].

3.1. Results without Segmentation and Ad Hoc Segmentations

We have considered two representative motions: Trial 1 and Trial 2. The first motion consists of jumping, hopping, turning, kicking, and punching, the second one is comprised of walking, squatting, running, stretching, jumping, punching, and drinking. The first motion is split into four segments [ 1 , 1300 ] , [ 1300 , 2000 ] , [ 2000 , 3000 ] , [ 3000 , 4500 ] , which were chosen visually by hand. Notice that the sampling rate for all examples was 120 Hz, so that the length of the motion segments are 10.8 s, 5.8 s, 8.3 s, and 12.5 s. The first segment consists of walking and hopping motions, the second one of a walking and a turning motion, the third one of punching (alternatively with both arms) and walking, and the fourth one of kicking (the right leg) and punching (alternatively with both arms). Similarly, the second motion was decomposed into segments [ 1 , 1800 ] , [ 1800 , 2500 ] , [ 2500 , 4500 ] . Hence, the lengths of the segments are 15.0 s, 5.8 s, and 16.7 s. The first segment consists of walking and squats, the second one of running (in a circle), and the third one of stretches.
An overview of results is given in Table 1.
In Figure 3, Figure 4, Figure 5 and Figure 6 we show the results of the approximations of the different marker coordinates by 25, 50, and 100 satellites and two oscillators of motion CMU 86 Trial 1 consisting of jumping, kicking, and punching. In Figure 7 a three-dimensional plot of the marker trajectory of the right wrist of the same motion is presented.
In Figure 8 and Figure 9 we give the approximations for a simple non-segmented motion. An approximation of a complicated motion (CMU 86 Trial 2) consisting of walking, squatting, running, stretching, jumping, punching, and drinking is given in Figure 10, Figure 11 and Figure 12. For this motion an RBF-network with three centers and 100 satellites was necessary for good approximations on the segmentation of the hand into three parts.
The integral relative accuracies (for x, y, and z coordinates together) are as follows: for the first segment consisting of walking and squats the accuracy is 0.006, for the second segment consisting of running (in a circle) it is 0.002, and for the third one consisting of stretches it is 0.005.
As the accuracies of course improve when using more satellites, we computed the Akaike information criterion corrected for finite sample sizes (AICc) [42], a likelihood-based measurement for systematic tests involving 20–250 satellites, which weights accuracy against the number of parameters (with lower AIC values being better). The results for Trial 1 with 1, 2, 3, and 4 centers is given in Figure 13.
Notice that only the comparative values are important. The global optimum is reached for three centers and 150 satellites (with a small increase for higher satellite numbers).

3.2. Results Based on Algorithmic Segmentations as Pre-Processing Steps

Algorithmic segmentation methods yield much smaller segments than our ad hoc segmentations. Using the method described by Krüger et al. [39] as a pre-processing step, the motion CMU 86 Trial 1 is segmented into six main parts with five transition motions. When taking each of the 11 segments as an input, only 16 satellite neurons per segment are sufficient for good approximations. Notice that the required number of neurons is more than a factor of 15 smaller than the number of frames in each segment.
In Figure 14 the absolute and relative integral errors for all 31 markers and all 11 segments of CMU 86 Trial 1 using two centers and 49 satellites are given. The differences between the relative integral errors and the absolute errors can be explained by the large motions of some markers in some segments. We observe a certain ruggedness of the fitting landscape, which can be explained by the rather complicated nature of the motions and the transitions between motions of very different characteristics.
In Figure 15 a systematic comparison of the approximation errors over the different segments in CMU 86 Trial 1 are given when using 16 satellites respectively 100 satellites.

3.3. Comparison with Other Approaches

In [28] a method for marker reconstructions based on local similarity searches, building local linear models of found similar motions, and using this information as priors in a pose-wise reconstruction process reported results on marker accuracy on the motions of family CMU 86 from the CMU mocap database. The overall Bayesian framework is similar to that already suggested by [27]. The reported average joint error for CMU 86 Trial 1 is 1.30 cm ([28], Table 3), when taking prior information of motions from the CMU database into account. In our approach the average joint errors are more than one order of magnitude smaller. Although the results are not fully comparable, it is encouraging to see that our approach gives better results even without relying on prior information of other motions, as the Bayesian approach used in [28] does.
We approximated the marker trajectories of the segmented motions of CMU motion 86 Trial 1 and Trial 2 with DMPs using the pydmps implementation by Travis DeWolf, which is available at https://github.com/studywolf/pydmps. We have used the code for the rhythmic DMPs (using 100 basis functions) on the algorithmically segmented motions. The results in comparison to our centralized networks are detailed in Figure 15 and Figure 16.

4. Discussion and Conclusions

We have shown that marker trajectories of representative body parts can be approximated well by centralized networks consisting of very few centers as oscillators—2 to 3 oscillators have been shown to be sufficient even for rather complicated motions. The needed satellites required even for very good approximations are one to two orders of magnitude smaller than the number of frames considered; hence, our technique yields very compact representations and compresses marker trajectories. The learned frequencies of one marker could be transferred to other markers, so our technique seems to be capable of the motion reconstruction problem from a few markers [27]. As this problem is of particular practical interest if the input data are not marker positions but sensor readings of inertial measurement units [40,41], an application of our method to this setting is of interest. As the accuracy of reconstruction at the level of a single marker is very good, we presume that such a technique could also yield much better reconstruction results than the existing Bayesian approaches. In future work we will investigate this line of research. Additionally, the use of surface electromyography (EMG) has become an increasingly practical sensor technology for human motion interaction (e.g., the Myo Gesture Control Armband), and our technique can be used for sensor data of different kinds. Additionally, for investigating surface EMG signals of animal motions, the centralized networks might yield another basic technique, which we will test on existing data sets [43].
While with the dynamic movement primitives (DMPs) the use of one oscillator has been commonly used and the use of radial basis functions closely correspond to our techniques, we can readily use more than one oscillator. In our experiments, the use of two (or three) oscillators yielded better results than using just one. The idea of switching has also been proposed in the context of DMPs [25]—yielding in some sense a conceptual ad hoc extension. As has been noted in [25] (Section 2.3.5), the modeling easily becomes complex. In our proposal the switching module stays within the realm of centralized networks. In principle, our techniques should be applicable in all contexts in which DMPs have been used, yielding a simpler modeling alternative.
The oscillator frequencies give very useful semantic information on motions that should be widely applicable. By searching for similar vectors of oscillator frequencies, our technique can also give a basis for motion retrieval, which in contrast to other techniques does not involve similarity measures for poses first [28] but works directly on marker trajectories. As vectors of oscillation frequencies are readily indexable, efficient retrieval from even huge motion databases is possible—and fine tuning the query regarding the weighting of different body parts is even possible without a re-indexing of the entire database. By manipulating the oscillator frequencies or transferring them to other marker positions, the presented techniques are also capable of various motion adaption and synthesis tasks, which range from a new technical basis for the classic ideas by Pullen and Bregler [44] to ideas related to motion fields [45]. It will be the topic of future work to explore these directions in more detail.
In our current method there is no need to use a priori knowledge on human motions by referring to similar known motions, as is the basis of Bayesian approaches [26,27,28]. Being an advantage on the one hand, it is on the other hand a disadvantage if such a priori knowledge on “similar motions” is available. Incorporating such a possibility is very much in the realm of neural networks, and will be a topic for future research.
Moreover, centralized networks should also be applicable in the context of motion anticipation: by extrapolation from the past into the future, the presented technique also has the potential for full body motion anticipation in the short-term when staying within a fixed tuple of oscillator frequencies and for the mid-term range when using switching. We will explore this possibility within our future research in the collaborative research unit “Anticipating Human Behavior”, funded by Deutsche Forschungsgemeinschaft under grant number FOR 2535.

Acknowledgments

The authors are grateful to F. Kul and H. Errami for their help in performing comparative computations with DMPs. Sergei Vakulenko was financially supported by Government of the Russian Federation, Grant 074-U01, also supported in part by grant RO1 OD010936 (formerly RR07801) from the US NIH and by grant A of Russian Fund of Basic Research. Ovidiu Radulescu was supported by Labex EPIGENMED (ANR-10-LABX-12-01). Ivan Morozov and Andres Weber were partially supported by grant We 1945/11-1 in the collaborative research unit FOR 2535 “Anticipating Human Behavior” funded by Deutsche Forschungsgemeinschaft.

Author Contributions

S.V., O.R., I.M. and A.W. conceived and designed the experiments; S.V. and I.M. performed the experiments; S.V., I.M. and A.W. analyzed the data; S.V. and I.M. contributed reagents/materials/analysis tools; S.V., O.R., I.M. and A.W. wrote the paper.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Ordóñez, F.J.; Roggen, D. Deep convolutional and LSTM recurrent neural networks for multimodal wearable activity recognition. Sensors 2016, 16, 115. [Google Scholar] [CrossRef] [PubMed]
  2. Holden, D.; Saito, J.; Komura, T. A deep learning framework for character motion synthesis and editing. ACM Trans. Graph. 2016, 35, 1–11. [Google Scholar] [CrossRef]
  3. Li, Z.; Zhou, Y.; Xiao, S.; He, C.; Li, H. Auto-Conditioned LSTM Network for Extended Complex Human Motion Synthesis. 2017. Available online: http://xxx.lanl.gov/abs/1707.05363 (accessed on 1 September 2017).
  4. Fragkiadaki, K.; Levine, S.; Felsen, P.; Malik, J. Recurrent Network Models for Human Dynamics. In Proceedings of the 2015 IEEE International Conference on Computer Vision, Santiago, Chile, 7–13 December 2015; pp. 4346–4354. [Google Scholar]
  5. Holden, D.; Komura, T.; Saito, J. Phase-functioned neural networks for character control. ACM Trans. Graph. 2017, 36. [Google Scholar] [CrossRef]
  6. Vakulenko, S.; Morozov, I.; Radulescu, O. Maximal switchability of centralized networks. Nonlinearity 2016, 29, 2327–2354. [Google Scholar] [CrossRef]
  7. Chialvo, D.R. Emergent complex neural dynamics. Nat. Phys. 2010, 6, 744–750. [Google Scholar] [CrossRef]
  8. Jeong, H.; Tombor, B.; Albert, R.; Oltvai, Z.; Barabási, A. The large-scale organization of metabolic networks. Nature 2000, 407, 651–654. [Google Scholar] [PubMed]
  9. Jeong, H.; Mason, S.P.; Barabási, A.L.; Oltvai, Z.N. Lethality and centrality in protein networks. Nature 2001, 411, 41–42. [Google Scholar] [CrossRef] [PubMed]
  10. Rabinovich, M.I.; Varona, P.; Selverston, A.I.; Abarbanel, H.D. Dynamical principles in neuroscience. Rev. Mod. Phys. 2006, 78, 1213–1265. [Google Scholar] [CrossRef]
  11. Dunne, J.A.; Williams, R.J.; Martinez, N.D. Food-web structure and network theory: The role of connectance and size. Proc. Natl. Acad. Sci. USA 2002, 99, 12917–12922. [Google Scholar] [CrossRef] [PubMed]
  12. Jordano, P.; Bascompte, J.; Olesen, J.M. Invariant properties in coevolutionary networks of plant–animal interactions. Ecol. Lett. 2003, 6, 69–81. [Google Scholar] [CrossRef]
  13. Dezső, Z.; Barabási, A.L. Halting viruses in scale-free networks. Phys. Rev. E 2002, 65, 055103. [Google Scholar] [CrossRef] [PubMed]
  14. Chiel, H.J.; Beer, R.D.; Quinn, R.D.; Espenschied, K.S. Robustness of a distributed neural network controller for locomotion in a hexapod robot. IEEE Trans. Robot. Autom. 1992, 8, 293–303. [Google Scholar] [CrossRef]
  15. Collins, J.J.; Richmond, S.A. Hard-wired central pattern generators for quadrupedal locomotion. Biol. Cybern. 1994, 71, 375–385. [Google Scholar] [CrossRef]
  16. Ijspeert, A.J. Central pattern generators for locomotion control in animals and robots: A review. Neural Netw. 2008, 21, 642–653. [Google Scholar] [CrossRef] [PubMed]
  17. Golubitsky, M.; Stewart, I.; Buono, P.L.; Collins, J. A modular network for legged locomotion. Phys. D Nonlinear Phenom. 1998, 115, 56–72. [Google Scholar] [CrossRef]
  18. Chen, S.; Cowan, C.F.; Grant, P.M. Orthogonal least squares learning algorithm for radial basis function networks. IEEE Trans. Neural Netw. 1991, 2, 302–309. [Google Scholar] [CrossRef] [PubMed]
  19. Schilling, R.J.; Carroll, J.J.; Al-Ajlouni, A.F. Approximation of nonlinear systems with radial basis function neural networks. IEEE Trans. Neural Netw. 2001, 12, 1–15. [Google Scholar] [CrossRef] [PubMed]
  20. Jonic, S.; Jankovic, T.; Gajic, V.; Popvic, D. Three machine learning techniques for automatic determination of rules to control locomotion. IEEE Trans. Biomed. Eng. 1999, 46, 300–310. [Google Scholar] [CrossRef] [PubMed]
  21. Schaal, S.; Peters, J.; Nakanishi, J. Control, planning, learning, and imitation with dynamic movement primitives. In Proceedings of the IEEE International Conference on Intelligent Robots and Systems (IROS 2003), Las Vegas, NV, USA, 27–31 October 2003; pp. 1–21. [Google Scholar]
  22. Schaal, S. Dynamic movement primitives—A framework for motor control in humans and humanoid robotics. In Adaptive Motion of Animals and Machines; Springer: Tokyo, Japan, 2006; pp. 261–280. [Google Scholar]
  23. Tamosiunaite, M.; Nemec, B.; Ude, A.; Wörgötter, F. Learning to pour with a robot arm combining goal and shape learning for dynamic movement primitives. Robot. Auton. Syst. 2011, 59, 910–922. [Google Scholar] [CrossRef]
  24. Ernesti, J.; Righetti, L.; Do, M.; Asfour, T.; Schaal, S. Encoding of periodic and their transient motions by a single dynamic movement primitive. In Proceedings of the 2012 12th IEEE-RAS International Conference on Humanoid Robots, Osaka, Japan, 29 November–1 December 2012; pp. 57–64. [Google Scholar]
  25. Ijspeert, A.J.; Nakanishi, J.; Hoffmann, H.; Pastor, P.; Schaal, S. Dynamical movement primitives: Learning attractor models for motor behaviors. Neural Comput. 2013, 25, 328–373. [Google Scholar] [CrossRef] [PubMed]
  26. Kovar, L.; Gleicher, M. Automated extraction and parameterization of motions in large data sets. ACM Trans. Graph. 2004, 23, 559–568. [Google Scholar] [CrossRef]
  27. Chai, J.; Hodgins, J.K. Performance animation from low-dimensional control signals. ACM Trans. Graph. 2005, 24, 686–696. [Google Scholar] [CrossRef]
  28. Krüger, B.; Tautges, J.; Weber, A.; Zinke, A. Fast local and global similarity searches in large motion capture databases. In Proceedings of the Eurographics/ACM SIGGRAPH Symposium on Computer Animation, Madrid, Spain, 2–4 July 2010; pp. 1–10. [Google Scholar]
  29. Albert, R.; Barabási, A.L. Statistical mechanics of complex networks. Rev. Mod. Phys. 2002, 74, 47–97. [Google Scholar] [CrossRef]
  30. Bascompte, J. Networks in ecology. Basic Appl. Ecol. 2007, 8, 485–490. [Google Scholar] [CrossRef]
  31. Tanizawa, T.; Paul, G.; Cohen, R.; Havlin, S.; Stanley, H.E. Optimization of network robustness to waves of targeted and random attacks. Phys. Rev. E 2005, 71, 047101. [Google Scholar] [CrossRef] [PubMed]
  32. Albert, R.; Jeong, H.; Barabási, A.L. Error and attack tolerance of complex networks. Nature 2000, 406, 378–382. [Google Scholar] [CrossRef] [PubMed]
  33. Bar-Yam, Y.; Epstein, I.R. Response of complex networks to stimuli. Proc. Natl. Acad. Sci. USA 2004, 101, 4341–4345. [Google Scholar] [CrossRef] [PubMed]
  34. Carlson, J.M.; Doyle, J. Complexity and robustness. Proc. Natl. Acad. Sci. USA 2002, 99, 2538–2545. [Google Scholar] [CrossRef] [PubMed]
  35. Vakulenko, S.A.; Radulescu, O. Flexible and robust networks. J. Bioinform. Comput. Biol. 2012, 10, 1241011. [Google Scholar] [CrossRef] [PubMed]
  36. Vakulenko, S.; Radulescu, O. Flexible and robust patterning by centralized gene networks. Fundam. Inform. 2012, 118, 345–369. [Google Scholar]
  37. Vakulenko, S. A system of coupled oscillators can have arbitrary prescribed attractors. J. Phys. A Gen. Phys. 1994, 27, 2335–2349. [Google Scholar] [CrossRef]
  38. Carnegie Mellon University Graphics Lab. Motion Capture Database. Available online: http://mocap.cs.cmu.edu (accessed on 1 June 2017).
  39. Krüger, B.; Vögele, A.; Willig, T.; Yao, A.; Klein, R.; Weber, A. Efficient unsupervised temporal segmentation of motion data. IEEE Trans. Multimed. 2017, 19, 797–812. [Google Scholar] [CrossRef]
  40. 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, 18:1–18:12. [Google Scholar] [CrossRef]
  41. Riaz, Q.; Tao, G.; Krüger, B.; Weber, A. Motion reconstruction using very few accelerometers and ground contacts. Graph. Models 2015, 79, 23–38. [Google Scholar] [CrossRef]
  42. Anderson, D.R. Model Based Inference in the Life Sciences; Springer: New York, NY, USA, 2008. [Google Scholar]
  43. Vögele, A.; Zsoldos, R.; Krüger, B.; Licka, T. Novel methods for surface EMG analysis and exploration based on multi-modal gaussian mixture models. PLoS ONE 2016. [Google Scholar] [CrossRef] [PubMed]
  44. Pullen, K.; Bregler, C. Motion capture assisted animation: Texturing and synthesis. ACM Trans. Graph. 2002, 21, 501–508. [Google Scholar] [CrossRef]
  45. Lee, Y.; Wampler, K.; Bernstein, G.; Popović, J.; Popović, Z. Motion fields for interactive character locomotion. ACM Trans. Graph. 2010, 29, 138:1–138:8. [Google Scholar] [CrossRef]
Figure 1. This image shows the control of one of the x-coordinates of human body motions by a network consisting of two oscillators ( v 1 , v 2 ) and a radial basis function (RBF) network with N = 6 nodes. The graph consists of eight nodes denoted by v 1 , v 2 , w 1 , w 2 , w 3 , w 4 , w 5 , w 6 . Each node w i corresponds to a contribution of a radial basis function Φ ( q q ¯ ( j ) ) . The nodes v 1 , v 2 form the set of centers C and they affect w i . In turn, the nodes w i determine the output coordinate x 1 .
Figure 1. This image shows the control of one of the x-coordinates of human body motions by a network consisting of two oscillators ( v 1 , v 2 ) and a radial basis function (RBF) network with N = 6 nodes. The graph consists of eight nodes denoted by v 1 , v 2 , w 1 , w 2 , w 3 , w 4 , w 5 , w 6 . Each node w i corresponds to a contribution of a radial basis function Φ ( q q ¯ ( j ) ) . The nodes v 1 , v 2 form the set of centers C and they affect w i . In turn, the nodes w i determine the output coordinate x 1 .
Sensors 17 02907 g001
Figure 2. Modular architecture. This can be seen as an example of the architecture described in [6]. The switching module consists of the center z and the satellites w ˜ 1 , w ˜ 2 , w ˜ 3 . The generating module consists of the centers v 1 , v 2 and the satellites w 1 , , w 6 . Note that there is a feedback between z and the satellites w i ; however, there is no feedback of w j on v l .
Figure 2. Modular architecture. This can be seen as an example of the architecture described in [6]. The switching module consists of the center z and the satellites w ˜ 1 , w ˜ 2 , w ˜ 3 . The generating module consists of the centers v 1 , v 2 and the satellites w 1 , , w 6 . Note that there is a feedback between z and the satellites w i ; however, there is no feedback of w j on v l .
Sensors 17 02907 g002
Figure 3. An approximation of x-coordinates by 25 satellites and two centers of motion (CMU 86 Trial 1) consisting of jumping, kicking, and punching (sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Figure 3. An approximation of x-coordinates by 25 satellites and two centers of motion (CMU 86 Trial 1) consisting of jumping, kicking, and punching (sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Sensors 17 02907 g003aSensors 17 02907 g003b
Figure 4. An approximation of y-coordinates by 25 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Figure 4. An approximation of y-coordinates by 25 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Sensors 17 02907 g004
Figure 5. An approximation of y-coordinates by 50 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Figure 5. An approximation of y-coordinates by 50 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Sensors 17 02907 g005
Figure 6. An approximation of z-coordinates by 100 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) The left heel; (c) Right wrist, distal; (d) The left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Figure 6. An approximation of z-coordinates by 100 satellites and two centers of motion (CMU 86 Trial 1; sampled at 120 Hz). (a) Right heel; (b) The left heel; (c) Right wrist, distal; (d) The left wrist, distal. The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations.
Sensors 17 02907 g006
Figure 7. Three-dimensional plot of marker trajectory of the motion of the right wrist (distal; CMU 86 Trial 1). The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations (with two centers and 100 satellites).
Figure 7. Three-dimensional plot of marker trajectory of the motion of the right wrist (distal; CMU 86 Trial 1). The red curve shows the experimentally observed coordinates and the green curve gives their neural approximations (with two centers and 100 satellites).
Sensors 17 02907 g007
Figure 8. An approximation of z (vertical) coordinates by 200 neurons and two centers for a simple non-segmented motion (sampled at 120 Hz). The center frequencies are 0.30 Hz and 0.72 Hz . (a) z-coordinate for the right heel; (b) The left heel; (c) z-coordinate for the right wrist, distal; (d) The left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves give their neural approximations.
Figure 8. An approximation of z (vertical) coordinates by 200 neurons and two centers for a simple non-segmented motion (sampled at 120 Hz). The center frequencies are 0.30 Hz and 0.72 Hz . (a) z-coordinate for the right heel; (b) The left heel; (c) z-coordinate for the right wrist, distal; (d) The left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves give their neural approximations.
Sensors 17 02907 g008
Figure 9. Approximations of x (left) and y coordinates (right) by 200 neurons and two centers for a simple non-segmented motion (sampled at 120 Hz). The center frequencies are 0.30 Hz and 0.72 Hz . (a) Right heel , x-coordinate; (b) Left heel, x-coordinate; (c) Right wrist, distal, x-coordinate; (d) Left wrist, distal, x-coordinate; (e) Right heel , y-coordinate; (f) Left heel, y-coordinate; (g) Right wrist, distal, y-coordinate; (h) Left wrist, distal, y-coordinate. The red curves show the experimentally observed coordinates and the blue curves give their neural approximations. Both curves coincide up to pixel accuracy in many places.
Figure 9. Approximations of x (left) and y coordinates (right) by 200 neurons and two centers for a simple non-segmented motion (sampled at 120 Hz). The center frequencies are 0.30 Hz and 0.72 Hz . (a) Right heel , x-coordinate; (b) Left heel, x-coordinate; (c) Right wrist, distal, x-coordinate; (d) Left wrist, distal, x-coordinate; (e) Right heel , y-coordinate; (f) Left heel, y-coordinate; (g) Right wrist, distal, y-coordinate; (h) Left wrist, distal, y-coordinate. The red curves show the experimentally observed coordinates and the blue curves give their neural approximations. Both curves coincide up to pixel accuracy in many places.
Sensors 17 02907 g009
Figure 10. Approximations of x coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by a radial basis function (RBF) network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal.
Figure 10. Approximations of x coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by a radial basis function (RBF) network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right heel; (b) Left heel; (c) Right wrist, distal; (d) Left wrist, distal.
Sensors 17 02907 g010
Figure 11. An approximation of y coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by an RBF-network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right ankle; (b) Left ankle; (c) Right heel; (d) Left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves represent their neural approximations.
Figure 11. An approximation of y coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by an RBF-network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right ankle; (b) Left ankle; (c) Right heel; (d) Left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves represent their neural approximations.
Sensors 17 02907 g011
Figure 12. An approximation of the z coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by an RBF-network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right ankle; (b) Left ankle; (c) Right heel; (d) Left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves represent their neural approximations.
Figure 12. An approximation of the z coordinates of a complicated motion (CMU 86 Trial 2; sampled at 120 Hz) by an RBF-network with three centers and 100 satellites. The motion was segmented into three intervals [ 1 , 1800 ] , [ 1800 , 2500 ] , and [ 2500 , 4000 ] . (a) Right ankle; (b) Left ankle; (c) Right heel; (d) Left wrist, distal. The red curves show the experimentally observed coordinates and the blue curves represent their neural approximations.
Sensors 17 02907 g012
Figure 13. Akaike information criterion corrected for finite sample sizes (AICc) for CMU 86 Trial 1 with 1, 2, 3, and 4 centers and varying numbers of satellites. The global optimum was reached for three centers and 150 satellites.
Figure 13. Akaike information criterion corrected for finite sample sizes (AICc) for CMU 86 Trial 1 with 1, 2, 3, and 4 centers and varying numbers of satellites. The global optimum was reached for three centers and 150 satellites.
Sensors 17 02907 g013
Figure 14. Absolute error (ErrABS) and relative integral errors (Err) for all 31 markers and all 11 segments of CMU 86 Trial 1 using two centers and 49 satellites.
Figure 14. Absolute error (ErrABS) and relative integral errors (Err) for all 31 markers and all 11 segments of CMU 86 Trial 1 using two centers and 49 satellites.
Sensors 17 02907 g014
Figure 15. Approximation errors (in mm) for the algorithmically found segments of motions in CMU 86 Trial 1. We give the errors for using 16 and 100 satellites. As a comparison we give the results using rhythmic dynamic movement primitives (DMPs) with 100 basis functions computed with pydmps, and the average approximation error of the Bayesian approach reported in [28] (Table 3). Notice that segments 2, 4, 6, and 8 are short transitional motions between the neighboring segments. The average over all segments is 8.7 mm for the DMPs, 7.9 mm for two centers and 16 satellites, and 6.7 mm for two centers and 100 satellites.
Figure 15. Approximation errors (in mm) for the algorithmically found segments of motions in CMU 86 Trial 1. We give the errors for using 16 and 100 satellites. As a comparison we give the results using rhythmic dynamic movement primitives (DMPs) with 100 basis functions computed with pydmps, and the average approximation error of the Bayesian approach reported in [28] (Table 3). Notice that segments 2, 4, 6, and 8 are short transitional motions between the neighboring segments. The average over all segments is 8.7 mm for the DMPs, 7.9 mm for two centers and 16 satellites, and 6.7 mm for two centers and 100 satellites.
Sensors 17 02907 g015
Figure 16. Approximation errors (in mm) for the algorithmically found segments of motions in CMU 86 Trial 2. We give the errors for using 16 satellites and 49 satellites. As a comparison we give the results using rhythmic DMPs with 100 basis functions computed with pydmps. The average over all segments is 8.0 mm for the DMPs, 15.6 mm for two centers and 16 satellites, and 6.3 mm for two centers and 49 satellites.
Figure 16. Approximation errors (in mm) for the algorithmically found segments of motions in CMU 86 Trial 2. We give the errors for using 16 satellites and 49 satellites. As a comparison we give the results using rhythmic DMPs with 100 basis functions computed with pydmps. The average over all segments is 8.0 mm for the DMPs, 15.6 mm for two centers and 16 satellites, and 6.3 mm for two centers and 49 satellites.
Sensors 17 02907 g016
Table 1. Integral relative accuracies of approximations by centralized networks of CMU 86 Trial 1 using different numbers of oscillators and satellites. The motion was segmented into four segments at frames [ 1 , 1300 , 2000 , 3000 , 4500 ] .
Table 1. Integral relative accuracies of approximations by centralized networks of CMU 86 Trial 1 using different numbers of oscillators and satellites. The motion was segmented into four segments at frames [ 1 , 1300 , 2000 , 3000 , 4500 ] .
Number of OscillatorsNumber of SatellitesIntegral Relative Accuracies
Segment 1Segment 2Segment 3Segment 4
11000.21330.08270.4230.0749
2250.12070.04860.04050.076
2500.03510.00890.00840.0586
21000.01890.00680.00290.0299
3250.08320.02530.02970.0685
31000.01330.00630.00310.0071

Share and Cite

MDPI and ACS Style

Vakulenko, S.; Radulescu, O.; Morozov, I.; Weber, A. Centralized Networks to Generate Human Body Motions. Sensors 2017, 17, 2907. https://doi.org/10.3390/s17122907

AMA Style

Vakulenko S, Radulescu O, Morozov I, Weber A. Centralized Networks to Generate Human Body Motions. Sensors. 2017; 17(12):2907. https://doi.org/10.3390/s17122907

Chicago/Turabian Style

Vakulenko, Sergei, Ovidiu Radulescu, Ivan Morozov, and Andres Weber. 2017. "Centralized Networks to Generate Human Body Motions" Sensors 17, no. 12: 2907. https://doi.org/10.3390/s17122907

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop