forked from TileDB-Inc/TileDB-Py
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwriting_dense_rgb.py
77 lines (63 loc) · 2.56 KB
/
writing_dense_rgb.py
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
# writing_dense_rgb.py
#
# LICENSE
#
# The MIT License
#
# Copyright (c) 2021 TileDB, Inc.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
#
# DESCRIPTION
#
# Please see the TileDB documentation for more information:
# https://docs.tiledb.com/main/solutions/tiledb-embedded/api-usage/writing-arrays/writing-in-dense-subarrays
#
# When run, this program will create a 2D+1 multi-component (eg RGB) dense array, write some
# data to it, and read the entire array data.
import tiledb, numpy as np
img_shape = (100, 224, 224)
img_uri = "writing_dense_rgb"
image_data = np.random.randint(low=0, high=100, size=(*img_shape, 3), dtype=np.int32)
def create_array():
domain = tiledb.Domain(
tiledb.Dim(
name="image_id", domain=(0, img_shape[0] - 1), tile=4, dtype=np.int32
),
tiledb.Dim(
name="x", domain=(0, img_shape[1] - 1), tile=img_shape[1], dtype=np.int32
),
tiledb.Dim(
name="y", domain=(0, img_shape[2] - 1), tile=img_shape[2], dtype=np.int32
),
)
# create multi-component attribute with three int32 components
attr = tiledb.Attr(dtype=np.dtype("i4, i4, i4"))
schema = tiledb.ArraySchema(domain=domain, sparse=False, attrs=[attr])
tiledb.Array.create(img_uri, schema)
image_data_rgb = image_data.view(np.dtype("i4, i4, i4"))
with tiledb.open(img_uri, "w") as A:
# write data to 1st image_id slot
A[:] = image_data_rgb
def read_array():
with tiledb.open(img_uri) as A:
print(A[:].shape)
if __name__ == "__main__":
create_array()
read_array()