Spaces:
				
			
			
	
			
			
					
		Running
		
	
	
	
			
			
	
	
	
	
		
		
					
		Running
		
	Add examples
Browse files- .gitattributes +1 -0
- README.md +1 -1
- app.py +30 -2
- images/95UF6LXe-Lo.jpg +3 -0
- images/ILip77SbmOE.jpg +3 -0
- images/README.md +7 -0
- images/et_78QkMMQs.jpg +3 -0
- images/rDEOVtE7vOs.jpg +3 -0
    	
        .gitattributes
    CHANGED
    
    | @@ -1,3 +1,4 @@ | |
|  | |
| 1 | 
             
            *.7z filter=lfs diff=lfs merge=lfs -text
         | 
| 2 | 
             
            *.arrow filter=lfs diff=lfs merge=lfs -text
         | 
| 3 | 
             
            *.bin filter=lfs diff=lfs merge=lfs -text
         | 
|  | |
| 1 | 
            +
            *.jpg filter=lfs diff=lfs merge=lfs -text
         | 
| 2 | 
             
            *.7z filter=lfs diff=lfs merge=lfs -text
         | 
| 3 | 
             
            *.arrow filter=lfs diff=lfs merge=lfs -text
         | 
| 4 | 
             
            *.bin filter=lfs diff=lfs merge=lfs -text
         | 
    	
        README.md
    CHANGED
    
    | @@ -4,7 +4,7 @@ emoji: 😻 | |
| 4 | 
             
            colorFrom: purple
         | 
| 5 | 
             
            colorTo: red
         | 
| 6 | 
             
            sdk: gradio
         | 
| 7 | 
            -
            sdk_version: 3.0. | 
| 8 | 
             
            app_file: app.py
         | 
| 9 | 
             
            pinned: false
         | 
| 10 | 
             
            ---
         | 
|  | |
| 4 | 
             
            colorFrom: purple
         | 
| 5 | 
             
            colorTo: red
         | 
| 6 | 
             
            sdk: gradio
         | 
| 7 | 
            +
            sdk_version: 3.0.3
         | 
| 8 | 
             
            app_file: app.py
         | 
| 9 | 
             
            pinned: false
         | 
| 10 | 
             
            ---
         | 
    	
        app.py
    CHANGED
    
    | @@ -4,6 +4,7 @@ from __future__ import annotations | |
| 4 |  | 
| 5 | 
             
            import argparse
         | 
| 6 | 
             
            import os
         | 
|  | |
| 7 | 
             
            import sys
         | 
| 8 | 
             
            from typing import Callable
         | 
| 9 |  | 
| @@ -219,6 +220,17 @@ def update_style_image(style_name: str) -> dict: | |
| 219 | 
             
                return gr.Markdown.update(value=text)
         | 
| 220 |  | 
| 221 |  | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 222 | 
             
            def main():
         | 
| 223 | 
             
                args = parse_args()
         | 
| 224 | 
             
                app = App(device=torch.device(args.device))
         | 
| @@ -245,12 +257,12 @@ This is an unofficial demo app for [https://github.com/williamyang1991/DualStyle | |
| 245 |  | 
| 246 | 
             
            <center><img id="overview" src="https://raw.githubusercontent.com/williamyang1991/DualStyleGAN/main/doc_images/overview.jpg" alt="overview"></center>
         | 
| 247 | 
             
            ''')
         | 
| 248 | 
            -
             | 
| 249 | 
             
                    with gr.Box():
         | 
| 250 | 
             
                        gr.Markdown('''## Step 1 (Preprocess Input Image)
         | 
| 251 |  | 
| 252 | 
             
            - Drop an image containing a near-frontal face to the **Input Image**.
         | 
| 253 | 
             
                - If there are multiple faces in the image, hit the Edit button in the upper right corner and crop the input image beforehand.
         | 
|  | |
| 254 | 
             
            - Hit the **Detect & Align Face** button.
         | 
| 255 | 
             
            - Hit the **Reconstruct Face** button.
         | 
| 256 | 
             
                - The final result will be based on this **Reconstructed Face**. So, if the reconstructed image is not satisfactory, you may want to change the input image.
         | 
| @@ -320,12 +332,28 @@ This is an unofficial demo app for [https://github.com/williamyang1991/DualStyle | |
| 320 | 
             
                            with gr.Column():
         | 
| 321 | 
             
                                output_image = gr.Image(label='Output Image')
         | 
| 322 |  | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 323 | 
             
                    gr.Markdown(
         | 
| 324 | 
            -
                        'Related App: [https://huggingface.co/spaces/hysts/DualStyleGAN](https://huggingface.co/spaces/hysts/DualStyleGAN)' | 
|  | |
| 325 | 
             
                    gr.Markdown(
         | 
| 326 | 
             
                        '<center><img src="https://visitor-badge.glitch.me/badge?page_id=gradio-blocks.dualstylegan" alt="visitor badge"/></center>'
         | 
| 327 | 
             
                    )
         | 
| 328 |  | 
|  | |
|  | |
|  | |
| 329 | 
             
                    detect_button.click(fn=app.detect_and_align_face,
         | 
| 330 | 
             
                                        inputs=input_image,
         | 
| 331 | 
             
                                        outputs=face_image)
         | 
|  | |
| 4 |  | 
| 5 | 
             
            import argparse
         | 
| 6 | 
             
            import os
         | 
| 7 | 
            +
            import pathlib
         | 
| 8 | 
             
            import sys
         | 
| 9 | 
             
            from typing import Callable
         | 
| 10 |  | 
|  | |
| 220 | 
             
                return gr.Markdown.update(value=text)
         | 
| 221 |  | 
| 222 |  | 
| 223 | 
            +
            def set_example(example: list) -> list[dict]:
         | 
| 224 | 
            +
                return [
         | 
| 225 | 
            +
                    gr.Image.update(value=example[0]),
         | 
| 226 | 
            +
                    gr.Radio.update(value=example[1]),
         | 
| 227 | 
            +
                    gr.Slider.update(value=example[2]),
         | 
| 228 | 
            +
                    gr.Slider.update(value=example[3]),
         | 
| 229 | 
            +
                    gr.Slider.update(value=example[4]),
         | 
| 230 | 
            +
                    gr.Checkbox.update(value=example[5]),
         | 
| 231 | 
            +
                ]
         | 
| 232 | 
            +
             | 
| 233 | 
            +
             | 
| 234 | 
             
            def main():
         | 
| 235 | 
             
                args = parse_args()
         | 
| 236 | 
             
                app = App(device=torch.device(args.device))
         | 
|  | |
| 257 |  | 
| 258 | 
             
            <center><img id="overview" src="https://raw.githubusercontent.com/williamyang1991/DualStyleGAN/main/doc_images/overview.jpg" alt="overview"></center>
         | 
| 259 | 
             
            ''')
         | 
|  | |
| 260 | 
             
                    with gr.Box():
         | 
| 261 | 
             
                        gr.Markdown('''## Step 1 (Preprocess Input Image)
         | 
| 262 |  | 
| 263 | 
             
            - Drop an image containing a near-frontal face to the **Input Image**.
         | 
| 264 | 
             
                - If there are multiple faces in the image, hit the Edit button in the upper right corner and crop the input image beforehand.
         | 
| 265 | 
            +
                - You can also load example inputs from the **Examples** section at the bottom of this page.
         | 
| 266 | 
             
            - Hit the **Detect & Align Face** button.
         | 
| 267 | 
             
            - Hit the **Reconstruct Face** button.
         | 
| 268 | 
             
                - The final result will be based on this **Reconstructed Face**. So, if the reconstructed image is not satisfactory, you may want to change the input image.
         | 
|  | |
| 332 | 
             
                            with gr.Column():
         | 
| 333 | 
             
                                output_image = gr.Image(label='Output Image')
         | 
| 334 |  | 
| 335 | 
            +
                    with gr.Box():
         | 
| 336 | 
            +
                        gr.Markdown('## Examples')
         | 
| 337 | 
            +
             | 
| 338 | 
            +
                        paths = sorted(pathlib.Path('images').glob('*.jpg'))
         | 
| 339 | 
            +
                        samples = [[path.as_posix(), 'cartoon', 26, 0.6, 1.0, False]
         | 
| 340 | 
            +
                                   for path in paths]
         | 
| 341 | 
            +
                        examples = gr.Dataset(components=[
         | 
| 342 | 
            +
                            input_image, style_type, style_index, structure_weight,
         | 
| 343 | 
            +
                            color_weight, structure_only
         | 
| 344 | 
            +
                        ],
         | 
| 345 | 
            +
                                              samples=samples)
         | 
| 346 | 
            +
             | 
| 347 | 
             
                    gr.Markdown(
         | 
| 348 | 
            +
                        'Related App: [https://huggingface.co/spaces/hysts/DualStyleGAN](https://huggingface.co/spaces/hysts/DualStyleGAN)'
         | 
| 349 | 
            +
                    )
         | 
| 350 | 
             
                    gr.Markdown(
         | 
| 351 | 
             
                        '<center><img src="https://visitor-badge.glitch.me/badge?page_id=gradio-blocks.dualstylegan" alt="visitor badge"/></center>'
         | 
| 352 | 
             
                    )
         | 
| 353 |  | 
| 354 | 
            +
                    examples.click(fn=set_example,
         | 
| 355 | 
            +
                                   inputs=examples,
         | 
| 356 | 
            +
                                   outputs=examples.components)
         | 
| 357 | 
             
                    detect_button.click(fn=app.detect_and_align_face,
         | 
| 358 | 
             
                                        inputs=input_image,
         | 
| 359 | 
             
                                        outputs=face_image)
         | 
    	
        images/95UF6LXe-Lo.jpg
    ADDED
    
    |   | 
| Git LFS Details
 | 
    	
        images/ILip77SbmOE.jpg
    ADDED
    
    |   | 
| Git LFS Details
 | 
    	
        images/README.md
    ADDED
    
    | @@ -0,0 +1,7 @@ | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 1 | 
            +
            These images are freely-usable ones from [Unsplash](https://unsplash.com/).
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            - https://unsplash.com/photos/rDEOVtE7vOs
         | 
| 4 | 
            +
            - https://unsplash.com/photos/et_78QkMMQs
         | 
| 5 | 
            +
            - https://unsplash.com/photos/ILip77SbmOE
         | 
| 6 | 
            +
            - https://unsplash.com/photos/95UF6LXe-Lo
         | 
| 7 | 
            +
             | 
    	
        images/et_78QkMMQs.jpg
    ADDED
    
    |   | 
| Git LFS Details
 | 
    	
        images/rDEOVtE7vOs.jpg
    ADDED
    
    |   | 
| Git LFS Details
 | 

