diff --git a/.Rbuildignore b/.Rbuildignore index 9fca0424af..332618274d 100644 --- a/.Rbuildignore +++ b/.Rbuildignore @@ -11,3 +11,4 @@ ^inst/examples/quickstart_sparse$ ^inst/examples/array_metadata_array$ ^\.editorconfig$ +^src/unused_*cpp.txt$ diff --git a/NAMESPACE b/NAMESPACE index f18a12b4b8..7dd610c3d8 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -70,7 +70,6 @@ export(tiledb_stats_enable) export(tiledb_stats_print) export(tiledb_subarray) export(tiledb_version) -exportClasses("tiledb_sparse") exportClasses(tiledb_array_schema) exportClasses(tiledb_attr) exportClasses(tiledb_config) @@ -80,6 +79,7 @@ exportClasses(tiledb_dim) exportClasses(tiledb_domain) exportClasses(tiledb_filter) exportClasses(tiledb_filter_list) +exportClasses(tiledb_sparse) exportMethods("[") exportMethods(attrs) exportMethods(cell_order) diff --git a/R/ArraySchema.R b/R/ArraySchema.R index 334aa9a24d..cd413a4d95 100644 --- a/R/ArraySchema.R +++ b/R/ArraySchema.R @@ -6,7 +6,7 @@ setClass("tiledb_array_schema", slots = list(ptr = "externalptr")) tiledb_array_schema.from_ptr <- function(ptr) { - if (missing(ptr) || typeof(ptr) != "externalptr" || is.null(ptr)) { + if (missing(ptr) || typeof(ptr) != "externalptr" || is.null(ptr)) { stop("ptr argument must be a non NULL externalptr to a tiledb_array_schema instance") } new("tiledb_array_schema", ptr = ptr) @@ -51,6 +51,9 @@ tiledb_array_schema <- function( stop("domain argument must be a tiledb::Domain") } is_attr <- function(obj) is(obj, "tiledb_attr") + if (is_attr(attrs)) { # if an attrs object given: + attrs <- list(attrs) # make it a list so that lapply works below + } if (missing(attrs) || length(attrs) == 0 || !all(vapply(attrs, is_attr, logical(1)))) { stop("attrs argument must be a list of one or tiled_attr objects") } diff --git a/R/Domain.R b/R/Domain.R index 164bf88b86..cab38c61b0 100644 --- a/R/Domain.R +++ b/R/Domain.R @@ -30,6 +30,9 @@ tiledb_domain <- function(dims, ctx = tiledb_get_context()) { stop("argument ctx must be a tiledb_ctx") } is_dim <- function(obj) is(obj, "tiledb_dim") + if (is_dim(dims)) { # if a dim object given: + dims <- list(dims) # make it a vector so that lapply works below + } if (missing(dims) || length(dims) == 0 || !all(vapply(dims, is_dim, logical(1)))) { stop("argument dims must be a list of one or more tileb_dim") } diff --git a/R/FilterList.R b/R/FilterList.R index 593e600241..2be1952d91 100644 --- a/R/FilterList.R +++ b/R/FilterList.R @@ -28,6 +28,9 @@ tiledb_filter_list <- function(filters = c(), ctx = tiledb_get_context()) { stop("argument ctx must be a tiledb_ctx") } is_filter <- function(obj) is(obj, "tiledb_filter") + if (is_filter(filters)) { # if a filters object given: + filters <- list(filters) # make it a list so that lapply works below + } filter_ptrs = c() if (length(filters) > 0) { if (!all(vapply(filters, is_filter, logical(1)))) { diff --git a/R/Metadata.R b/R/Metadata.R index 1982dc627d..8790861708 100644 --- a/R/Metadata.R +++ b/R/Metadata.R @@ -4,17 +4,14 @@ ##' Test if TileDB Array has Metadata ##' -##' @param arr A TileDB Array object, or a character URI describing one +##' @param arr A TileDB Array object ##' @param key A character value describing a metadata key ##' @return A logical value indicating if the given key exists in the ##' metdata of the given array ##' @export tiledb_has_metadata <- function(arr, key) { - if (is.character(arr)) { - return(has_metadata_simple(arr, key)) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("Argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -23,8 +20,8 @@ tiledb_has_metadata <- function(arr, key) { stop("Array is not open for reading, cannot access metadata.", call.=FALSE) } - ## Run query - return(has_metadata_ptr(arr@ptr, key)) + res <- libtiledb_array_get_metadata_list(arr@ptr) + return(key %in% names(res)) } ##' Return count of TileDB Array Metadata objects @@ -33,11 +30,8 @@ tiledb_has_metadata <- function(arr, key) { ##' @return A integer variable with the number of Metadata objects ##' @export tiledb_num_metadata <- function(arr) { - if (is.character(arr)) { - return(num_metadata_simple(arr)) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("Argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -47,21 +41,19 @@ tiledb_num_metadata <- function(arr) { } ## Run query - return(num_metadata_ptr(arr@ptr)) + return(libtiledb_array_get_metadata_num(arr@ptr)) } ##' Return a TileDB Array Metadata object given by key ##' ##' @param arr A TileDB Array object, or a character URI describing one ##' @param key A character value describing a metadata key -##' @return A object stored in the Metadata under the given key +##' @return A object stored in the Metadata under the given key, +##' or \sQuote{NULL} if none found. ##' @export tiledb_get_metadata <- function(arr, key) { - if (is.character(arr)) { - return(get_metadata_simple(arr, key)) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("Argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -70,8 +62,11 @@ tiledb_get_metadata <- function(arr, key) { stop("Array is not open for reading, cannot access metadata.", call.=FALSE) } - ## Run query - return(get_metadata_ptr(arr@ptr, key)) + res <- libtiledb_array_get_metadata_list(arr@ptr) + if (key %in% names(res)) + return(res[[key]]) + else + return(NULL) } ##' Store an object in TileDB Array Metadata under given key @@ -82,11 +77,8 @@ tiledb_get_metadata <- function(arr, key) { ##' @return A boolean value indicating success ##' @export tiledb_put_metadata <- function(arr, key, val) { - if (is.character(arr)) { - return(put_metadata_simple(arr, key, val)) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("Argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -96,7 +88,7 @@ tiledb_put_metadata <- function(arr, key, val) { } ## Run query - return(put_metadata_ptr(arr@ptr, key, val)) + return(libtiledb_array_put_metadata(arr@ptr, key, val)) } @@ -106,13 +98,8 @@ tiledb_put_metadata <- function(arr, key, val) { ##' @return A object stored in the Metadata under the given key ##' @export tiledb_get_all_metadata <- function(arr) { - if (is.character(arr)) { - res <- get_all_metadata_simple(arr) - class(res) <- "tiledb_metadata" - return(res) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("Argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -122,7 +109,7 @@ tiledb_get_all_metadata <- function(arr) { } ## Run query - res <- get_all_metadata_ptr(arr@ptr) + res <- libtiledb_array_get_metadata_list(arr@ptr) class(res) <- "tiledb_metadata" return(res) } @@ -138,16 +125,13 @@ print.tiledb_metadata <- function(x, width=NULL, ...) { ##' Delete a TileDB Array Metadata object given by key ##' -##' @param arr A TileDB Array object, or a character URI describing one +##' @param arr A TileDB Array object ##' @param key A character value describing a metadata key ##' @return A boolean indicating success ##' @export tiledb_delete_metadata <- function(arr, key) { - if (is.character(arr)) { - return(delete_metadata_simple(arr, key)) - } else if (!.isArray(arr)) { - message("Neither (text) URI nor Array.") - return(NULL) + if (!is(arr, "tiledb_sparse") && !is(arr, "tiledb_dense")) { + stop("ctx argument must be a TileDB (dense or sparse) array.", call.=FALSE) } ## Now deal with (default) case of an array object @@ -156,6 +140,7 @@ tiledb_delete_metadata <- function(arr, key) { stop("Array is not open for writing, cannot access metadata.", call.=FALSE) } - ## Run query - return(delete_metadata_ptr(arr@ptr, key)) + ## Run metadata removal + libtiledb_array_delete_metadata(arr@ptr, key); + invisible(TRUE) } diff --git a/R/RcppExports.R b/R/RcppExports.R index 51c7a227d9..c72e008d26 100644 --- a/R/RcppExports.R +++ b/R/RcppExports.R @@ -1,62 +1,6 @@ # Generated by using Rcpp::compileAttributes() -> do not edit by hand # Generator token: 10BE3573-1514-4C36-9D1C-5A225CD40393 -has_metadata_simple <- function(array_name, key) { - .Call(`_tiledb_has_metadata_simple`, array_name, key) -} - -has_metadata_ptr <- function(array, key) { - .Call(`_tiledb_has_metadata_ptr`, array, key) -} - -num_metadata_simple <- function(array_name) { - .Call(`_tiledb_num_metadata_simple`, array_name) -} - -num_metadata_ptr <- function(array) { - .Call(`_tiledb_num_metadata_ptr`, array) -} - -get_metadata_simple <- function(array_name, key) { - .Call(`_tiledb_get_metadata_simple`, array_name, key) -} - -get_metadata_ptr <- function(array, key) { - .Call(`_tiledb_get_metadata_ptr`, array, key) -} - -put_metadata_simple <- function(array_name, key, obj) { - .Call(`_tiledb_put_metadata_simple`, array_name, key, obj) -} - -put_metadata_ptr <- function(array, key, obj) { - .Call(`_tiledb_put_metadata_ptr`, array, key, obj) -} - -get_metadata_from_index_ptr <- function(array, idx) { - .Call(`_tiledb_get_metadata_from_index_ptr`, array, idx) -} - -get_metadata_from_index_simple <- function(array_name, idx) { - .Call(`_tiledb_get_metadata_from_index_simple`, array_name, idx) -} - -get_all_metadata_simple <- function(array_name) { - .Call(`_tiledb_get_all_metadata_simple`, array_name) -} - -get_all_metadata_ptr <- function(array) { - .Call(`_tiledb_get_all_metadata_ptr`, array) -} - -delete_metadata_simple <- function(array_name, key) { - .Call(`_tiledb_delete_metadata_simple`, array_name, key) -} - -delete_metadata_ptr <- function(array, key) { - .Call(`_tiledb_delete_metadata_ptr`, array, key) -} - tiledb_datatype_R_type <- function(datatype) { .Call(`_tiledb_tiledb_datatype_R_type`, datatype) } @@ -389,8 +333,28 @@ libtiledb_array_nonempty_domain <- function(array) { .Call(`_tiledb_libtiledb_array_nonempty_domain`, array) } -libtiledb_array_consolidate <- function(ctx, uri) { - .Call(`_tiledb_libtiledb_array_consolidate`, ctx, uri) +libtiledb_array_consolidate <- function(ctx, uri, cfgptr = NULL) { + invisible(.Call(`_tiledb_libtiledb_array_consolidate`, ctx, uri, cfgptr)) +} + +libtiledb_array_put_metadata <- function(array, key, obj) { + .Call(`_tiledb_libtiledb_array_put_metadata`, array, key, obj) +} + +libtiledb_array_get_metadata_num <- function(array) { + .Call(`_tiledb_libtiledb_array_get_metadata_num`, array) +} + +libtiledb_array_get_metadata_from_index <- function(array, idx) { + .Call(`_tiledb_libtiledb_array_get_metadata_from_index`, array, idx) +} + +libtiledb_array_get_metadata_list <- function(array) { + .Call(`_tiledb_libtiledb_array_get_metadata_list`, array) +} + +libtiledb_array_delete_metadata <- function(array, key) { + invisible(.Call(`_tiledb_libtiledb_array_delete_metadata`, array, key)) } libtiledb_query <- function(ctx, array, type) { diff --git a/R/SparseArray.R b/R/SparseArray.R index a2f80741be..77ce5f7178 100644 --- a/R/SparseArray.R +++ b/R/SparseArray.R @@ -4,7 +4,7 @@ #' @slot uri A character despription #' @slot as.data.frame A logical value #' @slot ptr External pointer to the underlying implementation -#' @exportClass "tiledb_sparse" +#' @exportClass tiledb_sparse setClass("tiledb_sparse", slots = list(ctx = "tiledb_ctx", uri = "character", as.data.frame = "logical", ptr = "externalptr")) diff --git a/TileDB-R.Rproj b/TileDB-R.Rproj index aa9a2dad9e..eb6db5d907 100644 --- a/TileDB-R.Rproj +++ b/TileDB-R.Rproj @@ -14,4 +14,4 @@ LaTeX: pdfLaTeX BuildType: Package PackageInstallArgs: --no-multiarch --with-keep.source -PackageRoxygenize: rd,collate,namespace +PackageRoxygenize: rd,namespace diff --git a/inst/notebooks/documentation.Rmd b/inst/notebooks/documentation.Rmd index 00080596c3..2e11ab92ae 100644 --- a/inst/notebooks/documentation.Rmd +++ b/inst/notebooks/documentation.Rmd @@ -38,7 +38,7 @@ create_array <- function(array_name) { tiledb_dim("cols", c(1L, 4L), 4L, "INT32"))) # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. - schema <- tiledb_array_schema(dom, attrs = c(tiledb_attr("a", type = "INT32"))) + schema <- tiledb_array_schema(dom, attrs = tiledb_attr("a", type = "INT32")) # Create the (empty) array on disk. tiledb_array_create(array_name, schema) @@ -71,8 +71,8 @@ create_array <- function(array_name) { dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"), tiledb_dim("cols", c(1L, 4L), 4L, "INT32"))) - # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. - schema = tiledb_array_schema(dom, attrs=c(tiledb_attr("a", type = "INT32")), sparse = TRUE) + # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. + schema = tiledb_array_schema(dom, attrs=tiledb_attr("a", type = "INT32"), sparse = TRUE) # Create the (empty) array on disk. tiledb_array_create(array_name, schema) @@ -90,6 +90,10 @@ write_array <- function(array_name) { create_array(urisparse) write_array(urisparse) +close_and_reopen <- function(arr, txt) { + res <- tiledb:::libtiledb_array_close(arr@ptr) + res <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, txt) +} ``` @@ -147,7 +151,7 @@ comp <- tiledb_filter("GZIP") tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10) # Create a filter list with the compressor -filter_list <- tiledb_filter_list(c(comp)) +filter_list <- tiledb_filter_list(comp) # Create attribute with the filter list attr <- tiledb_attr("attr", "INT32", filter_list = filter_list) @@ -324,7 +328,7 @@ d1 <- tiledb_dim(domain = c(1L, 5L)) d2 <- tiledb_dim(domain = c(1L, 5L)) dom <- tiledb_domain(c(d1, d2)) val <- tiledb_attr("val", type = "INT32") -sch <- tiledb_array_schema(dom, c(val), sparse=TRUE) +sch <- tiledb_array_schema(dom, val, sparse=TRUE) tiledb_array_create(tmp, sch) @@ -377,7 +381,7 @@ attr <- tiledb_attr("a", type = r_to_tiledb_type(vec)) ## set to two values per cell tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2) -sch <- tiledb_array_schema(dom, c(attr)) +sch <- tiledb_array_schema(dom, attr) tiledb_array_create(uridensefix, sch) ctx <- tiledb_ctx() @@ -730,8 +734,11 @@ v ### Writing Array Metadata ```{r writemetadata} -res <- tiledb_put_metadata(uridense, "aaa", 100L) -res <- tiledb_put_metadata(uridense, "bb", c(1.1, 2.2)) +arr <- tiledb_dense(uridense) +close_and_reopen(arr, "WRITE") +res <- tiledb_put_metadata(arr, "aaa", 100L) +res <- tiledb_put_metadata(arr, "bb", c(1.1, 2.2)) +invisible(tiledb:::libtiledb_array_close(arr@ptr)) ``` ### Reading Array Metadata @@ -739,18 +746,21 @@ res <- tiledb_put_metadata(uridense, "bb", c(1.1, 2.2)) One can read by key: ```{r readmetadata} -tiledb_get_metadata(uridense, "aaa") +close_and_reopen(arr, "READ") +tiledb_get_metadata(arr, "aaa") ``` Or one can retrieve all metadata at once: ```{r readmetadataall} -md <- tiledb_get_all_metadata(uridense) +md <- tiledb_get_all_metadata(arr) print(md) ``` ### Deleting Array Metadata ```{r deletemetadata} -res <- tiledb_delete_metadata(uridense, "aaa") +close_and_reopen(arr, "WRITE") +res <- tiledb_delete_metadata(arr, "aaa") + ``` diff --git a/inst/notebooks/documentation.html b/inst/notebooks/documentation.html index 73ac6257ac..5aed8a07a1 100644 --- a/inst/notebooks/documentation.html +++ b/inst/notebooks/documentation.html @@ -1701,7 +1701,7 @@

Prelimaries

tiledb_dim("cols", c(1L, 4L), 4L, "INT32"))) # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. - schema <- tiledb_array_schema(dom, attrs = c(tiledb_attr("a", type = "INT32"))) + schema <- tiledb_array_schema(dom, attrs = tiledb_attr("a", type = "INT32")) # Create the (empty) array on disk. tiledb_array_create(array_name, schema) @@ -1718,7 +1718,7 @@

Prelimaries

} create_array(uridense) -
## [1] "/tmp/Rtmpz7aolS/dense"
+
## [1] "/tmp/RtmpoOK3ly/dense"
write_array(uridense)
 
 
@@ -1735,8 +1735,8 @@ 

Prelimaries

dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"), tiledb_dim("cols", c(1L, 4L), 4L, "INT32"))) - # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. - schema = tiledb_array_schema(dom, attrs=c(tiledb_attr("a", type = "INT32")), sparse = TRUE) + # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer. + schema = tiledb_array_schema(dom, attrs=tiledb_attr("a", type = "INT32"), sparse = TRUE) # Create the (empty) array on disk. tiledb_array_create(array_name, schema) @@ -1752,8 +1752,13 @@

Prelimaries

} create_array(urisparse)
-
## [1] "/tmp/Rtmpz7aolS/sparse"
-
write_array(urisparse)
+
## [1] "/tmp/RtmpoOK3ly/sparse"
+
write_array(urisparse)
+
+close_and_reopen <- function(arr, txt) {
+  res <- tiledb:::libtiledb_array_close(arr@ptr)
+  res <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, txt)
+}

API Usage

@@ -1796,7 +1801,7 @@

Setting a Compressor

tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10) # Create a filter list with the compressor -filter_list <- tiledb_filter_list(c(comp)) +filter_list <- tiledb_filter_list(comp) # Create attribute with the filter list attr <- tiledb_attr("attr", "INT32", filter_list = filter_list) @@ -1883,7 +1888,7 @@

Creating Encrypted Arrays

# shortcut: borrow schema from dense array; could create schema too schema <- schema(tiledb_dense(uridense)) tiledb:::libtiledb_array_create_with_key(uridensewkey, schema@ptr, encryption_key) -
## [1] "/tmp/Rtmpz7aolS/densewkey"
+
## [1] "/tmp/RtmpoOK3ly/densewkey"
##TODO: R support
@@ -1944,9 +1949,9 @@

Writing Sparse Cells

d2 <- tiledb_dim(domain = c(1L, 5L)) dom <- tiledb_domain(c(d1, d2)) val <- tiledb_attr("val", type = "INT32") -sch <- tiledb_array_schema(dom, c(val), sparse=TRUE) +sch <- tiledb_array_schema(dom, val, sparse=TRUE) tiledb_array_create(tmp, sch) -
## [1] "/tmp/Rtmpz7aolS/sparse"
+
## [1] "/tmp/RtmpoOK3ly/sparse"
# Prepare some data
 data <- c(3L, 4L, 1L, 2L)
 
@@ -1986,9 +1991,9 @@ 

Fixed-length Attributes

## set to two values per cell tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2) -sch <- tiledb_array_schema(dom, c(attr)) +sch <- tiledb_array_schema(dom, attr) tiledb_array_create(uridensefix, sch)
-
## [1] "/tmp/Rtmpz7aolS/densefix"
+
## [1] "/tmp/RtmpoOK3ly/densefix"
ctx <- tiledb_ctx()
 arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensefix, "WRITE")
 subarr <- c(1L,4L, 1L,4L)
@@ -2027,7 +2032,7 @@ 

Var-length Attributes

## Create the (empty) array on disk. tiledb:::libtiledb_array_create(uridensevar, schptr)
-
## [1] "/tmp/Rtmpz7aolS/densevar"
+
## [1] "/tmp/RtmpoOK3ly/densevar"
data <- "abbcccddeeefghhhijjjkklmnoop";
 offsets <- c(0L, 1L, 3L, 6L, 8L, 11L, 12L, 13L, 16L, 17L, 20L, 22L, 23L, 24L, 25L, 27L)
 
@@ -2040,7 +2045,7 @@ 

Var-length Attributes

qryptr <- tiledb:::libtiledb_query_set_buffer_var_char(qryptr, "a1", bufptr) qryptr <- tiledb:::libtiledb_query_submit(qryptr) tiledb:::libtiledb_array_close(arrptr)
-
## <pointer: 0x55a211bf8a20>
+
## <pointer: 0x55d5011abad0>
#TODO Higher-level R support
@@ -2293,9 +2298,8 @@

Result Estimation

Time Traveling

ctx <- tiledb_ctx()
 tstamp <- Sys.time() - 1.0; # one seconds ago (as the arrays created here are in temp.files)
-arrptr <- tiledb:::libtiledb_array_open_at(ctx@ptr, uridense, "READ", tstamp)
-
## [1] "2020-03-09 12:18:22.387257 CDT"
-
subarr <- c(1L,2L, 2L,4L)
+arrptr <- tiledb:::libtiledb_array_open_at(ctx@ptr, uridense, "READ", tstamp)
+subarr <- c(1L,2L, 2L,4L)
 qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
 qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
 qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
@@ -2320,23 +2324,28 @@ 

Configuration

Array Metadata

Writing Array Metadata

-
res <- tiledb_put_metadata(uridense, "aaa", 100L)
-res <- tiledb_put_metadata(uridense, "bb", c(1.1, 2.2))
+
arr <- tiledb_dense(uridense)
+close_and_reopen(arr, "WRITE")
+res <- tiledb_put_metadata(arr, "aaa", 100L)
+res <- tiledb_put_metadata(arr, "bb", c(1.1, 2.2))
+invisible(tiledb:::libtiledb_array_close(arr@ptr))

Reading Array Metadata

One can read by key:

-
tiledb_get_metadata(uridense, "aaa")
+
close_and_reopen(arr, "READ")
+tiledb_get_metadata(arr, "aaa")
## [1] 100

Or one can retrieve all metadata at once:

-
md <- tiledb_get_all_metadata(uridense)
+
md <- tiledb_get_all_metadata(arr)
 print(md)
## aaa: 100
 ## bb:  1.1, 2.2

Deleting Array Metadata

-
res <- tiledb_delete_metadata(uridense, "aaa")
+
close_and_reopen(arr, "WRITE")
+res <- tiledb_delete_metadata(arr, "aaa")
diff --git a/inst/notebooks/documentation.nb.html b/inst/notebooks/documentation.nb.html index 313263b9bf..af413f7bc6 100644 --- a/inst/notebooks/documentation.nb.html +++ b/inst/notebooks/documentation.nb.html @@ -1890,12 +1890,93 @@

Prelimaries

We will the two basic examples for a dense and sparse array simply to create array data on disk to refer to later in examples that follow.

- -
create_array(uridense)
+ +
library(tiledb)
+
+tdir <- tempdir()
+uridense <- file.path(tdir, "dense")
+uridensefix <- file.path(tdir, "densefix")
+uridensevar <- file.path(tdir, "densevar")
+
+create_array <- function(array_name) {
+    # Check if the array already exists.
+    if (tiledb_object_type(array_name) == "ARRAY") {
+        message("Array already exists.")
+        return(invisible(NULL))
+    }
+
+    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
+    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
+                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))
+
+    # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
+    schema <- tiledb_array_schema(dom, attrs = tiledb_attr("a", type = "INT32"))
+
+    # Create the (empty) array on disk.
+    tiledb_array_create(array_name, schema)
+}
+
+write_array <- function(array_name) {
+    data <- array(c(c(1L, 5L, 9L, 13L),
+                    c(2L, 6L, 10L, 14L),
+                    c(3L, 7L, 11L, 15L),
+                    c(4L, 8L, 12L, 16L)), dim = c(4,4))
+    # Open the array and write to it.
+    A <- tiledb_dense(uri = array_name)
+    A[] <- data
+}
+
+create_array(uridense)
- -
[1] "/tmp/RtmpaoIiNJ/dense"
+ +
[1] "/tmp/RtmpMiNRCx/dense"
+ +
write_array(uridense)
+
+
+urisparse <- file.path(tdir, "sparse")
+
+create_array <- function(array_name) {
+    # Check if the array already exists.
+    if (tiledb_object_type(array_name) == "ARRAY") {
+        message("Array already exists.")
+        return(invisible(NULL))
+    }
+
+    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
+    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
+                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))
+
+    # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
+    schema = tiledb_array_schema(dom, attrs=tiledb_attr("a", type = "INT32"), sparse = TRUE)
+
+    # Create the (empty) array on disk.
+    tiledb_array_create(array_name, schema)
+}
+
+write_array <- function(array_name) {
+    I <- c(1, 2, 2)
+    J <- c(1, 4, 3)
+    data <- c(1L, 2L, 3L)
+    # Open the array and write to it.
+    A <- tiledb_sparse(uri = array_name)
+    A[I, J] <- data
+}
+
+create_array(urisparse)
+ + +
[1] "/tmp/RtmpMiNRCx/sparse"
+ + +
write_array(urisparse)
+
+close_and_reopen <- function(arr, txt) {
+  res <- tiledb:::libtiledb_array_close(arr@ptr)
+  res <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, txt)
+}
+ @@ -1908,11 +1989,11 @@

Create Dimension

-
library(tiledb)
-
-# Create dimension
-# In C++: Dimension::create<T>(...)
-dim <- tiledb_dim("dim", c(1L, 4L), 2L, "INT32")
+
library(tiledb)
+
+# Create dimension
+# In C++: Dimension::create<T>(...)
+dim <- tiledb_dim("dim", c(1L, 4L), 2L, "INT32")
@@ -1922,15 +2003,15 @@

Create Array Domain

-
library(tiledb)
-
-#  .. create dimensions `dim1`, `dim2`
-dim1 <- tiledb_dim("dim1", c(1L, 4L), 2L, "INT32")
-dim2 <- tiledb_dim("dim2", c(1L, 2L), 2L, "INT32")
-
-# Create domain with two dimensions
-# In C++: domain.add_dimensions(dim1).add_dimension(dim2)
-dom <- tiledb_domain(dims = c(dim1, dim2))
+
library(tiledb)
+
+#  .. create dimensions `dim1`, `dim2`
+dim1 <- tiledb_dim("dim1", c(1L, 4L), 2L, "INT32")
+dim2 <- tiledb_dim("dim2", c(1L, 2L), 2L, "INT32")
+
+# Create domain with two dimensions
+# In C++: domain.add_dimensions(dim1).add_dimension(dim2)
+dom <- tiledb_domain(dims = c(dim1, dim2))
@@ -1940,21 +2021,21 @@

Creating Attributes

-
# Create attribute
-# In C++: Attribute::create<T>(ctx, "attr")
-attr <- tiledb_attr("attr", "INT32")
+
# Create attribute
+# In C++: Attribute::create<T>(ctx, "attr")
+attr <- tiledb_attr("attr", "INT32")
-
# We can also set the number of attributes to a value other than one
-tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 3)
-
-# And we can set the a variable number of attributes (using NA to select variable size)
-tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
-## TODO: R function for level setter
+
# We can also set the number of attributes to a value other than one
+tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 3)
+
+# And we can set the a variable number of attributes (using NA to select variable size)
+tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
+## TODO: R function for level setter
@@ -1962,15 +2043,15 @@

Creating Attributes

Setting a Compressor

- -
comp <- tiledb_filter("GZIP")
-tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10)
-
-# Create a filter list with the compressor
-filter_list <- tiledb_filter_list(c(comp))
-
-# Create attribute with the filter list
-attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
+ +
comp <- tiledb_filter("GZIP")
+tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10)
+
+# Create a filter list with the compressor
+filter_list <- tiledb_filter_list(comp)
+
+# Create attribute with the filter list
+attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
@@ -1980,15 +2061,15 @@

Setting Other Filters

-
# Create filters
-f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
-f2 <- tiledb_filter("ZSTD")
-
-# Create a filter list with the two filters
-filter_list <- tiledb_filter_list(c(f1,f2))
-
-# Create attribute with the filter list
-attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
+
# Create filters
+f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
+f2 <- tiledb_filter("ZSTD")
+
+# Create a filter list with the two filters
+filter_list <- tiledb_filter_list(c(f1,f2))
+
+# Create attribute with the filter list
+attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
@@ -1998,8 +2079,8 @@

Setting the Tile Chunk Size

-
# ... create filter list
-set_max_chunk_size(filter_list, 10000)
+
# ... create filter list
+set_max_chunk_size(filter_list, 10000)
@@ -2010,14 +2091,14 @@

Creating the Array Schema

-
# ... create domain dom
-attr1 <- tiledb_attr("attr1", "INT32", filter_list = filter_list)
-attr2 <- tiledb_attr("attr2", "FLOAT64", filter_list = filter_list)
-
-# Create a dense array
-schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = FALSE)
-# Or, create a spaese array
-# schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = TRUE)
+
# ... create domain dom
+attr1 <- tiledb_attr("attr1", "INT32", filter_list = filter_list)
+attr2 <- tiledb_attr("attr2", "FLOAT64", filter_list = filter_list)
+
+# Create a dense array
+schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = FALSE)
+# Or, create a spaese array
+# schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = TRUE)
@@ -2026,13 +2107,13 @@

Setting the Tile and Cell Order

-
# ... create domain dom
-# ... create attributes attr1, attr2
-
-# The tile and order can be "ROW_MAJOR" or "COL_MAJOR"
-schema <- tiledb_array_schema(dom, c(attr1, attr2),
-                              cell_order = "COL_MAJOR",
-                              tile_order = "ROW_MAJOR")
+
# ... create domain dom
+# ... create attributes attr1, attr2
+
+# The tile and order can be "ROW_MAJOR" or "COL_MAJOR"
+schema <- tiledb_array_schema(dom, c(attr1, attr2),
+                              cell_order = "COL_MAJOR",
+                              tile_order = "ROW_MAJOR")
@@ -2042,14 +2123,14 @@

Setting the Data Tile Capacity

-
tiledb:::libtiledb_array_schema_set_capacity(schema@ptr, 100000)
-tiledb:::libtiledb_array_schema_get_capacity(schema@ptr)
+
tiledb:::libtiledb_array_schema_set_capacity(schema@ptr, 100000)
+tiledb:::libtiledb_array_schema_get_capacity(schema@ptr)
[1] 100000
-
## TODO R function for accessor
+
## TODO R function for accessor
@@ -2059,18 +2140,18 @@

Setting Coordinate and Offset Filters

-
# ... create domain dom
-# ... create attributes attr1, attr2
-# ... create filter lists fl1, fl2, similar to attributes
-f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
-f2 <- tiledb_filter("ZSTD")
-fl1 <- tiledb_filter_list(c(f1))
-fl2 <- tiledb_filter_list(c(f2))
-
-# Create the schema setting the coordinates and offsets filter lists
-schema <- tiledb_array_schema(dom, c(attr1, attr2),
-                              coords_filter_list = fl1,
-                              offsets_filter_list = fl2)
+
# ... create domain dom
+# ... create attributes attr1, attr2
+# ... create filter lists fl1, fl2, similar to attributes
+f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
+f2 <- tiledb_filter("ZSTD")
+fl1 <- tiledb_filter_list(c(f1))
+fl2 <- tiledb_filter_list(c(f2))
+
+# Create the schema setting the coordinates and offsets filter lists
+schema <- tiledb_array_schema(dom, c(attr1, attr2),
+                              coords_filter_list = fl1,
+                              offsets_filter_list = fl2)
@@ -2080,8 +2161,8 @@

Checking Correctness

-
tiledb:::libtiledb_array_schema_check(schema@ptr)
-## TODO: R function for access
+
tiledb:::libtiledb_array_schema_check(schema@ptr)
+## TODO: R function for access
@@ -2092,10 +2173,10 @@

Creating the Array

-
# ... create array schema
-
-# Create the array
-tiledb_array_create(uridense, schema)
+
# ... create array schema
+
+# Create the array
+tiledb_array_create(uridense, schema)
@@ -2105,19 +2186,19 @@

Creating Encrypted Arrays

-
encryption_key <- "0123456789abcdeF0123456789abcdeF"
-uridensewkey <- file.path(tdir, "densewkey")
-if (dir.exists(uridensewkey)) unlink(uridensewkey, recursive=TRUE)
-
-# shortcut: borrow schema from dense array; could create schema too
-schema <- schema(tiledb_dense(uridense))
-tiledb:::libtiledb_array_create_with_key(uridensewkey, schema@ptr, encryption_key)
+
encryption_key <- "0123456789abcdeF0123456789abcdeF"
+uridensewkey <- file.path(tdir, "densewkey")
+if (dir.exists(uridensewkey)) unlink(uridensewkey, recursive=TRUE)
+
+# shortcut: borrow schema from dense array; could create schema too
+schema <- schema(tiledb_dense(uridense))
+tiledb:::libtiledb_array_create_with_key(uridensewkey, schema@ptr, encryption_key)
- -
[1] "/tmp/RtmppsnBrT/densewkey"
+ +
[1] "/tmp/RtmpMiNRCx/densewkey"
-
##TODO: R support
+
##TODO: R support
@@ -2130,33 +2211,33 @@

Writing in Dense Subarrays

-
## prepare a larger 5 x 5 to embed into
-tmp <- tempfile()
-d1  <- tiledb_dim(domain = c(1L, 5L))
-d2  <- tiledb_dim(domain = c(1L, 5L))
-dom <- tiledb_domain(c(d1, d2))
-val <- tiledb_attr(name="val", type = "INT32")
-sch <- tiledb_array_schema(dom, c(val))
-tiledb_array_create(tmp, sch)
-
-dat <- matrix(as.integer(rnorm(25)*100), 5, 5)
-arr <- tiledb_dense(tmp, as.data.frame=FALSE)
-arr[] <- dat
-
-
-# Prepare a 2x3 dense array
-# Contrary to Python, R by default stores arrays in col-major order
-data <-  array(c(1L, 4L, 2L, 5L, 3L, 6L), dim=c(2,3))
-
-# Prepare the [1,2] x [2,4] subarray to write to
-I <- c(1:2)
-J <- c(2:4)
-
-# Open the array and write the data to it
-A <- tiledb_dense(uri = tmp)
-A[I, J] <- data
-
-unlink(tmp, recursive=TRUE)
+
## prepare a larger 5 x 5 to embed into
+tmp <- tempfile()
+d1  <- tiledb_dim(domain = c(1L, 5L))
+d2  <- tiledb_dim(domain = c(1L, 5L))
+dom <- tiledb_domain(c(d1, d2))
+val <- tiledb_attr(name="val", type = "INT32")
+sch <- tiledb_array_schema(dom, c(val))
+tiledb_array_create(tmp, sch)
+
+dat <- matrix(as.integer(rnorm(25)*100), 5, 5)
+arr <- tiledb_dense(tmp, as.data.frame=FALSE)
+arr[] <- dat
+
+
+# Prepare a 2x3 dense array
+# Contrary to Python, R by default stores arrays in col-major order
+data <-  array(c(1L, 4L, 2L, 5L, 3L, 6L), dim=c(2,3))
+
+# Prepare the [1,2] x [2,4] subarray to write to
+I <- c(1:2)
+J <- c(2:4)
+
+# Open the array and write the data to it
+A <- tiledb_dense(uri = tmp)
+A[I, J] <- data
+
+unlink(tmp, recursive=TRUE)
@@ -2165,19 +2246,19 @@

Basic Writing using Low-Level Code

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "WRITE")
-
-## data: simple (integer sequence) of 1:16 times 10
-vec <- 1:16 * 10L
-subarr <- c(1L,4L, 1L,4L)
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-res <- tiledb:::libtiledb_array_close(arrptr)
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "WRITE")
+
+## data: simple (integer sequence) of 1:16 times 10
+vec <- 1:16 * 10L
+subarr <- c(1L,4L, 1L,4L)
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+res <- tiledb:::libtiledb_array_close(arrptr)
@@ -2187,30 +2268,30 @@

Basic Writing using Low-Level Code

Writing Sparse Cells

- -
tmp <- urisparse
-unlink(tmp, recursive=TRUE)
-
-d1  <- tiledb_dim(domain = c(1L, 5L))
-d2  <- tiledb_dim(domain = c(1L, 5L))
-dom <- tiledb_domain(c(d1, d2))
-val <- tiledb_attr("val", type = "INT32")
-sch <- tiledb_array_schema(dom, c(val), sparse=TRUE)
-tiledb_array_create(tmp, sch)
+ +
tmp <- urisparse
+unlink(tmp, recursive=TRUE)
+
+d1  <- tiledb_dim(domain = c(1L, 5L))
+d2  <- tiledb_dim(domain = c(1L, 5L))
+dom <- tiledb_domain(c(d1, d2))
+val <- tiledb_attr("val", type = "INT32")
+sch <- tiledb_array_schema(dom, val, sparse=TRUE)
+tiledb_array_create(tmp, sch)
- -
[1] "/tmp/RtmppsnBrT/sparse"
+ +
[1] "/tmp/RtmpMiNRCx/sparse"
-
# Prepare some data
-data <- c(3L, 4L, 1L, 2L)
-
-I <- c(3, 4, 1, 2)
-J <- c(3, 4, 2, 1)
-
-# Open the array and write the data to it
-A <- tiledb_sparse(uri = tmp)
-A[I, J] <- data
+
# Prepare some data
+data <- c(3L, 4L, 1L, 2L)
+
+I <- c(3, 4, 1, 2)
+J <- c(3, 4, 2, 1)
+
+# Open the array and write the data to it
+A <- tiledb_sparse(uri = tmp)
+A[I, J] <- data
@@ -2220,20 +2301,20 @@

Writing Encrypted Arrays

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "WRITE", encryption_key)
-
-## data: simple (integer sequence) of 1:16 times 10
-vec <- 1:16 * 10L
-subarr <- c(1L,4L, 1L,4L)
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-res <- tiledb:::libtiledb_array_close(arrptr)
-# TODO Higher-level R support
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "WRITE", encryption_key)
+
+## data: simple (integer sequence) of 1:16 times 10
+vec <- 1:16 * 10L
+subarr <- c(1L,4L, 1L,4L)
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+res <- tiledb:::libtiledb_array_close(arrptr)
+# TODO Higher-level R support
@@ -2242,36 +2323,36 @@

Writing Encrypted Arrays

Fixed-length Attributes

- -
if (dir.exists(uridensefix)) unlink(uridensefix, recursive=TRUE)
-d1  <- tiledb_dim(domain = c(1L, 4L))
-d2  <- tiledb_dim(domain = c(1L, 4L))
-dom <- tiledb_domain(c(d1, d2))
-
-vec <- 1:32 * 10L
-attr <- tiledb_attr("a", type = r_to_tiledb_type(vec))
-
-## set to two values per cell
-tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2)
-sch <- tiledb_array_schema(dom, c(attr))
-tiledb_array_create(uridensefix, sch)
+ +
if (dir.exists(uridensefix)) unlink(uridensefix, recursive=TRUE)
+d1  <- tiledb_dim(domain = c(1L, 4L))
+d2  <- tiledb_dim(domain = c(1L, 4L))
+dom <- tiledb_domain(c(d1, d2))
+
+vec <- 1:32 * 10L
+attr <- tiledb_attr("a", type = r_to_tiledb_type(vec))
+
+## set to two values per cell
+tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2)
+sch <- tiledb_array_schema(dom, attr)
+tiledb_array_create(uridensefix, sch)
- -
[1] "/tmp/RtmppsnBrT/densefix"
+ +
[1] "/tmp/RtmpMiNRCx/densefix"
-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensefix, "WRITE")
-subarr <- c(1L,4L, 1L,4L)
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-res <- tiledb:::libtiledb_array_close(arrptr)
-
-#TODO Higher-level R support
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensefix, "WRITE")
+subarr <- c(1L,4L, 1L,4L)
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+res <- tiledb:::libtiledb_array_close(arrptr)
+
+#TODO Higher-level R support
@@ -2281,52 +2362,52 @@

Var-length Attributes

-
if (dir.exists(uridensevar)) unlink(uridensevar, recursive=TRUE)
-## Define array
-## The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
-dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
-                              tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))
-
-
-attr <- tiledb_attr("a1", type = "CHAR")
-## set to variable length
-tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
-
-## now set the schema
-ctx <- tiledb_ctx()
-schptr <- tiledb:::libtiledb_array_schema_create(ctx@ptr, "DENSE")
-tiledb:::libtiledb_array_schema_set_domain(schptr, dom@ptr)
-tiledb:::libtiledb_array_schema_set_cell_order(schptr, "ROW_MAJOR")
-tiledb:::libtiledb_array_schema_set_tile_order(schptr, "ROW_MAJOR")
-tiledb:::libtiledb_array_schema_add_attribute(schptr, attr@ptr)
-
-
-
-## Create the (empty) array on disk.
-tiledb:::libtiledb_array_create(uridensevar, schptr)
+
if (dir.exists(uridensevar)) unlink(uridensevar, recursive=TRUE)
+## Define array
+## The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
+dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
+                              tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))
+
+
+attr <- tiledb_attr("a1", type = "CHAR")
+## set to variable length
+tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
+
+## now set the schema
+ctx <- tiledb_ctx()
+schptr <- tiledb:::libtiledb_array_schema_create(ctx@ptr, "DENSE")
+tiledb:::libtiledb_array_schema_set_domain(schptr, dom@ptr)
+tiledb:::libtiledb_array_schema_set_cell_order(schptr, "ROW_MAJOR")
+tiledb:::libtiledb_array_schema_set_tile_order(schptr, "ROW_MAJOR")
+tiledb:::libtiledb_array_schema_add_attribute(schptr, attr@ptr)
+
+
+
+## Create the (empty) array on disk.
+tiledb:::libtiledb_array_create(uridensevar, schptr)
- -
[1] "/tmp/RtmppsnBrT/densevar"
+ +
[1] "/tmp/RtmpMiNRCx/densevar"
-
data <- "abbcccddeeefghhhijjjkklmnoop";
-offsets <- c(0L, 1L, 3L, 6L, 8L, 11L, 12L, 13L, 16L, 17L, 20L, 22L, 23L, 24L, 25L, 27L)
-
-ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "WRITE")
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-
-bufptr <- tiledb:::libtiledb_query_buffer_var_char_create(offsets, data)
-qryptr <- tiledb:::libtiledb_query_set_buffer_var_char(qryptr, "a1", bufptr)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-tiledb:::libtiledb_array_close(arrptr)
+
data <- "abbcccddeeefghhhijjjkklmnoop";
+offsets <- c(0L, 1L, 3L, 6L, 8L, 11L, 12L, 13L, 16L, 17L, 20L, 22L, 23L, 24L, 25L, 27L)
+
+ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "WRITE")
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+
+bufptr <- tiledb:::libtiledb_query_buffer_var_char_create(offsets, data)
+qryptr <- tiledb:::libtiledb_query_set_buffer_var_char(qryptr, "a1", bufptr)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+tiledb:::libtiledb_array_close(arrptr)
- -
<pointer: 0x7fb5fc018dc0>
+ +
<pointer: 0x7fd6a40137a0>
-
#TODO Higher-level R support
+
#TODO Higher-level R support
@@ -2336,12 +2417,12 @@

Getting the Fragment Info

-
## continuing from previous example on dense variable length array
-## (but this works of course with any array after a write is needed
-numfrag <- tiledb:::libtiledb_query_get_fragment_num(qryptr)
-uritxt <- tiledb:::libtiledb_query_get_fragment_uri(qryptr, 0)
-
-##TODO Higher-level R support
+
## continuing from previous example on dense variable length array
+## (but this works of course with any array after a write is needed
+numfrag <- tiledb:::libtiledb_query_get_fragment_num(qryptr)
+uritxt <- tiledb:::libtiledb_query_get_fragment_uri(qryptr, 0)
+
+##TODO Higher-level R support
@@ -2354,11 +2435,11 @@

Reading the Array Schema

-
array_name <- urisparse
-A <- tiledb_sparse(uri = array_name)
-# can also load dense
-sch <- schema(A)
-# can also open encrypted arrays with key
+
array_name <- urisparse
+A <- tiledb_sparse(uri = array_name)
+# can also load dense
+sch <- schema(A)
+# can also open encrypted arrays with key
@@ -2367,45 +2448,45 @@

Inspecting the array schema

-
array_name <- urisparse
-
-# Get array schema
-A <- tiledb_sparse(uri = array_name)
-# or use tiledb_dense(uri = array_name) for dense
-schema <- schema(A)
-
-# Get array type
-sparse <- is.sparse(schema)
-
-# Get tile capacity
-tiledb:::libtiledb_array_schema_get_capacity(sch@ptr)
+
array_name <- urisparse
+
+# Get array schema
+A <- tiledb_sparse(uri = array_name)
+# or use tiledb_dense(uri = array_name) for dense
+schema <- schema(A)
+
+# Get array type
+sparse <- is.sparse(schema)
+
+# Get tile capacity
+tiledb:::libtiledb_array_schema_get_capacity(sch@ptr)
[1] 10000
-
# TODO: R accessor for tile
-
-# Get tile order
-t_order <- tile_order(schema)
-
-# Get cell order
-c_order <- cell_order(schema)
-
-# Get coordinates and offset filter list
-reslist <- filter_list(schema)
-
-# Get the array domain
-dom <- domain(schema)
-
-# Get all attributes as list
-attrs <- attrs(schema)
-
-# Get attribute from name
-attr <- attrs(schema, "attr")
-
-# Dump the array schema in ASCII format to stdout
-show(schema)
+
# TODO: R accessor for tile
+
+# Get tile order
+t_order <- tile_order(schema)
+
+# Get cell order
+c_order <- cell_order(schema)
+
+# Get coordinates and offset filter list
+reslist <- filter_list(schema)
+
+# Get the array domain
+dom <- domain(schema)
+
+# Get all attributes as list
+attrs <- attrs(schema)
+
+# Get attribute from name
+attr <- attrs(schema, "attr")
+
+# Dump the array schema in ASCII format to stdout
+show(schema)
- Array type: sparse
@@ -2443,21 +2524,21 @@ 

Inspecting Domain

-
# ... get array schema
-# ... get domain from schema
-dom <- domain(schema)
-
-# Get the domain datatype (i.e., the datatype of all dimensions)
-type <- datatype(dom)
-
-# Get number of dimensions
-dim_num <- dim(dom)
-
-# Get all dimension
-dims <- dimensions(dom)
-
-# Dump the domain in ASCII format in the selected output
-show(dom)
+
# ... get array schema
+# ... get domain from schema
+dom <- domain(schema)
+
+# Get the domain datatype (i.e., the datatype of all dimensions)
+type <- datatype(dom)
+
+# Get number of dimensions
+dim_num <- dim(dom)
+
+# Get all dimension
+dims <- dimensions(dom)
+
+# Dump the domain in ASCII format in the selected output
+show(dom)
=== Domain ===
@@ -2481,26 +2562,26 @@ 

Inspecting Dimensions

-
# ... get array schema
-# ... get domain
-# ... get dimension by index or name
-
-#FIXME
-
-# Get dimension name
-dim_name <- name(dim)
-
-# Get dimension datatype
-dim_type <- datatype(dim)
-
-# Get dimension domain
-domain <- domain(dim)
-
-# Get tile extent
-tile_extent <- tile(dim)
-
-# Dump the dimension in ASCII format in the selected output
-show(dim)
+
# ... get array schema
+# ... get domain
+# ... get dimension by index or name
+
+#FIXME
+
+# Get dimension name
+dim_name <- name(dim)
+
+# Get dimension datatype
+dim_type <- datatype(dim)
+
+# Get dimension domain
+domain <- domain(dim)
+
+# Get tile extent
+tile_extent <- tile(dim)
+
+# Dump the dimension in ASCII format in the selected output
+show(dim)
@@ -2510,30 +2591,30 @@

Inspecting Attributes

-
# ... get array schema
-# ... get attribute by index or name
-
-stopifnot(is.null(attr))
-# Get attribute name
-attr_name <- name(attr)
-
-# Get attribute datatype
-attr_type <- datatype(attr)
-
-# Get filter list
-filter_list <- filter_list(attr)
-
-# Check if attribute is variable-length
-# variable length attribtues are not supported in R currently
-
-# Get number of values per cell
-num <- ncells(attr)
-
-# Get cell size for this attribute
-sz <-- tiledb:::libtiledb_attribute_get_cell_val(attr@ptr)
-
-# Dump the attribute in ASCII format in the selected output
-show(attr)
+
# ... get array schema
+# ... get attribute by index or name
+
+stopifnot(is.null(attr))
+# Get attribute name
+attr_name <- name(attr)
+
+# Get attribute datatype
+attr_type <- datatype(attr)
+
+# Get filter list
+filter_list <- filter_list(attr)
+
+# Check if attribute is variable-length
+# variable length attribtues are not supported in R currently
+
+# Get number of values per cell
+num <- ncells(attr)
+
+# Get cell size for this attribute
+sz <-- tiledb:::libtiledb_attribute_get_cell_val(attr@ptr)
+
+# Dump the attribute in ASCII format in the selected output
+show(attr)
@@ -2543,17 +2624,17 @@

Inspecting Filters

-
fl <- tiledb_filter_list()
-
-# get number of filter
-tiledb:::libtiledb_filter_list_get_nfilters(fl@ptr)
-
-# get max chunk size
-tiledb:::libtiledb_filter_list_get_max_chunk_size(fl@ptr)
-
-# get filter from index
-ind <- i
-tiledb:::libtiledb_filter_list_get_filter_from_index(fl@ptr, ind)
+
fl <- tiledb_filter_list()
+
+# get number of filter
+tiledb:::libtiledb_filter_list_get_nfilters(fl@ptr)
+
+# get max chunk size
+tiledb:::libtiledb_filter_list_get_max_chunk_size(fl@ptr)
+
+# get filter from index
+ind <- i
+tiledb:::libtiledb_filter_list_get_filter_from_index(fl@ptr, ind)
@@ -2564,18 +2645,18 @@

Basic Reading

-
# Create a TileDB context
-ctx <- tiledb_ctx()
-
-# Open a dense array
-A <- tiledb_dense(uri = uridense, ctx=ctx)
-
-# Or, open a sparse array
-# A <- tiledb_sparse(uri = "<array-uri>", ctx=ctx)
-
-# Slice only rows 1, 2 and cols 2, 3, 4
-data <- A[1:2, 2:4]
-show(data)
+
# Create a TileDB context
+ctx <- tiledb_ctx()
+
+# Open a dense array
+A <- tiledb_dense(uri = uridense, ctx=ctx)
+
+# Or, open a sparse array
+# A <- tiledb_sparse(uri = "<array-uri>", ctx=ctx)
+
+# Slice only rows 1, 2 and cols 2, 3, 4
+data <- A[1:2, 2:4]
+show(data)
     [,1] [,2] [,3]
@@ -2589,24 +2670,24 @@ 

Basic Reading using Low-Level Code

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
-## subarray of rows 1,2 and cols 2,3,4
-subarr <- c(1L,2L, 2L,4L)
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-v <- integer(6)  # reserve space
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-print(v)         # unformed array, no coordinates
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
+## subarray of rows 1,2 and cols 2,3,4
+subarr <- c(1L,2L, 2L,4L)
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+v <- integer(6)  # reserve space
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+print(v)         # unformed array, no coordinates
[1] 20 30 40 60 70 80
-
res <- tiledb:::libtiledb_array_close(arrptr)
+
res <- tiledb:::libtiledb_array_close(arrptr)
@@ -2617,27 +2698,27 @@

Reading Encrypted Arrays

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "READ", encryption_key)
-
-## subarray of rows 1,2 and cols 2,3,4
-subarr <- c(1L,2L, 2L,4L)
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-v <- integer(6)  # reserve space
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-print(v)         # unformed array, no coordinates
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "READ", encryption_key)
+
+## subarray of rows 1,2 and cols 2,3,4
+subarr <- c(1L,2L, 2L,4L)
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+v <- integer(6)  # reserve space
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+print(v)         # unformed array, no coordinates
[1] 20 30 40 60 70 80
-
res <- tiledb:::libtiledb_array_close(arrptr)
-
-## TODO open at timestamp example
+
res <- tiledb:::libtiledb_array_close(arrptr)
+
+## TODO open at timestamp example
@@ -2647,27 +2728,27 @@

Multi-range Subarrays

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
-
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
-
-## range of rows 1 and 2, and 4 for dim 1, all rows for dim 2
-qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 1L, 2L)
-qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 4L, 4L)
-qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 1, 1L, 4L)
-
-qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
-v <- integer(12)  # reserve space
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
-qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-print(v)         # unformed array, no coordinates
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
+
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+
+## range of rows 1 and 2, and 4 for dim 1, all rows for dim 2
+qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 1L, 2L)
+qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 4L, 4L)
+qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 1, 1L, 4L)
+
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+v <- integer(12)  # reserve space
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+print(v)         # unformed array, no coordinates
 [1]  10  20  30  40  50  60  70  80 130 140 150 160
-
res <- tiledb:::libtiledb_array_close(arrptr)
+
res <- tiledb:::libtiledb_array_close(arrptr)
@@ -2677,19 +2758,19 @@

Incomplete Queries

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
-subarr <- c(1L,4L, 1L,4L)
-qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
-vec <- integer(4)  # reserve (insufficient) space
-qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
-finished <- FALSE
-while (!finished) {
-  qryptr <- tiledb:::libtiledb_query_submit(qryptr)
-  print(vec)
-  finished <- tiledb:::libtiledb_query_status(qryptr) == "COMPLETE"
-}
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+subarr <- c(1L,4L, 1L,4L)
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+vec <- integer(4)  # reserve (insufficient) space
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
+finished <- FALSE
+while (!finished) {
+  qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+  print(vec)
+  finished <- tiledb:::libtiledb_query_status(qryptr) == "COMPLETE"
+}
[1] 10 20 30 40
@@ -2698,7 +2779,7 @@ 

Incomplete Queries

[1] 130 140 150 160
-
res <- tiledb:::libtiledb_array_close(arrptr)
+
res <- tiledb:::libtiledb_array_close(arrptr)
@@ -2708,12 +2789,12 @@

Result Estimation

-
ctx <- tiledb_ctx()
-arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "READ")
-qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
-estsz <- tiledb:::libtiledb_query_get_est_result_size_var(qryptr, "a1")
-res <- tiledb:::libtiledb_array_close(arrptr)
-estsz
+
ctx <- tiledb_ctx()
+arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "READ")
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+estsz <- tiledb:::libtiledb_query_get_est_result_size_var(qryptr, "a1")
+res <- tiledb:::libtiledb_array_close(arrptr)
+estsz
[1] 16 28
@@ -2725,11 +2806,22 @@

Result Estimation

Time Traveling

- -
v
+ +
ctx <- tiledb_ctx()
+tstamp <- Sys.time() - 1.0; # one seconds ago (as the arrays created here are in temp.files)
+arrptr <- tiledb:::libtiledb_array_open_at(ctx@ptr, uridense, "READ", tstamp)
+subarr <- c(1L,2L, 2L,4L)
+qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
+qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
+qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
+v <- integer(6)  # reserve space
+qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
+qryptr <- tiledb:::libtiledb_query_submit(qryptr)
+res <- tiledb:::libtiledb_array_close(arrptr)
+v
- -
[1] 2 3 4 6 7 8
+ +
[1] 0 0 0 0 0 0
@@ -2750,9 +2842,12 @@

Array Metadata

Writing Array Metadata

- -
res <- tiledb_put_metadata(uridense, "aaa", 100L)
-res <- tiledb_put_metadata(uridense, "bb", c(1.1, 2.2))
+ +
arr <- tiledb_dense(uridense)
+close_and_reopen(arr, "WRITE")
+res <- tiledb_put_metadata(arr, "aaa", 100L)
+res <- tiledb_put_metadata(arr, "bb", c(1.1, 2.2))
+invisible(tiledb:::libtiledb_array_close(arr@ptr))
@@ -2762,18 +2857,26 @@

Reading Array Metadata

One can read by key:

- -
tiledb_get_metadata(uridense, "aaa")
+ +
close_and_reopen(arr, "READ")
+tiledb_get_metadata(arr, "aaa")
+ +
[1] 100
+

Or one can retrieve all metadata at once:

- -
md <- tiledb_get_all_metadata(uridense)
-print(md)
+ +
md <- tiledb_get_all_metadata(arr)
+print(md)
+ +
aaa:    100
+bb: 1.1, 2.2
+ @@ -2781,15 +2884,16 @@

Reading Array Metadata

Deleting Array Metadata

- -
res <- tiledb_delete_metadata(uridense, "aaa")
+ +
close_and_reopen(arr, "WRITE")
+res <- tiledb_delete_metadata(arr, "aaa")
-
---
title: "TileDB R Notebook"
output:
  html_notebook:
    toc: yes
    highlight: pygments
    theme: lumen
  html_document:
    toc: yes
    df_print: paged
---

<!--This is an [R Markdown](http://rmarkdown.rstudio.com) Notebook. When you execute code within the notebook, the results appear beneath the code.  Try executing this chunk by clicking the *Run* button within the chunk or by placing your cursor inside it and pressing *Ctrl+Shift+Enter*.   Add a new chunk by clicking the *Insert Chunk* button on the toolbar or by pressing *Ctrl+Alt+I*.
When you save the notebook, an HTML file containing the code and output will be saved alongside it (click the *Preview* button or press *Ctrl+Shift+K* to preview the HTML file).  The preview shows you a rendered HTML copy of the contents of the editor. Consequently, unlike *Knit*, *Preview* does not run any R code chunks. Instead, the output of the chunk when it was last run in the editor is displayed.-->

# Prelimaries

We will the two basic examples for a dense and sparse array simply to create
array data on disk to refer to later in examples that follow.

```{r runexamples}
library(tiledb)

tdir <- tempdir()
uridense <- file.path(tdir, "dense")
uridensefix <- file.path(tdir, "densefix")
uridensevar <- file.path(tdir, "densevar")

create_array <- function(array_name) {
    # Check if the array already exists.
    if (tiledb_object_type(array_name) == "ARRAY") {
        message("Array already exists.")
        return(invisible(NULL))
    }

    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))

    # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
    schema <- tiledb_array_schema(dom, attrs = c(tiledb_attr("a", type = "INT32")))

    # Create the (empty) array on disk.
    tiledb_array_create(array_name, schema)
}

write_array <- function(array_name) {
    data <- array(c(c(1L, 5L, 9L, 13L),
                    c(2L, 6L, 10L, 14L),
                    c(3L, 7L, 11L, 15L),
                    c(4L, 8L, 12L, 16L)), dim = c(4,4))
    # Open the array and write to it.
    A <- tiledb_dense(uri = array_name)
    A[] <- data
}

create_array(uridense)
write_array(uridense)


urisparse <- file.path(tdir, "sparse")

create_array <- function(array_name) {
    # Check if the array already exists.
    if (tiledb_object_type(array_name) == "ARRAY") {
        message("Array already exists.")
        return(invisible(NULL))
    }

    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))

   # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
    schema = tiledb_array_schema(dom, attrs=c(tiledb_attr("a", type = "INT32")), sparse = TRUE)

    # Create the (empty) array on disk.
    tiledb_array_create(array_name, schema)
}

write_array <- function(array_name) {
    I <- c(1, 2, 2)
    J <- c(1, 4, 3)
    data <- c(1L, 2L, 3L)
    # Open the array and write to it.
    A <- tiledb_sparse(uri = array_name)
    A[I, J] <- data
}

create_array(urisparse)
write_array(urisparse)

```



# API Usage

## Creating Arrays

### Create Dimension

```{r createdim}
library(tiledb)

# Create dimension
# In C++: Dimension::create<T>(...)
dim <- tiledb_dim("dim", c(1L, 4L), 2L, "INT32")
```


### Create Array Domain

```{r creatarrdom}
library(tiledb)

#  .. create dimensions `dim1`, `dim2`
dim1 <- tiledb_dim("dim1", c(1L, 4L), 2L, "INT32")
dim2 <- tiledb_dim("dim2", c(1L, 2L), 2L, "INT32")

# Create domain with two dimensions
# In C++: domain.add_dimensions(dim1).add_dimension(dim2)
dom <- tiledb_domain(dims = c(dim1, dim2))
```

### Creating Attributes

```{r createattr}
# Create attribute
# In C++: Attribute::create<T>(ctx, "attr")
attr <- tiledb_attr("attr", "INT32")
```

```{r createattrvarnum}
# We can also set the number of attributes to a value other than one
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 3)

# And we can set the a variable number of attributes (using NA to select variable size)
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
## TODO: R function for level setter
```

#### Setting a Compressor

```{r setcompr}
comp <- tiledb_filter("GZIP")
tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10)

# Create a filter list with the compressor
filter_list <- tiledb_filter_list(c(comp))

# Create attribute with the filter list
attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
```


#### Setting Other Filters

```{r setfilr}
# Create filters
f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
f2 <- tiledb_filter("ZSTD")

# Create a filter list with the two filters
filter_list <- tiledb_filter_list(c(f1,f2))

# Create attribute with the filter list
attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
```


#### Setting the Tile Chunk Size

```{r settilechunksize}
# ... create filter list
set_max_chunk_size(filter_list, 10000)
```


### Creating the Array Schema

```{r createarrschema}
# ... create domain dom
attr1 <- tiledb_attr("attr1", "INT32", filter_list = filter_list)
attr2 <- tiledb_attr("attr2", "FLOAT64", filter_list = filter_list)

# Create a dense array
schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = FALSE)
# Or, create a spaese array
# schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = TRUE)
```

#### Setting the Tile and Cell Order

```{r settilecellorder}
# ... create domain dom
# ... create attributes attr1, attr2

# The tile and order can be "ROW_MAJOR" or "COL_MAJOR"
schema <- tiledb_array_schema(dom, c(attr1, attr2),
                              cell_order = "COL_MAJOR",
                              tile_order = "ROW_MAJOR")
```

#### Setting the Data Tile Capacity

```{r settilecapacity}
tiledb:::libtiledb_array_schema_set_capacity(schema@ptr, 100000)
tiledb:::libtiledb_array_schema_get_capacity(schema@ptr)
## TODO R function for accessor
```

#### Setting Coordinate and Offset Filters

```{r setcoordoffsetfilt}
# ... create domain dom
# ... create attributes attr1, attr2
# ... create filter lists fl1, fl2, similar to attributes
f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
f2 <- tiledb_filter("ZSTD")
fl1 <- tiledb_filter_list(c(f1))
fl2 <- tiledb_filter_list(c(f2))

# Create the schema setting the coordinates and offsets filter lists
schema <- tiledb_array_schema(dom, c(attr1, attr2),
                              coords_filter_list = fl1,
                              offsets_filter_list = fl2)
```


#### Checking Correctness

```{r arrayschemacheck}
tiledb:::libtiledb_array_schema_check(schema@ptr)
## TODO: R function for access
```



### Creating the Array

```{r createarray, eval=FALSE}
# ... create array schema

# Create the array
tiledb_array_create(uridense, schema)
```

### Creating Encrypted Arrays

```{r createwithkey}
encryption_key <- "0123456789abcdeF0123456789abcdeF"
uridensewkey <- file.path(tdir, "densewkey")
if (dir.exists(uridensewkey)) unlink(uridensewkey, recursive=TRUE)

# shortcut: borrow schema from dense array; could create schema too
schema <- schema(tiledb_dense(uridense))
tiledb:::libtiledb_array_create_with_key(uridensewkey, schema@ptr, encryption_key)
##TODO: R support
```


## Writing Arrays

### Writing in Dense Subarrays

```{r writedensesubarr, eval=FALSE}
## prepare a larger 5 x 5 to embed into
tmp <- tempfile()
d1  <- tiledb_dim(domain = c(1L, 5L))
d2  <- tiledb_dim(domain = c(1L, 5L))
dom <- tiledb_domain(c(d1, d2))
val <- tiledb_attr(name="val", type = "INT32")
sch <- tiledb_array_schema(dom, c(val))
tiledb_array_create(tmp, sch)

dat <- matrix(as.integer(rnorm(25)*100), 5, 5)
arr <- tiledb_dense(tmp, as.data.frame=FALSE)
arr[] <- dat


# Prepare a 2x3 dense array
# Contrary to Python, R by default stores arrays in col-major order
data <-  array(c(1L, 4L, 2L, 5L, 3L, 6L), dim=c(2,3))

# Prepare the [1,2] x [2,4] subarray to write to
I <- c(1:2)
J <- c(2:4)

# Open the array and write the data to it
A <- tiledb_dense(uri = tmp)
A[I, J] <- data

unlink(tmp, recursive=TRUE)
```


#### Basic Writing using Low-Level Code

```{r basiscwritinglowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "WRITE")

## data: simple (integer sequence) of 1:16 times 10
vec <- 1:16 * 10L
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
```


### Writing Sparse Cells

```{r writesparsecells}
tmp <- urisparse
unlink(tmp, recursive=TRUE)

d1  <- tiledb_dim(domain = c(1L, 5L))
d2  <- tiledb_dim(domain = c(1L, 5L))
dom <- tiledb_domain(c(d1, d2))
val <- tiledb_attr("val", type = "INT32")
sch <- tiledb_array_schema(dom, c(val), sparse=TRUE)
tiledb_array_create(tmp, sch)


# Prepare some data
data <- c(3L, 4L, 1L, 2L)

I <- c(3, 4, 1, 2)
J <- c(3, 4, 2, 1)

# Open the array and write the data to it
A <- tiledb_sparse(uri = tmp)
A[I, J] <- data

```


### Writing Encrypted Arrays

```{r writingencryptedlowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "WRITE", encryption_key)

## data: simple (integer sequence) of 1:16 times 10
vec <- 1:16 * 10L
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
# TODO Higher-level R support

```




### Fixed-length Attributes

```{r fixedlengthattributes}
if (dir.exists(uridensefix)) unlink(uridensefix, recursive=TRUE)
d1  <- tiledb_dim(domain = c(1L, 4L))
d2  <- tiledb_dim(domain = c(1L, 4L))
dom <- tiledb_domain(c(d1, d2))

vec <- 1:32 * 10L
attr <- tiledb_attr("a", type = r_to_tiledb_type(vec))

## set to two values per cell
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2)
sch <- tiledb_array_schema(dom, c(attr))
tiledb_array_create(uridensefix, sch)

ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensefix, "WRITE")
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)

#TODO Higher-level R support
```

### Var-length Attributes

```{r}
if (dir.exists(uridensevar)) unlink(uridensevar, recursive=TRUE)
## Define array
## The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                              tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))


attr <- tiledb_attr("a1", type = "CHAR")
## set to variable length
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)

## now set the schema
ctx <- tiledb_ctx()
schptr <- tiledb:::libtiledb_array_schema_create(ctx@ptr, "DENSE")
tiledb:::libtiledb_array_schema_set_domain(schptr, dom@ptr)
tiledb:::libtiledb_array_schema_set_cell_order(schptr, "ROW_MAJOR")
tiledb:::libtiledb_array_schema_set_tile_order(schptr, "ROW_MAJOR")
tiledb:::libtiledb_array_schema_add_attribute(schptr, attr@ptr)



## Create the (empty) array on disk.
tiledb:::libtiledb_array_create(uridensevar, schptr)

data <- "abbcccddeeefghhhijjjkklmnoop";
offsets <- c(0L, 1L, 3L, 6L, 8L, 11L, 12L, 13L, 16L, 17L, 20L, 22L, 23L, 24L, 25L, 27L)

ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "WRITE")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")

bufptr <- tiledb:::libtiledb_query_buffer_var_char_create(offsets, data)
qryptr <- tiledb:::libtiledb_query_set_buffer_var_char(qryptr, "a1", bufptr)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
tiledb:::libtiledb_array_close(arrptr)

#TODO Higher-level R support
```


### Getting the Fragment Info

```{r fragmentinfo}
## continuing from previous example on dense variable length array
## (but this works of course with any array after a write is needed
numfrag <- tiledb:::libtiledb_query_get_fragment_num(qryptr)
uritxt <- tiledb:::libtiledb_query_get_fragment_uri(qryptr, 0)

##TODO Higher-level R support
```

## Reading Arrays

### Reading the Array Schema

```{r schemaload}
array_name <- urisparse
A <- tiledb_sparse(uri = array_name)
# can also load dense
sch <- schema(A)
# can also open encrypted arrays with key
```

#### Inspecting the array schema

```{r schemainspect}
array_name <- urisparse

# Get array schema
A <- tiledb_sparse(uri = array_name)
# or use tiledb_dense(uri = array_name) for dense
schema <- schema(A)

# Get array type
sparse <- is.sparse(schema)

# Get tile capacity
tiledb:::libtiledb_array_schema_get_capacity(sch@ptr)
# TODO: R accessor for tile

# Get tile order
t_order <- tile_order(schema)

# Get cell order
c_order <- cell_order(schema)

# Get coordinates and offset filter list
reslist <- filter_list(schema)

# Get the array domain
dom <- domain(schema)

# Get all attributes as list
attrs <- attrs(schema)

# Get attribute from name
attr <- attrs(schema, "attr")

# Dump the array schema in ASCII format to stdout
show(schema)
```


#### Inspecting Domain

```{r inspectdomain}
# ... get array schema
# ... get domain from schema
dom <- domain(schema)

# Get the domain datatype (i.e., the datatype of all dimensions)
type <- datatype(dom)

# Get number of dimensions
dim_num <- dim(dom)

# Get all dimension
dims <- dimensions(dom)

# Dump the domain in ASCII format in the selected output
show(dom)
```

#### Inspecting Dimensions

```{r inspectdimensions, eval=FALSE}
# ... get array schema
# ... get domain
# ... get dimension by index or name

#FIXME

# Get dimension name
dim_name <- name(dim)

# Get dimension datatype
dim_type <- datatype(dim)

# Get dimension domain
domain <- domain(dim)

# Get tile extent
tile_extent <- tile(dim)

# Dump the dimension in ASCII format in the selected output
show(dim)

```


#### Inspecting Attributes

```{r inspectattr, eval=FALSE}
# ... get array schema
# ... get attribute by index or name

stopifnot(is.null(attr))
# Get attribute name
attr_name <- name(attr)

# Get attribute datatype
attr_type <- datatype(attr)

# Get filter list
filter_list <- filter_list(attr)

# Check if attribute is variable-length
# variable length attribtues are not supported in R currently

# Get number of values per cell
num <- ncells(attr)

# Get cell size for this attribute
sz <-- tiledb:::libtiledb_attribute_get_cell_val(attr@ptr)

# Dump the attribute in ASCII format in the selected output
show(attr)
```



#### Inspecting Filters

```{r inspectfilters, eval=FALSE}
fl <- tiledb_filter_list()

# get number of filter
tiledb:::libtiledb_filter_list_get_nfilters(fl@ptr)

# get max chunk size
tiledb:::libtiledb_filter_list_get_max_chunk_size(fl@ptr)

# get filter from index
ind <- i
tiledb:::libtiledb_filter_list_get_filter_from_index(fl@ptr, ind)
```

### Basic Reading

```{r basiscreading}
# Create a TileDB context
ctx <- tiledb_ctx()

# Open a dense array
A <- tiledb_dense(uri = uridense, ctx=ctx)

# Or, open a sparse array
# A <- tiledb_sparse(uri = "<array-uri>", ctx=ctx)

# Slice only rows 1, 2 and cols 2, 3, 4
data <- A[1:2, 2:4]
show(data)
```

#### Basic Reading using Low-Level Code

```{r basiscreadinglowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
## subarray of rows 1,2 and cols 2,3,4
subarr <- c(1L,2L, 2L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Reading Encrypted Arrays

```{r readencrypted}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "READ", encryption_key)

## subarray of rows 1,2 and cols 2,3,4
subarr <- c(1L,2L, 2L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)

## TODO open at timestamp example
```

### Multi-range Subarrays

```{r multirange}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")

## range of rows 1 and 2, and 4 for dim 1, all rows for dim 2
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 1L, 2L)
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 4L, 4L)
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 1, 1L, 4L)

qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(12)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Incomplete Queries

```{r incompletereads}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
subarr <- c(1L,4L, 1L,4L)
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
vec <- integer(4)  # reserve (insufficient) space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
finished <- FALSE
while (!finished) {
  qryptr <- tiledb:::libtiledb_query_submit(qryptr)
  print(vec)
  finished <- tiledb:::libtiledb_query_status(qryptr) == "COMPLETE"
}
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Result Estimation

```{r resultestimation}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "READ")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
estsz <- tiledb:::libtiledb_query_get_est_result_size_var(qryptr, "a1")
res <- tiledb:::libtiledb_array_close(arrptr)
estsz
```

### Time Traveling

```{r timetravel}
ctx <- tiledb_ctx()
tstamp <- Sys.time() - 1.0; # one seconds ago (as the arrays created here are in temp.files)
arrptr <- tiledb:::libtiledb_array_open_at(ctx@ptr, uridense, "READ", tstamp)
subarr <- c(1L,2L, 2L,4L)
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
v
```

## Embedded SQL

## Asynchronous Queries

## Configuration

## Array Metadata

### Writing Array Metadata

```{r writemetadata}
res <- tiledb_put_metadata(uridense, "aaa", 100L)
res <- tiledb_put_metadata(uridense, "bb", c(1.1, 2.2))
```

### Reading Array Metadata

One can read by key:

```{r readmetadata}
tiledb_get_metadata(uridense, "aaa")
```

Or one can retrieve all metadata at once:

```{r readmetadataall}
md <- tiledb_get_all_metadata(uridense)
print(md)
```

### Deleting Array Metadata

```{r deletemetadata}
res <- tiledb_delete_metadata(uridense, "aaa")
```

+
---
title: "TileDB R Notebook"
output:
  html_notebook:
    toc: yes
    highlight: pygments
    theme: lumen
  html_document:
    toc: yes
    df_print: paged
---

<!--This is an [R Markdown](http://rmarkdown.rstudio.com) Notebook. When you execute code within the notebook, the results appear beneath the code.  Try executing this chunk by clicking the *Run* button within the chunk or by placing your cursor inside it and pressing *Ctrl+Shift+Enter*.   Add a new chunk by clicking the *Insert Chunk* button on the toolbar or by pressing *Ctrl+Alt+I*.
When you save the notebook, an HTML file containing the code and output will be saved alongside it (click the *Preview* button or press *Ctrl+Shift+K* to preview the HTML file).  The preview shows you a rendered HTML copy of the contents of the editor. Consequently, unlike *Knit*, *Preview* does not run any R code chunks. Instead, the output of the chunk when it was last run in the editor is displayed.-->

# Prelimaries

We will the two basic examples for a dense and sparse array simply to create
array data on disk to refer to later in examples that follow.

```{r runexamples}
library(tiledb)

tdir <- tempdir()
uridense <- file.path(tdir, "dense")
uridensefix <- file.path(tdir, "densefix")
uridensevar <- file.path(tdir, "densevar")

create_array <- function(array_name) {
    # Check if the array already exists.
    if (tiledb_object_type(array_name) == "ARRAY") {
        message("Array already exists.")
        return(invisible(NULL))
    }

    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))

    # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
    schema <- tiledb_array_schema(dom, attrs = tiledb_attr("a", type = "INT32"))

    # Create the (empty) array on disk.
    tiledb_array_create(array_name, schema)
}

write_array <- function(array_name) {
    data <- array(c(c(1L, 5L, 9L, 13L),
                    c(2L, 6L, 10L, 14L),
                    c(3L, 7L, 11L, 15L),
                    c(4L, 8L, 12L, 16L)), dim = c(4,4))
    # Open the array and write to it.
    A <- tiledb_dense(uri = array_name)
    A[] <- data
}

create_array(uridense)
write_array(uridense)


urisparse <- file.path(tdir, "sparse")

create_array <- function(array_name) {
    # Check if the array already exists.
    if (tiledb_object_type(array_name) == "ARRAY") {
        message("Array already exists.")
        return(invisible(NULL))
    }

    # The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
    dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                                  tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))

    # The array will be dense with a single attribute "a" so each (i,j) cell can store an integer.
    schema = tiledb_array_schema(dom, attrs=tiledb_attr("a", type = "INT32"), sparse = TRUE)

    # Create the (empty) array on disk.
    tiledb_array_create(array_name, schema)
}

write_array <- function(array_name) {
    I <- c(1, 2, 2)
    J <- c(1, 4, 3)
    data <- c(1L, 2L, 3L)
    # Open the array and write to it.
    A <- tiledb_sparse(uri = array_name)
    A[I, J] <- data
}

create_array(urisparse)
write_array(urisparse)

close_and_reopen <- function(arr, txt) {
  res <- tiledb:::libtiledb_array_close(arr@ptr)
  res <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, txt)
}
```



# API Usage

## Creating Arrays

### Create Dimension

```{r createdim}
library(tiledb)

# Create dimension
# In C++: Dimension::create<T>(...)
dim <- tiledb_dim("dim", c(1L, 4L), 2L, "INT32")
```


### Create Array Domain

```{r creatarrdom}
library(tiledb)

#  .. create dimensions `dim1`, `dim2`
dim1 <- tiledb_dim("dim1", c(1L, 4L), 2L, "INT32")
dim2 <- tiledb_dim("dim2", c(1L, 2L), 2L, "INT32")

# Create domain with two dimensions
# In C++: domain.add_dimensions(dim1).add_dimension(dim2)
dom <- tiledb_domain(dims = c(dim1, dim2))
```

### Creating Attributes

```{r createattr}
# Create attribute
# In C++: Attribute::create<T>(ctx, "attr")
attr <- tiledb_attr("attr", "INT32")
```

```{r createattrvarnum}
# We can also set the number of attributes to a value other than one
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 3)

# And we can set the a variable number of attributes (using NA to select variable size)
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)
## TODO: R function for level setter
```

#### Setting a Compressor

```{r setcompr}
comp <- tiledb_filter("GZIP")
tiledb_filter_set_option(comp,"COMPRESSION_LEVEL", 10)

# Create a filter list with the compressor
filter_list <- tiledb_filter_list(comp)

# Create attribute with the filter list
attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
```


#### Setting Other Filters

```{r setfilr}
# Create filters
f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
f2 <- tiledb_filter("ZSTD")

# Create a filter list with the two filters
filter_list <- tiledb_filter_list(c(f1,f2))

# Create attribute with the filter list
attr <- tiledb_attr("attr", "INT32", filter_list = filter_list)
```


#### Setting the Tile Chunk Size

```{r settilechunksize}
# ... create filter list
set_max_chunk_size(filter_list, 10000)
```


### Creating the Array Schema

```{r createarrschema}
# ... create domain dom
attr1 <- tiledb_attr("attr1", "INT32", filter_list = filter_list)
attr2 <- tiledb_attr("attr2", "FLOAT64", filter_list = filter_list)

# Create a dense array
schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = FALSE)
# Or, create a spaese array
# schema <- tiledb_array_schema(dom, c(attr1, attr2), sparse = TRUE)
```

#### Setting the Tile and Cell Order

```{r settilecellorder}
# ... create domain dom
# ... create attributes attr1, attr2

# The tile and order can be "ROW_MAJOR" or "COL_MAJOR"
schema <- tiledb_array_schema(dom, c(attr1, attr2),
                              cell_order = "COL_MAJOR",
                              tile_order = "ROW_MAJOR")
```

#### Setting the Data Tile Capacity

```{r settilecapacity}
tiledb:::libtiledb_array_schema_set_capacity(schema@ptr, 100000)
tiledb:::libtiledb_array_schema_get_capacity(schema@ptr)
## TODO R function for accessor
```

#### Setting Coordinate and Offset Filters

```{r setcoordoffsetfilt}
# ... create domain dom
# ... create attributes attr1, attr2
# ... create filter lists fl1, fl2, similar to attributes
f1 <- tiledb_filter("BIT_WIDTH_REDUCTION")
f2 <- tiledb_filter("ZSTD")
fl1 <- tiledb_filter_list(c(f1))
fl2 <- tiledb_filter_list(c(f2))

# Create the schema setting the coordinates and offsets filter lists
schema <- tiledb_array_schema(dom, c(attr1, attr2),
                              coords_filter_list = fl1,
                              offsets_filter_list = fl2)
```


#### Checking Correctness

```{r arrayschemacheck}
tiledb:::libtiledb_array_schema_check(schema@ptr)
## TODO: R function for access
```



### Creating the Array

```{r createarray, eval=FALSE}
# ... create array schema

# Create the array
tiledb_array_create(uridense, schema)
```

### Creating Encrypted Arrays

```{r createwithkey}
encryption_key <- "0123456789abcdeF0123456789abcdeF"
uridensewkey <- file.path(tdir, "densewkey")
if (dir.exists(uridensewkey)) unlink(uridensewkey, recursive=TRUE)

# shortcut: borrow schema from dense array; could create schema too
schema <- schema(tiledb_dense(uridense))
tiledb:::libtiledb_array_create_with_key(uridensewkey, schema@ptr, encryption_key)
##TODO: R support
```


## Writing Arrays

### Writing in Dense Subarrays

```{r writedensesubarr, eval=FALSE}
## prepare a larger 5 x 5 to embed into
tmp <- tempfile()
d1  <- tiledb_dim(domain = c(1L, 5L))
d2  <- tiledb_dim(domain = c(1L, 5L))
dom <- tiledb_domain(c(d1, d2))
val <- tiledb_attr(name="val", type = "INT32")
sch <- tiledb_array_schema(dom, c(val))
tiledb_array_create(tmp, sch)

dat <- matrix(as.integer(rnorm(25)*100), 5, 5)
arr <- tiledb_dense(tmp, as.data.frame=FALSE)
arr[] <- dat


# Prepare a 2x3 dense array
# Contrary to Python, R by default stores arrays in col-major order
data <-  array(c(1L, 4L, 2L, 5L, 3L, 6L), dim=c(2,3))

# Prepare the [1,2] x [2,4] subarray to write to
I <- c(1:2)
J <- c(2:4)

# Open the array and write the data to it
A <- tiledb_dense(uri = tmp)
A[I, J] <- data

unlink(tmp, recursive=TRUE)
```


#### Basic Writing using Low-Level Code

```{r basiscwritinglowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "WRITE")

## data: simple (integer sequence) of 1:16 times 10
vec <- 1:16 * 10L
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
```


### Writing Sparse Cells

```{r writesparsecells}
tmp <- urisparse
unlink(tmp, recursive=TRUE)

d1  <- tiledb_dim(domain = c(1L, 5L))
d2  <- tiledb_dim(domain = c(1L, 5L))
dom <- tiledb_domain(c(d1, d2))
val <- tiledb_attr("val", type = "INT32")
sch <- tiledb_array_schema(dom, val, sparse=TRUE)
tiledb_array_create(tmp, sch)


# Prepare some data
data <- c(3L, 4L, 1L, 2L)

I <- c(3, 4, 1, 2)
J <- c(3, 4, 2, 1)

# Open the array and write the data to it
A <- tiledb_sparse(uri = tmp)
A[I, J] <- data

```


### Writing Encrypted Arrays

```{r writingencryptedlowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "WRITE", encryption_key)

## data: simple (integer sequence) of 1:16 times 10
vec <- 1:16 * 10L
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
# TODO Higher-level R support

```




### Fixed-length Attributes

```{r fixedlengthattributes}
if (dir.exists(uridensefix)) unlink(uridensefix, recursive=TRUE)
d1  <- tiledb_dim(domain = c(1L, 4L))
d2  <- tiledb_dim(domain = c(1L, 4L))
dom <- tiledb_domain(c(d1, d2))

vec <- 1:32 * 10L
attr <- tiledb_attr("a", type = r_to_tiledb_type(vec))

## set to two values per cell
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, 2)
sch <- tiledb_array_schema(dom, attr)
tiledb_array_create(uridensefix, sch)

ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensefix, "WRITE")
subarr <- c(1L,4L, 1L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)

#TODO Higher-level R support
```

### Var-length Attributes

```{r}
if (dir.exists(uridensevar)) unlink(uridensevar, recursive=TRUE)
## Define array
## The array will be 4x4 with dimensions "rows" and "cols", with domain [1,4].
dom <- tiledb_domain(dims = c(tiledb_dim("rows", c(1L, 4L), 4L, "INT32"),
                              tiledb_dim("cols", c(1L, 4L), 4L, "INT32")))


attr <- tiledb_attr("a1", type = "CHAR")
## set to variable length
tiledb:::libtiledb_attribute_set_cell_val_num(attr@ptr, NA)

## now set the schema
ctx <- tiledb_ctx()
schptr <- tiledb:::libtiledb_array_schema_create(ctx@ptr, "DENSE")
tiledb:::libtiledb_array_schema_set_domain(schptr, dom@ptr)
tiledb:::libtiledb_array_schema_set_cell_order(schptr, "ROW_MAJOR")
tiledb:::libtiledb_array_schema_set_tile_order(schptr, "ROW_MAJOR")
tiledb:::libtiledb_array_schema_add_attribute(schptr, attr@ptr)



## Create the (empty) array on disk.
tiledb:::libtiledb_array_create(uridensevar, schptr)

data <- "abbcccddeeefghhhijjjkklmnoop";
offsets <- c(0L, 1L, 3L, 6L, 8L, 11L, 12L, 13L, 16L, 17L, 20L, 22L, 23L, 24L, 25L, 27L)

ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "WRITE")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "WRITE")
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")

bufptr <- tiledb:::libtiledb_query_buffer_var_char_create(offsets, data)
qryptr <- tiledb:::libtiledb_query_set_buffer_var_char(qryptr, "a1", bufptr)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
tiledb:::libtiledb_array_close(arrptr)

#TODO Higher-level R support
```


### Getting the Fragment Info

```{r fragmentinfo}
## continuing from previous example on dense variable length array
## (but this works of course with any array after a write is needed
numfrag <- tiledb:::libtiledb_query_get_fragment_num(qryptr)
uritxt <- tiledb:::libtiledb_query_get_fragment_uri(qryptr, 0)

##TODO Higher-level R support
```

## Reading Arrays

### Reading the Array Schema

```{r schemaload}
array_name <- urisparse
A <- tiledb_sparse(uri = array_name)
# can also load dense
sch <- schema(A)
# can also open encrypted arrays with key
```

#### Inspecting the array schema

```{r schemainspect}
array_name <- urisparse

# Get array schema
A <- tiledb_sparse(uri = array_name)
# or use tiledb_dense(uri = array_name) for dense
schema <- schema(A)

# Get array type
sparse <- is.sparse(schema)

# Get tile capacity
tiledb:::libtiledb_array_schema_get_capacity(sch@ptr)
# TODO: R accessor for tile

# Get tile order
t_order <- tile_order(schema)

# Get cell order
c_order <- cell_order(schema)

# Get coordinates and offset filter list
reslist <- filter_list(schema)

# Get the array domain
dom <- domain(schema)

# Get all attributes as list
attrs <- attrs(schema)

# Get attribute from name
attr <- attrs(schema, "attr")

# Dump the array schema in ASCII format to stdout
show(schema)
```


#### Inspecting Domain

```{r inspectdomain}
# ... get array schema
# ... get domain from schema
dom <- domain(schema)

# Get the domain datatype (i.e., the datatype of all dimensions)
type <- datatype(dom)

# Get number of dimensions
dim_num <- dim(dom)

# Get all dimension
dims <- dimensions(dom)

# Dump the domain in ASCII format in the selected output
show(dom)
```

#### Inspecting Dimensions

```{r inspectdimensions, eval=FALSE}
# ... get array schema
# ... get domain
# ... get dimension by index or name

#FIXME

# Get dimension name
dim_name <- name(dim)

# Get dimension datatype
dim_type <- datatype(dim)

# Get dimension domain
domain <- domain(dim)

# Get tile extent
tile_extent <- tile(dim)

# Dump the dimension in ASCII format in the selected output
show(dim)

```


#### Inspecting Attributes

```{r inspectattr, eval=FALSE}
# ... get array schema
# ... get attribute by index or name

stopifnot(is.null(attr))
# Get attribute name
attr_name <- name(attr)

# Get attribute datatype
attr_type <- datatype(attr)

# Get filter list
filter_list <- filter_list(attr)

# Check if attribute is variable-length
# variable length attribtues are not supported in R currently

# Get number of values per cell
num <- ncells(attr)

# Get cell size for this attribute
sz <-- tiledb:::libtiledb_attribute_get_cell_val(attr@ptr)

# Dump the attribute in ASCII format in the selected output
show(attr)
```



#### Inspecting Filters

```{r inspectfilters, eval=FALSE}
fl <- tiledb_filter_list()

# get number of filter
tiledb:::libtiledb_filter_list_get_nfilters(fl@ptr)

# get max chunk size
tiledb:::libtiledb_filter_list_get_max_chunk_size(fl@ptr)

# get filter from index
ind <- i
tiledb:::libtiledb_filter_list_get_filter_from_index(fl@ptr, ind)
```

### Basic Reading

```{r basiscreading}
# Create a TileDB context
ctx <- tiledb_ctx()

# Open a dense array
A <- tiledb_dense(uri = uridense, ctx=ctx)

# Or, open a sparse array
# A <- tiledb_sparse(uri = "<array-uri>", ctx=ctx)

# Slice only rows 1, 2 and cols 2, 3, 4
data <- A[1:2, 2:4]
show(data)
```

#### Basic Reading using Low-Level Code

```{r basiscreadinglowlevel}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
## subarray of rows 1,2 and cols 2,3,4
subarr <- c(1L,2L, 2L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Reading Encrypted Arrays

```{r readencrypted}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open_with_key(ctx@ptr, uridensewkey, "READ", encryption_key)

## subarray of rows 1,2 and cols 2,3,4
subarr <- c(1L,2L, 2L,4L)

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)

## TODO open at timestamp example
```

### Multi-range Subarrays

```{r multirange}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")

qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")

## range of rows 1 and 2, and 4 for dim 1, all rows for dim 2
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 1L, 2L)
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 0, 4L, 4L)
qryptr <- tiledb:::libtiledb_query_add_range(qryptr, 1, 1L, 4L)

qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(12)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
print(v)         # unformed array, no coordinates
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Incomplete Queries

```{r incompletereads}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridense, "READ")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
subarr <- c(1L,4L, 1L,4L)
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
vec <- integer(4)  # reserve (insufficient) space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", vec)
finished <- FALSE
while (!finished) {
  qryptr <- tiledb:::libtiledb_query_submit(qryptr)
  print(vec)
  finished <- tiledb:::libtiledb_query_status(qryptr) == "COMPLETE"
}
res <- tiledb:::libtiledb_array_close(arrptr)
```

### Result Estimation

```{r resultestimation}
ctx <- tiledb_ctx()
arrptr <- tiledb:::libtiledb_array_open(ctx@ptr, uridensevar, "READ")
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
estsz <- tiledb:::libtiledb_query_get_est_result_size_var(qryptr, "a1")
res <- tiledb:::libtiledb_array_close(arrptr)
estsz
```

### Time Traveling

```{r timetravel}
ctx <- tiledb_ctx()
tstamp <- Sys.time() - 1.0; # one seconds ago (as the arrays created here are in temp.files)
arrptr <- tiledb:::libtiledb_array_open_at(ctx@ptr, uridense, "READ", tstamp)
subarr <- c(1L,2L, 2L,4L)
qryptr <- tiledb:::libtiledb_query(ctx@ptr, arrptr, "READ")
qryptr <- tiledb:::libtiledb_query_set_subarray(qryptr, subarr)
qryptr <- tiledb:::libtiledb_query_set_layout(qryptr, "ROW_MAJOR")
v <- integer(6)  # reserve space
qryptr <- tiledb:::libtiledb_query_set_buffer(qryptr, "a", v)
qryptr <- tiledb:::libtiledb_query_submit(qryptr)
res <- tiledb:::libtiledb_array_close(arrptr)
v
```

## Embedded SQL

## Asynchronous Queries

## Configuration

## Array Metadata

### Writing Array Metadata

```{r writemetadata}
arr <- tiledb_dense(uridense)
close_and_reopen(arr, "WRITE")
res <- tiledb_put_metadata(arr, "aaa", 100L)
res <- tiledb_put_metadata(arr, "bb", c(1.1, 2.2))
invisible(tiledb:::libtiledb_array_close(arr@ptr))
```

### Reading Array Metadata

One can read by key:

```{r readmetadata}
close_and_reopen(arr, "READ")
tiledb_get_metadata(arr, "aaa")
```

Or one can retrieve all metadata at once:

```{r readmetadataall}
md <- tiledb_get_all_metadata(arr)
print(md)
```

### Deleting Array Metadata

```{r deletemetadata}
close_and_reopen(arr, "WRITE")
res <- tiledb_delete_metadata(arr, "aaa")

```

diff --git a/man/tiledb_delete_metadata.Rd b/man/tiledb_delete_metadata.Rd index 77d630b4c3..2e6f66aab7 100644 --- a/man/tiledb_delete_metadata.Rd +++ b/man/tiledb_delete_metadata.Rd @@ -7,7 +7,7 @@ tiledb_delete_metadata(arr, key) } \arguments{ -\item{arr}{A TileDB Array object, or a character URI describing one} +\item{arr}{A TileDB Array object} \item{key}{A character value describing a metadata key} } diff --git a/man/tiledb_get_metadata.Rd b/man/tiledb_get_metadata.Rd index 7ecdb85388..a7358e0c8e 100644 --- a/man/tiledb_get_metadata.Rd +++ b/man/tiledb_get_metadata.Rd @@ -12,7 +12,8 @@ tiledb_get_metadata(arr, key) \item{key}{A character value describing a metadata key} } \value{ -A object stored in the Metadata under the given key +A object stored in the Metadata under the given key, +or \sQuote{NULL} if none found. } \description{ Return a TileDB Array Metadata object given by key diff --git a/man/tiledb_has_metadata.Rd b/man/tiledb_has_metadata.Rd index 5891ec9656..6c9569389b 100644 --- a/man/tiledb_has_metadata.Rd +++ b/man/tiledb_has_metadata.Rd @@ -7,7 +7,7 @@ tiledb_has_metadata(arr, key) } \arguments{ -\item{arr}{A TileDB Array object, or a character URI describing one} +\item{arr}{A TileDB Array object} \item{key}{A character value describing a metadata key} } diff --git a/src/RcppExports.cpp b/src/RcppExports.cpp index 2e1c07b74e..c7cdd46ad8 100644 --- a/src/RcppExports.cpp +++ b/src/RcppExports.cpp @@ -6,172 +6,6 @@ using namespace Rcpp; -// has_metadata_simple -bool has_metadata_simple(const std::string array_name, const std::string key); -RcppExport SEXP _tiledb_has_metadata_simple(SEXP array_nameSEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(has_metadata_simple(array_name, key)); - return rcpp_result_gen; -END_RCPP -} -// has_metadata_ptr -bool has_metadata_ptr(Rcpp::XPtr array, const std::string key); -RcppExport SEXP _tiledb_has_metadata_ptr(SEXP arraySEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(has_metadata_ptr(array, key)); - return rcpp_result_gen; -END_RCPP -} -// num_metadata_simple -int num_metadata_simple(const std::string array_name); -RcppExport SEXP _tiledb_num_metadata_simple(SEXP array_nameSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - rcpp_result_gen = Rcpp::wrap(num_metadata_simple(array_name)); - return rcpp_result_gen; -END_RCPP -} -// num_metadata_ptr -int num_metadata_ptr(Rcpp::XPtr array); -RcppExport SEXP _tiledb_num_metadata_ptr(SEXP arraySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - rcpp_result_gen = Rcpp::wrap(num_metadata_ptr(array)); - return rcpp_result_gen; -END_RCPP -} -// get_metadata_simple -SEXP get_metadata_simple(const std::string array_name, const std::string key); -RcppExport SEXP _tiledb_get_metadata_simple(SEXP array_nameSEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(get_metadata_simple(array_name, key)); - return rcpp_result_gen; -END_RCPP -} -// get_metadata_ptr -SEXP get_metadata_ptr(Rcpp::XPtr array, const std::string key); -RcppExport SEXP _tiledb_get_metadata_ptr(SEXP arraySEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(get_metadata_ptr(array, key)); - return rcpp_result_gen; -END_RCPP -} -// put_metadata_simple -bool put_metadata_simple(const std::string array_name, const std::string key, const SEXP obj); -RcppExport SEXP _tiledb_put_metadata_simple(SEXP array_nameSEXP, SEXP keySEXP, SEXP objSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - Rcpp::traits::input_parameter< const SEXP >::type obj(objSEXP); - rcpp_result_gen = Rcpp::wrap(put_metadata_simple(array_name, key, obj)); - return rcpp_result_gen; -END_RCPP -} -// put_metadata_ptr -bool put_metadata_ptr(Rcpp::XPtr array, const std::string key, const SEXP obj); -RcppExport SEXP _tiledb_put_metadata_ptr(SEXP arraySEXP, SEXP keySEXP, SEXP objSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - Rcpp::traits::input_parameter< const SEXP >::type obj(objSEXP); - rcpp_result_gen = Rcpp::wrap(put_metadata_ptr(array, key, obj)); - return rcpp_result_gen; -END_RCPP -} -// get_metadata_from_index_ptr -SEXP get_metadata_from_index_ptr(Rcpp::XPtr array, const int idx); -RcppExport SEXP _tiledb_get_metadata_from_index_ptr(SEXP arraySEXP, SEXP idxSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - Rcpp::traits::input_parameter< const int >::type idx(idxSEXP); - rcpp_result_gen = Rcpp::wrap(get_metadata_from_index_ptr(array, idx)); - return rcpp_result_gen; -END_RCPP -} -// get_metadata_from_index_simple -SEXP get_metadata_from_index_simple(const std::string array_name, const int idx); -RcppExport SEXP _tiledb_get_metadata_from_index_simple(SEXP array_nameSEXP, SEXP idxSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - Rcpp::traits::input_parameter< const int >::type idx(idxSEXP); - rcpp_result_gen = Rcpp::wrap(get_metadata_from_index_simple(array_name, idx)); - return rcpp_result_gen; -END_RCPP -} -// get_all_metadata_simple -SEXP get_all_metadata_simple(const std::string array_name); -RcppExport SEXP _tiledb_get_all_metadata_simple(SEXP array_nameSEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - rcpp_result_gen = Rcpp::wrap(get_all_metadata_simple(array_name)); - return rcpp_result_gen; -END_RCPP -} -// get_all_metadata_ptr -SEXP get_all_metadata_ptr(Rcpp::XPtr array); -RcppExport SEXP _tiledb_get_all_metadata_ptr(SEXP arraySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - rcpp_result_gen = Rcpp::wrap(get_all_metadata_ptr(array)); - return rcpp_result_gen; -END_RCPP -} -// delete_metadata_simple -bool delete_metadata_simple(const std::string array_name, const std::string key); -RcppExport SEXP _tiledb_delete_metadata_simple(SEXP array_nameSEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< const std::string >::type array_name(array_nameSEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(delete_metadata_simple(array_name, key)); - return rcpp_result_gen; -END_RCPP -} -// delete_metadata_ptr -bool delete_metadata_ptr(Rcpp::XPtr array, const std::string key); -RcppExport SEXP _tiledb_delete_metadata_ptr(SEXP arraySEXP, SEXP keySEXP) { -BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; - Rcpp::RNGScope rcpp_rngScope_gen; - Rcpp::traits::input_parameter< Rcpp::XPtr >::type array(arraySEXP); - Rcpp::traits::input_parameter< const std::string >::type key(keySEXP); - rcpp_result_gen = Rcpp::wrap(delete_metadata_ptr(array, key)); - return rcpp_result_gen; -END_RCPP -} // tiledb_datatype_R_type std::string tiledb_datatype_R_type(std::string datatype); RcppExport SEXP _tiledb_tiledb_datatype_R_type(SEXP datatypeSEXP) { @@ -1132,17 +966,75 @@ BEGIN_RCPP END_RCPP } // libtiledb_array_consolidate -std::string libtiledb_array_consolidate(XPtr ctx, std::string uri); -RcppExport SEXP _tiledb_libtiledb_array_consolidate(SEXP ctxSEXP, SEXP uriSEXP) { +void libtiledb_array_consolidate(XPtr ctx, std::string uri, Nullable> cfgptr); +RcppExport SEXP _tiledb_libtiledb_array_consolidate(SEXP ctxSEXP, SEXP uriSEXP, SEXP cfgptrSEXP) { BEGIN_RCPP - Rcpp::RObject rcpp_result_gen; Rcpp::RNGScope rcpp_rngScope_gen; Rcpp::traits::input_parameter< XPtr >::type ctx(ctxSEXP); Rcpp::traits::input_parameter< std::string >::type uri(uriSEXP); - rcpp_result_gen = Rcpp::wrap(libtiledb_array_consolidate(ctx, uri)); + Rcpp::traits::input_parameter< Nullable> >::type cfgptr(cfgptrSEXP); + libtiledb_array_consolidate(ctx, uri, cfgptr); + return R_NilValue; +END_RCPP +} +// libtiledb_array_put_metadata +bool libtiledb_array_put_metadata(XPtr array, std::string key, SEXP obj); +RcppExport SEXP _tiledb_libtiledb_array_put_metadata(SEXP arraySEXP, SEXP keySEXP, SEXP objSEXP) { +BEGIN_RCPP + Rcpp::RObject rcpp_result_gen; + Rcpp::RNGScope rcpp_rngScope_gen; + Rcpp::traits::input_parameter< XPtr >::type array(arraySEXP); + Rcpp::traits::input_parameter< std::string >::type key(keySEXP); + Rcpp::traits::input_parameter< SEXP >::type obj(objSEXP); + rcpp_result_gen = Rcpp::wrap(libtiledb_array_put_metadata(array, key, obj)); + return rcpp_result_gen; +END_RCPP +} +// libtiledb_array_get_metadata_num +R_xlen_t libtiledb_array_get_metadata_num(XPtr array); +RcppExport SEXP _tiledb_libtiledb_array_get_metadata_num(SEXP arraySEXP) { +BEGIN_RCPP + Rcpp::RObject rcpp_result_gen; + Rcpp::RNGScope rcpp_rngScope_gen; + Rcpp::traits::input_parameter< XPtr >::type array(arraySEXP); + rcpp_result_gen = Rcpp::wrap(libtiledb_array_get_metadata_num(array)); + return rcpp_result_gen; +END_RCPP +} +// libtiledb_array_get_metadata_from_index +SEXP libtiledb_array_get_metadata_from_index(XPtr array, int idx); +RcppExport SEXP _tiledb_libtiledb_array_get_metadata_from_index(SEXP arraySEXP, SEXP idxSEXP) { +BEGIN_RCPP + Rcpp::RObject rcpp_result_gen; + Rcpp::RNGScope rcpp_rngScope_gen; + Rcpp::traits::input_parameter< XPtr >::type array(arraySEXP); + Rcpp::traits::input_parameter< int >::type idx(idxSEXP); + rcpp_result_gen = Rcpp::wrap(libtiledb_array_get_metadata_from_index(array, idx)); + return rcpp_result_gen; +END_RCPP +} +// libtiledb_array_get_metadata_list +SEXP libtiledb_array_get_metadata_list(XPtr array); +RcppExport SEXP _tiledb_libtiledb_array_get_metadata_list(SEXP arraySEXP) { +BEGIN_RCPP + Rcpp::RObject rcpp_result_gen; + Rcpp::RNGScope rcpp_rngScope_gen; + Rcpp::traits::input_parameter< XPtr >::type array(arraySEXP); + rcpp_result_gen = Rcpp::wrap(libtiledb_array_get_metadata_list(array)); return rcpp_result_gen; END_RCPP } +// libtiledb_array_delete_metadata +void libtiledb_array_delete_metadata(XPtr array, std::string key); +RcppExport SEXP _tiledb_libtiledb_array_delete_metadata(SEXP arraySEXP, SEXP keySEXP) { +BEGIN_RCPP + Rcpp::RNGScope rcpp_rngScope_gen; + Rcpp::traits::input_parameter< XPtr >::type array(arraySEXP); + Rcpp::traits::input_parameter< std::string >::type key(keySEXP); + libtiledb_array_delete_metadata(array, key); + return R_NilValue; +END_RCPP +} // libtiledb_query XPtr libtiledb_query(XPtr ctx, XPtr array, std::string type); RcppExport SEXP _tiledb_libtiledb_query(SEXP ctxSEXP, SEXP arraySEXP, SEXP typeSEXP) { @@ -1771,20 +1663,6 @@ END_RCPP } static const R_CallMethodDef CallEntries[] = { - {"_tiledb_has_metadata_simple", (DL_FUNC) &_tiledb_has_metadata_simple, 2}, - {"_tiledb_has_metadata_ptr", (DL_FUNC) &_tiledb_has_metadata_ptr, 2}, - {"_tiledb_num_metadata_simple", (DL_FUNC) &_tiledb_num_metadata_simple, 1}, - {"_tiledb_num_metadata_ptr", (DL_FUNC) &_tiledb_num_metadata_ptr, 1}, - {"_tiledb_get_metadata_simple", (DL_FUNC) &_tiledb_get_metadata_simple, 2}, - {"_tiledb_get_metadata_ptr", (DL_FUNC) &_tiledb_get_metadata_ptr, 2}, - {"_tiledb_put_metadata_simple", (DL_FUNC) &_tiledb_put_metadata_simple, 3}, - {"_tiledb_put_metadata_ptr", (DL_FUNC) &_tiledb_put_metadata_ptr, 3}, - {"_tiledb_get_metadata_from_index_ptr", (DL_FUNC) &_tiledb_get_metadata_from_index_ptr, 2}, - {"_tiledb_get_metadata_from_index_simple", (DL_FUNC) &_tiledb_get_metadata_from_index_simple, 2}, - {"_tiledb_get_all_metadata_simple", (DL_FUNC) &_tiledb_get_all_metadata_simple, 1}, - {"_tiledb_get_all_metadata_ptr", (DL_FUNC) &_tiledb_get_all_metadata_ptr, 1}, - {"_tiledb_delete_metadata_simple", (DL_FUNC) &_tiledb_delete_metadata_simple, 2}, - {"_tiledb_delete_metadata_ptr", (DL_FUNC) &_tiledb_delete_metadata_ptr, 2}, {"_tiledb_tiledb_datatype_R_type", (DL_FUNC) &_tiledb_tiledb_datatype_R_type, 1}, {"_tiledb_libtiledb_version", (DL_FUNC) &_tiledb_libtiledb_version, 0}, {"_tiledb_libtiledb_ctx", (DL_FUNC) &_tiledb_libtiledb_ctx, 1}, @@ -1868,7 +1746,12 @@ static const R_CallMethodDef CallEntries[] = { {"_tiledb_libtiledb_array_close", (DL_FUNC) &_tiledb_libtiledb_array_close, 1}, {"_tiledb_libtiledb_array_query_type", (DL_FUNC) &_tiledb_libtiledb_array_query_type, 1}, {"_tiledb_libtiledb_array_nonempty_domain", (DL_FUNC) &_tiledb_libtiledb_array_nonempty_domain, 1}, - {"_tiledb_libtiledb_array_consolidate", (DL_FUNC) &_tiledb_libtiledb_array_consolidate, 2}, + {"_tiledb_libtiledb_array_consolidate", (DL_FUNC) &_tiledb_libtiledb_array_consolidate, 3}, + {"_tiledb_libtiledb_array_put_metadata", (DL_FUNC) &_tiledb_libtiledb_array_put_metadata, 3}, + {"_tiledb_libtiledb_array_get_metadata_num", (DL_FUNC) &_tiledb_libtiledb_array_get_metadata_num, 1}, + {"_tiledb_libtiledb_array_get_metadata_from_index", (DL_FUNC) &_tiledb_libtiledb_array_get_metadata_from_index, 2}, + {"_tiledb_libtiledb_array_get_metadata_list", (DL_FUNC) &_tiledb_libtiledb_array_get_metadata_list, 1}, + {"_tiledb_libtiledb_array_delete_metadata", (DL_FUNC) &_tiledb_libtiledb_array_delete_metadata, 2}, {"_tiledb_libtiledb_query", (DL_FUNC) &_tiledb_libtiledb_query, 3}, {"_tiledb_libtiledb_query_type", (DL_FUNC) &_tiledb_libtiledb_query_type, 1}, {"_tiledb_libtiledb_query_set_layout", (DL_FUNC) &_tiledb_libtiledb_query_set_layout, 2}, diff --git a/src/array_metadata.cpp b/src/array_metadata.cpp deleted file mode 100644 index 52ea5ab450..0000000000 --- a/src/array_metadata.cpp +++ /dev/null @@ -1,284 +0,0 @@ - -// questions: -// - simple accessor functions or s4 instances or XPtr? -// -> s4 instance could cache more easily -// -> XPtr easiest -// - base layer here and refined interface in R function? -// -> add s4 instance on R side -// -> XPtr easier -// - other functionality: -// consolidate_metadata ? -// [DONE] delete_metadata - -#include - -#define STRICT_R_HEADERS -#include - -using namespace tiledb; - -// forward declaration -const char* _tiledb_datatype_to_string(tiledb_datatype_t dtype); - -// ---- has_metadata -bool has_metadata_impl(tiledb::Array& array, const std::string key) { - tiledb_datatype_t v_type; - return array.has_metadata(key.c_str(), &v_type); -} - -// [[Rcpp::export]] -bool has_metadata_simple(const std::string array_name, const std::string key) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_READ); // Open array for reading - return has_metadata_impl(array, key); -} - -// [[Rcpp::export]] -bool has_metadata_ptr(Rcpp::XPtr array, const std::string key) { - return has_metadata_impl(*array, key); -} - - -// ---- metadata_num -int num_metadata_impl(tiledb::Array& array) { - uint64_t nm = array.metadata_num(); - return static_cast(nm); -} - -// [[Rcpp::export]] -int num_metadata_simple(const std::string array_name) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_READ); // Open array for reading - return num_metadata_impl(array); -} - -// [[Rcpp::export]] -int num_metadata_ptr(Rcpp::XPtr array) { - return num_metadata_impl(*array); -} - -template -Rcpp::IntegerVector copy_int_vector(const uint32_t v_num, const void* v) { - // Strictly speaking a check for under/overflow would be needed here yet this for - // metadata annotation (and not data payload) so extreme ranges are less likely - Rcpp::IntegerVector vec(v_num); - const T *ivec = static_cast(v); - size_t n = static_cast(v_num); - for (size_t i=0; i(ivec[i]); - return(vec); -} - -// ---- get_metadata -SEXP convert_vector_to_sexp(const tiledb_datatype_t v_type, const uint32_t v_num, const void* v) { - // This supports a limited set of basic types as the metadata - // annotation is not meant to support complete serialization - if (v_type == TILEDB_INT32) { - Rcpp::IntegerVector vec(v_num); - std::memcpy(vec.begin(), v, v_num*sizeof(int32_t)); - return(vec); - } else if (v_type == TILEDB_FLOAT64) { - Rcpp::NumericVector vec(v_num); - std::memcpy(vec.begin(), v, v_num*sizeof(double)); - return(vec); - } else if (v_type == TILEDB_FLOAT32) { - Rcpp::NumericVector vec(v_num); - const float *fvec = static_cast(v); - size_t n = static_cast(v_num); - for (size_t i=0; i(fvec[i]); - return(vec); - } else if (v_type == TILEDB_CHAR || v_type == TILEDB_STRING_ASCII) { - Rcpp::CharacterVector vec(1); - std::string s(static_cast(v)); - s.resize(v_num); // incoming char* not null terminated, ensures v_num bytes and terminate - return(Rcpp::wrap(s)); - } else if (v_type == TILEDB_INT8) { - Rcpp::LogicalVector vec(v_num); - const int8_t *ivec = static_cast(v); - size_t n = static_cast(v_num); - for (size_t i=0; i(ivec[i]); - return(vec); - } else if (v_type == TILEDB_UINT8) { - // Strictly speaking a check for under/overflow would be needed here (and below) yet this - // is for metadata annotation (and not data payload) so extreme ranges are less likely - return copy_int_vector(v_num, v); - } else if (v_type == TILEDB_INT16) { - return copy_int_vector(v_num, v); - } else if (v_type == TILEDB_UINT16) { - return copy_int_vector(v_num, v); - } else if (v_type == TILEDB_UINT32) { - return copy_int_vector(v_num, v); - } else if (v_type == TILEDB_INT64) { - return copy_int_vector(v_num, v); - } else if (v_type == TILEDB_UINT64) { - return copy_int_vector(v_num, v); - } else { - Rcpp::stop("No support yet for %s", _tiledb_datatype_to_string(v_type)); - } -} - -SEXP get_metadata_impl(tiledb::Array& array, const std::string key) { - // Read with key - tiledb_datatype_t v_type; - uint32_t v_num; - const void* v; - array.get_metadata(key.c_str(), &v_type, &v_num, &v); - if (v == NULL) { - return R_NilValue; - } - - return convert_vector_to_sexp(v_type, v_num, v); -} - -// [[Rcpp::export]] -SEXP get_metadata_simple(const std::string array_name, const std::string key) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_READ); // Open array for reading - return get_metadata_impl(array, key); -} - -// [[Rcpp::export]] -SEXP get_metadata_ptr(Rcpp::XPtr array, const std::string key) { - return get_metadata_impl(*array, key); -} - - -// ---- put_metadata -bool put_metadata_impl(tiledb::Array array, const std::string key, const SEXP obj) { - // May want to add a mapper from SEXP type to tiledb type in libtiledb.cpp - switch(TYPEOF(obj)) { - case VECSXP: { - Rcpp::stop("List objects are not supported."); - array.close(); - return false; - break;// not reached - } - case REALSXP: { - Rcpp::NumericVector v(obj); - array.put_metadata(key.c_str(), TILEDB_FLOAT64, v.size(), v.begin()); - break; - } - case INTSXP: { - Rcpp::IntegerVector v(obj); - array.put_metadata(key.c_str(), TILEDB_INT32, v.size(), v.begin()); - break; - } - case STRSXP: { - Rcpp::CharacterVector v(obj); - std::string s(v[0]); - // We use TILEDB_CHAR interchangeably with TILEDB_STRING_ASCII is this best string type? - array.put_metadata(key.c_str(), TILEDB_CHAR, s.length(), s.c_str()); - break; - } - case LGLSXP: { // experimental: map R logical (ie TRUE, FALSE, NA) to int8 - Rcpp::LogicalVector v(obj); - size_t n = static_cast(v.size()); - std::vector ints(n); - for (size_t i=0; i(v[i]); - array.put_metadata(key.c_str(), TILEDB_INT8, ints.size(), ints.data()); - break; - } - default: { - Rcpp::stop("No support (yet) for type '%d'.", TYPEOF(obj)); - array.close(); - return false; - break; // not reached - } - } - // Close array - Important so that the metadata get flushed - array.close(); - return true; -} - -// [[Rcpp::export]] -bool put_metadata_simple(const std::string array_name, const std::string key, const SEXP obj) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_WRITE); // Open array for writing - return put_metadata_impl(array, key, obj); -} - -// [[Rcpp::export]] -bool put_metadata_ptr(Rcpp::XPtr array, const std::string key, const SEXP obj) { - return put_metadata_impl(*array, key, obj); -} - - -// ---- get by index -SEXP get_metadata_from_index_impl(tiledb::Array& array, const int idx) { - std::string key; - tiledb_datatype_t v_type; - uint32_t v_num; - const void* v; - array.get_metadata_from_index(static_cast(idx), &key, &v_type, &v_num, &v); - if (v == NULL) { - return R_NilValue; - } - - RObject vec = convert_vector_to_sexp(v_type, v_num, v); - vec.attr("names") = Rcpp::CharacterVector::create(key); - return vec; -} - -// [[Rcpp::export]] -SEXP get_metadata_from_index_ptr(Rcpp::XPtr array, const int idx) { - return get_metadata_from_index_impl(*array, idx); -} - -// [[Rcpp::export]] -SEXP get_metadata_from_index_simple(const std::string array_name, const int idx) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_READ); // Open array for reading - return get_metadata_from_index_impl(array, idx); -} - -// ---- get all metadata -SEXP get_all_metadata_impl(tiledb::Array& array) { - uint64_t nm = array.metadata_num(); - int n = static_cast(nm); - Rcpp::List lst(n); - Rcpp::CharacterVector names(n); - for (auto i=0; i array) { - return get_all_metadata_impl(*array); -} - - -// ---- delete metadata -void delete_metadata_impl(tiledb::Array& array, const std::string key) { - array.delete_metadata(key); -} - -// [[Rcpp::export]] -bool delete_metadata_simple(const std::string array_name, const std::string key) { - Context ctx; // Create TileDB context - Array array(ctx, array_name, TILEDB_WRITE); // Open array for reading - delete_metadata_impl(array, key); - return true; -} - -// [[Rcpp::export]] -bool delete_metadata_ptr(Rcpp::XPtr array, const std::string key) { - delete_metadata_impl(*array, key); - return true; -} diff --git a/src/libtiledb.cpp b/src/libtiledb.cpp index ebe49cf6fa..0b6348afd6 100644 --- a/src/libtiledb.cpp +++ b/src/libtiledb.cpp @@ -921,15 +921,15 @@ void libtiledb_attribute_dump(XPtr attr) { * TileDB Array Schema */ //[[Rcpp::export]] -XPtr libtiledb_array_schema( - XPtr ctx, - XPtr domain, - List attributes, - std::string cell_order, - std::string tile_order, - Nullable> coords_filter_list = R_NilValue, - Nullable> offsets_filter_list = R_NilValue, - bool sparse = false) { +XPtr +libtiledb_array_schema(XPtr ctx, + XPtr domain, + List attributes, + std::string cell_order, + std::string tile_order, + Nullable> coords_filter_list = R_NilValue, + Nullable> offsets_filter_list = R_NilValue, + bool sparse = false) { // check that external pointers are supported R_xlen_t nattr = attributes.length(); if (nattr == 0) { @@ -1195,12 +1195,12 @@ bool libtiledb_array_is_open(XPtr array) { // [[Rcpp::export]] bool libtiledb_array_is_open_for_reading(XPtr array) { - return array->is_open() && array->query_type() != TILEDB_READ; + return array->is_open() && array->query_type() == TILEDB_READ; } // [[Rcpp::export]] bool libtiledb_array_is_open_for_writing(XPtr array) { - return array->is_open() && array->query_type() != TILEDB_WRITE; + return array->is_open() && array->query_type() == TILEDB_WRITE; } // [[Rcpp::export]] @@ -1260,10 +1260,169 @@ List libtiledb_array_nonempty_domain(XPtr array) { } // [[Rcpp::export]] -std::string libtiledb_array_consolidate(XPtr ctx, - std::string uri) { - tiledb::Array::consolidate(*ctx.get(), uri); - return uri; +void libtiledb_array_consolidate(XPtr ctx, + std::string uri, + Nullable> cfgptr = R_NilValue) { + + if (cfgptr.isNotNull()) { + XPtr cfg(cfgptr); + tiledb::Array::consolidate(*ctx.get(), uri, cfg); + } else { + tiledb::Array::consolidate(*ctx.get(), uri); + } +} + +// [[Rcpp::export]] +bool libtiledb_array_put_metadata(XPtr array, + std::string key, SEXP obj) { + + // we implement a simpler interface here as the 'type' is given from + // the supplied SEXP, as is the extend + switch(TYPEOF(obj)) { + case VECSXP: { + Rcpp::stop("List objects are not supported."); + break;// not reached + } + case REALSXP: { + Rcpp::NumericVector v(obj); + array->put_metadata(key.c_str(), TILEDB_FLOAT64, v.size(), v.begin()); + break; + } + case INTSXP: { + Rcpp::IntegerVector v(obj); + array->put_metadata(key.c_str(), TILEDB_INT32, v.size(), v.begin()); + break; + } + case STRSXP: { + Rcpp::CharacterVector v(obj); + std::string s(v[0]); + // We use TILEDB_CHAR interchangeably with TILEDB_STRING_ASCII is this best string type? + array->put_metadata(key.c_str(), TILEDB_CHAR, s.length(), s.c_str()); + break; + } + case LGLSXP: { // experimental: map R logical (ie TRUE, FALSE, NA) to int8 + Rcpp::LogicalVector v(obj); + size_t n = static_cast(v.size()); + std::vector ints(n); + for (size_t i=0; i(v[i]); + array->put_metadata(key.c_str(), TILEDB_INT8, ints.size(), ints.data()); + break; + } + default: { + Rcpp::stop("No support (yet) for type '%d'.", TYPEOF(obj)); + break; // not reached + } + } + // Close array - Important so that the metadata get flushed + // not here, array opening and closing responsibility of caller: array.close(); + return true; +} + +// [[Rcpp::export]] +R_xlen_t libtiledb_array_get_metadata_num(XPtr array) { + uint64_t num = array->metadata_num(); + return static_cast(num); +} + +// helper function to copy int vector +template +Rcpp::IntegerVector copy_int_vector(const uint32_t v_num, const void* v) { + // Strictly speaking a check for under/overflow would be needed here yet this for + // metadata annotation (and not data payload) so extreme ranges are less likely + Rcpp::IntegerVector vec(v_num); + const T *ivec = static_cast(v); + size_t n = static_cast(v_num); + for (size_t i=0; i(ivec[i]); + return(vec); +} + +// helper function to convert_metadata +SEXP _metadata_to_sexp(const tiledb_datatype_t v_type, const uint32_t v_num, const void* v) { + // This supports a limited set of basic types as the metadata + // annotation is not meant to support complete serialization + if (v_type == TILEDB_INT32) { + Rcpp::IntegerVector vec(v_num); + std::memcpy(vec.begin(), v, v_num*sizeof(int32_t)); + return(vec); + } else if (v_type == TILEDB_FLOAT64) { + Rcpp::NumericVector vec(v_num); + std::memcpy(vec.begin(), v, v_num*sizeof(double)); + return(vec); + } else if (v_type == TILEDB_FLOAT32) { + Rcpp::NumericVector vec(v_num); + const float *fvec = static_cast(v); + size_t n = static_cast(v_num); + for (size_t i=0; i(fvec[i]); + return(vec); + } else if (v_type == TILEDB_CHAR || v_type == TILEDB_STRING_ASCII) { + Rcpp::CharacterVector vec(1); + std::string s(static_cast(v)); + s.resize(v_num); // incoming char* not null terminated, ensures v_num bytes and terminate + return(Rcpp::wrap(s)); + } else if (v_type == TILEDB_INT8) { + Rcpp::LogicalVector vec(v_num); + const int8_t *ivec = static_cast(v); + size_t n = static_cast(v_num); + for (size_t i=0; i(ivec[i]); + return(vec); + } else if (v_type == TILEDB_UINT8) { + // Strictly speaking a check for under/overflow would be needed here (and below) yet this + // is for metadata annotation (and not data payload) so extreme ranges are less likely + return copy_int_vector(v_num, v); + } else if (v_type == TILEDB_INT16) { + return copy_int_vector(v_num, v); + } else if (v_type == TILEDB_UINT16) { + return copy_int_vector(v_num, v); + } else if (v_type == TILEDB_UINT32) { + return copy_int_vector(v_num, v); + } else if (v_type == TILEDB_INT64) { + return copy_int_vector(v_num, v); + } else if (v_type == TILEDB_UINT64) { + return copy_int_vector(v_num, v); + } else { + Rcpp::stop("No support yet for %s", _tiledb_datatype_to_string(v_type)); + } +} + +// [[Rcpp::export]] +SEXP libtiledb_array_get_metadata_from_index(XPtr array, int idx) { + std::string key; + tiledb_datatype_t v_type; + uint32_t v_num; + const void* v; + array->get_metadata_from_index(static_cast(idx), &key, &v_type, &v_num, &v); + if (v == NULL) { + return R_NilValue; + } + + RObject vec = _metadata_to_sexp(v_type, v_num, v); + vec.attr("names") = Rcpp::CharacterVector::create(key); + return vec; +} + +// [[Rcpp::export]] +SEXP libtiledb_array_get_metadata_list(XPtr array) { + uint64_t num = array->metadata_num(); + int n = static_cast(num); + Rcpp::List lst(n); + Rcpp::CharacterVector names(n); + for (auto i=0; i array, std::string key) { + array->delete_metadata(key.c_str()); } /** diff --git a/src/tiledb_declarations.h b/src/tiledb_declarations.h index f290863ef9..033f5fe4b4 100644 --- a/src/tiledb_declarations.h +++ b/src/tiledb_declarations.h @@ -278,7 +278,7 @@ void libtiledb_array_schema_check(XPtr ## static void consolidate_metadata(const Context& ctx, const std::string& uri, Config* const config = nullptr) ## static void consolidate_metadata(const Context& ctx, const std::string& uri, tiledb_encryption_type_t encryption_type, const void* encryption_key, uint32_t key_length, Config* const config = nullptr) ## static void consolidate_metadata(const Context& ctx, const std::string& uri, tiledb_encryption_type_t encryption_type, const std::string& encryption_key, Config* const config = nullptr) -## void put_metadata(const std::string& key, tiledb_datatype_t value_type, uint32_t value_num, const void* value) +## y void put_metadata(const std::string& key, tiledb_datatype_t value_type, uint32_t value_num, const void* value) ## void delete_metadata(const std::string& key) ## void get_metadata(const std::string& key, tiledb_datatype_t* value_type, uint32_t* value_num, const void** value) ## bool has_metadata(const std::string& key, tiledb_datatype_t* value_type) @@ -301,6 +301,10 @@ XPtr libtiledb_array_close(XPtr array); std::string libtiledb_array_query_type(XPtr array); List libtiledb_array_nonempty_domain(XPtr array); std::string libtiledb_array_consolidate(XPtr ctx, std::string uri); +bool libtiledb_array_put_metadata(XPtr array, std::string key, SEXP obj); +R_xlen_t libtiledb_array_get_metadata_num(XPtr array); +SEXP libtiledb_array_get_metadata_from_index(XPtr array, int idx); +void libtiledb_array_delete_metadata(XPtr array, std::string key); ## Query @@ -377,6 +381,29 @@ DataFrame libtiledb_object_walk(XPtr ctx, std:: ## VFS +## +## C++ API +## +## VFS(const Context& ctx, const Config& config) +## void create_bucket(const std::string& uri) +## void remove_bucket(const std::string& uri) +## bool is_bucket(const std::string& uri) +## void empty_bucket(const std::string& bucket) +## bool is_empty_bucket(const std::string& bucket) +## void create_dir(const std::string& uri) +## bool is_dir(const std::string& uri) +## bool is_file(const std::string& uri) +## void remove_file(const std::string& uri) +## uint64_t dir_size(const std::string& uri) +## std::vector ls(const std::string& uri) +## uint64_t file_size(const std::string& uri) +## void move_file(const std::string& old_uri, const std::string& new_uri) +## void move_dir(const std::string& old_uri, const std::string& new_uri) +## void touch(const std::string& uri) +## const Context& context() +## std::shared_ptr ptr() +## Config config() +## static int ls_getter(const char* path, void* data) XPtr tiledb_vfs(XPtr ctx, Nullable> config=R_NilValue); std::string tiledb_vfs_create_bucket(XPtr vfs, std::string uri); std::string tiledb_vfs_remove_bucket(XPtr vfs, std::string uri); @@ -393,6 +420,23 @@ std::string tiledb_vfs_move_file(XPtr vfs, std::strin std::string tiledb_vfs_move_dir(XPtr vfs, std::string old_uri, std::string new_uri); std::string tiledb_vfs_touch(XPtr vfs, std::string uri); +## VFSFilebuf +## +## C++ API +## +## VFSFilebuf(const VFS& vfs) +## VFSFilebuf* open(const std::string& uri, std::ios::openmode openmode = std::ios::in) +## bool is_open() +## VFSFilebuf* close() +## const std::string& get_uri() +## std::streambuf::pos_type seekoff( off_type offset, std::ios::seekdir seekdir, std::ios::openmode openmode) +## pos_type seekpos(pos_type pos, std::ios::openmode openmode) +## std::streamsize showmanyc() +## std::streamsize xsgetn(char_type* s, std::streamsize n) +## int_type uflow() +## std::streamsize xsputn(const char_type* s, std::streamsize n) +## int_type overflow(int_type c) + ## Stats void libtiledb_stats_enable(); diff --git a/tests/testthat/test_Metadata.R b/tests/testthat/test_Metadata.R index 3a26ae992e..95b26336bd 100644 --- a/tests/testthat/test_Metadata.R +++ b/tests/testthat/test_Metadata.R @@ -14,23 +14,34 @@ unlink_and_create_simple <- function(tmp) { sch <- tiledb_array_schema(dom, c(a1, a2), sparse=TRUE) tiledb_array_create(tmp, sch) + arr <- tiledb_sparse(tmp, as.data.frame=FALSE) + + tiledb:::libtiledb_array_close(arr@ptr) + tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "WRITE") + ## write one record directly to (text) URI - tiledb_put_metadata(tmp, "vec", c(1.1, 2.2, 3.3)) + tiledb_put_metadata(arr, "vec", c(1.1, 2.2, 3.3)) - arr <- tiledb_sparse(tmp, as.data.frame=FALSE) arr } unlink_and_create_ptr <- function(tmp) { arr <- unlink_and_create_simple(tmp) + tiledb:::libtiledb_array_close(arr@ptr) ## write one record via ptr arrW <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "WRITE") - tiledb:::put_metadata_ptr(arrW, "txt", "the quick brown fox") + tiledb:::libtiledb_array_put_metadata(arrW, "txt", "the quick brown fox") tiledb:::libtiledb_array_close(arrW) arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") - return(arrR) + ##return(arrR) + arr <- tiledb_sparse(tmp, as.data.frame=FALSE) +} + +close_and_reopen <- function(arr, txt) { + res <- tiledb:::libtiledb_array_close(arr@ptr) + res <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, txt) } ## infrastructure @@ -47,10 +58,12 @@ teardown({ test_that("Can check presence of metadata", { arr <- unlink_and_create_ptr(tmp) - expect_error(tiledb:::has_metadata_ptr(NULL, "")) - expect_false(tiledb:::has_metadata_ptr(arr, "")) - expect_true(tiledb:::has_metadata_ptr(arr, "vec")) - expect_true(tiledb:::has_metadata_ptr(arr, "txt")) + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") + + expect_error(tiledb_has_metadata(NULL, "")) + expect_false(tiledb_has_metadata(arr, "")) + expect_true(tiledb_has_metadata(arr, "vec")) + expect_true(tiledb_has_metadata(arr, "txt")) unlink(tmp, recursive = TRUE, force = TRUE) }) @@ -58,8 +71,10 @@ test_that("Can check presence of metadata", { test_that("Can retrieve count of metadata", { arr <- unlink_and_create_ptr(tmp) - expect_error(tiledb:::num_metadata_ptr(NULL)) - expect_equal(tiledb:::num_metadata_ptr(arr), 2L) + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") + + expect_error(tiledb_num_metadata(NULL)) + expect_equal(tiledb_num_metadata(arr), 2L) unlink(tmp, recursive = TRUE, force = TRUE) }) @@ -67,9 +82,11 @@ test_that("Can retrieve count of metadata", { test_that("Can get metadata", { arr <- unlink_and_create_ptr(tmp) - expect_error(tiledb:::get_metadata_ptr(NULL, "")) - expect_equal(tiledb:::get_metadata_ptr(arr, ""), NULL) - expect_equal(tiledb:::get_metadata_ptr(arr, "vec"), c(1.1, 2.2, 3.3)) + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") + + expect_error(tiledb_get_metadata(NULL, "")) + expect_equal(tiledb_get_metadata(arr, ""), NULL) + expect_equal(tiledb_get_metadata(arr, "vec"), c(1.1, 2.2, 3.3)) unlink(tmp, recursive = TRUE, force = TRUE) }) @@ -77,36 +94,42 @@ test_that("Can get metadata", { test_that("Can put metadata", { arr <- unlink_and_create_ptr(tmp) - tiledb:::libtiledb_array_close(arr) - arrW <- tiledb:::libtiledb_array_open_with_ptr(arr, "WRITE") + tiledb:::libtiledb_array_close(arr@ptr) + arrW <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "WRITE") - expect_true(tiledb:::put_metadata_ptr(arrW, "foo", "the quick brown fox")) - expect_error(tiledb:::put_metadata_ptr(arrW, "foo", list(a=c(1,2,3), b=c("a", "b")))) + expect_true(tiledb_put_metadata(arr, "foo", "the quick brown fox")) + expect_error(tiledb_put_metadata(arr, "foo", list(a=c(1,2,3), b=c("a", "b")))) - tiledb:::libtiledb_array_close(arrW) + tiledb:::libtiledb_array_close(arr@ptr) unlink(tmp, recursive = TRUE, force = TRUE) }) test_that("Can do round trip", { - ## will use 'simpler' accessors to not have to flip between read and write arr <- unlink_and_create_simple(tmp) vec <- c(1.1, 2.2, 3.3) - expect_true(tiledb:::put_metadata_simple(tmp, "dvec", vec)) - expect_equal(tiledb:::get_metadata_simple(tmp, "dvec"), vec) + expect_true(tiledb_put_metadata(arr, "dvec", vec)) + close_and_reopen(arr, "READ") + expect_equal(tiledb_get_metadata(arr, "dvec"), vec) vec <- c(1L, 2L, 3L) - expect_true(tiledb:::put_metadata_simple(tmp, "ivec", vec)) - expect_equal(tiledb:::get_metadata_simple(tmp, "ivec"), vec) + close_and_reopen(arr, "WRITE") + expect_true(tiledb_put_metadata(arr, "ivec", vec)) + close_and_reopen(arr, "READ") + expect_equal(tiledb_get_metadata(arr, "ivec"), vec) vec <- "the quick brown fox" - expect_true(tiledb:::put_metadata_simple(tmp, "char", vec)) - expect_equal(tiledb:::get_metadata_simple(tmp, "char"), vec) + close_and_reopen(arr, "WRITE") + expect_true(tiledb_put_metadata(arr, "char", vec)) + close_and_reopen(arr, "READ") + expect_equal(tiledb_get_metadata(arr, "char"), vec) vec <- c(TRUE, FALSE, TRUE) - expect_true(tiledb:::put_metadata_simple(tmp, "lvec", vec)) - expect_equal(tiledb:::get_metadata_simple(tmp, "lvec"), vec) + close_and_reopen(arr, "WRITE") + expect_true(tiledb_put_metadata(arr, "lvec", vec)) + close_and_reopen(arr, "READ") + expect_equal(tiledb_get_metadata(arr, "lvec"), vec) unlink(tmp, recursive = TRUE, force = TRUE) }) @@ -114,10 +137,13 @@ test_that("Can do round trip", { test_that("Can get by index", { arr <- unlink_and_create_ptr(tmp) - expect_error(tiledb:::get_metadata_from_index_ptr(NULL, "")) - expect_error(tiledb:::get_metadata_from_index_ptr(arr, -1)) - expect_equal(tiledb:::get_metadata_from_index_ptr(arr, 0), c(txt="the quick brown fox")) - expect_equal(unname(tiledb:::get_metadata_from_index_ptr(arr, 1)), c(1.1, 2.2, 3.3)) + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") + + expect_error(tiledb:::libtiledb_get_metadata_from_index(NULL, "")) + expect_error(tiledb:::libtiledb_get_metadata_from_index(arr@ptr, -1)) + expect_equal(tiledb:::libtiledb_array_get_metadata_from_index(arr@ptr, 0), + c(txt="the quick brown fox")) + expect_equal(unname(tiledb:::libtiledb_array_get_metadata_from_index(arr@ptr, 1)), c(1.1, 2.2, 3.3)) unlink(tmp, recursive = TRUE, force = TRUE) }) @@ -125,7 +151,9 @@ test_that("Can get by index", { test_that("Can get all", { arr <- unlink_and_create_ptr(tmp) - res <- tiledb:::get_all_metadata_ptr(arr) + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") + + res <- tiledb_get_all_metadata(arr) expect_equal(length(res), 2L) expect_true("vec" %in% names(res)) expect_true("txt" %in% names(res)) @@ -134,28 +162,23 @@ test_that("Can get all", { test_that("Can deleye by key", { arr <- unlink_and_create_ptr(tmp) - ## should be two before we add - expect_equal(tiledb:::num_metadata_ptr(arr), 2L) - - tiledb:::libtiledb_array_close(arr) - arrW <- tiledb:::libtiledb_array_open_with_ptr(arr, "WRITE") + arrR <- tiledb:::libtiledb_array_open_with_ptr(arr@ptr, "READ") - expect_true(tiledb:::put_metadata_ptr(arrW, "foo", "the quick brown fox")) + ## should be two before we add + expect_equal(tiledb_num_metadata(arr), 2L) - tiledb:::libtiledb_array_close(arrW) - arr <- tiledb:::libtiledb_array_open_with_ptr(arrW, "READ") + close_and_reopen(arr, "WRITE") + expect_true(tiledb_put_metadata(arr, "foo", "the quick brown fox")) + close_and_reopen(arr, "READ") ## should be three after we add - expect_equal(tiledb:::num_metadata_ptr(arr), 3L) - - tiledb:::libtiledb_array_close(arr) - arrW <- tiledb:::libtiledb_array_open_with_ptr(arr, "WRITE") + expect_equal(tiledb_num_metadata(arr), 3L) - expect_true(tiledb:::delete_metadata_ptr(arr, "foo")) + close_and_reopen(arr, "WRITE") + expect_true(tiledb_delete_metadata(arr, "foo")) - tiledb:::libtiledb_array_close(arrW) - arr <- tiledb:::libtiledb_array_open_with_ptr(arrW, "READ") + close_and_reopen(arr, "READ") ## should be two after we delete - expect_equal(tiledb:::num_metadata_ptr(arr), 2L) + expect_equal(tiledb_num_metadata(arr), 2L) })