Array-backed
ixfx’s grids are not data structures in the sense of ways of storing & recalling data. But there a few helper functions to have grid semantics on arrays.
A grid can be represented as a one- or two- dimensional array.
You can see the 2D representation is very grid-like. The 1D representation on the other hand is packed into a series of values. In this form, we need to know the number of columns to ‘decode’ the array and know how to split it up into rows and columns. In the 2D form, we get this from the length of the inner and outer arrays.
Creating
If you already have an array of data, use Array1d.wrap or Array2d.wrap , depending on the representation.
This will return a new object that allows you to read and write with grid semantics, as well as access the underlying array.
Example with the 1D array:
If you want to go the other way and make an array for a given grid, use Array1d.createArray
Values from coordinates
Grids.values takes a grid and iterator as input and yields cell values
Iterating
By.cellValues iterates over all cell values of a Type Grids.GridReadable . It runs left-to-right, top-to-bottom.
By.cellAndValues is similar, but returns the cell position and value, in the form of: