# DirectEdit: Step-Level Accurate Inversion for Flow-Based Image Editing

DirectEdit is a simple yet highly efficient training-free editing method that eliminates the inherent reconstruction error of inversion, achieving precise background preservation and reliable feature sharing.

# Setup
Install the conda environment:
```bash
conda env create -f environment.yml
conda activate directedit
```

# Real Image Editing

You can edit your own images using the Gradio demo:

```python
python demo.py
```

or you can edit a single image with the following script:


``` python
python edit_real_flux_singleimg.py --recov_cfg 3\
                         --attn_ratio 0.1\
                         --src_path 'examples/1.jpg'\
                         --src_prompt 'a cup of coffee with a drawing of a tulip put on the wooden table.'\
                         --tar_prompt 'a cup of coffee with a drawing of a lion put on the wooden table.'\
                         --saved_path './'\
                         --mask_path 'mask_path'(Optional)

python edit_real_sd35_singleimg.py --recov_cfg 2\
                         --attn_ratio 0.3\
                         --src_path 'examples/1.jpg'\
                         --src_prompt 'a cup of coffee with a drawing of a tulip put on the wooden table.'\
                         --tar_prompt 'a cup of coffee with a drawing of a lion put on the wooden table.'\
                         --saved_path './'\
                         --mask_path 'mask_path'(Optional)
```

**Intuition of hyperparameters**:  

```
*recov_cfg*
- **Recommended**: 2.0 - 3.5
- **Warning**: Values too small (<1.5) or too large (>4.0) will produce poor quality results
- Optimal range provides best balance between prompt adherence and image quality

*attn_ratio*
- **Recommended**: 0.05 - 0.2
- **Effect**: This hyperparameter influences the consistency between the edited region and the source image, where a greater number of injection steps results in higher similarity.

*mask_path*
- **Effect**: Achieving precise background preservation using masks.
- The mask can be obtained through segmentation or manual drawing. We provide a mask segmentation function in the Gradio demo; you can obtain the mask by clicking the edit object of the uploaded image.
```

