audio.py 1.22 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
3

4
from dataclasses import dataclass
5
from pathlib import Path
6
from typing import Literal
7
8
from urllib.parse import urljoin

9
import numpy.typing as npt
10

11
12
13
14
15
16
17
18
from vllm.utils import PlaceholderModule

from .base import VLLM_S3_BUCKET_URL, get_vllm_public_assets

try:
    import librosa
except ImportError:
    librosa = PlaceholderModule("librosa")  # type: ignore[assignment]
19
20
21

ASSET_DIR = "multimodal_asset"

22
23
AudioAssetName = Literal["winning_call", "mary_had_lamb"]

24
25
26

@dataclass(frozen=True)
class AudioAsset:
27
28
29
30
31
    name: AudioAssetName

    @property
    def filename(self) -> str:
        return f"{self.name}.ogg"
32
33

    @property
34
    def audio_and_sample_rate(self) -> tuple[npt.NDArray, float]:
35
        audio_path = get_vllm_public_assets(filename=self.filename,
36
                                            s3_prefix=ASSET_DIR)
37
        return librosa.load(audio_path, sr=None)
38

39
    def get_local_path(self) -> Path:
40
        return get_vllm_public_assets(filename=self.filename,
41
42
                                      s3_prefix=ASSET_DIR)

43
44
    @property
    def url(self) -> str:
45
        return urljoin(VLLM_S3_BUCKET_URL, f"{ASSET_DIR}/{self.name}.ogg")