This application claims the priority benefit of Korean Patent Application No. 10-2020-0015776 filed on Feb. 10, 2020, in the Korean Intellectual Property Office, the disclosure of which is incorporated herein by reference for all purposes.
One or more example embodiments relate to a method and apparatus for generating and simulating a motion of an object.
Computer graphics (CG) is a technology for generating images using a computer. It may generate images by converting an outer shape and color of a model to numerals and representing them digitally. With the development of CG and related technologies, a digital video producing technology that represents a movement of an object as more lively or animated images has been more widely used in various fields of industry including, for example, game and animation. To generate an animated CG video, various methods including, for example, a modeling method of simulating a motion of an object in accordance with physical laws and a modeling method of applying a pattern of an interaction with another object in a three-dimensional (3D) space, are under development.
An aspect provides a technology for generating and simulating a motion of a first object controlling a second object based on a motion specification.
Another aspect provides a technology for generating and simulating a new motion based on an already simulated motion of a first object and a trajectory of a second object.
According to an example embodiment, there is provided a method of generating a motion of an object, the method including predicting a motion of a first object based on a motion specification, refining a motion of the first object based on the predicted motion and a trajectory of a second object controlled by the first object, generating a vector controlling joints of the first object based on the refined motion, and simulating a motion of the first object and the trajectory of the second object based on the generated vector.
The predicting of the motion of the first object may include predicting a motion of the first object in a current iteration based on a motion of the first object simulated in a previous iteration.
The trajectory of the second object may include a trajectory of the second object simulated in the previous iteration.
The generating of the vector may include generating a plurality of windows based on a plurality of states included in the refined motion, and generating a vector for each of the windows based on states of the first object included in a corresponding window and positions of the second object included in the corresponding window.
The predicting of the motion of the first object may include predicting a motion of the first object in the current iteration based on an example motion corresponding to the motion specification among example motions stored in advance in a database (DB).
The predicting of the motion of the first object may include selecting a first reference state from among a plurality of reference states included in the example motion based on a first cost function based on the motion specification and a first state of the first object, and determining a subsequent state of the first state based on whether the first reference state is included in a predefined kick motion.
When the first reference state is included in the predefined motion, the determining of the subsequent state of the first state may include determining a subsequent state of the first reference state in the predefined motion to be the subsequent state of the first state. When the first reference state is not included in the predefined motion, the determining of the subsequent state of the first state may include determining the subsequent state of the first state based on the first state, the first reference state, and the subsequent state of the first reference state.
The refining of the motion of the first object may include refining a state of the first object in a kick frame corresponding to a state of the first object in which a kick pose is taken, based on a position of the second object in the kick frame.
The generating of the vector may include generating a control policy based on a second cost function based on the refined motion of the first object and the trajectory of the second object, and on a constraint associated with the joints of the first object, in a dynamic system including the first object and the second object, and generating the vector based on the generated control policy.
The generating of the control policy may include determining the control policy such that the second cost function is less than a preset threshold value while satisfying the constraint. The control policy may include a target state vector corresponding to the motion of the first object and the trajectory of the second object, a target control vector corresponding to joint torques of the first object, and a target feedback gain indicating a ratio between the target state vector and the target control vector.
The simulating may include simulating the motion of the first object and the trajectory of the second object based on the vector and an external force.
The motion of the first object may include a plurality of states of the first object corresponding to a plurality of frames. At least one of the frames may be a kick frame corresponding to a state of the first object in which a kick pose is taken.
Each of states included in the motion of the first object may include positions of the joints of the first object corresponding to a corresponding frame, rotation values of the joints, displacements of the positions, and displacements of the rotation values.
The motion specification may include a motion type, a motion velocity, and a motion angle.
The first object may include a human being playing soccer, the second object may include a soccer ball, and the motion type may include forward dribbling, side dribbling and shooting.
According to another example embodiment, there is provided an apparatus for generating a motion of an object, the apparatus including at least one processor configured to refine a motion of a first object based on a motion of the first object predicted based on a motion specification and a trajectory of a second object controlled by the first object, and simulate a motion of the first object and the trajectory of the second object based on a vector controlling joints of the first object based on the refined motion.
The processor may predict a motion of the first object in a current iteration based on a motion of the first object simulated in a previous iteration.
The trajectory of the second object may include a trajectory of the second object simulated in the previous iteration.
The processor may generate a plurality of windows based on a plurality of states included in the refined motion, and generate a vector for each of the windows based on states of the first object included in a corresponding window and positions of the second object included in the corresponding window.
Additional aspects of example embodiments will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the disclosure.
These and/or other aspects, features, and advantages of the present disclosure will become apparent and more readily appreciated from the following description of example embodiments, taken in conjunction with the accompanying drawings of which:
Hereinafter, some example embodiments will be described in detail with reference to the accompanying drawings. Regarding the reference numerals assigned to the elements in the drawings, it should be noted that the same elements will be designated by the same reference numerals, wherever possible, even though they are shown in different drawings. Also, in the description of embodiments, detailed description of well-known related structures or functions will be omitted when it is deemed that such description will cause ambiguous interpretation of the present disclosure.
The terminology used herein is for describing various examples only, and is not to be used to limit the disclosure. The articles “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. The terms “comprises,” “includes,” and “has” specify the presence of stated features, numbers, operations, members, elements, and/or combinations thereof, but do not preclude the presence or addition of one or more other features, numbers, operations, members, elements, and/or combinations thereof.
Although terms such as “first,” “second,” and “third” may be used herein to describe various members, components, regions, layers, or sections, these members, components, regions, layers, or sections are not to be limited by these terms. Rather, these terms are only used to distinguish one member, component, region, layer, or section from another member, component, region, layer, or section. Thus, a first member, component, region, layer, or section referred to in examples described herein may also be referred to as a second member, component, region, layer, or section without departing from the teachings of the examples.
In addition, when an element, such as a layer, region, or substrate, is described as being “on,” “connected to,” or “coupled to” another element, it may be directly “on,” “connected to,” or “coupled to” the other element, or there may be one or more other elements intervening therebetween. In contrast, when an element is described as being “directly on,” “directly connected to,” or “directly coupled to” another element, there can be no other elements intervening therebetween.
Unless otherwise defined, all terms, including technical and scientific terms, used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this disclosure pertains. Terms, such as those defined in commonly used dictionaries, are to be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art, and are not to be interpreted in an idealized or overly formal sense unless expressly so defined herein.
Hereinafter, a motion to be generated in a system according to example embodiments described herein will be described as a soccer motion, a first object will be described as a character performing the soccer motion, and a second object will be described as a ball, for example, a soccer ball. However, the motion, the first object, and the second object are not limited to the foregoing examples.
Hereinafter, −[ ] may indicate , {circumflex over ( )}[ ] may indicate , ∘[ ] may indicate , and ∇[ ] may denote .
Referring to
The motion predicting component 110 may perform the motion predicting operation 111 to predict a motion including a kick pose from example motions stored in a motion database (DB) 130 and a user motion specification. The predicted motion may be refined through the motion refining operation 112 of the system such that positions of foot joints involved with the kick pose are positioned on or around a ball. The foot joints involved with the kick pose may include a left foot joint and a right foot joint. Hereinafter, a foot joint kicking the ball among the foot joints involved with the kick pose will be referred to as a kick foot or a swing foot for the convenience of description, and another foot joint supporting the kick foot or the swing foot will be referred to as a support foot for the convenience of description.
The motion simulating component 120 may generate a feedback control vector to be used to simulate a full-body motion based on a trajectory of the ball. The motion simulated by the feedback control vector may be fed back to the motion predicting component 110 for predicting a subsequent reference motion.
The motion predicting operation 111 may include an operation of generating a reference motion. Herein, a reference motion M may include character states corresponding to a plurality of frames and be represented as M={Ci|i=1, 2, . . . , Np}, in which Np denotes a size of the reference motion M, for example, the number of frames corresponding to the reference motion M, and Ci denotes a character state corresponding to an ith frame. The term “character state” used herein may indicate a state of a character performing a motion. The character state Ci corresponding to the ith frame may include a pose Qi and a displacement Di of a character that are included in the ith frame, and be represented as Ci=(Qi, Di).
The pose Qi included in the character state Ci corresponding to the ith frame may include a position of a root of the character and rotation values (e.g., quaternion) of joints of the character, and be represented as Qi=(pi0, qi0, qi1, . . . , qiNJ-1). Herein, pi0∈R3 denotes the position of the root, and qi0∈S3 denotes a rotation value of the root, and qij∈S3 denotes a rotation value of a joint j (j=1, 2, . . . , NJ−1, in which Nj denotes the number of the joints of the character). The root described herein may indicate a reference joint, for example, a lower portion of a waist or a pelvis of a human being, among a plurality of joints included in the character. The joint j may indicate one the joints included in the character, excluding the root. The position and the rotation value of the joint j may be determined based on the root.
The displacement Di included in the character state Ci corresponding to the ith frame may include a displacement of the position of the root included in the character and displacements of the rotation values of the joints included in the character, and be represented as Di=(Δpi0, Δqi0, Δqi1, . . . , ΔqiNJ-1). Herein, Δpi0∈R3 denotes the displacement of the position of the root, Δqi0∈S3 denotes a displacement of the rotation value of the root, and Δqij∈S3 denotes a displacement of the rotation value of the joint j. Herein, Δpi0 denotes a difference between the position of the root of the character corresponding to the ith frame and a position of the root of the character corresponding to an i+1th frame. In addition, the displacement of the rotation value may indicate a difference between the rotation value of the joint j of the character corresponding to the ith frame and a rotation value of the joint j of the character corresponding to the i+1 frame.
A rotation value qij of a joint included in a character state may indicate an angle between bones connected by the joint. In addition, a displacement Δqi0 of a rotation value of a joint included in a character state may indicate a difference between a rotation value of the joint included in a character state corresponding to a current frame (e.g., ith frame) and a rotation value of the joint included in a character state corresponding to a subsequent frame (e.g., i+1th frame).
For example, referring to
A reference motion M may include at least one kick frame. The kick frame may refer to a frame corresponding to a state of a character taking a kick pose. The kick pose may be a motion of kicking a ball.
A trajectory of the ball, or a ball trajectory B, may include a position of the ball corresponding to each frame. The ball trajectory B may be represented as B={Bi|i=1, 2, . . . , Nb}. Herein, Bi∈R3 may indicate a position of the ball corresponding to an ith frame, and Nb denotes a size of B, for example, the number of frames corresponding to B.
When a motion specification is input or a current reference motion is all used up, or there is an unexpected external force of a great magnitude, the system may perform an operation of generating a new reference motion.
Before generating a motion, a preprocessing process may be performed on motion clips stored in the DB 130. For example, the preprocessing process may include classifying the motion clips stored in the DB 130 into three motion groups based on a motion type, displaying a kick frame included in the motion clips, and storing, as a predefined kick motion, motion sub-clips including the kick frame and a preset number of frames positioned before and behind the kick frame. Referring to
According to an example embodiment, the system may generate a reference motion based on a motion specification, for example, U={t, v, θ}. Herein, t∈{fwd, side, shoot} indicates a motion type, v denotes a target velocity, and θ denotes a target rotation angle. The motion type t may be used to determine a motion group including motion clips to be used to generate a reference motion.
According to an example embodiment, based on an input motion specification and a character state Ci=(Qi, Di) in a current frame i of a reference motion, a character state −Cp=(−Qp, −Dp) may be selected from motion clips included in a motion group corresponding to a motion type. Herein, p denotes an index of a frame corresponding to a character state selected from motion clips, and the selected character state −Cp may indicate a character state that minimizes a first cost function among all character states −Cj=(−Qj, −Dj) included in the motion group. The first cost function will be described hereinafter.
According to an example embodiment, based on whether −Cp is included in a predefined kick motion, a character state Ci+1 corresponding to a subsequent frame i+1 of a character state Ci corresponding to a current frame i may be determined. A subsequent state may indicate a character state corresponding to a subsequent frame of a current frame. For example, when −Cp is included in the predefined kick motion, the system may determine a subsequent state of −Cp included in the predefined kick motion to be a subsequent state of a reference motion. In contrast, when −Cp is not included in the predefined kick motion, the system may generate a subsequent state Ci+1=(Qi+1, Di+1) of Ci based on Ci, −Cp, and a subsequent state −Cp+1 of −Cp. In this example, to determine Ci+1, {circumflex over ( )}Ci+1 may be calculated first as follows.
{circumflex over ( )}Ci+1=({circumflex over ( )}Qi+1,{circumflex over ( )}Di+1)=(Qi⊚−Dp,−Dp+1),
Q
i⊚−Dp=(pi0+Δ−pp0,Δ−qp0qi0,Δ−qp1qi1, . . . ,Δ−qpNJ-1qiNJ-1)
After calculating {circumflex over ( )}Ci+1, a position Qi+1 of a subsequent state of a character may be obtained by assigning a weight to {circumflex over ( )}Qi+1 to mix it with −Qp+1. In a similar way to one applied to obtain Qi+1, a displacement Di+1 of the subsequent state of the character may be obtained by assigning a weight to {circumflex over ( )}Di+1 and mixing it with −Dp+1. Such a process of determining a subsequent state of a current state in a reference motion may be iterated until −Cp is included in a predefined motion.
The system may select a character state −Cp from motion clips based on a first cost function including four terms.
cost=αrSr(v,−Cj)+αdSd(Ci,−Cj)+αbSb(Ci,−Cj,B)+αθSθ(−Cj,θ), where
αr, αd, αb, and αθ denote weights for the corresponding terms. Sr(v, −Cj) may indicate a cost for obtaining a target velocity v included in a motion specification. Sd(Ci, −Cj) may indicate a cost for improving interdependency on each other of frames including successive character states included in a reference motion while satisfying the motion specification. Sb(Ci,−Cj, B) may indicate a cost for inducting a character to control a ball at a desirable time and position. Sθ(−Cj, θ) may indicate a cost for obtaining a target rotation angle θ included in the motion specification.
The first term Sr(v, −Cj) may be defined as follows.
where
−Cj denotes a character state in a frame j of a motion clip, Δ−p0j+1 denotes a positional displacement of a root from the frame j to a frame j+1 of the motion clip. In addition, h denotes a time interval between two successive frames. ∥Δ−pj+1∥xy may indicate a length of Δ−p0j+1 projected to a floor surface. −Cp to be selected by the term Sr(v, −Cj) may indicate a character state −Cp of a motion clip that minimizes a sum of squares of differences between the target velocity v and character root velocities, with respect to Ns states from a state −Cj to a state −Cj+Ns-1 of the motion clip.
The second term Sd(Ci, −Cj) may be defined as follows.
Sd(Ci,
−Cp to be selected by the cost term Sd(Ci, −Cj) may indicate a character state −Cp that minimizes a sum of d(Ci-1, −Cj-1) which is a motion distance between Ci-1 of a reference motion and −Cj-1 of a motion clip, with respect to l=1, . . . , Nd, based on previous states of a current state Ci of the reference motion, for example, Nd previous states from a state Ci-1 to a state Ci-Nd. The motion distance d(Ci-1, −Cj-1) may be a motion distance that is calculated by a known method.
The third term Sb(Ci,−Cj, B) may be defined as follows.
where
−fj+k∈R3 may indicate a position of a foot joint of a character that is included in a state −Cj+k including a kick pose in a motion sub-clip starting from a state −Cj. Bi+k may indicate a position of a ball corresponding to a frame i+k included in a trajectory B of the ball. Δ−pj0 may indicate a displacement of a character root in a frame j with respect to −p00 of a motion clip. −Cp to be selected by the term Sb(Ci,−Cj, B) may indicate −Cp including a kick pose that is closest to the ball among a set −K of kick poses included in motion clips. However, when a kick pose is not included in the motion clips, a small positive constant c may be returned.
The fourth term Sθ(−Cj, θ) may be defined as follows.
Sθ(−Cj, θ)=(−θj−θ)2, where
−θj denotes a rotation angle of a state −Cj that is indicated in advance. −Cp to be selected by the term Sθ(−Cj, θ) may indicate −Cp in which a rotation value of a character root projected to a floor surface is closest to a target rotation angle θ.
According to the term Sd(Ci, −Cj) in the first cost function, Nd previous states of a current state Ci from a state Ci-1 to a state Ci-Nd may need to be considered, and thus the first cost function may be calculated when at least Nd character states are included in a reference motion. However, the Nd previous states of the current state Ci are not present in a step in which the reference motion is initially generated, and thus the term Sd(Ci, −Cj) in the first cost function may not be calculated. In such a case, based on whether a reference motion for which simulation is already completed in the system has been generated before, a method of setting the Nd previous states {C1-i|i=1, 2, . . . , Nd} of the current state Ci may vary.
For example, when a reference motion for which simulation is already completed in the system has been generated before, character states included in a most recently generated reference motion may be used to generate a current reference motion. In this example, most recent Nd states of a reference motion simulated immediately before may be set to be a previous state {C1-i|i=1, 2, . . . , Nd} of the current reference motion. That is, the system may correspond to a feedback system in which a motion generated in a previous step is applied to a motion to be generated in a next step.
In contrast, when a reference motion for which simulation is already completed in the system has not been generated before, Nd states included in a motion sub-clip may be set to be a previous state {C1-i|i=1, 2, . . . , Nd} of a current reference motion. For this, the system may select C1init that minimizes an initial cost Sinit from among all states −Cj included in a motion clip corresponding to a motion type t0 of an initial motion specification U0=(t0, v0, θ0). The initial cost Sinit may be represented as follows.
When C1init that minimizes Sinit is determined, the system may select Nd states starting from C1init from a selected motion clip, and set the selected Nd states to be a previous state {C1-i|i=1, 2, . . . , Nd} of a current reference motion. Herein, C1-Nd=C1init. A rotation value q1-i0 and a displacement Δp1-i0 of a character root in each state C1-i may be refined to be arranged in accordance with an initial position of a ball.
As described above, the motion predicting component 110 may generate a reference motion based on a first cost function. The generating of the reference motion based on the first cost function may include generating the reference motion such that the first cost function is minimized.
A reference motion M={Ci|i=1, . . . , Np} that is generated as described above may be a reference motion generated without considering a position of a ball and a kick pose of a character, and thus the reference motion may need to be refined based on the position of the ball and the kick pose of the character.
For example, referring to
Thus, the motion predicting component 110 may adjust a character state included in a reference motion to be suitable for a position of a ball and a kick pose through the motion refining operation 112. The motion refining operation 112 may include changing positions of joints included in a character to be suitable for the position of the ball and the kick pose by changing a reference motion M. The joints included in the character of which the respective positions are to be changed based on the position of the ball may include a kick foot.
The motion refining operation 112 may include defining two displacement vectors v0 and v1 respectively for a position fk of a kick foot included in a character state Cκ corresponding to a kick frame K from a root position p10 included in a character state C1 corresponding to a first frame, and for a position Bκ of a ball corresponding to the kick frame κ from the root position p10.
v
0
=f
κ
−p
1
0,
v
1
=B
κ
−p
1
0
The motion refining operation 112 may then include deriving, from the two displacement vectors v0 and v1, a scaling factor η∈R and a rotation vector θr∈R3 that are used to change a reference motion such that a position of a kick foot matches a position of a ball. Herein, η and θr may be represented as follows.
where
a symbol {circumflex over ( )} indicates normalization of a corresponding vector.
The motion refining operation 112 may then include converting a positional displacement Δpi0 between and a position pi0 of a root and a position of the root in each frame, and a rotation value displacement Δqi0, using η and θr for each frame i=1, 2, . . . , Np, as represented below.
where
E(θr) indicates a function that maps a rotation vector θr to a corresponding rotation matrix, and exp(θr) indicates a function that maps the rotation vector θr to a corresponding quaternion.
In general, a motion of a character obtained by simulating a reference motion may not exactly match the reference motion due to fine and complex motion dynamics required to control a ball. As the simulation progresses, a current state of the character may tend to deviate from a corresponding state of a reference motion M, which may negatively affect the stability of motion control. The system may reduce such a deviation for each window through the simulation-based motion changing operation 121. The simulation-based motion changing operation 121 that changes a motion to be suitable for simulation may include optimizing a motion.
For example, referring to
The system may define a system dynamic model that handles a motion of a character and a motion of a ball and dynamics of each of the motions, and a physical interaction therebetween. The system may first define a state vector xi and a control vector ui corresponding to a window in each time step i included in the system dynamic model.
x
i=[(Qic)T(Qib)T(∘Qic)T(∘Qib)T]T,
u
i=τi, where
Qic∈Rnc indicates a pose of a character having an nc degree of freedom (DoF), and Qib∈R6 indicates a position and a rotation value of a second object having 6DoF. In addition, ∘Qic and ∘Qib indicate a derived function based on a time Qic and a time Qib, respectively. For efficiency of calculation, it may be possible to reduce a DoF of a state vector by representing a movement of joints, excluding some joints (e.g., shoulder joint) based on a Euler angle.
In addition, τi∈Rnc-6 indicates joint torques of a character, excluding a root, in a window of a time step i. The joint torques of the character may correspond to rotation forces determined based on rotation values and rotation value displacements of the joints included in the character. As described above, rotation values qij of joints included in a character state of the character may correspond to angles formed between bones connected through the joints, and the joint torques may be determined based on rotation value displacements of the joints included in the character.
In the system dynamic model, a state vector xi+1 corresponding to a window of a subsequent time step i+1 of a current time step i may be represented as follows based on a size h of a time step when performing an integration and on a semi-implicit Euler method.
x
i+1
=g(xi,ui)=[(Qic+h∘Qi+1c)(Qib+h∘Qi+1b)(∘Qi+1c)(∘Qi+1b)]
In a subsequent time step, a joint velocity ∘Qi+1c of a character and a velocity ∘Qi+1b of a ball may be derived as follows by combining dynamics of the character and the ball with a physical interaction therebetween.
where
τic=[01×6 (τi)T]T∈Rnc. M(⋅) may indicate a total mass matrix, and e(⋅) may indicate a bias force. The mass matrix M(⋅) may be a mass matrix obtained by converting a general mass matrix based on an armature inertial and damping to improve the stability of a numerical integration of dynamics. The bias force e(⋅) may correspond to torques generated by an external force fec applied to the character and an external force feb applied to the ball in addition to gravity, a Coriolis force, and a centrifugal force. kd denotes a damping gain, and J(⋅) indicates a kinematic Jacobian matrix of a contact point on which a contact impulse fict acts.
The motion simulating component 120 may optimize a motion of a character and a motion of a ball and simulate them such that the character moves according to a reference motion M while interacting with the motion of the ball, based on a current state vector xi and the reference motion M. For example, based on the system dynamic model, a series of control vectors U={ui|i=1, 2, . . . , Nopt−1} may be derived as follows by formulating a finite-horizon optimization control problem in a window including Nopt frames.
where
c(xi, ui) and cf(xNopt) indicate a second cost function in a time step i (i=1, 2, . . . , Nopt-1) and a last time step Nopt, respectively. Two equations x1=x and xi+1=g(xi, ui) may be an equation that limits the system dynamic model that derives a state vector xi+1 in a subsequent time step i+1 from a state vector xi in a current time step i. γj(xi) may indicate a jth inequality constraint in a time step i, in which j=1, 2, . . . , L (L denotes the number of inequality constraints).
When −Xc={(−Qic, ∇Qic)|i=1, 2, . . . , Nopt} is defined as a target trajectory of a character in a window that is extracted from a reference motion M, each second cost function c(xi, ui) in a time step i (i=1, 2, . . . , Nopt−1) may be represented as follows.
c(xi,ui)=cref(xi,ui)+cfpos(xi)+cball(xi)
A term cref(xi, ui) included in a second cost function may indicate a cost for tracking a target trajectory −Xc of a character, and be represented as follows.
where
ri∈R3 indicates a displacement vector from a root to a head joint in a time step i, and −ri denotes a target vector calculated from −Qic. A first term of cref(xi, ui) may indicate a cost for tracking a target pose of the character, a second term of cref(xi, ui) may indicate a cost for maintaining a joint velocity to be close to a target velocity, a third term of cref(xi, ui) may indicate a cost for maintaining a rotation value of an upper body joint to be close to a target rotation value of the upper body joint, and a fourth term of cref(xi, ui) may indicate an energy consumption cost. In addition, wi (i=1, 2, 3, 4) denotes a weight of each term.
cfpos(xi) may indicate a cost for tracking a target position of a kick foot, and be represented as follows.
where
pilf and pirf may respectively indicate a position of a left foot joint and a position of a right foot joint in a time step i. In addition, −pilf and −pirf may indicate a target position of the left foot joint and a target position of the right foot joint, respectively. w5 denotes a weight. Thus, cfpos(xi) may be a cost for a character to kick a ball with a swing foot in a timely manner and place a support foot of the character at a correct position.
cball(xi) may indicate a cost for controlling a ball, and be represented as follows.
where
Rbiy∈R indicates a position of a ball on a y axis in a root coordinate system R in a time step i. For example, referring to
A first term of cball(xi) may indicate a cost for adjusting a position of a character such that a ball is arranged in front of the character, and be activated only when a character motion of the character corresponds to forward dribbling. A second term of cball(xi) may indicate a cost for the character to kick the ball at the target velocity of the ball, and be activated in frames close to a kick frame because a speed of the ball is controlled by a motion of the character kicking the ball.
Under an inequality constraint γj(xi)≤0 (j=1, 2, . . . , L) based on each time step i (i=1, 2, . . . , Nopt) that a shape of a foot of the character is a cuboid shape, it may be activated in the frames close to the kick frame as a cost for arranging the ball to be kicked from a front side of a swing foot at a right time.
Fbi may indicate a position of the ball in a kick foot coordinate system F in a time step i. Referring to
−Fbxi≤0,Fbxi−rb≤0, where
rb denotes a radius of the ball.
In addition, by the following four inequality constraints, it may be set such that a position of a ball projected to a y-z plane of a local coordinate system is arranged to be in front of a kick foot.
Referring to
The system may use an iterative linear quadratic Gaussian (iLQG) algorithm without constraints to solve an optimization control problem, and thus require a process of converting the constraints to a cost condition. For this, a smooth-max (hereinafter simply smax) function and a smooth-min (hereinafter simply smin) function that have a threshold value α may be defined as represented below.
A first function may return a value close to (x−α) when x>α, and a value close to 0 otherwise. A second function may return a value close to (α−x) when x<α, and a value close to 0 otherwise. β denotes a smoothing coefficient that adjusts the closeness of a function to 0 when x=α. Using the smax (⋅) and smin (⋅) functions, an inequality constraint may be converted to a third cost function including the following three terms.
c
kick(xi)=w8(cxkick(xi)+cykick(xi)+czkick(xi)), where
w8 denotes a weight constant, and each term in ckick(xi) may be defined as follows.
Since a control vector uNopt is not required in a last time step Nopt, and thus cf(xNopt) of the third cost function may be the same as c(xi, ui) in another time step i, except that it does not have a fourth term
in cref(xi, ui).
When a current state vector xi and a reference motion M are given, the optimization control problem of the system dynamic model may be solved by the iLQG algorithm that is a modification to a differential dynamic programming (DDP) algorithm. The iLQG algorithm may be substantially faster than the DDP algorithm because it does not use a dichotomy function of the system dynamic model. The iLQG algorithm applied to the system dynamic model may generate an optimal control policy to obtain an optimal feedback control vector for controlling a soccer motion. Thus, the generated optimal control policy may include an optimal control vector {u*i|i=1, 2, . . . , Nopt−1}, an optimal state vector {x*i|i=1, 2, . . . , Nopt}, and an optimal feedback gain matrix {K*i|i=1, 2, . . . , Nopt−1}. The system may calculate an optimal feedback control vector u*fbi in each frame i of a window based on the optimal control policy as represented below.
u*
i
fb
=u*
i
+K*
i(xi−x*i)
A second term may indicate a term for compensating for a deviation between a current state and an optimal state vector. The motion simulating operation 122 may include updating a current state xi based on a feedback control vector u*ifb indicating feedback torques of joints of a character and on an external force when there is the external force. The system may perform simulation for each window while moving windows until a state simulated with a great external force applied to the character deviates greatly from a corresponding state of a reference motion or a generated reference motion is all used up.
Referring to
For example, when a state simulated by applying the external force to the character deviates greatly from a corresponding state of a reference motion or a generated reference motion is all used up, the system described herein may generate a new reference motion by activating a feedback control loop based on Nd character states of a most recently simulated motion of the character.
The motion of the first object predicted in operation 910 may correspond to a reference motion described above. The motion of the first object may include a plurality of states of the first object corresponding to a plurality of frames, and at least one of the frames may be a kick frame corresponding to a state of the first object taking a kick pose. Each of the states included in the motion of the first object may include positions of the joints of the first object corresponding to each of the frames, rotation values of the joints, displacements of the positions, and displacements of the rotation values. As described above, a state of the first object corresponding to a frame i may be represented as Ci=(Qi, Di).
The motion specification may include a motion type, a motion velocity, and a motion angle. The motion type may correspond to a motion type t described above. The motion velocity may correspond to a target velocity v described above, and the motion angle may correspond to a target angle θ described above. The first object may include a human being who plays soccer or a character performing soccer, and the second object may include a ball. In this case, the motion type may include forward dribbling, side dribbling, and shooting.
Operation 910 of predicting the motion of the first object may include predicting a motion of the first object in a current iteration based on an example motion corresponding to the motion specification among example motions stored in a DB. The example motions may correspond to motion clips described above, and the example motion corresponding to the motion specification may correspond to a motion clip included in a motion group corresponding to the motion type included in the motion specification. The motion of the first object predicted in the current iteration may correspond to a reference motion generated in a current time step i as described above.
Operation 910 of predicting the motion of the first object may include selecting a first reference state from among a plurality of reference states included in the example motion based on a first cost function based on the motion specification and a first state of the first object, and determining a subsequent state of the first state based on whether the selected first reference state is included in a predefined kick motion. When the first reference state is included in the predefined motion, the determining of the subsequent state of the first state may include determining, to be the subsequent state of the first state, a subsequent state of the first reference state in the predefined kick motion. When the first reference state is not included in the predefined motion, the determining of the subsequent state of the first state may include determining the subsequent state of the first state based on the first state, the first reference state, and the subsequent state of the first reference state. The first reference state may correspond to a character state −Cp selected from a motion clip based on the first cost function including four terms described above.
Operation 910 of predicting the motion of the first object may include predicting a motion of the first object in a current iteration based on a motion of the first object simulated in a previous iteration. That is, operation 910 may include generating a current reference motion based on a reference motion of the first object with which simulation is already completed, in addition to generating the reference motion of the first object based on a motion clip stored in the DB and the motion specification.
Operation 920 of refining the motion of the first object may include refining a state of the first object in the kick frame corresponding to a state of the first object taking the kick pose based on a position of the second object in the kick frame. For example, in a case in which the first object is a character and the second object is a ball, operation 920 may correspond to an operation of refining a reference motion based on a position of the ball and a kick pose of the character.
Operation 930 of generating the vector for controlling the joints of the first object may include generating a plurality of windows based on a plurality of states included in the refined motion, and generating a vector for each of the windows based on states of the first object included in a corresponding window and positions of the second object included in the corresponding window, for each of the windows. Herein, a window may correspond to a unit obtained by dividing a motion of the first object including a plurality of frames by a size including a preset number of frames. The vector for controlling the joints of the first object may correspond to a feedback control vector described above.
Operation 930 of generating the vector for controlling the joints of the first object may include generating a control policy based on a second cost function based on the refined motion of the first object and the trajectory of the second object, and on a constraint associated with the joints of the first object, in a dynamic system including the first object and the second object, and generating the vector based on the generated control policy. The dynamic system may correspond to a system dynamic model described above. The trajectory of the second object may include a trajectory of the second object simulated in a previous iteration. The constraint may include an inequality constraint described above.
The control policy may include a target state vector corresponding to the motion of the first object and the trajectory of the second object, a target control vector corresponding to joint torques of the first object, and a target feedback gain indicating a ratio between the target state vector and the target control vector. The target state vector may include an optimal state vector described above, the target control vector may include an optimal control vector described above, and the target feedback gain may include an optical feedback gain matrix described above.
The generating of the control policy may include determining the control policy such that the second cost function is less than a preset threshold value while satisfying the constraint. For example, the generating of the control policy may include determining the control policy such that the second cost function is minimized. In this example, the target state vector included in the control policy may correspond to the optimal state vector, the target control vector may correspond to the optical control vector, and the target feedback gain may correspond to the optimal feedback gain matrix.
Operation 940 of simulating the motion of the first object and the trajectory of the second object may include simulating the motion of the first object and the trajectory of the second object based on the vector generated in operation 930 and an external force. The motion of the first object and the trajectory of the second object that are simulated in operation 940 may be used to perform operation 910 of predicting a motion of the first object in a next iteration.
The example embodiments described herein may be applied to various applications that simulate a motion of a first object (e.g., avatar, character, user, robot, and others) and a trajectory of a second object (e.g., ball, tool, and others) controlled by the first object. For example, the example embodiments may be applied to control a robot. In this example, a signal that controls the robot may be generated based on a motion of the first object. For another example, the example embodiments may be applied to a game engine. In this example, objects in a game may be represented or modeled based on a motion of the first object and/or a trajectory of the second object.
The units described herein may be implemented using hardware components and software components. For example, the hardware components may include microphones, amplifiers, band-pass filters, audio to digital convertors, non-transitory computer memory and processing devices. A processing device may be implemented using one or more general-purpose or special purpose computers, such as, for example, a processor, a controller and an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate array (FPGA), a programmable logic unit (PLU), a microprocessor or any other device capable of responding to and executing instructions in a defined manner. The processing device may run an operating system (OS) and one or more software applications that run on the OS. The processing device also may access, store, manipulate, process, and create data in response to execution of the software. For purpose of simplicity, the description of a processing device is used as singular; however, one skilled in the art will appreciated that a processing device may include multiple processing elements and multiple types of processing elements. For example, a processing device may include multiple processors or a processor and a controller. In addition, different processing configurations are possible, such a parallel processors.
The software may include a computer program, a piece of code, an instruction, or some combination thereof, to independently or collectively instruct or configure the processing device to operate as desired. Software and data may be embodied permanently or temporarily in any type of machine, component, physical or virtual equipment, computer storage medium or device, or in a propagated signal wave capable of providing instructions or data to or being interpreted by the processing device. The software also may be distributed over network coupled computer systems so that the software is stored and executed in a distributed fashion. The software and data may be stored by one or more non-transitory computer readable recording mediums. The non-transitory computer readable recording medium may include any data storage device that can store data which can be thereafter read by a computer system or processing device.
The methods according to the above-described example embodiments may be recorded in non-transitory computer-readable media including program instructions to implement various operations of the above-described example embodiments. The media may also include, alone or in combination with the program instructions, data files, data structures, and the like. The program instructions recorded on the media may be those specially designed and constructed for the purposes of example embodiments, or they may be of the kind well-known and available to those having skill in the computer software arts.
Examples of non-transitory computer-readable media include magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROM discs, DVDs, and/or Blue-ray discs; magneto-optical media such as optical discs; and hardware devices that are specially configured to store and perform program instructions, such as read-only memory (ROM), random access memory (RAM), flash memory (e.g., USB flash drives, memory cards, memory sticks, etc.), and the like. Examples of program instructions include both machine code, such as produced by a compiler, and files containing higher level code that may be executed by the computer using an interpreter. The above-described devices may be configured to act as one or more software modules in order to perform the operations of the above-described example embodiments, or vice versa.
While this disclosure includes specific examples, it will be apparent to one of ordinary skill in the art that various changes in form and details may be made in these examples without departing from the spirit and scope of the claims and their equivalents. The examples described herein are to be considered in a descriptive sense only, and not for purposes of limitation. Descriptions of features or aspects in each example are to be considered as being applicable to similar features or aspects in other examples. Suitable results may be achieved if the described techniques are performed in a different order, and/or if components in a described system, architecture, device, or circuit are combined in a different manner and/or replaced or supplemented by other components or their equivalents. Therefore, the scope of the disclosure is defined not by the detailed description, but by the claims and their equivalents, and all variations within the scope of the claims and their equivalents are to be construed as being included in the disclosure.
Number | Date | Country | Kind |
---|---|---|---|
10-2020-0015776 | Feb 2020 | KR | national |