【论文阅读笔记】Meta 3D AssetGen

【论文阅读笔记】Meta 3D AssetGen: Text-to-Mesh Generation with High-Quality Geometry, Texture, and PBR Materials

  • Info
  • 摘要
  • 引言
    • 创新点
  • 相关工作
    • T23D
    • 基于图片的3d 重建
    • 使用 PBR 材料的 3D 建模。
  • 方法
    • 文本到图像:从文本中生成阴影和反照率图像
    • Image-to-3D:基于pbr的大型重构模型
      • 反射模型
      • 推断的阴影
      • loss
      • LightPlane实现
    • 网格提取和纹理细化器
  • 实验
    • 稀疏视角重建
    • Text-to-3D生成
  • 总结
  • 附录


Info

project:https://assetgen.github.io/
paper:https://arxiv.org/abs/2407.02445

Meta 这一手有点顶,连发三篇,PBR 材质打通了我比较惊讶的是这个数据集的组织形式,怎么把材质种类划分的这么好,希望大佬指教
在这里插入图片描述

摘要

我们提出了 Meta 3D AsetGen (AssetGen),这是文本到 3D 生成的重大进步,它产生了忠实、高质量的网格,具有纹理和材料控制。与在 3D 对象外观中烘烤阴影的作品相比,AsetGen 输出基于物理的渲染 (PBR) 材料,支持逼真的重新照明。AsetGen 使用分解阴影和反照率外观通道生成对象的前几个视图,然后使用延迟阴影损失重建 3D 中的颜色、金属度和粗糙度以进行有效监督。**它还使用符号距离函数更可靠地表示 3D 形状,并为直接形状监督引入了相应的损失。**这是使用融合内核实现的,以实现高内存效率。在网格提取之后,在UV空间中操作的纹理细化转换器显著提高了清晰度和细节。AsetGen 在倒角距离方面提高了 17%,在 LPIPS 中比用于少视图重建的最佳并行工作提高了 40%,人类对可比速度的最佳行业竞争对手的偏好为 72%,包括那些支持 PBR 的人。

引言

  1. PBR 材质的重要性
  2. AsetGen 在 30 秒以下生成资产,同时优于先前在忠实度、生成的 3D 网格质量以及材料的质量和控制方面相当速度的工作,支持基于物理的渲染 (PBR) [85]。
  3. AsetGen 使用受 [40] 启发的两阶段设计。第一阶段从4个规范视点随机生成对象的4个图像,第二阶段确定性地从这些视图中重建对象的3D形状和外观(图1)。这种方法比基于 SDS 的技术 [66] 更快、更稳健,并且比单级 3D 生成器产生更多样化和更忠实的结果 [36, 59, 92, 77]。

创新点

我们考虑了反照率、金属度和粗糙度来渲染准确反映环境照明的场景。此外,由于网格在应用程序和与 PBR 的兼容性方面的流行,我们专注于网格作为输出表示。

  1. 我们的第一个贡献是扩展两个阶段以生成 PBR 信息。由于图像到 3D 阶段是确定性的,它是文本到图像阶段,它是随机的,应该解决分配材料的歧义。这可以通过**微调文本到图像模型来直接输出所需的 PBR 通道来完成,但由于 PBR 和自然图像之间的差距很大,我们发现这是有问题的。相反,我们为文本到图像模型分配了更简单的任务,即输出外观的阴影和反照率(无阴影)版本。**这允许图像到 3D 组件通过分析反照率和阴影通道之间的差异来准确预测 PBR 材料。
  2. 我们的第二个创新在于网格生成步骤。现有的工作通常输出一个不透明度场来表示 3D 形状,但后者可能会导致定义不明确的水平集,从而导致网格伪影。为了解决这个问题,**AsetGen 的图像到 3D 阶段 MetaILRM 直接预测符号距离场 (SDF) 而不是不透明度场。**这会产生更高质量的网格,因为SDF的零水平集更可靠地跟踪对象的表面。此外,这种表示可以很容易地使用地面真实深度图进行监督,这对于不透明度来说是不可能的我们使用VolSDF[107]来不同地渲染基于SDF的模型,并通过在内存高效的LightPlane Kernels[6]中实现渲染来提高训练效率。这允许对高分辨率渲染进行更大的批次和光度损失监督,从而获得更好的纹理质量。

挖个坑,解读一下LightPlane

相关工作

T23D

受文本到图像模型的启发,早期的文本到 3D 方法 [62, 33 , 26 , 109 , 104 ] 在字幕 3D 资产的数据集上训练 3D 扩散模型。然而,3D 数据的有限大小和多样性阻碍了对开放词汇提示的泛化。因此,最近的工作基于在数十亿个字幕图像上训练的文本到图像模型的此类生成器。2 其中,[73]、54等工作微调2D扩散模型输出3D表示,但由于2D-3D域间隙较大,质量有限。其他方法可以深入研究两组。

  1. 第一组包含基于DreamFusion的方法,这是[66]的开创性工作,并通过SDS损失优化NeRF来提取3D对象,将其渲染与预先训练的文本到图像模型的信念相匹配。考虑了扩展:(i)其他3D表示,如哈希网格[42,67]、网格[42]和3D高斯(3DGS)[7,110,12,12];(ii)改进的SDS[89,93,118,30];(iii)单眼条件反射[67,80,112,76];(iv)预测额外的法线或深度以获得更好的几何形状[68,76]。然而,蒸馏方法容易出现Janus效应(复制对象部分)和内容漂移等问题[72]。一种常见的解决方案是通过将视图一致性先验合并到扩散模型中,通过对相机[45,71,31,11,67]进行调节,或者通过联合生成多个对象视图[72,96,91,38,17]。此外,SDS 优化很慢,每个资产需要几分钟到小时;这个问题在 [50, 99] 中部分解决,带有摊销 SDS。
  2. 第二组方法包括更快的两阶段方法[44,49,47,106,105,8,81,28,23],它首先使用文本到图像或视频模型[52,13]生成对象的多个视图,然后使用NERF[56]或3DGS[37]进行逐场景优化。然而,每个场景的优化需要几个高度一致的视图,这些视图很难可靠地生成。Instant3D[40]通过生成仅四个视图的网格和从这些视图重建对象的前馈网络(LRM[29])来提高速度和稳健性。One-2-3-45++ [43] 将 LRM 替换为 3D 扩散模型。

我们的 AsetGen 建立在 Instant3D 范式之上,并将 LRM 升级为输出 PBR 材料和基于 SDF 的 3D 形状的表示。此外,它从四个带有阴影和反照率通道的视图网格开始,这是从图像中预测准确的3D形状和材料的关键。

Instant3D

基于图片的3d 重建

从图像中重建3D。3D场景重建,在传统的多视图立体(MVS)意义上,假设可以访问密集的场景视图集。最近的重建方法,如NeRF[56],通过最小化多视图渲染损失来优化3D表示。
有两种流行的3D表示类:(i)网格[22,13,24,61,57,74]或3D点/高斯[37,25]等显式表示,以及(ii)占用场[63]、亮度场[56,60]和符号距离函数(SDF)[108]等隐式表示。与占用场相比,SDF[64,107,90,17,21]简化了表面约束集成,提高了场景几何。出于这个原因,我们采用了 SDF 公式并证明它优于占用率。
相反,稀疏视图重建假设输入视图很少(通常为 1 到 8)。减轻密集多个视图缺乏的一种方法是在优化过程中利用 2D 扩散先验 [53, 97],但这通常很慢并且不是很健壮。最近,作者专注于在大型数据集上训练前馈重构器[14,35,55,46,98,58,92]。特别是,最先进的LRM[29]训练一个大的Transformer[87],使用三平面表示来预测NeRF[7,9]。LRM扩展研究其他3D表示,如网格[101,95]和3DGS[119,103,78,114],改进的骨干[94,95]和训练协议[84,34]。

我们的方法还建立在 LRM 之上,但引入了三个关键修改:(i)改进几何形状的 SDF 公式,(ii)重新照明的 PBR 材料预测,以及(iii)纹理细化器以获得更好的纹理细节。

使用 PBR 材料的 3D 建模。

大多数 3D 生成器输出具有烘烤照明的 3D 对象,无论是视图相关的 [56, 37] 还是与视图无关的 [29]。由于烘焙照明忽略了模型对环境照明的响应,不适合具有受控照明的图形管道。**基于物理的渲染(PBR)定义了材料属性,以便合适的着色器可以真实地解释照明。**一些MVS工作考虑了使用NeRF[4,3,100]、SDF[115]、可微网格[61,27]或3DGS[32,41]估计PBR材料。在生成建模中,[10,68,48,102]使用PBR模型增强了文本到3D SDS优化[66]。与它们不同的是,我们将 PBR 建模集成到我们的前馈文本到 3D 网络中,首次解锁了具有可控 PBR 材料的基于快速文本生成 3D 资产。

方法

AsetGen 是一个两阶段管道(图 2)。首先,文本到图像(第3.1节),将文本作为输入,生成具有材料信息的4视图图像网格。其次,图像到 3D 包括一种新颖的基于 PBR 的稀疏视图重建模型(第 3.2 节)和纹理细化器(第 3.3 节)。因此,AsetGen 适用于两个任务:text-to-3D(阶段 1+2)和image-to-3D(仅阶段 2)。
在这里插入图片描述

文本到图像:从文本中生成阴影和反照率图像

类似于MVDREAM 和 Instant3D,首先 fintuene 了一个生成四视角的模型。但是发现如果直接预测 PBR 材质(abeldo、roughness、metallic)无法收敛,转而去预测abeldo和 shading降低难度(输入输出改为 6 通道)

Image-to-3D:基于pbr的大型重构模型

训练 MetalLRM,输入是6 通道图像,借助 Triplane 后面接两个 MLP 分别预测 SDF R 3 − > R R^3->R R3>R和PBR系数 R 3 − > R 5 R^3->R^5 R3>R5 abeldo、roughness、metallic R B G RBG RBG
k ( x ) = ( ρ 0 , γ , α )  are the albedo, metalness and roughness.  k(\boldsymbol{x})=\left(\rho_{0}, \gamma, \alpha\right) \text { are the albedo, metalness and roughness. } k(x)=(ρ0,γ,α) are the albedo, metalness and roughness. 
学习模型的关键是可微分渲染算子 R。这将场 ℓ : R 3 → R D \ell: \mathbb{R}^{3} \rightarrow \mathbb{R}^{D} :R3RD、SDF s、视点π和像素u∈U = [0, W) × [0, H)作为输入,并根据渲染方程[56]输出场在像素上的投影,该渲染方程具有与渲染场ℓ相同数量的通道D:
R ( u ∣ ℓ , s , π ) = ∫ 0 ∞ ℓ ( x t ) σ ( x t ∣ s ) e − ∫ 0 t σ ( x τ ∣ s ) d τ d t . \mathcal{R}(u \mid \ell, s, \pi)=\int_{0}^{\infty} \ell\left(\boldsymbol{x}_{t}\right) \sigma\left(\boldsymbol{x}_{t} \mid s\right) e^{-\int_{0}^{t} \sigma\left(\boldsymbol{x}_{\tau} \mid s\right) d \tau} d t . R(u,s,π)=0(xt)σ(xts)e0tσ(xτs)dτdt.

这里 xt = x0 - tωo, t ∈ [0, ∞) 是沿方向 -ωo ∈ S2 的像素 u 从相机中心 x0 到射线。函数 σ(x | s) 是 3D 点 x 的不透明度,使用VolSDF[107]公式从SDF值s(X)得到:
σ ( x ∣ s ) = a 2 ( 1 + sign ⁡ s ( x ) ( 1 − e − ∣ s ( x ) ∣ / b ) ) , \sigma(\boldsymbol{x} \mid s)=\frac{a}{2}\left(1+\operatorname{sign} s(\boldsymbol{x})\left(1-e^{-|s(\boldsymbol{x})| / b}\right)\right), σ(xs)=2a(1+signs(x)(1es(x)∣/b)),
其中 a, b 是超参数

反射模型

阴影RGB图像ˆI中的对象ˆI(U)=R(u|L,s,π)的外观是通过渲染其辐射场ℓ(X)=L(x,ωo|k,n)来获得的,其中n是单位法线的场。亮度是物体在观察者方向ωo反射的光(见App.A.8 的详细信息),其中 PBR 由下式给出:
L ( x , ω o ∣ k , n ) = ∫ H ( n ) f ( ω i , ω o ∣ k ( x ) , n ( x ) ) L ( x , − ω i ) ( n ( x ) ⋅ ω i ) d Ω i L\left(\boldsymbol{x}, \boldsymbol{\omega}_{\mathrm{o}} \mid k, \boldsymbol{n}\right)=\int_{H(\boldsymbol{n})} f\left(\boldsymbol{\omega}_{\mathrm{i}}, \boldsymbol{\omega}_{\mathrm{o}} \mid k(\boldsymbol{x}), \boldsymbol{n}(\boldsymbol{x})\right) L\left(\boldsymbol{x},-\boldsymbol{\omega}_{\mathrm{i}}\right)\left(\boldsymbol{n}(\boldsymbol{x}) \cdot \boldsymbol{\omega}_{\mathrm{i}}\right) d \Omega_{\mathrm{i}} L(x,ωok,n)=H(n)f(ωi,ωok(x),n(x))L(x,ωi)(n(x)ωi)dΩi
其中 ωo, ωi ∈ H(n) = {ω ∈ S2 : n · ω ≥ 0} 是指向对象外部的两个单位向量,L(x, −ωi) 是从 x 处的环境在立体角 dΩi 中从方向 ωi 入射的辐射。双向反射分布函数 (BRDF) f 告诉从方向 -ωi(传入)接收到的光如何被对象 [20] 分散到不同的方向 ωo(传出)

在PBR中,我们考虑了BRDF的物理启发模型,在真实感和复杂性之间取得平衡[2,85,75,15,88];具体来说,我们使用迪士尼GGX模型[88,5],它只依赖于参数ρ0、γ和α(见App.A.12.1 用于 f 的参数形式)。因此,MetaI LRM 在每个 3D 点 x 处预测三元组 k(x) = (ρ0, γ, α)。

推断的阴影

在实践中,我们不是使用方程式1,3计算 I ^ ( u ) = R ( u ∣ L , s , π ) \hat{I}(u)=\mathcal{R}(u \mid L, s, \pi) I^(u)=R(uL,s,π),我们使用延迟着色过程 [20]:
I ^ ( u ) = R def ⁡ ( u ∣ k , s , π ) = ∫ H ( n ) f ( ω i , ω o ∣ k ˉ , n ‾ ) L e n v ( − ω i ) ( n ‾ ⋅ ω i ) d Ω i , ( 4 ) \hat{I}(u)=\mathcal{R}_{\operatorname{def}}(u \mid k, s, \pi)=\int_{H(\boldsymbol{n})} f\left(\boldsymbol{\omega}_{\mathrm{i}}, \boldsymbol{\omega}_{\mathrm{o}} \mid \bar{k}, \overline{\boldsymbol{n}}\right) L_{\mathrm{env}}\left(-\boldsymbol{\omega}_{\mathrm{i}}\right)\left(\overline{\boldsymbol{n}} \cdot \boldsymbol{\omega}_{\mathrm{i}}\right) d \Omega_{\mathrm{i}}, \text(4) I^(u)=Rdef(uk,s,π)=H(n)f(ωi,ωokˉ,n)Lenv(ωi)(nωi)dΩi,(4)

其中Lenv是环境辐射度(假设所有x都假定相同),̄ k ˉ = R ( u ∣ k , s , π ) \bar{k}=\mathcal{R}(u \mid k, s, \pi) kˉ=R(uk,s,π)和̄ n ‾ = R ( u ∣ n , s , π ) \overline{\boldsymbol{n}}=\mathcal{R}(u \mid \boldsymbol{n}, s, \pi) n=R(un,s,π)是材料和正常场的渲染版本。Eq.(4)的优点是,在Eq.(1)的评估过程中,BRDF f只评估每个像素一次,这比对每个3D点这样做要快得多,内存密集更少,特别是对于训练/反向传播。此外,在训练过程中,假设环境光是无穷远处的单个光源,因此积分(4)简化为评估单个项。

loss

因此,MetaILRM 是一个神经网络,它将一组图像 ( I i , π i ) i = 1 N \left(I_{i}, \pi_{i}\right)_{i=1}^{N} (Ii,πi)i=1N作为输入,并为 SDF 和 PBR 字段输出估计 s ^ \hat s s^ k ^ \hat k k^

我们从网格表面数据集 M ⊂ R3 和地面实况 PBR 材料 k : M → R5 对其进行训练。

重建模型通常通过对渲染的监督进行训练[29,95]。然而,通过方程式进行物理上准确的渲染。 (1) 非常昂贵。我们以两种方式克服了这个障碍。首先,我们渲染原始的ground-truth PBR字段k,并使用它们来监督其MSE损失的预测对应项,跳过Eq.(1)。对于与自然图像足够相似的渲染反照率ρ0 -我们也使用LPIPS[116]损失:

L p b r = LPIPS ⁡ ( R ( ⋅ ∣ ρ ^ 0 , s ^ , π ) , R ( ⋅ ∣ ρ 0 , M , π ) ) + ∥ R ( ⋅ ∣ k ^ , s ^ , π ) − R ( ⋅ ∣ k , M , π ) ∥ 2 . \mathcal{L}_{\mathrm{pbr}}=\operatorname{LPIPS}\left(\mathcal{R}\left(\cdot \mid \hat{\rho}_{0}, \hat{s}, \pi\right), \mathcal{R}\left(\cdot \mid \rho_{0}, M, \pi\right)\right)+\|\mathcal{R}(\cdot \mid \hat{k}, \hat{s}, \pi)-\mathcal{R}(\cdot \mid k, M, \pi)\|^{2} . Lpbr=LPIPS(R(ρ^0,s^,π),R(ρ0,M,π))+R(k^,s^,π)R(k,M,π)2.

我们通过添加计算效率高的延迟阴影损失来进一步监督 PBR 字段:
L def  = ∥ w ⊙ ( R d e f ( ⋅ ∣ k ^ , s ^ , π ) − R d e f ( ⋅ ∣ k , M , π ) ) ∥ 2 \mathcal{L}_{\text {def }}=\left\|\sqrt{w} \odot\left(\mathcal{R}_{\mathrm{def}}(\cdot \mid \hat{k}, \hat{s}, \pi)-\mathcal{R}_{\mathrm{def}}(\cdot \mid k, M, \pi)\right)\right\|^{2} Ldef = w (Rdef(k^,s^,π)Rdef(k,M,π)) 2
权重 w(u) = ^n(u) · n(u) 是像素 u 处预测法线和真实法线的点积。它折扣尚未学习预测几何的损失。图 13 (b) 可视化了延迟阴影和渲染损失。

最后,我们还使用直接损失Lsdf来监督SDF场(如[1]所示),深度渲染与地面真实之间的深度MSE损失 L d e p t h L_depth Ldepth,并在 a l p h a alpha alpha掩码渲染和真实掩码之间使用二元交叉熵 L m a s k L_mask Lmask。参考appendix.6.2 了解更多详细信息。

LightPlane实现

我们将 MetaILRM 建立在 LightplaneLRM [6] 上,这是 LRM [29] 的一种变体,它利用内存和计算高效的 Lightplant splatting 和渲染内核,提供更好的质量重建。然而,由于LightplaneLRM使用密度场,这对于网格转换来说是次优的[90,64,1],我们使用Eq.(2)使用VolSDF[107]渲染器扩展了Lightplane渲染器GPU内核。此外,我们还将直接 SDF 损失 Lsdf 融合到内核中,因为朴素的 autograd 实现太内存了。

网格提取和纹理细化器

第3.2节的MetaILRM模块输出一个符号距离函数s,隐式定义对象表面A = {x∈R3 | s(x) = 0}作为s的水平集。我们使用 Marching Tetrahedra 算法 [18] 来跟踪水平集并输出网格 M ≈ A。然后,xAtlas[111]提取UV映射φ:[0,V]2→M,将每个2DUV空间点v=φ(X)映射到网格上的点x∈M。

接下来,目标是提取一个高质量的5通道PBR纹理图像̄K∈RV ×V ×5,捕捉每个网格点的反照率、金属度和粗糙度。纹理图像 K 可以通过将预测的 PBR 场 ^k 采样为 K ( v ) ← k ^ ( φ ( v ) ) K(v) ← \hat k (φ(v)) K(v)k^(φ(v))来直接定义,但由于 MetaILRM 的分辨率有限,这通常会产生模糊的结果。相反,我们设计了一个纹理细化器模块,该模块将粗略的 PBR 采样纹理图像作为输入,以及表示对象的 N 个视图并输出更清晰的纹理 k ˉ \bar k kˉ。本质上,该模块利用来自不同视图的信息来细化粗纹理图像。图 2 的右侧部分说明了该模块。

更具体地说,它依赖于输入 N + 1 个纹理图像 {Ki}N i=0 的网络 Φ。首先,K0 ∈ RV ×V ×11 的每个像素 v ∈ [0, V ]2 用法线、3D 位置和 MetaILRM 的 PBR 场 k(φ(v)) 的输出在 v 的 3D 点 φ(v) 上进行评估。剩余的 K1,。, KN 对应于具有 6 个通道的部分纹理图像(对于基本颜色和阴影颜色),这些图像是通过将对象视图反向投影到网格表面来获得的。

网络Φ利用两个U-Nets将{Ki}N i=0融合到增强纹理̄K中。Φ 的目标是为每个 UV 点 v 选择 N 个输入视图中的哪一个提供了最佳信息。具体来说,每个部分纹理图像 Ki 由第一个 U-Net 并行处理,得到的信息通过交叉注意力传达给第二个 U-Net,其目标是将 K0 细化到增强的纹理 ̄K 中。请参阅应用程序。A.7 了解更多详细信息。

这样的网络在相同的数据集上进行训练,并使用 PBR 和反照率渲染损失作为 MetaILRM 进行监督。唯一的区别是网格(其几何形状是固定的)使用 PyTorch3D 的 [69] 网格光栅化器而不是 Lightplane SDF 渲染器以不同的方式渲染。

实验

我们的训练数据由 3D 艺术家创建的 140,000 个不同语义类别的网格组成。对于每个资产,我们以[−30◦,50◦]范围内的随机高程渲染36个视图,在物体周围30◦均匀间隔,用随机选择的环境地图照明。我们从每个视图渲染阴影图像、反照率、金属度、粗糙度、深度图和前景蒙版文本到图像阶段基于架构上类似于 Emu [16] 的内部文本到图像模型,在 10,000 个高质量 3D 样本的子集上进行微调,由使用 Llama3 [86] 的 Cap3D 类管道 [51] 标题其他阶段改为使用整个 3D 数据集。为了评估,在[103,101,40]之后,我们使用渲染图像和地面真实图像之间的PSNR和LPIPS[116]来评估视觉质量。PSNR 在前景区域计算,以避免由于背景空而导致的度量膨胀。几何质量由渲染深度图和真实深度图(前景像素)之间的 L1 误差以及对象轮廓的 IoU 来衡量。我们进一步报告了20,000的倒角距离(CD)和正常正确性(NC)在预测和地面真实形状上均匀采样的点。用LPIPS和PSNR对反照率图像进行材料分解,对金属度和粗糙度通道进行PSNR评估。所有指标都是在网格化输出上计算的,而不是神经渲染上计算的。

在这里插入图片描述

稀疏视角重建

我们解决了稀疏视图重建任务,即从 Google Scanned Objects (GSO) [19] 的 332 个网格子集上从对象的 4 个姿势图像预测 3D 网格。我们与最先进的Instant3D-LRM[40]、GRM[103]、InstantMesh[101]和MeshLRM[95]进行了比较。我们还包括 LightplaneLRM [6],这是一个改进的 Instant3DLRM 版本,作为我们的基础模型。MeshLRM [95] 尚未开源,因此我们仅将它们的网页定性地与网格进行比较。所有方法都使用相同的输入视图以 5122 分辨率进行评估。由于后者都没有预测 PBR 材料,并且由于 GSO 缺乏真实的 PBR 材料,为了公平起见,我们使用了我们模型的变体来预测阴影对象纹理。

Figure3和Table3还展示了进一步的消融实验
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
接下来,我们考虑使用 PBR 材料进行稀疏视图重建的任务,其目标是从对象的四个姿势阴影 2D 视图重建 3D 几何和纹理属性(反照率、金属度和粗糙度)。这是在 256 个艺术家创建的 3D 网格的内部数据集上进行的,这些数据集是为高质量的材料策划的。**由于不存在现有的少视图前馈 PBR 重构器,我们在 Tab 1 中进行了消融研究和图3 、图 12。**虽然添加额外的 MLP 头添加材料预测提供了一些改进,但我们观察到结合延迟阴影损失和纹理细化对于高质量的 PBR 分解至关重要。示例 PBR 预测如图 8 所示。
在这里插入图片描述
在这里插入图片描述

Text-to-3D生成

最后,我们使用 PBR 材料评估文本到 3D。我们与最先进的前馈方法进行了比较,这些方法以相当的速度生成资产(每个资产约为 10 到 30 秒)。这包括GRM[103]、InstantMesh[101]和LightplaneLRM[6]的文本到3D变体。GRM 使用 Instant3D 的 4 视图网格生成器,InstantMesh 从我们的 2D 扩散模型接收第一个视图,然后生成 6 个视图,而 LightplaneLRM 从我们的网格生成器接受 4 个视图。因为这些方法烘烤照明而不是生成 PBR 材料,为了评估,我们将平面纹理阴影应用于我们的输出【我理解是shade乘以abeldo】。此外,我们与Meshy v3[83]和LumaAI Genie 1.0[82]的预览阶段进行了比较,PBR工作流的专有文本到3D方法分别在30和15秒内创建资产。附录中提供了与 Luma 和 Meshy 的明显更长的细化阶段的比较。图5显示AssetGen网格在视觉上更具吸引力,具有有意义的材料图6和图11提供了更多的示例和比较,并展示了细粒度的材料控制。对于定量评估,我们在 Tab 中进行了广泛的用户研究。2使用来自DreamFusion[66]的404个去重文本提示。**用户展示了生成网格和基线网格的 360° 视频,并要求他们根据 3D 形状质量和与文本提示对齐对它们进行评分。共收集了 11,080 个响应,对 AsetGen 的网格有显着偏好。**最后,我们消融了与图 3 中仅反照率输入相比生成双通道反照率+阴影网格的效果,揭示了前者的显着 PBR 分解优势。此外,图 12 说明了我们的延迟阴影损失的影响。
在这里插入图片描述

总结

我们介绍了 Meta 3D AsetGen,这是稀疏视图重建和文本到 3D 的重大进步。Meta 3D AsssetGen可以生成具有高质量纹理和忠实于输入文本的PBR材料的3D网格。这使用了几个关键的创新:生成具有阴影通道和反照率通道的多视图网格,引入了一种新的重建网络,该网络使用延迟阴影来训练该网络,通过新的可扩展的基于SDF的渲染器和SDF损失来改进几何图形,并引入新的纹理细化网络。综合评估和消融证明了这些设计选择和最先进的性能的有效性。

附录

限制

Meta 3D AsssetGen 显着提高了形状生成,但面临几个限制。尽管对多视图图像网格生成器进行微调以进行视图一致性,但不能保证它,可能会影响 3D 重建质量。由于我们使用SDF作为底层表示,重构器可能会错误地模拟半透明对象或薄结构,如头发或毛皮。此外,虽然我们的可伸缩Triton[65]实现支持分辨率为128×128的三平面表示,但这种表示是低效的,因为它的大部分容量用于空区域。未来的工作可以探索可扩展的表示,例如八叉树、稀疏体素网格和基于哈希的方法,这可能会消除对单独纹理增强模型的需求。我们还只预测反照率、金属度和粗糙度,而不是发射率或环境遮挡。最后,我们的方法仅在对象级重建上进行了测试,为未来的研究留下了场景尺度的 3D 生成。

额外的定性实验

本节描述了额外的定性比较,由于空间有限,无法包含在主要论文中。首先,请参考补充材料中附的视频,提供 Meta 3D AsetGen 定性结果的整体呈现。在图7中,我们强调了MetaILRM在几何、纹理和材料重建中的作用在图 11 中,我们通过更改相同概念的文本提示来可视化 Meta 3D AsetGen 提供的材料的控制,即金属度和粗糙度图 8 显示了在给定四个输入测试视图的情况下使用 MetaILRM 提取的材料图的渲染在图 9 中,我们提供了与 MeshLRM 更广泛的定性比较,这是最强的少视图重建基线最后,图 6 提供了一组文本条件生成,描述了 Blender 阴影渲
染以及渲染的 PBR 图

在这里插入图片描述
在这里插入图片描述

额外的文生3D比较

Tab2 将 Meta 3D AsetGen 的文本到 3D 代与几个快速基线进行比较,为了完整起见,本节包括与明显较慢的方法进行比较。更具体地说,我们进行了与 Tab 相同的用户研究。2 但我们比较了行业基线 Meshy v3 和 Luma Genie 的“细化”阶段,其资产生成时间分别为 5 分钟和 10 分钟。标签。4 包含用户研究的结果。Meta 3D AsssetGen 在文本保真度和视觉质量方面都显着优于 Meshy,同时速度提高了 10 倍。令人惊讶的是,Meta 3D AsetGen 在文本保真度方面与 Luma Genie 相当,在视觉质量的 40% 的情况下获胜。考虑到 Meta 3D AsetGen 的 20 倍生成时间,这是一个显着的结果。
在这里插入图片描述

额外的技术细节

Grid生成器 多视角diffusion fintune unet

我们采用在用文本[16]注释的数十亿个图像上预训练的文本到图像扩散模型,并将其输入和输出通道扩展2倍,以支持同时生成阴影外观和反照率。我们微调模型以预测四个图像 I i , i = 1 , … , 4 I_{i}, i=1, \ldots, 4 Ii,i=1,,4,类似于 [72, 40],通过最小化标准扩散损失。训练总共跨越 2 天,使用 32 个 A100 GPU,总批量大小为 128,学习率为 10−5

MetaILRM

如主要论文所述,MetaILRM 使用直接 SDF 损失 Lsdf、PBR 损失 Lpbr、延迟阴影损失 Ldef、二元交叉熵损失 Lmask 和深度 MSE 损失 Ldepth 进行优化,因此全局目标是:
L = 0.5 L sdf  + L pbr  + 0.5 L def  + 0.1 L mask  + 0.1 L depth  . \mathcal{L}=0.5 \mathcal{L}_{\text {sdf }}+\mathcal{L}_{\text {pbr }}+0.5 \mathcal{L}_{\text {def }}+0.1 \mathcal{L}_{\text {mask }}+0.1 \mathcal{L}_{\text {depth }} . L=0.5Lsdf +Lpbr +0.5Ldef +0.1Lmask +0.1Ldepth .

纹理细化器仅使用 PBR 损失和延迟着色损失: L p b r + 0.5 L d e f L_{pbr} + 0.5L_{def} Lpbr+0.5Ldef

在每个训练批次中,我们随机抽取每个场景的 4 个视图作为源输入视图 I i I_i Ii 和另外 4 个目标视图 I t g t I_tgt Itgt,其中我们渲染 MetaILRM 预测的 sdf 场,或纹理细化器预测的网格。然后我们评估目标视图中上述损失。每个 GPU 3 个场景随机采样,我们在 64 个 GPUS NVIDIA A100 gpu 上训练,产生 3 × 4 × 64 = 768 张图像的有效批量大小。使用 Adam [39] 优化了总损失,学习率为 10-4,用于 13K 步。

延迟阴影损失消融

除了定量验证Tab中延迟阴影损失Ldef的好处外。1,我们还在图12中提供了定性证明。具体来说,反照率和阴影通道预测的PBR材料在3D灯笼资产的实际金属部分表现出更好的金属度图。

直接SDF损失 L sdf L_\text{sdf} Lsdf

我们遵循Azinovic等人[1]对SDF场的直接SDF监督。给定图像中的像素 p 和对应于像素的光线上的采样点 S p S_p Sp,直接 SDF 损失计算为
L sdf  ( p ) = L sdf  t r ( p ) + 0.01 L sdf  f s ( p ) . \mathcal{L}_{\text {sdf }}(p)=\mathcal{L}_{\text {sdf }}^{\mathrm{tr}}(p)+0.01 \mathcal{L}_{\text {sdf }}^{\mathrm{fs}}(p) . Lsdf (p)=Lsdf tr(p)+0.01Lsdf fs(p).

L s d f t r L^{tr}_{sdf} Lsdftr 是一个“自由空间”目标,它迫使 MLP 预测位于相机原点和表面截断区域之间的样本 s ∈ S p f s s \in S^{fs}_p sSpfs 的值为 1:

L sdf  f r ( p ) = 1 ∣ S p f r ∣ ∑ s ∈ S p f s ( D s − 1 ) 2 \mathcal{L}_{\text {sdf }}^{\mathrm{fr}}(p)=\frac{1}{\left|S_{p}^{\mathrm{fr}}\right|} \sum_{s \in S_{p}^{\mathrm{fs}}}\left(D_{s}-1\right)^{2} Lsdf fr(p)= Spfr 1sSpfs(Ds1)2

其中 D s D_s Ds是来自MLP的预测SDF。对于截断区域内的样本 ( s ∈ S p t r s \in S^{tr}_p sSptr ),我们应用 L sdf t r L^{tr}_\text{sdf} Lsdftr ,即靠近表面的样本的符号距离目标。

L sdf  t r ( p ) = 1 ∣ S p t r ∣ ∑ s ∈ S p t r ( D s − D ^ s ) 2 \mathcal{L}_{\text {sdf }}^{\mathrm{tr}}(p)=\frac{1}{\left|S_{p}^{\mathrm{tr}}\right|} \sum_{s \in S_{p}^{\mathrm{tr}}}\left(D_{s}-\hat{D}_{s}\right)^{2} Lsdf tr(p)= Sptr 1sSptr(DsD^s)2

由于 B ×H × W × N ray 点的评估,对此的 NAÏve PyTorch 实现是内存密集型的,其中 B、H、W、Nray 分别是批次中目标图像的数量、高度、宽度和每条射线点的数量。因此,为了支持射线上的大批量、图像分辨率和更密集的点采样,我们使用自定义Triton[65]内核实现了直接的SDF损失。

深度loss L depth \mathcal{L}_{\text {depth}} Ldepth

深度损失 L d e p t h L_depth Ldepth 最小化了渲染深度预测 R d e p t h ( ⋅ ∣ s ^ , π ) R_{depth}(· | \hat{s}, π) Rdepth(s^,π)地面真实深度 R d e p t h ( ⋅ ∣ M , π ) R_{depth}(· | M, π) Rdepth(M,π)之间的均方误差

L depth  = ∥ R depth  ( ⋅ ∣ s ^ , π ) − R depth  ( ⋅ ∣ M , π ) ∥ 2 \mathcal{L}_{\text {depth }}=\left\|\mathcal{R}_{\text {depth }}(\cdot \mid \hat{s}, \pi)-\mathcal{R}_{\text {depth }}(\cdot \mid M, \pi)\right\|^{2} Ldepth =Rdepth (s^,π)Rdepth (M,π)2

其中 R d e p t h ( s , π ) R_{depth}(s, π) Rdepth(s,π) 是从视点 π 渲染形状表示 s(网格或 SDF)的深度图的算子。

纹理精细化

在第3.3节中描述了我们的纹理细化器的高级概述之后,这里我们提供更多的细节。
在这里插入图片描述


图 13:(a) Cross-View Attention 的说明。跨视图注意有助于UNet分支之间的通信,处理预测的纹理特征和UV空间投影的输入视图。该层使用多头注意力机制将预测的纹理特征与基于匹配的 UV 投影输入视图特征融合。(b) 延迟阴影损失计算示例。延迟阴影使用反照率、金属度、粗糙度、法线、物体位置和光源位置计算像素阴影。我们将其应用于地面实况通道(顶部)和预测通道(中间)。误差计算为两者之间的差异,由地面实况法线和预测法线之间的相似性加权,以避免由于不正确的法线而惩罚阴影误差

如前所述,纹理细化器网络Φ总共接受N + 1个纹理图像Ki。网络的第一个输入是增强纹理图像 K 0 ∈ R V × V × 11 K_0∈R^{V ×V ×11} K0RV×V×11,由下式给出:
∀ v ∈ [ 0 , V ] 2 : K 0 ( v ) = { k ( x v ) ⊕ n ( x v ) ⊕ x v ,  if  v ∈ Im ⁡ ( ϕ ) , 0 ,  otherwise  ,  where  x v = ϕ ( v ) . \forall v \in[0, V]^{2}: \quad K_{0}(v)=\left\{\begin{array}{ll}k\left(\boldsymbol{x}_{v}\right) \oplus \boldsymbol{n}\left(\boldsymbol{x}_{v}\right) \oplus \boldsymbol{x}_{v}, & \text { if } v \in \operatorname{Im}(\phi), \\\mathbf{0}, & \text { otherwise },\end{array} \text { where } \boldsymbol{x}_{v}=\phi(v) .\right. v[0,V]2:K0(v)={k(xv)n(xv)xv,0, if vIm(ϕ), otherwise , where xv=ϕ(v).

条件 v ∈ I m ( φ ) v \in I_m(φ) vIm(φ)选择与网格点对应的“有效”UV点;⊕表示通道级联,使 K 0 ( v ) K_0(v) K0(v)是来自MetaI LRM、正常 n ( x v ) n(xv) n(xv)和3D点 x v xv xv的5个PBR参数 k ( x v ) k(xv) k(xv)的堆栈。

除了 K 0 K_0 K0,我们输入到网络 Φ 纹理图像 K i K_i Ki,每个图像都是通过直接从相应的输入视图 I i I_i Ii 中查找信息来提取的(因此避开 MetaILRM)。如上所述,每个有效纹理点 v 对应于网格上唯一的 3D 点 xv = φ(v) ∈ M,这反过来又投影到图像 I i I_i Ii 中的像素 u = π i ( x v ) u = π_i(xv) u=πi(xv)。设 χ i ( v ) ∈ 0 , 1 χ_i(v) \in {0, 1} χi(v)0,1 是指示点 xv 在图像 I i I_i Ii 中是否可见的标志。当点xv在几个视图中可见时,最好在最正的视图中测量,这是由xv处的法线n与射线方向ωv∝x0−xv之间的余弦相似度ωo·n(xv)捕获的。所有这些信息都是通过设置打包到额外的纹理图像中 K i ∈ R V × V × ( D + 1 ) K_i \in R_V ×V ×(D+1) KiRV×V×(D+1):

∀ v ∈ [ 0 , V ] 2 : K i ( v ) = { I i ( π i ( x v ) ) ⊕ ( ω v ⋅ n ( x v ) ) ,  if  v ∈ Im ⁡ ( ϕ )  and  χ i ( v ) = 1 0 ,  otherwise  \forall v \in[0, V]^{2}: \quad K_{i}(v)=\left\{\begin{array}{ll}I_{i}\left(\pi_{i}\left(\boldsymbol{x}_{v}\right)\right) \oplus\left(\boldsymbol{\omega}_{v} \cdot \boldsymbol{n}\left(\boldsymbol{x}_{v}\right)\right), & \text { if } v \in \operatorname{Im}(\phi) \text { and } \chi_{i}(v)=1 \\\mathbf{0}, & \text { otherwise }\end{array}\right. v[0,V]2:Ki(v)={Ii(πi(xv))(ωvn(xv)),0, if vIm(ϕ) and χi(v)=1 otherwise 

纹理网络Φ是一个U-Net,它以纹理增强纹理图像 K 0 K_0 K0为输入,输出最终的增强纹理 K ∈ R V × V × 5 K∈R_V ×V ×5 KRV×V×5。该网络还融合了来自视图特定纹理图像Ki的信息。目标是为每个 UV 点 v 选择 N 个输入视图中的哪一个提供最佳信息。这是通过交叉注意力实现的。具体来说,每个 K i K_i Ki 由另一个 U-Net 并行处理,第一个通过多头交叉注意力查询所有其他信息。在图 13 (a) 中,我们提供了后一个跨视图注意力层的图示。

基于物理的渲染:辐射、BRDFs和模型(重头戏,反复看反复忘)

ToDo

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/782015.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python 比webdriver更好用的ChromiumPage

优点(目前发现的): 不用配合selenium不用下载对应浏览器的webdriver,不用对应浏览器版本不用设置webdriver路径之类的设置目前没看到有出现像webdriver类似的浏览器被控制的提示,使用过程中好像也没被检测出来。每次不…

unity3d:Shader知识点,矩阵,函数,坐标转换,Tags,半透明,阴影,深度,亮度,优化

基本结构 Shader "MyShaderName" {Properties {// 属性}SubShader {// 针对显卡A的SubShaderPass {// 设置渲染状态和标签Tags { "LightMode""ForwardBase" }// 开始Cg代码片段CGPROGRAM// 该代码片段的编译指令,例如:#p…

【vite创建项目】

搭建vue3tsvitepinia框架 一、安装vite并创建项目1、用vite构建项目2、配置vite3、找不到模块 “path“ 或其相对应的类型声明。 二、安装element-plus1、安装element-plus2、引入框架 三、安装sass sass-loader1、安装sass 四、安装vue-router-next 路由1、安装vue-router42搭…

python基础篇(8):异常处理

在Python编程中,异常是程序运行时发生的错误,它会中断程序的正常执行流程。异常处理机制使得程序能够捕获这些错误,并进行适当的处理,从而避免程序崩溃。 1 错误类型 代码的错误一般会有语法错误和异常错误两种,语法错…

CTF常用sql注入(一)联合注入和宽字节

0x01 前言 给自己总结一下sql注入的常用姿势吧,记录一下学习 0x02 联合 联合注入的关键词是union SQL的union联合注入原理是联合两个表进行注入攻击,使用union select关键词来进行联合查询。 那么为什么我们在题目中一般是只写一个呢 因为 $sql &quo…

逆变器学习笔记(三)

DCDC电源芯片外围器件选型_dcdc的comp补偿-CSDN博客、 1.芯片的COMP引脚通常用于补偿网络: 芯片的COMP引脚通常用于补偿网络,在控制环路中发挥重要作用。COMP引脚接电容和电阻串联接地,主要是为了稳定控制环路、调整环路响应速度和滤波噪声…

cs231n作业1——SVM

参考文章:cs231n assignment1——SVM SVM 训练阶段,我们的目的是为了得到合适的 𝑊 和 𝑏 ,为实现这一目的,我们需要引进损失函数,然后再通过梯度下降来训练模型。 def svm_loss_naive(W, …

NAT 打洞

由于 ipv4 地址数量的有限性,导致实际网络部署模式中存在大量的 NAT 网络。对于 NAT 内部的主机,可以主动发起去公网的流量,但对于位于不同 NAT 内的两台主机而言,想要直接进行点对点的连接,就需要用到打洞技术了。 常…

Bash ——shell

Bash作为用户与操作系统之间的接口,让用户通过命令行输入各种指令来控制和操作计算机系统。 shell的两种解释: 1.linux命令解释器 Terminal 终端 ——》shell命令 ——》 Linux kernel (内核) Linux内核的作用: 1.…

AI与编程:一个学生的心路历程与思考

前言 大家好,本人是在一个在校的大学生,方向是前端语言。爱好是码代码和看一点小新闻,游戏也是喜爱的。其实本篇文章的想法是源于网上一些人对AI以及对前端的看法,看完网上的评论后我也是有感而发。本篇文章的讨论中心也是围绕着A…

IDA*——AcWing 180. 排书

IDA* 定义 IDA*(Iterative Deepening A*)是一种结合了深度优先搜索(DFS)的递归深度限制特性和A搜索的启发式估价函数的搜索算法。它主要用于解决启发式搜索问题,尤其是当搜索空间很大或者搜索成本不确定时。 IDA* 是…

SprongBoot及其基础应用全套部署脚本和配置

POM.xml配置 </dependencies> <!--skywalking日志监控依赖--><dependency><groupId>org.apache.skywalking</groupId><artifactId>apm-toolkit-logback-1.x</artifactId><version>8.5.0</version></dependency&g…

轻松驾驭开发之旅:Maven配置阿里云CodeUp远程私有仓库全攻略

文章目录 引言一、为什么选择阿里云CodeUp作为远程私有仓库&#xff1f;二、Maven配置阿里云CodeUp远程私有仓库的步骤准备工作配置Maven的settings.xml文件配置项目的pom.xml文件验证配置是否成功 三、使用阿里云CodeUp远程私有仓库的注意事项 引言 在软件开发的世界里&#…

软件工程(上)

目录 软件过程模型&#xff08;软件开发模型&#xff09; 瀑布模型 原型模型 V模型 构件组装模型 螺旋模型&#xff08;原型瀑布&#xff09; 基于构件的软件工程&#xff08;CBSE&#xff09; 快速应用开发模型&#xff08;RAD&#xff09; 统一过程&#xff08;UP&a…

Http Json参数到x-www-form-urlencoded参数的在线转换工具

Json参数到x-www-form-urlencoded参数的在线转换工具

C语言 printf 函数多种输出格式以及占位输出

一、输出格式 在C语言中&#xff0c;printf 函数提供了多种输出格式&#xff0c;用于控制不同类型数据的输出方式。 1.整数输出格式 %d&#xff1a;以十进制形式输出整数。 %o&#xff1a;以八进制形式输出整数&#xff08;无前导0&#xff09;。 %x 或 %X&#xff1a;以十六进…

CMD命令详细介绍 | 超详细版本!

文章目录 启动cmd命令用户启动使用管理员的账号启动 文件夹命令网络命令其他常用命令介绍常用快捷方式程序员相关命令 本文参考了博客园一篇帖子&#xff0c;ULR&#xff1a;cmd常用命令介绍(可收藏) - Mrwhite86 - 博客园 (cnblogs.com) CMD是Windows操作系统自带的命令行解释…

嵌入式C语言面试相关知识——内存管理(不定期更新)

嵌入式C语言面试相关知识——内存管理&#xff08;不定期更新&#xff09; 一、博客声明二、自问题目1、嵌入式系统的内存布局是怎么样的&#xff1f;2、动态内存分配在嵌入式系统中的使用有什么注意事项&#xff1f;3、什么是内存碎片&#xff0c;如何减少内存碎片&#xff1f…

恢复出厂设置后如何从 iPhone 恢复数据

在 iPhone 恢复出厂设置后&#xff0c;所有数据都会被删除&#xff0c;并且 iPhone 将恢复到原始出厂设置&#xff0c;这意味着您的所有 iPhone 数据&#xff0c;包括照片、视频、联系人和应用程序都将消失。 幸运的是&#xff0c;如果您有备份可以恢复&#xff0c;这并不一定…

Edge浏览器油猴插件的安装与使用

油猴 (又称篡改猴或Tampermonkey) 是最流行的浏览器扩展之一。它允许用户自定义并增强网页的功能。用户脚本是小型 JavaScript 程序&#xff0c;可用于向网页添加新功能或修改现有功能。使用油猴&#xff0c;您可以轻松在任何网站上创建、管理和运行这些用户脚本。 1.插件的安…