<!DOCTYPE html>
<html data-wf-domain="" data-wf-page="596e65d120426e09785027f0" data-wf-site="596e65d120426e09785027eb" data-wf-status="1"
    class="w-mod-js wf-opensans-n3-active wf-opensans-n4-active wf-roboto-n4-active wf-opensans-i3-active wf-opensans-i4-active wf-opensans-n6-active wf-opensans-i6-active wf-opensans-n7-active wf-opensans-i7-active wf-opensans-n8-active wf-opensans-i8-active wf-roboto-n3-active wf-roboto-n5-active wf-active">

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <title>NeMF</title>
    <meta content="width=device-width, initial-scale=1" name="viewport">
    <meta content="Webflow" name="generator">
    <link href="./files/supplemental.css" rel="stylesheet" type="text/css">
    <script src="./files/webfont.js" type="text/javascript"></script>
    <script type="text/javascript">
        WebFont.load({
            google: {
                families: ["Open Sans:300,300italic,400,400italic,600,600italic,700,700italic,800,800italic", "Roboto:300,regular,500"]
            }
        });
    </script>
    <script type="text/javascript">
        ! function (o, c) {
            var n = c.documentElement,
                t = " w-mod-";
            n.className += t + "js", ("ontouchstart" in o || o.DocumentTouch && c instanceof DocumentTouch) && (n.className += t + "touch")
        }(window, document);
    </script>
</head>


<body class="body">
    <div class="section">
        <div class="container-3 w-container">
            <h1 class="papertitle">NeMF: Neural Motion Fields for Kinematic Animation</h1>
            <div class="text-block">Submission ID: 5631</div>
        </div>
    </div>

    <div class="section-2">
        <div class="container w-container">
            <ul role="list" class="list">
                <li class="list-item">
                    <a href="#experiment_1">1. Sanity Test</a>
                    <ul role="list">
                        <li>
                            <a href="#experiment_1_1">1.1 Motion Reconstruction</a>
                        </li>
                        <li>
                            <a href="#experiment_1_2">1.2 Temporal Sampling</a>
                        </li>
                    </ul>
                </li>
                <li class="list-item">
                    <a href="#experiment_2">2. Comparison</a>
                    <ul role="list">
                        <li>
                            <a href="#experiment_2_1">2.1 Comparison with Different Architectures</a>
                        </li>
                        <li>
                            <a href="#experiment_2_2">2.2 Comparison with other Methods</a>
                        </li>
                    </ul>
                </li>
                <li class="list-item">
                    <a href="#experiment_3">3. Play with the Latent Space</a>
                    <ul role="list">
                        <li>
                            <a href="#experiment_3_1">3.1 Interpolation</a>
                        </li>
                        <li>
                            <a href="#experiment_3_2">3.2 Composition</a>
                        </li>
                    </ul>
                </li>
                <li class="list-item">
                    <a href="#experiment_4">4. Applications</a>
                    <ul role="list">
                        <li>
                            <a href="#experiment_4_1">4.1 Motion In-betweening</a>
                        </li>
                        <li>
                            <a href="#experiment_4_2">4.2 Motion Re-navigating</a>
                        </li>
                    </ul>
                </li>
                <li class="list-item">
                    <a target="_blank" href="files/NeMF_Supplemental.pdf">5. Supplemental</a>
                </li>
            </ul>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_1" class="experimenttitle">1. Sanity Test</h3>
            </div>
            <div class="w-container">
                <h3 id="experiment_1_1" class="subexperimenttitle">1.1 Motion Reconstruction</h3>
                <p class="paragraph">
                    We first perform a sanity test to validate the reconstruction capability of our single-motion NeMF architecture. Here we present two examples of human motion and dog motion,
                    respectively. Note that the dog motion contains 4336 frames (73 seconds) in total and we just render the first 900
                    frames for visualization.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/amass_recon.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-6">
                        <video width=" 100%" height="100%" source="" src="./files/video/dog.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_1_2" class="subexperimenttitle">1.2 Temporal Sampling</h3>
                <p class="paragraph">
                    Unlike other motion models, NeMF is a continuous motion model that can synthesize motion at different frame rates in theory. However, in practice, the dimension of the Fourier
                    temporal features generated by positional encoding plays a critical role in
                    the smoothness of motion. Here we show three comparisons of different dimensions to verify that a proper dimension choice can produce smooth motion even sampled at 240 fps.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/30fps.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width=" 100%" height="100%" source="" src="./files/video/60fps.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width=" 100%" height="100%" source="" src="./files/video/240fps.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
            </div>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_2" class="experimenttitle">2. Comparison</h3>
            </div>
            <div class="w-container">
                <h3 id="experiment_2_1" class="subexperimenttitle">2.1 Comparison with Different Architectures</h3>
                <p class="paragraph">
                    In the seperate model, we let NeMF predicts the local motion and global orientation first and then predict the global translation, while alternatively, in the integrated model, the
                    whole motion is predicted all together. Here we show that the integrated model tends to have sliding artifacts when being used in motion inbetweening tasks.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/no_trans.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-6">
                        <video width=" 100%" height="100%" source="" src="./files/video/with_trans.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_2_2" class="subexperimenttitle">2.2 Comparison with other Methods</h3>
                <p class="paragraph">
                    Here we show the comparison of our method with <a target="_blank" href="https://sites.google.com/view/hm-vae/home">HM-VAE</a> and <a target="_blank"
                        href="https://geometry.stanford.edu/projects/humor/">HuMoR</a> for the motion reconstruction task. Note that HM-VAE fails to reconstruct a plausible result and HuMoR's result
                    will
                    gradually diverge. Our method achieves the best reconstruction result among these three methods.
                </p>
                <div class="w-container">
                    <video width="100%" height="100%" source="" src="./files/video/recon_comp_1.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
            </div>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_3" class="experimenttitle">3. Play with The Latent Space</h3>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_1" class="subexperimenttitle">3.1 Interpolation</h3>
                <p class="paragraph">
                    In the video below, we linearly interpolate the latent codes from the two motions on the side and visualize three samples in the middle. These results suggest the smoothness of our
                    latent space which produces a smooth style changing while preserving the perceptual plausibility.
                </p>
                <div class="w-container">
                    <video width="100%" height="100%" source="" src="./files/video/lerp_color.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_2" class="subexperimenttitle">3.2 Composition</h3>
                <p class="paragraph">
                    Since we disentangle the latent space for global root orientation and local motion, we can combine different global and local latent codes to create interesting new motions. In the
                    case below, we cancel the spinning motion of a pirouette jump by replacing the global latent code.
                </p>
                <div class="w-container">
                    <video width="90%" height="90%" source="" src="./files/video/reorient_spin.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
                <p class="paragraph">
                    In the case below, we introduce a natural turning to the global translation also by changing the global latent code.
                </p>
                <div class="w-container">
                    <video width="90%" height="90%" source="" src="./files/video/reorient_turn.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
            </div>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_4" class="experimenttitle">4. Applications</h3>
            </div>
            <div class="w-container">
                <h3 id="experiment_4_1" class="subexperimenttitle">4.1 Motion In-betweening</h3>
                <p class="paragraph">
                    <b>Motion Clips In-betweening</b>&emsp;Here we show the example of generating 30-frame inbetweens for 2 clips. We compare our results with SLERP, <a target="_blank"
                        href="https://www.gdcvault.com/play/1025165/Inertialization">Inertialization</a>, <a target="_blank"
                        href="https://montreal.ubisoft.com/en/automatic-in-betweening-for-faster-animation-authoring/">Robust Motion In-betweening (RMI)</a> and <a target="_blank"
                        href="https://sites.google.com/view/hm-vae/home">HM-VAE</a>.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/slerp.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/inertia.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/rmi.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/hm_vae.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/nemf.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <video width="100%" height="100%" source="" src="./files/video/clip_inbetween/gt.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
                <p class="paragraph">
                    <b>AIST++ Dance In-betweening</b>&emsp;Here we show the example of generating transitions between two real dancing footages in AIST++.
                </p>
                <div class="w-container">
                    <video width="100%" height="100%" source="" src="./files/video/aist_1.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
                <div class="w-container">
                    <video width="100%" height="100%" source="" src="./files/video/aist_2.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>
                <p class="paragraph">
                    <b>Sparse Keyframe In-betweening</b>&emsp;Here we show the example of generating inbetweens for keyframes placed every 20 frames. We compare our results with SLERP and <a
                        target="_blank" href="https://sites.google.com/view/hm-vae/home">HM-VAE</a>.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/keyframe_inbetween/slerp.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/keyframe_inbetween/hm_vae.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/keyframe_inbetween/nemf.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-6">
                        <video width="100%" height="100%" source="" src="./files/video/keyframe_inbetween/gt.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_4_2" class="subexperimenttitle">4.2 Motion Re-Navigating</h3>
                <p class="paragraph">
                    Here we show the example of redirecting the reference motion to different synthetic trajectories.
                </p>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-4">
                        <h3 class="heading-2"> Reference Motion</h3>
                        <video width="100%" height="100%" source="" src="./files/video/renavi_gt_hi.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <h3 class="heading-2"> Straight Line</h3>
                        <video width="100%" height="100%" source="" src="./files/video/renavi_line_hi.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-4">
                        <h3 class="heading-2"> Sinusoidal Curve</h3>
                        <video width="100%" height="100%" source="" src="./files/video/renavi_sinusoidal_hi.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>
            </div>
        </div>
    </div>

    <script src="./files/jquery-3.4.1.min.220afd743d.js" type="text/javascript" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
    <script src="./files/webflow.3cd0ca831.js" type="text/javascript"></script>
</body>