mirror of
https://github.com/huggingface/transformers.git
synced 2025-07-05 22:00:09 +06:00

* upadte * Update src/transformers/models/paligemma/processing_paligemma.py Co-authored-by: amyeroberts <22614925+amyeroberts@users.noreply.github.com> * update docs * better example in tests * support image tokens * read token * Update tests/models/paligemma/test_processing_paligemma.py Co-authored-by: Pablo Montalvo <39954772+molbap@users.noreply.github.com> * nit: naming * Update docs/source/en/model_doc/paligemma.md Co-authored-by: amyeroberts <22614925+amyeroberts@users.noreply.github.com> * conflicts after rebasing --------- Co-authored-by: amyeroberts <22614925+amyeroberts@users.noreply.github.com> Co-authored-by: Pablo Montalvo <39954772+molbap@users.noreply.github.com>
107 lines
5.4 KiB
Markdown
107 lines
5.4 KiB
Markdown
<!--Copyright 2024 The HuggingFace Team. All rights reserved.
|
||
|
||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
|
||
the License. You may obtain a copy of the License at
|
||
|
||
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
||
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
|
||
an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
|
||
specific language governing permissions and limitations under the License.
|
||
|
||
⚠️ Note that this file is in Markdown but contain specific syntax for our doc-builder (similar to MDX) that may not be
|
||
rendered properly in your Markdown viewer.
|
||
|
||
-->
|
||
|
||
# PaliGemma
|
||
|
||
## Overview
|
||
|
||
The PaliGemma model was proposed in [PaliGemma – Google's Cutting-Edge Open Vision Language Model](https://huggingface.co/blog/paligemma) by Google. It is a 3B vision-language model composed by a [SigLIP](siglip) vision encoder and a [Gemma](gemma) language decoder linked by a multimodal linear projection. It cuts an image into a fixed number of VIT tokens and prepends it to an optional prompt. One particularity is that the model uses full block attention on all the image tokens plus the input text tokens. It comes in 3 resolutions, 224x224, 448x448 and 896x896 with 3 base models, with 55 fine-tuned versions for different tasks, and 2 mix models.
|
||
|
||
<img src="https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/blog/paligemma/paligemma_arch.png"
|
||
alt="drawing" width="600"/>
|
||
|
||
<small> PaliGemma architecture. Taken from the <a href="https://huggingface.co/blog/paligemma">blog post.</a> </small>
|
||
|
||
This model was contributed by [Molbap](https://huggingface.co/Molbap).
|
||
|
||
## Usage tips
|
||
|
||
- PaliGemma is not meant for conversational use, and it works best when fine-tuning to a specific use case. Some downstream tasks on which PaliGemma can be fine-tuned include image captioning, visual question answering (VQA), object detection, referring expression segmentation and document understanding.
|
||
- One can use `PaliGemmaProcessor` to prepare images, text and optional labels for the model. When fine-tuning a PaliGemma model, the `suffix` argument can be passed to the processor which creates the `labels` for the model:
|
||
|
||
```python
|
||
prompt = "What is on the flower?"
|
||
answer = "a bee"
|
||
inputs = processor(images=raw_image, text=prompt, suffix=answer, return_tensors="pt")
|
||
```
|
||
|
||
## Usage Example
|
||
|
||
The model can accept a single or multiple images. According to the [paper](https://arxiv.org/abs/2407.07726v1), the checkpoint PaliGemma can transfer to tasks which take multiple images as input. NLVR2 is one such task, which asks one question about two images, and requires looking at both to give the correct answer. Here's an example code for single and multi image inference.
|
||
|
||
### Single-image Inference
|
||
|
||
```python
|
||
from transformers import AutoProcessor, PaliGemmaForConditionalGeneration
|
||
|
||
model_id = "google/paligemma-3b-mix-224"
|
||
model = PaliGemmaForConditionalGeneration.from_pretrained(model_id)
|
||
processor = AutoProcessor.from_pretrained(model_id)
|
||
|
||
prompt = "What is on the flower?"
|
||
image_file = "https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/bee.jpg?download=true"
|
||
raw_image = Image.open(requests.get(image_file, stream=True).raw)
|
||
inputs = processor(raw_image, prompt, return_tensors="pt")
|
||
output = model.generate(**inputs, max_new_tokens=20)
|
||
|
||
print(processor.decode(output[0], skip_special_tokens=True)[inputs.input_ids.shape[1]: ])
|
||
```
|
||
|
||
### Multi-image Inference
|
||
|
||
```python
|
||
model_id = "google/paligemma-3b-ft-nlvr2-448" # checkpoint tuned for multiple images
|
||
model = PaliGemmaForConditionalGeneration.from_pretrained(model_id)
|
||
processor = PaliGemmaProcessor.from_pretrained(model_id)
|
||
|
||
prompt = "answer en Which of the two pictures shows a snowman, first or second?"
|
||
stop_sign_image = Image.open(
|
||
requests.get("https://www.ilankelman.org/stopsigns/australia.jpg", stream=True).raw
|
||
)
|
||
snow_image = Image.open(
|
||
requests.get(
|
||
"https://huggingface.co/microsoft/kosmos-2-patch14-224/resolve/main/snowman.jpg", stream=True
|
||
).raw
|
||
)
|
||
|
||
inputs = processor(images=[[snow_image, stop_sign_image]], text=prompt, return_tensors="pt")
|
||
|
||
output = model.generate(**inputs, max_new_tokens=20)
|
||
print(processor.decode(output[0], skip_special_tokens=True)[inputs.input_ids.shape[1]: ])
|
||
|
||
```
|
||
|
||
## Resources
|
||
|
||
A list of official Hugging Face and community (indicated by 🌎) resources to help you get started with PaliGemma. If you're interested in submitting a resource to be included here, please feel free to open a Pull Request and we'll review it! The resource should ideally demonstrate something new instead of duplicating an existing resource.
|
||
|
||
- A blog post introducing all the features of PaliGemma can be found [here](https://huggingface.co/blog/paligemma).
|
||
- Demo notebooks on how to fine-tune PaliGemma for VQA with the Trainer API along with inference can be found [here](https://github.com/huggingface/notebooks/tree/main/examples/paligemma).
|
||
- Demo notebooks on how to fine-tune PaliGemma on a custom dataset (receipt image -> JSON) along with inference can be found [here](https://github.com/NielsRogge/Transformers-Tutorials/tree/master/PaliGemma). 🌎
|
||
|
||
## PaliGemmaConfig
|
||
|
||
[[autodoc]] PaliGemmaConfig
|
||
|
||
## PaliGemmaProcessor
|
||
|
||
[[autodoc]] PaliGemmaProcessor
|
||
|
||
## PaliGemmaForConditionalGeneration
|
||
|
||
[[autodoc]] PaliGemmaForConditionalGeneration
|
||
- forward
|