File: __init__.py

package info (click to toggle)
python-sigima 1.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 24,956 kB
  • sloc: python: 33,326; makefile: 3
file content (127 lines) | stat: -rw-r--r-- 3,445 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# Copyright (c) DataLab Platform Developers, BSD 3-Clause license, see LICENSE file.

"""
I/O (:mod:`sigima.io`)
-----------------------

This package provides input/output functionality for reading and writing
signals and images in various formats. It includes a registry for managing
the available formats and their associated read/write functions.

General purpose I/O functions
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

This package provides functions to read and write signals and images, allowing users
to easily handle different file formats without needing to know the specifics
of each format.

It includes the following main functions:

- :py:func:`read_signals`: Read a list of signals from a file.
- :py:func:`read_signal`: Read a single signal from a file.
- :py:func:`write_signal`: Write a single signal to a file.
- :py:func:`read_images`: Read a list of images from a file.
- :py:func:`read_image`: Read a single image from a file.
- :py:func:`write_image`: Write a single image to a file.

Supported formats
^^^^^^^^^^^^^^^^^

.. autodata:: SIGNAL_FORMAT_INFO

.. autodata:: IMAGE_FORMAT_INFO

Adding new formats
^^^^^^^^^^^^^^^^^^

To add new formats, you can create a new class that inherits from
:py:class:`sigima.io.image.base.ImageFormatBase` or
:py:class:`sigima.io.signal.base.SignalFormatBase` and implement the required methods.

.. note::

    Thanks to the plugin system, you can add new formats simply by defining a new class
    in a separate module, and it will be automatically discovered and registered, as
    long as it is imported in your application or library.

Example of a new image format plugin:

.. code-block:: python

    from sigima.io.image.base import ImageFormatBase
    from sigima.io.base import FormatInfo

    class MyImageFormat(ImageFormatBase):
        \"\"\"Object representing MyImageFormat image file type\"\"\"

        FORMAT_INFO = FormatInfo(
            name="MyImageFormat",
            extensions="*.myimg",
            readable=True,
            writeable=False,
        )

        @staticmethod
        def read_data(filename: str) -> np.ndarray:
            \"\"\"Read data and return it

            Args:
                filename (str): path to MyImageFormat file

            Returns:
                np.ndarray: image data
            \"\"\"
            # Implement reading logic here
            pass
"""

from __future__ import annotations

from sigima.io.common.objmeta import (
    read_annotations,
    read_metadata,
    read_roi,
    read_roi_grid,
    write_annotations,
    write_metadata,
    write_roi,
    write_roi_grid,
)
from sigima.io.convenience import (
    read_image,
    read_images,
    read_signal,
    read_signals,
    write_image,
    write_images,
    write_signal,
    write_signals,
)
from sigima.io.image.base import ImageIORegistry
from sigima.io.signal.base import SignalIORegistry

__all__ = [
    "IMAGE_FORMAT_INFO",
    "SIGNAL_FORMAT_INFO",
    "ImageIORegistry",
    "SignalIORegistry",
    "read_annotations",
    "read_image",
    "read_images",
    "read_metadata",
    "read_roi",
    "read_roi_grid",
    "read_signal",
    "read_signals",
    "write_annotations",
    "write_image",
    "write_images",
    "write_metadata",
    "write_roi",
    "write_roi_grid",
    "write_signal",
    "write_signals",
]

SIGNAL_FORMAT_INFO = SignalIORegistry.get_format_info(mode="rst")
IMAGE_FORMAT_INFO = ImageIORegistry.get_format_info(mode="rst")