image.py 955 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
ImageAssetName = Literal["stop_sign", "cherry_blossom"]

15
16
17

@dataclass(frozen=True)
class ImageAsset:
18
    name: ImageAssetName
19

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

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