silveroxides commited on
Commit
f8094f7
1 Parent(s): cc2f7e6

Upload README.md

Browse files
Files changed (1) hide show
  1. README.md +182 -0
README.md ADDED
@@ -0,0 +1,182 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: mit
3
+ pipeline_tag: text-to-image
4
+ tags:
5
+ - image-to-image
6
+ ---
7
+
8
+ <h1 align="center">OmniGen: Unified Image Generation</h1>
9
+
10
+
11
+ <p align="center">
12
+ <a href="">
13
+ <img alt="Build" src="https://img.shields.io/badge/Project%20Page-OmniGen-yellow">
14
+ </a>
15
+ <a href="https://arxiv.org/abs/2409.11340">
16
+ <img alt="Build" src="https://img.shields.io/badge/arXiv%20paper-2409.11340-b31b1b.svg">
17
+ </a>
18
+ <a href="https://huggingface.co/spaces/Shitao/OmniGen">
19
+ <img alt="License" src="https://img.shields.io/badge/HF%20Demo-🤗-lightblue">
20
+ </a>
21
+ <a href="https://huggingface.co/Shitao/OmniGen-v1">
22
+ <img alt="Build" src="https://img.shields.io/badge/HF%20Model-🤗-yellow">
23
+ </a>
24
+ </p>
25
+
26
+ <h4 align="center">
27
+ <p>
28
+ <a href=#2-news>News</a> |
29
+ <a href=#3-methodology>Methodology</a> |
30
+ <a href=#4-what-can-omnigen-do>Capabilities</a> |
31
+ <a href=#5-quick-start>Quick Start</a> |
32
+ <a href="#6-finetune">Finetune</a> |
33
+ <a href="#license">License</a> |
34
+ <a href="#citation">Citation</a>
35
+ <p>
36
+ </h4>
37
+
38
+ More information please refer to our github repo: https://github.com/VectorSpaceLab/OmniGen
39
+
40
+ ## 1. Overview
41
+
42
+ OmniGen is a unified image generation model that can generate a wide range of images from multi-modal prompts. It is designed to be simple, flexible and easy to use. We provide [inference code](#5-quick-start) so that everyone can explore more functionalities of OmniGen.
43
+
44
+ Existing image generation models often require loading several additional network modules (such as ControlNet, IP-Adapter, Reference-Net, etc.) and performing extra preprocessing steps (e.g., face detection, pose estimation, cropping, etc.) to generate a satisfactory image. However, **we believe that the future image generation paradigm should be more simple and flexible, that is, generating various images directly through arbitrarily multi-modal instructions without the need for additional plugins and operations, similar to how GPT works in language generation.**
45
+
46
+ Due to the limited resources, OmniGen still has room for improvement. We will continue to optimize it, and hope it inspire more universal image generation models. You can also easily fine-tune OmniGen without worrying about designing networks for specific tasks; you just need to prepare the corresponding data, and then run the [script](#6-finetune). Imagination is no longer limited; everyone can construct any image generation task, and perhaps we can achieve very interesting, wonderful and creative things.
47
+
48
+ If you have any questions, ideas or interesting tasks you want OmniGen to accomplish, feel free to discuss with us: 2906698981@qq.com, wangyueze@tju.edu.cn, zhengliu1026@gmail.com. We welcome any feedback to help us improve the model.
49
+
50
+
51
+
52
+ ## 2. News
53
+ - 2024-10-22: :fire: We release the code for OmniGen. Inference: [docs/inference.md](https://github.com/VectorSpaceLab/OmniGen/blob/main/docs/inference.md) Train: [docs/fine-tuning.md](https://github.com/VectorSpaceLab/OmniGen/blob/main/docs/fine-tuning.md)
54
+ - 2024-10-22: :fire: We release the first version of OmniGen. Model Weight: [Shitao/OmniGen-v1](https://huggingface.co/Shitao/OmniGen-v1) HF Demo: [🤗](https://huggingface.co/spaces/Shitao/OmniGen)
55
+
56
+
57
+
58
+ ## 3. Methodology
59
+
60
+ You can see details in our [paper](https://arxiv.org/abs/2409.11340).
61
+
62
+
63
+ ## 4. What Can OmniGen do?
64
+ ![demo](./demo_cases.png)
65
+
66
+ OmniGen is a unified image generation model that you can use to perform various tasks, including but not limited to text-to-image generation, subject-driven generation, Identity-Preserving Generation, image editing, and image-conditioned generation. **OmniGen don't need additional plugins or operations, it can automatically identify the features (e.g., required object, human pose, depth mapping) in input images according the text prompt.**
67
+ We showcase some examples in [inference.ipynb](https://github.com/VectorSpaceLab/OmniGen/blob/main/inference.ipynb). And in [inference_demo.ipynb](https://github.com/VectorSpaceLab/OmniGen/blob/main/inference_demo.ipynb), we show a insteresting pipeline to generate and modify a image.
68
+
69
+ If you are not entirely satisfied with certain functionalities or wish to add new capabilities, you can try [fine-tuning OmniGen](#6-finetune).
70
+
71
+
72
+
73
+ ## 5. Quick Start
74
+
75
+
76
+ ### Using OmniGen
77
+ Install via Github(Recommend):
78
+ ```bash
79
+ git clone https://github.com/staoxiao/OmniGen.git
80
+ cd OmniGen
81
+ pip install -e .
82
+ ```
83
+ or via pypi:
84
+ ```bash
85
+ pip install OmniGen
86
+ ```
87
+
88
+ Here are some examples:
89
+ ```python
90
+ from OmniGen import OmniGenPipeline
91
+
92
+ pipe = OmniGenPipeline.from_pretrained("Shitao/OmniGen-v1")
93
+
94
+ # Text to Image
95
+ images = pipe(
96
+ prompt="A curly-haired man in a red shirt is drinking tea.",
97
+ height=1024,
98
+ width=1024,
99
+ guidance_scale=2.5,
100
+ seed=0,
101
+ )
102
+ images[0].save("example_t2i.png") # save output PIL Image
103
+
104
+ # Multi-modal to Image
105
+ # In prompt, we use the placeholder to represent the image. The image placeholder should be in the format of <img><|image_*|></img>
106
+ # You can add multiple images in the input_images. Please ensure that each image has its placeholder. For example, for the list input_images [img1_path, img2_path], the prompt needs to have two placeholders: <img><|image_1|></img>, <img><|image_2|></img>.
107
+ images = pipe(
108
+ prompt="A man in a black shirt is reading a book. The man is the right man in <img><|image_1|></img>."
109
+ input_images=["./imgs/test_cases/two_man.jpg"]
110
+ height=1024,
111
+ width=1024,
112
+ separate_cfg_infer=False, # if OOM, you can set separate_cfg_infer=True
113
+ guidance_scale=3,
114
+ img_guidance_scale=1.6
115
+ )
116
+ images[0].save("example_ti2i.png") # save output PIL image
117
+ ```
118
+ For more details about the argument in inference, please refer to [docs/inference.md](https://github.com/VectorSpaceLab/OmniGen/blob/main/docs/inference.md).
119
+ For more examples for image generation, you can refer to [inference.ipynb](https://github.com/VectorSpaceLab/OmniGen/blob/main/inference.ipynb) and [inference_demo.ipynb](https://github.com/VectorSpaceLab/OmniGen/blob/main/inference_demo.ipynb)
120
+
121
+
122
+ ### Using Diffusers
123
+ Coming soon.
124
+
125
+
126
+ ### Gradio Demo
127
+
128
+ We construct an online demo in [Huggingface](https://huggingface.co/spaces/Shitao/OmniGen).
129
+
130
+ For the local gradio demo, you can run:
131
+ ```python
132
+ python app.py
133
+ ```
134
+
135
+
136
+
137
+ ## 6. Finetune
138
+ We provide a training script `train.py` to fine-tune OmniGen.
139
+ Here is a toy example about LoRA finetune:
140
+ ```bash
141
+ accelerate launch --num_processes=1 train.py \
142
+ --model_name_or_path Shitao/OmniGen-v1 \
143
+ --batch_size_per_device 2 \
144
+ --condition_dropout_prob 0.01 \
145
+ --lr 1e-3 \
146
+ --use_lora \
147
+ --lora_rank 8 \
148
+ --json_file ./toy_data/toy_subject_data.jsonl \
149
+ --image_path ./toy_data/images \
150
+ --max_input_length_limit 18000 \
151
+ --keep_raw_resolution \
152
+ --max_image_size 1024 \
153
+ --gradient_accumulation_steps 1 \
154
+ --ckpt_every 10 \
155
+ --epochs 200 \
156
+ --log_every 1 \
157
+ --results_dir ./results/toy_finetune_lora
158
+ ```
159
+
160
+ Please refer to [docs/finetune.md](https://github.com/VectorSpaceLab/OmniGen/blob/main/docs/fine-tune.md) for more details (e.g. full finetune).
161
+
162
+
163
+
164
+ ## License
165
+ This repo is licensed under the [MIT License](LICENSE).
166
+
167
+
168
+ ## Citation
169
+ If you find this repository useful, please consider giving a star ⭐ and citation
170
+ ```
171
+ @article{xiao2024omnigen,
172
+ title={Omnigen: Unified image generation},
173
+ author={Xiao, Shitao and Wang, Yueze and Zhou, Junjie and Yuan, Huaying and Xing, Xingrun and Yan, Ruiran and Wang, Shuting and Huang, Tiejun and Liu, Zheng},
174
+ journal={arXiv preprint arXiv:2409.11340},
175
+ year={2024}
176
+ }
177
+ ```
178
+
179
+
180
+
181
+
182
+