论文 | VON模型解读《Visual Object Networks: Image Generation with Disentangled 3D Representation》

一 写在前面

未经允许,不得转载,谢谢~~~

这篇文章用GAN网络实现了从single image到3D voxel shape,再到生成不同角度,不同纹理的新图像。

二 文章主要内容

2.1 motivation

目前用GAN网络可以完成很多从image生成新的image的工作,并且效果也都不错。但是缺乏3D shape info,对应的就完成不了很多人类可以简单完成的功能,for example:

  • change viewpoint;
  • change texture;
  • transfer appearance;
  • ...

所以这点就作为本文的motivation,文章希望能够先从单张图像上恢复出3D信息,然后再从3D shape进行图像的生成,这样就可以支持上述3D shape层面的操作。

2.2 main work

  1. 文章通过disentangled object presentation训练一个能够同时生成3D shape和2D images的对抗生成网络。
    (这里对disentangled单词的理解结合文章其他内容,我觉得可以理解为将object的shape,viewpoint,texture独立开)

  2. 特别的,借鉴graphic rendering engine中的常见做法,将图像分成三个条件独立的部分:

    • shape 形状信息
    • viewpoint 角度信息
    • texture 纹理信息
  3. main pipeline
    网络结构图:

主要可以分成以下的3步:

  • 从image通过对抗生成网络生成3D shape。
  • 结合view point 和上一步得到的3D shape,通过映射模块P,得到包含<深度depth, 轮廓silhouette>信息的 2.5D sketches。
  • 结合纹理信息texture和2.5D sketches,通过对抗生成网络生成得到目标图像2D image x。

整个过程就是以上的3步,整体的网络依靠GAN网络进行生成和判别;

整个网络是可以end to end进行训练的。

2.3 related work

  • GANs for 2D image systhesis
  • 3D shape generation
  • Inverse graphics

三 网络具体实现

3.1 dataset

文章基于图像的shape, viewpoint, texture是相互独立的,基于这一点,整个网络训练的时候就不需要paired <2D Images, 3D shapes>, 这一点在很大程度上降低了对数据集标注的要求。

即使用的2D images dataset和3D shapes dataset可以是相互独立的,不需要一一对应,当然整体类别信息需要一致。

这一点体现在网络上就是从2D images生成3D voxel shape的过程,目标只需要判断生成出来的3D shape像是真实的3D shape即可,没有特定的映射关系。

文章中选用了chair和car两个类别进行实验,使用的两个数据集分别是

  • 3D shape: shapenet
  • 2D shape: pix3D + google上爬取到的图像

3.2 formulation

主要就是以上介绍的3个部分。

这部分涉到到很多公式和细节,想认真了解的建议看看原文,这里只记录一些比较重点的部分。

3.2.1 Learning 3D Shape Priors

  • 指的是从2D image到3D shape的过程;
  • 用对抗生成网络完成,包含一个生成器G_shape,一个判别器D_shape。
  • loss函数如下:


3.2.2 Generating 2.5D Sketches

  • 指的是从3D shape + viewpoint生成2.5D sketches的部分;
  • 这个部分的大概意思是给定一个相机位置,先设定从相机位置到一个图像面板各个像素之间的射线群,然后看哪些射线会击中voxels上的点,由射线上的点推断出对应的depth深度信息和visibility (silhouette) 轮廓信息。
  • 具体的细节我还没有看懂,希望大佬指点==

3.2.3 Learning 2D Texture Priors

  • 指的是从2.5D sketches+texture生成新图像的部分;
  • 同样用对抗网络的方式生成,包含了很多内容。
  • 首先是这个阶段的生成器G_texture,判别器D_image,得到这个部分的loss函数:


  • 然后是上个阶段虽然没有生成器,但是作者还是赋予了一个判别器D_2.5D,还有一个识别器E_2.5D, 所以上个阶段的loss的loss函数为:


  • 然后出了GAN网络的loss,还借鉴了cycleGAN的思想,在这里除了E_2.5D,给texture也增强了一个识别器E_texture,相对应的为三个阶段分别设计了三个cycleGAN类似的loss:



  • 最后还加了一个惩罚项:


所以最终这个部分的loss计算公式为:


3.2.4 full model

  • 将3.2.1和3.3.3的两部分loss叠加,得到最终整个模型的loss表示:


3.2.5 network training

虽然文章整体结构是end to end训练的,但在实际操作的时候是先训练部分:

  1. 在3D shape dataset上训练G_shape
  2. 然后在给定ground truth 3D shape和image data的基础上训练G_texture
  3. 最后将两个整合在一起做end to end 的finetune

3.2.6 补充:关于GAN

GAN真的是无所不能啊~

我自己也还没有实战过GAN网络的训练,先补充一点粗略的理解。

  1. 经典的GAN网络一般都由一个生成器G和一个判别器D组成;
  2. 生成器的目的是希望生成的东西和对应的真实的数据集越接近越好,note as min(G)
  3. 判别器的目的是希望能判断出生成出来的东西是假的,即跟真实的数据集越远越好,note as max(D)
  4. 前向的过程是先经过生成器,再经过判别器,梯度回传的时候就反过来,note as:


  5. 其中L指的是loss函数,在这个例子里(G_shape)里,对应的就是:


四 写在最后

1 首先是个人对文章工作的一点想法:

这篇文章整体来说还是很fancy的,依靠GAN网络还原出3D shape,然后再借助2.5D sketches生成各种形状角度的新图像。

文章将shape, texture, viewpoint独立开来这一点起到了很好的实现上的便利性:1) 利用这一点可以做到对不匹配的2D images dataset和3D shape dataset数据进行学习;2) 而且这种在生成3D shape时不考虑角度、纹理信息,只在生成新图像的时候考虑这两个因素的做法可以使得生成的图像与输入的图像可以在样子上有很大的diversity。

整个网络是class-specific的,即一次只能使用于同一个类别,如果能突破这个条件限制就更好了。

2 关于论文阅读笔记记录的一点想法:

还是感觉自己看的文章数量不够多,另外每一篇都用详细的方式去记录还是挺占用时间的。

后面可能会做一些简单记录的尝试~

另外这篇文章中如何根据3D shape + camera parameter得到2.5D sketches的部分没有完全看懂,希望有大佬可以指点迷津,感谢 ̄▽ ̄

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352