byeongjun-park commited on
Commit
7355d35
β€’
1 Parent(s): cc3abfa

HarmonyView update

Browse files
app.py CHANGED
@@ -20,21 +20,16 @@ _DESCRIPTION = '''
20
  <a style="display:inline-block; margin-left: .5em" href="https://arxiv.org/abs/2312.15980"><img src="https://img.shields.io/badge/2312.15980-f9f7f7?logo="></a>
21
  <a style="display:inline-block; margin-left: .5em" href='https://github.com/byeongjun-park/HarmonyView'><img src='https://img.shields.io/github/stars/byeongjun-park/HarmonyView?style=social' /></a>
22
  </div>
23
- Given a single-view image, HarmonyView is able to generate multiview-consistent images, which enables direct 3D reconstruction with NeuS or NeRF without SDS loss </br>
24
 
25
  Procedure: </br>
26
- **Step 1**. Upload an image or select an example. ==> The foreground is masked out by SAM and we crop it as inputs. </br>
27
- **Step 2**. Select "Elevation angle "and click "Run generation". ==> Generate multiview images. The **Elevation angle** is the elevation of the Input image. (This costs about 45s.) </br>
 
28
  You may adjust the **Crop size** and **Elevation angle** to get a better result! <br>
29
  To reconstruct a NeRF or a 3D mesh from the generated images, please refer to our [github repository](https://github.com/byeongjun-park/HarmonyView). <br>
30
  We have heavily borrowed codes from [Syncdreamer](https://huggingface.co/spaces/liuyuan-pal/SyncDreamer), which is an our strong baseline.
31
  '''
32
- _USER_GUIDE0 = "Step1: Please upload an image in the block above (or choose an example shown in the left)."
33
- # _USER_GUIDE1 = "Step1: Please select a **Crop size** and click **Crop it**."
34
- _USER_GUIDE2 = "Step2: Please choose a **Elevation angle** and click **Run Generate**. The **Elevation angle** is the elevation of the Input image. This costs about 45s."
35
- _USER_GUIDE3 = "Generated multiview images are shown below! (You may adjust the **Crop size** and **Elevation angle** to get a better result!)"
36
-
37
- others = '''**Step 1**. Select "Crop size" and click "Crop it". ==> The foreground object is centered and resized. </br>'''
38
 
39
  deployed = True
40
 
@@ -180,14 +175,16 @@ def run_demo():
180
 
181
  # NOTE: Examples must match inputs
182
  examples_full = [
183
- ['hf_demo/examples/monkey.png',30,200,"SAM output"],
184
- ['hf_demo/examples/cat.png',30,200,"SAM output"],
185
- ['hf_demo/examples/crab.png',30,200,"SAM output"],
186
- ['hf_demo/examples/elephant.png',30,200,"SAM output"],
187
- ['hf_demo/examples/flower.png',0,200,"SAM output"],
 
 
188
  ['hf_demo/examples/forest.png',30,200,"SAM output"],
 
189
  ['hf_demo/examples/teapot.png',20,200,"SAM output"],
190
- ['hf_demo/examples/basket.png',30,200,"SAM output"],
191
  ]
192
 
193
  image_block = gr.Image(type='pil', image_mode='RGBA', height=256, label='Input image', tool=None, interactive=True)
@@ -216,7 +213,6 @@ def run_demo():
216
 
217
  with gr.Column(scale=0.8):
218
  image_block.render()
219
- # guide_text = gr.Markdown(_USER_GUIDE0, visible=True)
220
  crop_size.render()
221
  fig0 = gr.Image(value=Image.open('assets/crop_size.jpg'), type='pil', image_mode='RGB', height=256, show_label=False, tool=None, interactive=False)
222
 
@@ -238,9 +234,7 @@ def run_demo():
238
 
239
  output_block = gr.Image(type='pil', image_mode='RGB', label="Outputs of HarmonyView", height=256, interactive=False)
240
 
241
- image_block.change(fn=partial(sam_predict, mask_predictor, removal), inputs=[image_block], outputs=[sam_block], queue=True) \
242
- .success(fn=resize_inputs, inputs=[image_block, sam_block, crop_size, background_removal], outputs=[input_block], queue=True)
243
-
244
  background_removal.change(fn=resize_inputs, inputs=[image_block, sam_block, crop_size, background_removal], outputs=[input_block], queue=True)
245
  crop_size.change(fn=resize_inputs, inputs=[image_block, sam_block, crop_size, background_removal], outputs=[input_block], queue=True)
246
 
 
20
  <a style="display:inline-block; margin-left: .5em" href="https://arxiv.org/abs/2312.15980"><img src="https://img.shields.io/badge/2312.15980-f9f7f7?logo="></a>
21
  <a style="display:inline-block; margin-left: .5em" href='https://github.com/byeongjun-park/HarmonyView'><img src='https://img.shields.io/github/stars/byeongjun-park/HarmonyView?style=social' /></a>
22
  </div>
23
+ Given a single-view image, HarmonyView is able to generate diverse and multiview-consistent images, resulting in creating plausible 3D contents with NeuS or NeRF </br>
24
 
25
  Procedure: </br>
26
+ **Step 1**. Upload an image. ==> The foreground is masked out by SAM. </br>
27
+ **Step 2**. Select the input to HarmonyView (Input image or SAM output). ==> Then, we crop it as inputs. </br>
28
+ **Step 3**. Select "Elevation angle "and click "Run generation". ==> Generate multiview images. The **Elevation angle** is the elevation of the Input image. (This costs about 45s.) </br>
29
  You may adjust the **Crop size** and **Elevation angle** to get a better result! <br>
30
  To reconstruct a NeRF or a 3D mesh from the generated images, please refer to our [github repository](https://github.com/byeongjun-park/HarmonyView). <br>
31
  We have heavily borrowed codes from [Syncdreamer](https://huggingface.co/spaces/liuyuan-pal/SyncDreamer), which is an our strong baseline.
32
  '''
 
 
 
 
 
 
33
 
34
  deployed = True
35
 
 
175
 
176
  # NOTE: Examples must match inputs
177
  examples_full = [
178
+ ['hf_demo/examples/dragon.png',30,200,"Input image"],
179
+ ['hf_demo/examples/drum_kids.png',15,240,"Input image"],
180
+ ['hf_demo/examples/table.png',30,200,"Input image"],
181
+ ['hf_demo/examples/panda_back.png', 15, 240, "SAM output"],
182
+ ['hf_demo/examples/boxer_toy.png', 30, 220, "SAM output"],
183
+ ['hf_demo/examples/rose.png',30,200,"Input image"],
184
+ ['hf_demo/examples/monkey.png', 30, 200, "SAM output"],
185
  ['hf_demo/examples/forest.png',30,200,"SAM output"],
186
+ ['hf_demo/examples/flower.png',0,200,"SAM output"],
187
  ['hf_demo/examples/teapot.png',20,200,"SAM output"],
 
188
  ]
189
 
190
  image_block = gr.Image(type='pil', image_mode='RGBA', height=256, label='Input image', tool=None, interactive=True)
 
213
 
214
  with gr.Column(scale=0.8):
215
  image_block.render()
 
216
  crop_size.render()
217
  fig0 = gr.Image(value=Image.open('assets/crop_size.jpg'), type='pil', image_mode='RGB', height=256, show_label=False, tool=None, interactive=False)
218
 
 
234
 
235
  output_block = gr.Image(type='pil', image_mode='RGB', label="Outputs of HarmonyView", height=256, interactive=False)
236
 
237
+ image_block.change(fn=partial(sam_predict, mask_predictor, removal), inputs=[image_block], outputs=[sam_block], queue=True)
 
 
238
  background_removal.change(fn=resize_inputs, inputs=[image_block, sam_block, crop_size, background_removal], outputs=[input_block], queue=True)
239
  crop_size.change(fn=resize_inputs, inputs=[image_block, sam_block, crop_size, background_removal], outputs=[input_block], queue=True)
240
 
hf_demo/examples/{cat.png β†’ boxer_toy.png} RENAMED
File without changes
hf_demo/examples/{crab.png β†’ dragon.png} RENAMED
File without changes
hf_demo/examples/{elephant.png β†’ drum_kids.png} RENAMED
File without changes
hf_demo/examples/{basket.png β†’ panda_back.png} RENAMED
File without changes
hf_demo/examples/rose.png ADDED

Git LFS Details

  • SHA256: d01571b56f8c6a1bc08c23aaa9c5547b02ba53de9c953502985b9d7addbe951f
  • Pointer size: 132 Bytes
  • Size of remote file: 1.67 MB
hf_demo/examples/table.png ADDED

Git LFS Details

  • SHA256: 88de449626b15ecbc0dd68813a4d6a16e077dfb36175c4acc8e3097b8dac569f
  • Pointer size: 132 Bytes
  • Size of remote file: 1.89 MB