audio.py 892 Bytes
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
from dataclasses import dataclass
4
from typing import Literal
5
6
from urllib.parse import urljoin

7
import numpy.typing as npt
8

9
10
11
12
13
14
15
16
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]
17
18
19
20
21
22
23
24
25

ASSET_DIR = "multimodal_asset"


@dataclass(frozen=True)
class AudioAsset:
    name: Literal["winning_call", "mary_had_lamb"]

    @property
26
    def audio_and_sample_rate(self) -> tuple[npt.NDArray, float]:
27
28
        audio_path = get_vllm_public_assets(filename=f"{self.name}.ogg",
                                            s3_prefix=ASSET_DIR)
29
        return librosa.load(audio_path, sr=None)
30
31
32

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