METHOD AND APPARATUS FOR GENERATING MOTION OF OBJECT

Information

  • Patent Application
  • 20210248287
  • Publication Number
    20210248287
  • Date Filed
    June 11, 2020
    4 years ago
  • Date Published
    August 12, 2021
    3 years ago
Abstract
A method of simulating a motion of an object controlling another object based on an example motion or a previously generated motion of the object is disclosed. The method includes refining a motion of a first object based on a motion of the first object predicted based on a motion specification, and on a trajectory of a second object controlled by the first object, and simulating the motion of the first object and the trajectory of the second object based on a vector for controlling joints of the first object that is generated based on the refined motion.
Description
CROSS-REFERENCE TO RELATED APPLICATION(S)

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.


BACKGROUND
1. Field

One or more example embodiments relate to a method and apparatus for generating and simulating a motion of an object.


2. Description of Related Art

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.


SUMMARY

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.





BRIEF DESCRIPTION OF THE DRAWINGS

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:



FIG. 1 illustrates an example of a system for generating a simulated motion of a first object controlling a second object according to an example embodiment;



FIG. 2 illustrates an example of a state of a character corresponding to each frame according to an example embodiment;



FIGS. 3A through 3C illustrate examples of results of simulating a trajectory of a ball and a state of a character in a kick frame according to an example embodiment;



FIG. 4 illustrates an example of a process of dividing a reference motion into windows by a certain frame size and moving them iteratively according to an example embodiment;



FIG. 5 illustrates an example of joints of a character and a rotation value of each of the joints according to an example embodiment;



FIG. 6 illustrates an example of a root coordinate system R and a position of a ball according to an example embodiment;



FIGS. 7A through 7C illustrate an example of a kick foot coordinate system F and a position of a ball according to an example embodiment;



FIGS. 8A and 8B illustrate an example of when a great external force is applied to a character performing a soccer motion according to an example embodiment; and



FIG. 9 illustrates an example of a flowchart of a motion generating method according to an example embodiment.





DETAILED DESCRIPTION

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.



FIG. 1 illustrates an example of a system for generating a simulated motion of a first object controlling a second object according to an example embodiment.


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 custom-character, {circumflex over ( )}[ ] may indicate custom-character, [ ] may indicate custom-character, and [ ] may denote custom-character.


Referring to FIG. 1, a motion generating system (hereinafter simply “system”) includes a motion predicting component 110 and a motion simulating component 120. The motion predicting component 110 and the motion simulating component 120 may operate in cooperation with each other through a feedback loop to generate a simulated soccer motion. Operations to be performed in the system include a motion predicting operation 111, a motion refining operation 112, a simulation-based motion changing operation 121, and a motion simulating operation 122. Such a series of the operations described in the foregoing may form the feedback loop. In addition, a finally simulated motion generating operation 101 may be performed after at least one iteration of the feedback loop.


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 FIG. 5, joints included in a character may correspond to points illustrated in FIG. 5, and a rotation value qij of each of the joints included in a state of the character may indicate an angle formed between bones connected by each of the joints. In addition, θj illustrated in FIG. 5 may indicate qij, in which j=1, 2, . . . , and 10.


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 FIG. 2, each illustrated shape of a character may be a shape representing a state of the character corresponding to each frame. For example, motion sub-clips 210 including a kick frame corresponding to a character shape 201 taking a kick pose and a preset number of frames positioned before and behind the kick frame may be stored as a predefined kick motion in the DB 130. A rotation angle of the character in a plurality of frames included in each motion clip may then be displayed. For example, G={gfwd, gside, gshoot}, which may indicate a set of motion groups corresponding to a certain motion type. In addition, K={Qk|k=1, 2, . . . , Nk}, which may indicate a set of kick poses included in motion clips. Herein, gfwd denotes a motion type indicating forward dribbling, gside denotes a motion type indicating side dribbling, and gshoot denotes a motion type indicating shooting. In addition, Qk denotes a kick pose, and Nk denotes the number of kick poses included in motion clips.


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)=(QiDp,Dp+1),






Q
iDp=(pi0pp0qp0qi0qp1qi1, . . . ,Δ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.









S
r



(

v
,


C
_

j


)


=




l
=
0



N
s

-
1





(

v
-





Δ



p
_

0

j
+
l






x

y


h


)

2



,




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+1xy 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, Cj)=Σl=1Ndd(Ci-l,Cj-l), where



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.








S
b



(


C
i

,


C
_

j

,


)


=

{











f
_


j
+
k


-

(


B

i
+
k


-

(



p
_

0
j

+

p
0
i


)


)




xy
2






if







f
_


j
+
k







exists






ϵ





otherwise




,






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.








S
init



(


v
0

,


C
_

j


)


=




l
=
0



N
s

-
1





(


v
0

-





Δ



p
_

0

j
+
l






x

y


h


)

2






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 FIGS. 3A through 3C, a result of simulating a reference motion refined based on a position of a ball and a kick pose of a character in a kick frame may be obtained as illustrated in FIG. 3A. However, when the position of the ball is not considered, positions of foot joints included in the kick pose may not be accurately arranged in accordance with the position of the ball as illustrated in FIG. 3B. In addition, when the kick pose is not considered, a position of a foot joint of the other foot of a swing foot may be arranged inaccurately as illustrated in FIG. 3C.


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.







η
=





(

v
1

)

xy







(

v
0

)

xy





,






θ
r

=



cos

-
1




(



(


v
^

0

)

xy

·


(


v
^

1

)

xy


)




(



(


v
^

0

)

xy

×


(


v
^

1

)

xy


)



,




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.








(

p
0
i

)

xy


=

{








(

p
0
i

)

xy






if





i

=
1









(

p
0

i
-
1


)

xy


+

η






E


(

θ
r

)





(

Δ






p
0

i
-
1



)

xy






otherwise










,







(

Δ






p
0
i


)

xy


=

η






E


(

θ
r

)





(

Δ






p
0
i


)

xy



,







(

Δ






q
0
i


)



=


exp


(

θ
r

)





q
0
i

.









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 FIG. 4, the system may change a remaining portion of a reference motion M such that a position of a root of a character in an initial state matches a position of the root in a current state, while moving a window in the reference motion M. Subsequently, the system may arrange a kick foot in a kick frame included in the reference motion M based on a position of a ball. The kick frame may correspond to a first frame of a last window included in the reference motion M. For example, the system may divide the reference motion M into optimization windows of a size including Nopt frames, and generate a feedback control vector while moving a window iteratively m times at intervals of Nshift frames and solving an optimal control problem in each window. In this example, a feedback control vector generated in a window in a time step i may generate a simulated motion corresponding to the window in the time step i, and the generated simulated motion corresponding to the window in the time step i may be used to generate a simulated motion corresponding to a window in a time step i+1.


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
ii, 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+hQi+1c)(Qib+hQi+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.








[





Q
.

c

i
+
1








Q
.

b

i
+
1





]

=


[





Q
.

c
i







Q
.

b
i




]

+


hM

-
1




(


[




τ
c
i






0

6
×
1





]

-

[




e


(


Q
c
i

,


Q
.

c
i

,

f
c
e


)







e


(


Q
b
i

,


Q
.

b
i

,

f
b
e


)





]

-


k
d



[





Q
.

c
i







Q
.

b
i




]



)


+



M

-
1




[





J


(

Q
c
i

)


T







J


(

Q
b
i

)


T




]




f
ct
i




,










where









M

=

[




M


(

Q
c
i

)





0


n
c

×
6







0

6
×

n
c






M


(

Q
b
i

)





]


,




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.









min
U






i
=
1



N
opt

-
1




c


(


x
i

,

u
i


)




+


c
f



(

x

N
opt


)



,






subject





to






x
1


=
x

,


x

i
+
1


=



g


(


x
i

,

u
i


)







for





i

=
1


,
2
,





,


N
opt

-
1

,








γ
j



(

x
i

)




0





for





i


=
1

,
2
,





,

N
opt

,

j
=
1

,
2
,





,

L
.





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.









c
ref



(


x
i

,

u
i


)


=




w
1

2








Q
_

c
i

-

Q
c
i




2


+



w
2

2








Q
_

c
i

-

Q
c
i




2


+



w
3

2








r
_

i

-

r
i




2


+



w
4

2






r
i



2




,




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.









c
fpos



(

x
i

)


=



w
5

2







[





p
_

lf
i







p
_

rf
i




]

-

[




p
lf
i






p
rf
i




]




2



,




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.









c
ball



(

x
i

)


=




w
6

2




(

b
y
i




R

)

2


+



w
7

2









b
.

_

i

-


b
.

i




2




,




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 FIG. 6, the root coordinate system R may indicate a position Rby of the ball on the y axis in the root coordinate system R having a root position 601 as a starting point. In addition, bi indicates a time-based derived function of a position bi∈R3 of the ball in the time step i, and bi indicates a target velocity of the ball in the time step i. w6 and w7 denote weights.


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 FIG. 7A, the kick foot coordinate system F may be a three-dimensional (3D) coordinate system having a position of a kick foot as a starting point. The position Fbi of the ball may be indicated by an x-axis coordinate, a y-axis coordinate, and a z-axis coordinate (Fbix, Fbiy, Fbiz) in the kick foot coordinate system F. In detail, referring to FIG. 7B illustrating a side view (in a x-z plane direction), the x-axis coordinate of the ball in the kick foot coordinate system F may be determined to be Fbx. In addition, referring to FIG. 7C illustrating a front view (in a y-z plane direction), the y-axis coordinate and the z-axis coordinate of the ball in the kick foot coordinate system F may be determined to be Fby and Fbz, respectively. In the system dynamic model, by the following two inequality constraints, it may be set such that a front side of a foot kicks a ball in an x-axis direction.





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.










-

1
2




l
y


-

F

b
y
i




0

,



F

b
y
i


-


1
2



l
y




0

,








-

1
2




l
z


-

F

b
z
i




0

,



F

b
z
i


-


1
2



l
z




0.





Referring to FIG. 7C, ly and lz may respectively indicate a width and a height of a front side. The system dynamic model may allow a portion of a kick foot to get to a ball for more natural contact between colliding bodies.


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.








smax


(


x
;
α

,
β

)


=


1
2



(





(

x
-
α

)

2

+

β
2



+

(

x
-
α

)


)



,






smin


(


x
;
α

,
β

)


=


1
2




(





(

x
-
α

)

2

+

β
2



-

(

x
-
α

)


)

.







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.









c
x
kick



(

x
i

)


=


smin


(



F

b
x
i


;
0

,
β

)


+

smax


(



F

b
x
i


;

r
b


,
β

)




,







c
y
kick



(

x
i

)


=


smin


(



F

b
y
i


;


-

1
2




l
y



,
β

)


+

smax


(



F

b
y
i


;


1
2



l
y



,
β

)




,







c
z
kick



(

x
i

)


=


smin


(



F

b
z
i


;


1
2



l
z



,
β

)


+


smax


(



F

b
z
i


;


1
2



l
z



,
β

)


.







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








w
4

2






τ
Nopt



2





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 FIGS. 8A and 8B, a great external force may be applied to a character performing a soccer motion when the character is pushed or tackled by another character.


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.



FIG. 9 illustrates an example of a flowchart of a motion generating method according to an example embodiment. Referring to FIG. 9, a motion generating method includes operation 910 of predicting a motion of a first object based on a motion specification, operation 920 of refining the motion of the first object based on the predicted motion and a trajectory of a second object controlled by the first object, operation 930 of generating a vector for controlling joints of the first object based on the refined motion, and operation 940 of simulating the motion of the first object and the trajectory of the second object based on the generated vector.


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.

Claims
  • 1. A method of generating a motion of an object, comprising: 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; andsimulating a motion of the first object and the trajectory of the second object based on the generated vector.
  • 2. The method of claim 1, wherein the predicting of the motion of the first object comprises: predicting a motion of the first object in a current iteration based on a motion of the first object simulated in a previous iteration.
  • 3. The method of claim 1, wherein the trajectory of the second object includes a trajectory of the second object simulated in a previous iteration.
  • 4. The method of claim 1, wherein the generating of the vector comprises: generating a plurality of windows based on a plurality of states included in the refined motion; andgenerating 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.
  • 5. The method of claim 1, wherein the predicting of the motion of the first object comprises: 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 advance in a database.
  • 6. The method of claim 1, wherein the predicting of the motion of the first object comprises: selecting a first reference state from among a plurality of reference states included in an example motion based on a first cost function based on the motion specification and a first state of the first object; anddetermining a subsequent state of the first state based on whether the first reference state is included in a predefined kick motion.
  • 7. The method of claim 6, wherein the determining of the subsequent state of the first state comprises: when the first reference state is included in the predefined kick motion, determining a subsequent state of the first reference state in the predefined kick motion to be the subsequent state of the first state; andwhen the first reference state is not included in the predefined kick motion, 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.
  • 8. The method of claim 1, wherein the refining of the motion of the first object comprises: 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.
  • 9. The method of claim 1, wherein the generating of the vector comprises: in a dynamic system including the first object and the second object, 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; andgenerating the vector based on the generated control policy.
  • 10. The method of claim 9, wherein the generating of the control policy comprises: determining the control policy such that the second cost function is less than a preset threshold value while satisfying the constraint, wherein the control policy includes 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.
  • 11. The method of claim 1, wherein the simulating comprises: simulating the motion of the first object and the trajectory of the second object based on the vector and an external force.
  • 12. The method of claim 1, wherein the motion of the first object includes a plurality of states of the first object corresponding to a plurality of frames, wherein at least one of the frames is a kick frame corresponding to a state of the first object in which a kick pose is taken.
  • 13. The method of claim 1, wherein each of states included in the motion of the first object includes 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.
  • 14. The method of claim 1, wherein the motion specification includes a motion type, a motion velocity, and a motion angle.
  • 15. The method of claim 14, wherein the first object includes a human being playing soccer, the second object includes a soccer ball, and the motion type includes forward dribbling, side dribbling, and shooting.
  • 16. A non-transitory computer-readable storage medium storing instructions that, when executed by a processor, cause the processor to perform the method of claim 1.
  • 17. An apparatus for generating a motion of an object, comprising: 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.
  • 18. The apparatus of claim 17, wherein the processor is configured to predict a motion of the first object in a current iteration based on a motion of the first object simulated in a previous iteration.
  • 19. The apparatus of claim 17, wherein the trajectory of the second object includes a trajectory of the second object simulated in a previous iteration.
  • 20. The apparatus of claim 17, wherein the processor is configured to 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.
Priority Claims (1)
Number Date Country Kind
10-2020-0015776 Feb 2020 KR national