ImageReward
Project description
ImageReward
🤗 HF Repo • 🐦 Twitter • 📃 Paper
ImageReward: Learning and Evaluating Human Preferences for Text-to-Image Generation
ImageReward is the first general-purpose text-to-image human preference RM, which is trained on in total 137k pairs of expert comparisons.
It outperforms existing text-image scoring methods, such as CLIP (by 38.6%), Aesthetic (by 39.6%), and BLIP (by 31.6%), in terms of understanding human preference in text-to-image synthesis. Try image-reward
package in only 3 lines of code!
# pip install image-reward
import ImageReward as RM
model = RM.load("ImageReward-v1.0")
rewards = model.score("<prompt>", ["<img1_obj_or_path>", "<img2_obj_or_path>", ...])
If you find ImageReward
's open-source effort useful, please 🌟 us to encourage our following developement!
Quick Start
Install Dependency
We have integrated the whole repository to a single python package image-reward
. Following the commands below to prepare the environment:
# Clone the ImageReward repository (containing data for testing)
git clone https://github.com/THUDM/ImageReward.git
cd ImageReward
# Install the integrated package `image-reward`
pip install image-reward
Example Use
We provide example images in the assets/images
directory of this repo. The example prompt is:
a painting of an ocean with clouds and birds, day time, low depth field effect
Use the following code to get the human preference scores from ImageReward:
import os
import torch
import ImageReward as RM
if __name__ == "__main__":
prompt = "a painting of an ocean with clouds and birds, day time, low depth field effect"
img_prefix = "assets/images"
generations = [f"{pic_id}.webp" for pic_id in range(1, 5)]
img_list = [os.path.join(img_prefix, img) for img in generations]
model = RM.load("ImageReward-v1.0")
with torch.no_grad():
ranking, rewards = model.inference_rank(prompt, img_list)
# Print the result
print("\nPreference predictions:\n")
print(f"ranking = {ranking}")
print(f"rewards = {rewards}")
for index in range(len(img_list)):
score = model.score(prompt, img_list[index])
print(f"{generations[index]:>16s}: {score:.2f}")
The output should be like as follow (the exact numbers may be slightly different depending on the compute device):
Preference predictions:
ranking = [1, 2, 3, 4]
rewards = [[0.5811622738838196], [0.2745276093482971], [-1.4131819009780884], [-2.029569625854492]]
1.webp: 0.58
2.webp: 0.27
3.webp: -1.41
4.webp: -2.03
Integration into Stable Diffusion Web UI
We have developed a custom script to integrate ImageReward into SD Web UI for a convenient experience.
The script is located at demo/sdwebui/image_reward.py
in this repository.
The usage of the script is described as follows:
- Dependency:
pip install image-reward
- Install: put the custom script into the
stable-diffusion-webui/scripts/
directory - Reload: restart the service, or click the "Reload custom script" button at the bottom of the settings tab of SD Web UI. (If the button can't be found, try clicking the "Show all pages" button at the bottom of the left sidebar.)
- Select: go back to the "txt2img"/"img2img" tab, and select "ImageReward - generate human preference scores" from the "Script" dropdown menu in the lower left corner.
- Run: the specific usage varies depending on the functional requirements, as described in the "Features" section below.
Features
Score generated images and append to image information
Usage:
- Do not check the "Filter out images with low scores" checkbox.
- Click the "Generate" button to generate images.
- Check the ImageReward at the bottom of the image information below the gallery.
Demo video:
Automatically filter out images with low scores
Usage:
- Check the "Filter out images with low scores" checkbox.
- Enter the score lower limit in "Lower score limit". (ImageReward roughly follows the standard normal distribution, with a mean of 0 and a variance of 1.)
- Click the "Generate" button to generate images.
- Images with scores below the lower limit will be automatically filtered out and will not appear in the gallery.
- Check the ImageReward at the bottom of the image information below the gallery.
Demo video:
View the scores of images that have been scored
Usage:
- Upload the scored image file in the "PNG Info" tab
- Check the image information on the right with the score of the image at the bottom.
Example:
Reproduce Experiments in Table 2
Run the following script to automatically download data, baseline models, and run experiments:
bash ./scripts/test.sh
If you want to check the raw data files individually:
- Test prompts and corresponding human rankings for images are located in
data/test.json
. - Generated outputs for each prompt (originally from DiffusionDB) can be downloaded from Huggingface or Tsinghua Cloud. It should be decompressed to
data/test_images
.
Reproduce Experiments in Table 4
TODO
Citation
@misc{xu2023imagereward,
title={ImageReward: Learning and Evaluating Human Preferences for Text-to-Image Generation},
author={Jiazheng Xu and Xiao Liu and Yuchen Wu and Yuxuan Tong and Qinkai Li and Ming Ding and Jie Tang and Yuxiao Dong},
year={2023},
eprint={2304.05977},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file image-reward-1.2.tar.gz
.
File metadata
- Download URL: image-reward-1.2.tar.gz
- Upload date:
- Size: 26.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 61e0a716a9ab9d225c234081a818c6b9190d8de77390fd30451bff66dd544d50 |
|
MD5 | 91b95aae5ab19c883d391089aa40f479 |
|
BLAKE2b-256 | f00803c454186f1025ad184d26700984a83a0bdb88272996816e8ec6ddf633a2 |
File details
Details for the file image_reward-1.2-py3-none-any.whl
.
File metadata
- Download URL: image_reward-1.2-py3-none-any.whl
- Upload date:
- Size: 31.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f15f30af293e6dbc5779f0df4f5110a97bb764ac2458c35f78c61e0481720e49 |
|
MD5 | a6d2be66ecea6ccae6d88be54c2d732f |
|
BLAKE2b-256 | 4c053a5d4a12852ada7ec5f4eb455d2e2c5ce284ee0b1b990ff8b11b8955d06a |