bigalgebra is designed to interoperate with the
bigmemory ecosystem. This vignette demonstrates how to
create in-memory and file-backed big.matrix objects,
interact with them via the package’s wrappers, and manage the underlying
resources safely.
big.matrix objectsIn-memory matrices behave much like ordinary R matrices but reside in shared memory, allowing multiple R sessions to access the same data.
X <- big.matrix(3, 3, type = "double", init = 0)
X[,] <- matrix(1:9, nrow = 3)
X[]
#> [,1] [,2] [,3]
#> [1,] 1 4 7
#> [2,] 2 5 8
#> [3,] 3 6 9Once created, the objects can be passed directly to Level 1 helpers:
File-backed matrices persist their contents on disk, making them suitable for data sets that exceed available RAM.
dir.create(tmp_fb <- tempfile())
Y <- filebacked.big.matrix(4, 2, type = "double",
backingpath = tmp_fb,
backingfile = "fb.bin",
descriptorfile = "fb.desc",
init = 0)
Y[,] <- matrix(runif(8), nrow = 4)
Y[]
#> [,1] [,2]
#> [1,] 0.3441184 0.5806132
#> [2,] 0.4463136 0.8288208
#> [3,] 0.9459595 0.6529837
#> [4,] 0.1157464 0.5171191These objects participate in higher-level operations without being loaded into memory.
Z <- filebacked.big.matrix(4, 2, type = "double",
backingpath = tmp_fb,
backingfile = "res.bin",
descriptorfile = "res.desc",
init = 0)
dvcal(ALPHA = 1.5, X = Y, BETA = 0, Y = Z)
Z[]
#> [,1] [,2]
#> [1,] 0.5161775 0.8709198
#> [2,] 0.6694703 1.2432312
#> [3,] 1.4189392 0.9794756
#> [4,] 0.1736195 0.7756786