tensorneko-util 0.3.21__py3-none-any.whl → 0.3.23__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- tensorneko_util/io/audio/audio_writer.pyi +29 -0
- tensorneko_util/io/video/video_reader.pyi +38 -0
- tensorneko_util/io/video/video_writer.pyi +33 -0
- tensorneko_util/preprocess/crop.pyi +15 -0
- tensorneko_util/util/dispatched_misc.pyi +23 -0
- tensorneko_util/util/dispatcher.py +17 -2
- tensorneko_util/util/ref.pyi +38 -0
- tensorneko_util/version.txt +1 -1
- tensorneko_util/visualization/watcher/web/dist/assets/index.9d369ef8.css +5 -0
- tensorneko_util/visualization/watcher/web/dist/assets/index.f19b5d1c.js +188 -0
- tensorneko_util/visualization/watcher/web/dist/index.html +2 -2
- {tensorneko_util-0.3.21.dist-info → tensorneko_util-0.3.23.dist-info}/METADATA +20 -9
- {tensorneko_util-0.3.21.dist-info → tensorneko_util-0.3.23.dist-info}/RECORD +16 -10
- {tensorneko_util-0.3.21.dist-info → tensorneko_util-0.3.23.dist-info}/WHEEL +1 -1
- tensorneko_util/visualization/watcher/web/dist/assets/index.6e281472.js +0 -188
- tensorneko_util/visualization/watcher/web/dist/assets/index.cf95019d.css +0 -5
- {tensorneko_util-0.3.21.dist-info → tensorneko_util-0.3.23.dist-info/licenses}/LICENSE +0 -0
- {tensorneko_util-0.3.21.dist-info → tensorneko_util-0.3.23.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
from typing import overload, Union
|
|
2
|
+
from pathlib import Path
|
|
3
|
+
|
|
4
|
+
from .audio_data import AudioData
|
|
5
|
+
from ...backend.audio_lib import AudioLib
|
|
6
|
+
from ...util.type import T_ARRAY
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class AudioWriter:
|
|
10
|
+
|
|
11
|
+
@classmethod
|
|
12
|
+
@overload
|
|
13
|
+
def to(cls, path: Union[str, Path], audio: AudioData, channel_first: bool = True, backend: AudioLib = None
|
|
14
|
+
) -> None: ...
|
|
15
|
+
|
|
16
|
+
@classmethod
|
|
17
|
+
@overload
|
|
18
|
+
def to(cls, path: Union[str, Path], audio: T_ARRAY, sample_rate: int = 16000, channel_first: bool = True,
|
|
19
|
+
backend: AudioLib = None
|
|
20
|
+
): ...
|
|
21
|
+
|
|
22
|
+
@overload
|
|
23
|
+
def __new__(cls, path: Union[str, Path], audio: AudioData, channel_first: bool = True, backend: AudioLib = None
|
|
24
|
+
) -> None: ...
|
|
25
|
+
|
|
26
|
+
@overload
|
|
27
|
+
def __new__(cls, path: Union[str, Path], audio: T_ARRAY, sample_rate: int = 16000, channel_first: bool = True,
|
|
28
|
+
backend: AudioLib = None
|
|
29
|
+
): ...
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
from typing import Optional, overload, Union
|
|
2
|
+
from pathlib import Path
|
|
3
|
+
|
|
4
|
+
from numpy import ndarray
|
|
5
|
+
|
|
6
|
+
from .video_data import VideoData
|
|
7
|
+
from ...backend.visual_lib import VisualLib
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class VideoReader:
|
|
11
|
+
|
|
12
|
+
@classmethod
|
|
13
|
+
def of(cls, path: Union[str, Path], channel_first: bool = True, backend: Optional[VisualLib] = None) -> VideoData:
|
|
14
|
+
...
|
|
15
|
+
|
|
16
|
+
@classmethod
|
|
17
|
+
def with_indexes(cls, path: Union[str, Path], indexes: ndarray,
|
|
18
|
+
channel_first: bool = True, backend: Optional[VisualLib] = None
|
|
19
|
+
) -> VideoData:
|
|
20
|
+
...
|
|
21
|
+
|
|
22
|
+
@classmethod
|
|
23
|
+
@overload
|
|
24
|
+
def with_range(cls, path: Union[str, Path], start: int, end: int, step: int, channel_first: bool = True,
|
|
25
|
+
backend: Optional[VisualLib] = None
|
|
26
|
+
) -> VideoData:
|
|
27
|
+
...
|
|
28
|
+
|
|
29
|
+
@classmethod
|
|
30
|
+
@overload
|
|
31
|
+
def with_range(cls, path: Union[str, Path], end: int, channel_first: bool = True,
|
|
32
|
+
backend: Optional[VisualLib] = None
|
|
33
|
+
) -> VideoData:
|
|
34
|
+
...
|
|
35
|
+
|
|
36
|
+
def __new__(cls, path: Union[str, Path], channel_first: bool = True, backend: Optional[VisualLib] = None
|
|
37
|
+
) -> VideoData:
|
|
38
|
+
...
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
from typing import overload, Optional, Union
|
|
2
|
+
from pathlib import Path
|
|
3
|
+
|
|
4
|
+
from .video_data import VideoData
|
|
5
|
+
from ...backend.visual_lib import VisualLib
|
|
6
|
+
from ...util.type import T_ARRAY
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class VideoWriter:
|
|
10
|
+
|
|
11
|
+
@classmethod
|
|
12
|
+
@overload
|
|
13
|
+
def to(cls, path: Union[str, Path], video: VideoData, audio_codec: str = None, channel_first: bool = False,
|
|
14
|
+
backend: VisualLib = None
|
|
15
|
+
) -> None: ...
|
|
16
|
+
|
|
17
|
+
@classmethod
|
|
18
|
+
@overload
|
|
19
|
+
def to(cls, path: Union[str, Path], video: T_ARRAY, video_fps: float, audio: T_ARRAY = None,
|
|
20
|
+
audio_fps: Optional[int] = None, audio_codec: str = None, channel_first: bool = False,
|
|
21
|
+
backend: VisualLib = None
|
|
22
|
+
) -> None: ...
|
|
23
|
+
|
|
24
|
+
@overload
|
|
25
|
+
def __new__(cls, path: Union[str, Path], video: VideoData, audio_codec: str = None, channel_first: bool = False,
|
|
26
|
+
backend: VisualLib = None
|
|
27
|
+
) -> None: ...
|
|
28
|
+
|
|
29
|
+
@overload
|
|
30
|
+
def __new__(cls, path: Union[str, Path], video: T_ARRAY, video_fps: float, audio: T_ARRAY = None,
|
|
31
|
+
audio_fps: Optional[int] = None, audio_codec: str = None, channel_first: bool = False,
|
|
32
|
+
backend: VisualLib = None
|
|
33
|
+
) -> None: ...
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
from typing import overload, Union
|
|
2
|
+
|
|
3
|
+
from numpy import ndarray
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
@overload
|
|
7
|
+
def crop_with_padding(image: ndarray, x1: int, x2: int, y1: int, y2: int, pad_value: Union[int, float] = 0.,
|
|
8
|
+
batch: bool = False
|
|
9
|
+
) -> ndarray: ...
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
@overload
|
|
13
|
+
def crop_with_padding(image: ndarray, x1: ndarray, x2: ndarray, y1: ndarray, y2: ndarray,
|
|
14
|
+
pad_value: Union[int, float] = 0., batch: bool = False
|
|
15
|
+
) -> ndarray: ...
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
from typing import overload, List
|
|
2
|
+
|
|
3
|
+
from numpy import ndarray
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
@overload
|
|
7
|
+
def sparse2binary(x: ndarray, length: int = None) -> ndarray:
|
|
8
|
+
...
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
@overload
|
|
12
|
+
def sparse2binary(x: List[int], length: int = None) -> List[int]:
|
|
13
|
+
...
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
@overload
|
|
17
|
+
def binary2sparse(x: ndarray) -> ndarray:
|
|
18
|
+
...
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
@overload
|
|
22
|
+
def binary2sparse(x: List[int]) -> List[int]:
|
|
23
|
+
...
|
|
@@ -1,12 +1,28 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
3
|
import inspect
|
|
4
|
+
import sys
|
|
4
5
|
import warnings
|
|
5
6
|
from typing import Callable, Dict, List, Generic, Sequence, Optional, TYPE_CHECKING, overload
|
|
6
7
|
|
|
7
8
|
from .type import T
|
|
8
9
|
|
|
9
10
|
|
|
11
|
+
def _is_union_type(annotation) -> bool:
|
|
12
|
+
"""
|
|
13
|
+
Check if the annotation is a Union type.
|
|
14
|
+
Compatible with Python 3.8 ~ 3.14+
|
|
15
|
+
"""
|
|
16
|
+
if sys.version_info >= (3, 14):
|
|
17
|
+
# Python 3.14+: str(Union[int, str]) returns "int | str"
|
|
18
|
+
# Use typing.get_origin() for reliable detection
|
|
19
|
+
from typing import Union, get_origin
|
|
20
|
+
return get_origin(annotation) is Union
|
|
21
|
+
else:
|
|
22
|
+
# Python < 3.14: str(Union[int, str]) returns "typing.Union[int, str]"
|
|
23
|
+
return str(annotation)[:13] == "typing.Union["
|
|
24
|
+
|
|
25
|
+
|
|
10
26
|
class DispatcherTypeWarning(Warning):
|
|
11
27
|
pass
|
|
12
28
|
|
|
@@ -38,8 +54,7 @@ class Dispatcher:
|
|
|
38
54
|
possible_types = [[]]
|
|
39
55
|
|
|
40
56
|
for param in parameters:
|
|
41
|
-
|
|
42
|
-
is_union = str(param.annotation)[:13] == "typing.Union["
|
|
57
|
+
is_union = _is_union_type(param.annotation)
|
|
43
58
|
|
|
44
59
|
# if no default value and not union, just append to each possible types
|
|
45
60
|
if param.default is inspect.Signature.empty and not is_union:
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from typing import Generic, overload
|
|
4
|
+
|
|
5
|
+
from .type import P
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class Ref(Generic[P]):
|
|
9
|
+
value: P
|
|
10
|
+
@overload
|
|
11
|
+
def __new__(cls, value: str) -> StringRef: ...
|
|
12
|
+
@overload
|
|
13
|
+
def __new__(cls, value: int) -> IntRef: ...
|
|
14
|
+
@overload
|
|
15
|
+
def __new__(cls, value: float) -> FloatRef: ...
|
|
16
|
+
@overload
|
|
17
|
+
def __new__(cls, value: bool) -> BoolRef: ...
|
|
18
|
+
|
|
19
|
+
class StringRef(Ref[str]):
|
|
20
|
+
def __str__(self) -> str: ...
|
|
21
|
+
|
|
22
|
+
class IntRef(Ref[int]):
|
|
23
|
+
def __int__(self) -> int: ...
|
|
24
|
+
|
|
25
|
+
class FloatRef(Ref[float]):
|
|
26
|
+
def __float__(self) -> float: ...
|
|
27
|
+
|
|
28
|
+
class BoolRef(Ref[bool]):
|
|
29
|
+
def __bool__(self) -> bool: ...
|
|
30
|
+
|
|
31
|
+
@overload
|
|
32
|
+
def ref(value: str) -> StringRef: ...
|
|
33
|
+
@overload
|
|
34
|
+
def ref(value: int) -> IntRef: ...
|
|
35
|
+
@overload
|
|
36
|
+
def ref(value: float) -> FloatRef: ...
|
|
37
|
+
@overload
|
|
38
|
+
def ref(value: bool) -> BoolRef: ...
|
tensorneko_util/version.txt
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
0.3.
|
|
1
|
+
0.3.23
|