image.py 883 Bytes
Newer Older
1
2
3
from dataclasses import dataclass
from typing import Literal

4
import torch
5
6
from PIL import Image

7
from .base import get_vllm_public_assets
8

9
VLM_IMAGES_DIR = "vision_model_images"
10
11
12
13


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

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

    @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)
29
        return torch.load(image_path, map_location="cpu", weights_only=True)