File size: 4,550 Bytes
9b0faeb
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97

<div align=center>
<img src="assets/logo.png" width="150px">
</div>
<h2 align="center"> 
  SmartPhotoCrafter: Unified Reasoning, Generation and Optimization for Automatic Photographic Image Editing
</h2>


<a href=""><img src='https://img.shields.io/badge/arXiv-2501.11325-red?style=flat&logo=arXiv&logoColor=red' alt='arxiv'></a>&nbsp;
<a href="https://vivocameraresearch.github.io/smartphotocrafterweb"><img src='https://img.shields.io/badge/Project-Page-Green' alt='Project'></a>&nbsp;
<a href=""><img src='https://img.shields.io/badge/πŸ€—-HuggingFace-blue' alt='HuggingFace'></a>&nbsp;
<a href=""><img src='https://img.shields.io/badge/πŸ€–-ModelScope-purple' alt='ModelScope'></a>&nbsp;
<a href="http://www.apache.org/licenses/LICENSE-2.0"><img src='https://img.shields.io/badge/License-CC BY--NC--SA--4.0-lightgreen?style=flat&logo=Lisence' alt='License'></a>&nbsp;

**SmartPhotoCrafter** is an end-to-end framework for automatic photographic image editing that reformulates traditional editing as a closed-loop reasoning-to-generation process. Unlike prior methods that rely on explicit user instructions, our approach autonomously identifies aesthetic deficiencies, reasons about improvement strategies, and performs targeted edits without human prompts.


## ✨ Highlights 
- **Fully Automatic Editing** – No user instructions or parameters required; the model completes the closed loop of quality assessment β†’ reasoning β†’ editing autonomously.
- **Dual Capability** – Supports both **image restoration** (denoising, deblurring, low-light enhancement) and **image retouching** (color, tone, contrast enhancement).
- **Aesthetic Reasoning** – Explicitly generates image quality analysis and editing suggestions, improving interpretability.
- **High-Fidelity Generation** – Preserves original content structure while delivering photo-realistic outputs with high tonal/color semantic sensitivity.
- **Reinforcement Learning Optimization** – Jointly optimizes reasoning and generation modules, aligning editing trajectories with human aesthetic preferences.

## πŸ–ΌοΈ Demo
![teaser](./assets/teaser.png)

## πŸ“£ News 
- **`2026/04/07`**: We open-source the inference scripts and pretrained weights.

## βœ… To-Do List for SmartPhotoCrafter Release
- βœ… Release the inference code of SmartPhotoCrafter
- [  ]  Release the SmartPhotoCrafter pretrained weights




## Requirements and Installation

### Prepare Environment 
Create a conda environment & install requirements 
```shell
# python==3.10.0 cuda==12.4 torch==2.5
conda create -n smartphotocrafter python==3.10.0
conda activate smartphotocrafter
pip install -r requirements.txt
```

### πŸ“¦ Pretrained Model Weights
| Models           | Download |   Features |
|------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| SmartPhotoCrafter      | πŸ€— [Huggingface]() πŸ€– [ModelScope]()         | 
Qwen-Image-Edit-2509 | πŸ€— [Huggingface](https://huggingface.co/Qwen/Qwen-Image-Edit-2509) πŸ€– [ModelScope](https://www.modelscope.cn/models/Qwen/Qwen-Image-Edit-2509) | Base Model |
 

## πŸ˜‰ Demo Inference
We provide scripts for both automatic and manual editing. Automatic editing only requires inputting one image, while manual editing requires adding a prompt.

Automatically edit reasoning scripts
```PowerShell
bash scripts/inference/automatic-edit.sh
```

Manual edit reasoning scripts
```PowerShell
bash scripts/inference/manual-eidt.sh
```

Script example
```PowerShell
CUDA_VISIBLE_DEVICES=0 python infer.py \
    --model_path "ckpt/Qwen-Image-Edit-2509" \
    --dit_path "ckpt/DiT.safetensors" \
    --vlm_path "ckpt/text_encoder" \
    --image_path "example/841012.png" \
    --output_folder "example/output/automatic" \
    --seed 42 \
```


## πŸš€ Training
Coming Soon ...

## ⭐ Acknowledgement
Our code is modified based on [Edit-R1](https://github.com/PKU-YuanGroup/Edit-R1). We adopt [Qwen-Image-Edit-2509](https://github.com/QwenLM/Qwen-Image) as the base model. 

## πŸ“œ License 
All the materials, including code, checkpoints, and demos, are made available under the [Creative Commons BY-NC-SA 4.0](https://creativecommons.org/licenses/by-nc-sa/4.0/) license. You are free to copy, redistribute, remix, transform, and build upon the project for non-commercial purposes, as long as you give appropriate credit and distribute your contributions under the same license.


## πŸŽ“ Citation

```bibtex

```