<!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>Perm</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>
    <script id="MathJax-script" async src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js"></script>
</head>


<body class="body">
    <div class="section">
        <div class="container-3 w-container">
            <h1 class="papertitle">
                <font style="font-variant: small-caps">Perm</font>: A Parametric Representation for Multi-Style 3D Hair Modeling
            </h1>
            <div class="text-block">Submission ID: 2303</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. PCA-based Strand Representation</a>
                </li>
                <li class="list-item">
                    <a href="#experiment_2">2. Analysis of GroomGen</a>
                </li>
                <li class="list-item">
                    <a href="#experiment_3">3. Additional Results</a>
                    <ul role="list">
                        <li>
                            <a href="#experiment_3_1">3.1 Random Hairstyle Synthesis</a>
                        </li>
                        <li>
                            <a href="#experiment_3_2">3.2 Hairstyle Interpolation</a>
                        </li>
                        <li>
                            <a href="#experiment_3_3">3.3 Single-view Hair Reconstruction</a>
                        </li>
                        <li>
                            <a href="#experiment_3_4">3.4 Hair-conditioned Image Generation</a>
                        </li>
                    </ul>
                </li>
            </ul>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_1" class="experimenttitle">1. PCA-based Strand Representation</h3>
            </div>
            <p class="paragraph">
                To validate our PCA-based strand representation, we compare it to various deep learning-based methods and a simpler PCA formulation. All the models are trained on both USC-HairSalon
                and a private dataset with a greater diversity. Both experiments show a similar trend, where our PCA-based strand representation achieves a significantly low position error with a
                comparatively low curvature error.
            </p>
            <div class="videoresult w-row">
                <p align="center">
                    Models trained on USC-HairSalon
                </p>
                <img src="assets/usc-pca-table.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
                <p align="center">
                    Models trained on private dataset
                </p>
                <img src="assets/private-pca-table.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
            </div>
        </div>
    </div>
    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_2" class="experimenttitle">2. Analysis of GroomGen</h3>
            </div>
            <p class="paragraph">
                We first show the comparison of strand VAE in GroomGen, where both our implementation and the official checkpoint failed to faithfully reproduce the curly hairstyle.
            </p>
            <div class="videoresult w-row">
                <img src="assets/groomgen-strand-vae.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
            </div>
            <p class="paragraph">
                We then show the comparison of hairstyle VAE in GroomGen, where our implementation produces results that are more natural but sometimes over-smooth. The official checkpoint produces
                results that are less natural with weird curl patterns. These differences should arise from the difference in the training data.
            </p>
            <div class="videoresult w-row">
                <img src="assets/groomgen-hairstyle-vae.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
            </div>
            <p class="paragraph">
                We finally show that to create a similar kinky hairstyle, 100 points per strand is not enough, and GroomGen's architecture is unstable and cannot fully reconstruct the hairstyle.
            </p>
            <div class="videoresult w-row">
                <img src="assets/groomgen-verify.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
            </div>
        </div>
    </div>
    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h3 id="experiment_3" class="experimenttitle">3. Additional Results</h3>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_1" class="subexperimenttitle">3.1 Random Hairstyle Synthesis</h3>
                <p class="paragraph">
                    Here we show random hair models synthesized by sampling the latent space, with comparison to GroomGen (our implementation).
                </p>
                <div class="videoresult w-row">
                    <img src="assets/sampling.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_2" class="subexperimenttitle">3.2 Hairstyle Interpolation</h3>
                <p class="paragraph">
                    Here we show hairstyle interpolation results, with comparison to [Weng et al. 2013] and [Zhou et al. 2018].
                </p>
                <div class="videoresult w-row">
                    <img src="assets/interpolation.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_3" class="subexperimenttitle">3.3 Single-view Hair Reconstruction</h3>
                <p class="paragraph">
                    Here we show single-view hair reconstruction and editing results from an image sequence, with comparison to [Yang et al. 2019] and HairStep.
                </p>
                <div class="videoresult w-row">
                    <img src="assets/single-view.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
                </div>
            </div>
            <div class="w-container">
                <h3 id="experiment_3_4" class="subexperimenttitle">3.4 Hair-conditioned Image Generation</h3>
                <p class="paragraph">
                    Here we show more hair-conditioned image generation results.
                </p>
                <div class="videoresult w-row">
                    <img src="assets/image-gen.png" style="width: 100%; height: auto; margin-right: 0%; margin-left: 0%;">
                </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>