<!DOCTYPE html><html> <head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1"><link rel="stylesheet" href="https://bulma.io/vendor/fontawesome-free-6.5.2-web/css/all.min.css"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css"><link rel="stylesheet" href="_astro/index.BTx1weqX.css"></head><body> <section class="section title-section"> <div class="container-widescreen has-text-centered"> <h1 class="work-title">A3D: Does Diffusion Dream about 3D Alignment?</h1> <p class="venue">Anonymous ICLR 2025 submission</p> <p class="venue" style="color: red;">Please see the updated version of the supplementary anonymous webpage at<br><a href="https://qrd9ph4uipym.github.io" target="_blank">https://qrd9ph4uipym.github.io</a></p>   </div> </section> <section class="section" id="abstract"> <div class="container-widescreen"> <h2 class="section-title"> <span>Abstract</span> <a class="section-title-anchor" href="#abstract"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>  <div class="text-content"> <p>
We tackle the problem of text-driven 3D generation from a geometry alignment perspective.
            Given a set of the text prompts, we aim at the generation of a collection of objects with their semantically corresponding parts being aligned between these objects.
            Recent methods based on Score Distillation have succeeded in distilling the knowledge from 2D diffusion models to high-quality representations of the 3D objects.
            These methods handle multiple text queries separately, and therefore the resulting objects have a high variability in object pose and structure.
            However, in some applications, such as 3D asset design, it may be desirable to obtain a set of objects aligned with each other.
            In order to achieve the alignment of the corresponding parts of the generated objects, we propose to embed these objects into a common latent space and optimize the continuous transitions between these objects.
            We enforce two kinds of properties of these transitions: smoothness of the transition and plausibility of the intermediate objects along the transition.
            We demonstrate that both of this properties are essential for good alignment.
            We provide several practical scenarios that benefit from alignment between the objects, including 3D editing and object hybridization, and experimentally demonstrate the effectiveness of our method.
</p> </div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline=""> <source src="vid/teaser/teaser.mp4" type="video/mp4"> </video> <div class="text-content"> <p>
Our method A3D enables conditioning text-to-3D generation process on a set of text prompts to jointly generate a set of 3D objects with a shared structure (top).
            This enables a user to make "hybrids" combined of different parts from multiple aligned objects (middle), or perform text-driven structure-preserving transformation of an input 3D model (bottom).
</p> </div>  </div> </section> <section class="section" id="overview"> <div class="container-widescreen"> <h2 class="section-title"> <span>Motivation</span> <a class="section-title-anchor" href="#overview"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>  <video width="100%" autoplay="" loop="" muted="" controls="" playsinline=""> <source src="vid/motivation/motivation.mp4" type="video/mp4"> </video> <div class="text-content"> <p>
Collections of objects generated with existing text-to-3D methods lack structural consistency (top).
            Shapes obtained with existing text-driven 3D editing methods lack text-to-asset alignment and visual quality (middle).
            In contrast, our method enables the generation of structurally coherent, text-aligned assets with high visual quality (bottom).
</p> </div> <div class="text-content">
Below, we show our complete set of results for
<ol> <li><a href="#generation-of-multiple">Generation of multiple aligned 3D objects</a></li> <li><a href="#hybridization">Hybridization, combining parts of the aligned 3D objects</a></li> <li><a href="#pose-preserving-transform">Pose-preserving transformation of 3D models</a></li> <li><a href="#ablation">Ablation</a></li> </ol> </div>  </div> </section> <section class="section" id="generation-of-multiple"> <div class="container-widescreen"> <h2 class="section-title"> <span>Generation of multiple aligned 3D objects</span> <a class="section-title-anchor" href="#generation-of-multiple"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>   <div class="text-content" data-astro-cid-kjvexx3d> <p data-astro-cid-kjvexx3d>
We evaluate our method in the generation of sets of aligned objects on 15 pairs of prompts describing pairs of objects with similar morphology but different geometry and appearance, such as a car and a carriage.
            We include various categories of objects, namely different kinds of animals, humanoids, plants, vehicles, furniture, and buildings.
</p> <p data-astro-cid-kjvexx3d>
Below, we show pairs of objects generated with existing methods and our method, in different columns.
            Each pair of rows shows the results for one pair of prompts written below.
            For each object, we show a color rendering and a rendering of the geometry below it.
</p> <p data-astro-cid-kjvexx3d>
Our method generates both objects in the pair simultaneously, while the other methods initially generate one of the object and then generate the other one from the first.
            We show two sets of results.
            Here, we show the first set of results, with the left object generated first, denoted with <span style="font-family: &quot;Times New Roman&quot;" data-astro-cid-kjvexx3d>p<sub data-astro-cid-kjvexx3d>1</sub>→p<sub data-astro-cid-kjvexx3d>2</sub></span>.
            We show the second set further.
</p> </div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/00_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/01_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/02_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/03_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/04_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/05_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/06_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/07_frw.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div style="height: 4rem" data-astro-cid-kjvexx3d></div> <div class="text-content" data-astro-cid-kjvexx3d> <p data-astro-cid-kjvexx3d>
Here, we show the second set of results with the right object generated first, denoted with <span style="font-family: &quot;Times New Roman&quot;" data-astro-cid-kjvexx3d>p<sub data-astro-cid-kjvexx3d>1</sub>←p<sub data-astro-cid-kjvexx3d>2</sub></span>.
</p> </div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/00_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/01_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/02_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/03_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/04_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/05_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/06_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video> <div class="vidsep" data-astro-cid-kjvexx3d></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-kjvexx3d> <source src="vid/gen2/v04_pairs/vids/07_inv.mp4" type="video/mp4" data-astro-cid-kjvexx3d> </video>  </div> </section> <section class="section" id="hybridization"> <div class="container-widescreen"> <h2 class="section-title"> <span>Hybridization: combining the aligned 3D objects</span> <a class="section-title-anchor" href="#hybridization"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>   <div class="text-content" data-astro-cid-zleqpzth> <p data-astro-cid-zleqpzth>
We show examples of the hybrid objects combining parts of aligned objects produced by our method, and illustrate the process of getting these hybrids below.
            In some of these experiments, we intentionally choose the hyperparameters of our method different from the ones used for the generation of pairs of objects above, to increase the visual difference between the generated objects for better visibility of the hybridization.
</p> <p data-astro-cid-zleqpzth>
To choose which part of each object we want to use, we assign several anchor points to each object (shown in the left column) and manually place these points in the common 3D space of the objects.
            We define the spatial distribution of the latent code (shown in the second column) via linear interpolation between the latent codes corresponding to the objects associated with the two closest anchors.
            The resulting objects are shown on the right.
</p> </div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-zleqpzth> <source src="vid/hybrid/v03_3/vids/00.mp4" type="video/mp4" data-astro-cid-zleqpzth> </video> <div class="vidsep" data-astro-cid-zleqpzth></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-zleqpzth> <source src="vid/hybrid/v03/vids/00.mp4" type="video/mp4" data-astro-cid-zleqpzth> </video>  </div> </section> <section class="section" id="pose-preserving-transform"> <div class="container-widescreen"> <h2 class="section-title"> <span>Pose-preserving transformation of 3D models</span> <a class="section-title-anchor" href="#pose-preserving-transform"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>   <div class="text-content" data-astro-cid-k5oag7uf> <p data-astro-cid-k5oag7uf>
We evaluate the capability of our method to transform an initial 3D model while preserving its structure on 26 text prompts.
            For each prompt we find a coarse initial model with the desired structure on the web, or use the SMPL parametric human body model in a desired pose.
</p> <p data-astro-cid-k5oag7uf>
Below, we show the objects generated with existing methods and our method from an initial 3D model on the left.
            Each row shows the results obtained for the text prompt below.
            For each object, we show a color rendering and a rendering of the geometry.
</p> </div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/00.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/01.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/02.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/03.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/04.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/05.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/06.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/07.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video> <div class="vidsep" data-astro-cid-k5oag7uf></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-k5oag7uf> <source src="vid/editing/v03_pairs/vids/08.mp4" type="video/mp4" data-astro-cid-k5oag7uf> </video>  </div> </section> <section class="section" id="ablation"> <div class="container-widescreen"> <h2 class="section-title"> <span>Ablation</span> <a class="section-title-anchor" href="#ablation"> <span class="icon is-medium"><i class="fas fa-link"></i></span> </a> </h2>   <p data-astro-cid-gpozl6yb>
We compare our method with two branches of baselines for generating pairs of objects.
        We refer to the baselines in the first branch as (A-C), and in the second branch as (E, F), while (D) is our complete method.
        See the description of the baselines in Section 6.
</p> <p data-astro-cid-gpozl6yb>
For each pair of generated objects we show the results in three rows.
        The first two rows show pairs of objects generated with our method in the column (D) and the baselines in the other columns.
        The last row shows an overlay of the silhouettes of the objects, demonstrating the alignment of their structural parts.
</p> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/ant.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/bike.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/bird_dino.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/car.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/dwarf_minotaur.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/gopher.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/horse_skeleton.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/lego.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/magnolia.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/marine_gen2.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/mermaid.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/robot_gen2.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/ship.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/temple.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video> <div class="vidsep" data-astro-cid-gpozl6yb></div> <video width="100%" autoplay="" loop="" muted="" controls="" playsinline="" data-astro-cid-gpozl6yb> <source src="vid/ablation/v02/vids/throne.mp4" type="video/mp4" data-astro-cid-gpozl6yb> </video>  </div> </section> <!--    <Bibtex/>--> <!--    <Footer/>--> </body></html>
