image.py 922 Bytes
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
4
5
from dataclasses import dataclass
from typing import Literal

6
import torch
7
8
from PIL import Image

9
from .base import get_vllm_public_assets
10

11
VLM_IMAGES_DIR = "vision_model_images"
12
13
14
15


@dataclass(frozen=True)
class ImageAsset:
16
    name: Literal["stop_sign", "cherry_blossom"]
17

18
    @property
19
    def pil_image(self) -> Image.Image:
20
21
22
        image_path = get_vllm_public_assets(filename=f"{self.name}.jpg",
                                            s3_prefix=VLM_IMAGES_DIR)
        return Image.open(image_path)
23
24
25
26
27
28
29
30

    @property
    def image_embeds(self) -> torch.Tensor:
        """
        Image embeddings, only used for testing purposes with llava 1.5.
        """
        image_path = get_vllm_public_assets(filename=f"{self.name}.pt",
                                            s3_prefix=VLM_IMAGES_DIR)
31
        return torch.load(image_path, map_location="cpu", weights_only=True)