Skip to content

Commit 3615631

Browse files
authored
Add mem:// backend example (#1904)
* Add mem:// backend example * check the URI before creating the array
1 parent 9047c32 commit 3615631

File tree

1 file changed

+50
-0
lines changed

1 file changed

+50
-0
lines changed

examples/in_memory_vfs.py

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
# in_memory_vfs.py
2+
#
3+
# LICENSE
4+
#
5+
# The MIT License
6+
#
7+
# Copyright (c) 2024 TileDB, Inc.
8+
#
9+
# Permission is hereby granted, free of charge, to any person obtaining a copy
10+
# of this software and associated documentation files (the "Software"), to deal
11+
# in the Software without restriction, including without limitation the rights
12+
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13+
# copies of the Software, and to permit persons to whom the Software is
14+
# furnished to do so, subject to the following conditions:
15+
#
16+
# The above copyright notice and this permission notice shall be included in
17+
# all copies or substantial portions of the Software.
18+
#
19+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25+
# THE SOFTWARE.
26+
#
27+
# DESCRIPTION
28+
#
29+
# When run, this program will create a random numpy array, create a TileDB
30+
# DenseArray from it in memory, and read the entire array back from memory.
31+
# It then compares the original numpy array with the TileDB array to check
32+
# that data was written and read correctly (prints True) or not (prints False).
33+
#
34+
35+
import numpy as np
36+
37+
import tiledb
38+
39+
# Create TileDB VFS
40+
vfs = tiledb.VFS()
41+
42+
file = "mem://myarray"
43+
data = np.random.rand(10, 10)
44+
45+
if not vfs.is_file(file):
46+
with tiledb.from_numpy(file, data):
47+
pass
48+
49+
with tiledb.open(file) as A:
50+
print(np.all(A[:] == data))

0 commit comments

Comments
 (0)