Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/showlab/Image2Paragraph

[A toolbox for fun.] Transform Image into Unique Paragraph with ChatGPT, BLIP2, OFA, GRIT, Segment Anything, ControlNet.
https://github.com/showlab/Image2Paragraph

chatgpt gpt4 segmentt-anything toolbox

Last synced: 2 months ago
JSON representation

[A toolbox for fun.] Transform Image into Unique Paragraph with ChatGPT, BLIP2, OFA, GRIT, Segment Anything, ControlNet.

Awesome Lists containing this project

README

        


Your Image Description

# Image.txt: Transform Image Into Unique Paragraph

[![Hugging Face Spaces](https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Spaces-blue)](https://huggingface.co/spaces/Awiny/Image2Paragraph), ![](https://img.shields.io/twitter/follow/awinyimgprocess?style=social), [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1RCzMgApzbwI6cp_NZGIbHBP_HDslZjeH?usp=sharing)

[Project Website](https://zhaohengyuan1.github.io/image2paragraph.github.io)

(huggingface sometimes may not work with safari, use chrome)

**Demo**

![](examples/demo.gif)


Your Image Description News

- 17/April/2023. In addition to semantic segment anything, we use [Edit Anything](https://github.com/sail-sg/EditAnything) to get region-level semantic. Now all models takes less than 20s on 8G memory GPU card. (10times faster than previous version on cpu)
- 17/April/2023. Our project is online on Huggingface. Have a try! [huggingface](https://huggingface.co/spaces/Awiny/Image2Paragraph/tree/main)
- 14/April/2023. Our project is very popular in twitter. Looking [the posted twitter](https://twitter.com/awinyimgprocess/status/1646225454599372800?s=46&t=HvOe9T2n35iFuCHP5aIHpQ) for details.

**(Can run on 8GB memory GPU within 20S!)**


Your Image Description

**Main Pipeline**


Your Image Description

**Reasoning Details**


Your Image Description

### To Do List

#### Done
- [x] GRIT example.
- [x] ControNet, BLIP2.
- [x] Semantic Segment Anything.
- [x] Segment Anything for fine-grained semantic.
- [x] Gradio.
- [x] Integrate GRIT into our code.
- [x] Support GPT4 API.
- [x] Notebook/Huggingface Space.
- [x] Region Semantic Classification from Edit-Anything.
- [x] Make the model lightweight.

#### Doing
- [ ] Replace ChatGPT with own trained LLM.
- [ ] Other grounding text2image model as instead of Canny ControlNet.
- [ ] Show retrieval result in gradio.

## Visualization

The text to image model is conrolnet with canny from diffuser.


Your Image Description



Your Image Description



Your Image Description

## Installation

Please find installation instructions in [install.md](install.md).

## 2. Start

### Simple visualization

```bash
export OPENAI_KEY=[YOUR KEY HERE]
python main.py --image_src [image_path] --out_image_name [out_file_name]
```

If your GPU memory smaller than 8 GPB.
```bash
python main.py --image_caption_device cpu --semantic_segment_device cpu
```

If you have no GPU available.
```bash
python main.py --image_caption_device cpu --semantic_segment_device cpu --dense_caption_device cpu --contolnet_device cpu
```

like
```bash
python main.py --image_src "examples/3.jpg" --out_image_name "output/3_result.jpg"
```

**Note: If you have GPU card with larger memory than 15GB. Set all device to GPU for fast inference.**

The generated text and image are show in "output/".

**Note: Use GPT4 for good result as GPT3.5 miss the position information sometime.**

## Use gradio directly

```bash
python main_gradio.py
```

![](examples/gradio_UI.png)

If you have GPU Memory larger than 20GB.
Use device='cuda' as default.

## 3. Visualization



Your Image Description


A dog sitting on a porch with a bike.


Your Image Description


Your Image Description



Input
BLIP2 Image Caption
GRIT Dense Caption
Semantic Segment Anything

The final generated paragraph with ChatGPT is:

> This image depicts a black and white dog sitting on a porch beside a red bike. The dense caption mentions other objects in the scene, such as a white car parked on the street and a red bike parked on the side of the road. The region semantic provides more specific information, including the porch, floor, wall, and trees. The dog can be seen sitting on the floor beside the bike, and there is also a parked bicycle and tree in the background. The wall is visible on one side of the image, while the street and trees can be seen in the other direction.

## 4. Retrieval Result on COCO

| Method | Trainable Parameter | Running Time | IR@1 | TR@1|
|---|---|---|---|---|
| Image-text | 230M | 9H | 43.8 | 33.2 |
|Generated Paragraph-text| 0 |5m|__49.7__|__36.1__|

Interesting, we find compress image into paragraph. The retrieval result is even better than use source image.

## Others
If you have more suggestions or functions need to be implemented in this codebase, feel free to drop me an email awinyimg dot gmail dot com or open an issue.

## Acknowledgment

This work is based on [ChatGPT](http://chat.openai.com), [Edit_Anything](https://github.com/sail-sg/EditAnything), [BLIP2](https://huggingface.co/spaces/Salesforce/BLIP2), [GRIT](https://github.com/JialianW/GRiT), [OFA](https://github.com/OFA-Sys/OFA),[Segment-Anything](https://segment-anything.com), [Semantic-Segment-Anything](https://github.com/fudan-zvg/Semantic-Segment-Anything), [ControlNet](https://github.com/lllyasviel/ControlNet).