Zarr
zarr
Provides an Ocaml implementation of the Zarr version 3 storage format specification. It supports creation of arrays and groups as well as chunking arrays along any dimension. One can store a Zarr hierarchy in memory or on disk. Zarr also supports reading zarr hierarchies created using other implementations, as long as they are spec-compliant.
Consult the examples and limitations for more info.
module Node : sig ... end
This module provides functionality for manipulating Zarr nodes.
module Metadata : sig ... end
This module provides functionality for manipulating a Zarr node's metadata JSON document.
module Storage : sig ... end
module Memory : sig ... end
module Zip : sig ... end
module Http : sig ... end
module Types : sig ... end
module Codecs : sig ... end
An array has an associated list of codecs. Each codec specifies a bidirectional transform (an encode transform and a decode transform). This module contains building blocks for creating and working with a chain of codecs.
module Indexing = Ndarray.Indexing
module Util : sig ... end
module Ndarray : sig ... end
Here we show how the library's asynchronous API using Lwt's concurrency monad can be used.
open Zarr
open Zarr.Ndarray
open Zarr.Indexing
open Zarr.Codecs
open Zarr_lwt.Storage
open FilesystemStore.Deferred.Syntax
let _ =
Lwt_main.run begin
let store = FilesystemStore.create "testdata.zarr" in
let group_node = Node.Group.root in
let* () = FilesystemStore.Group.create group_node in
let array_node = ArrayNode.(group_node / "name") in
let* () = FilesystemStore.Array.create
~codecs:[`Bytes BE] ~shape:[|100; 100; 50|] ~chunks:[|10; 15; 20|]
Ndarray.Float32 Float.neg_infinity array_node store in
let slice = [|R [|0; 20|]; I 10; L [||]|] in
let* x = FilesystemStore.Array.read store array_node slice Ndarray.Float32 in
let x' = Ndarray.map (fun _ -> Random.int 11 |> Float.of_int) x
in FilesystemStore.Array.write store array_node slice x'
end
This library also provides custom extensions not defined in the version 3 specification. These are tabulated below:
Extension Point | Details |
---|---|
Data Types |
|
Although this implementation tries to be spec compliant, it does come with a few limitations:
float16
, uint32
, complex128
, r*
, and variable length strings.