ak.contents.RegularArray#
Defined in awkward.contents.regulararray on line 37.
- class ak.contents.RegularArray(self, content, size, zeros_length=0, *, parameters=None)#
RegularArray describes lists that all have the same length, the single
integer size
. Its underlying content
is a flattened view of the data;
that is, each list is not stored separately in memory, but is inferred as a
subinterval of the underlying data.
If the content
length is not an integer multiple of size
, then the length
of the RegularArray is truncated to the largest integer multiple.
An extra field zeros_length
is ignored unless the size
is zero. This sets the
length of the RegularArray in only those cases, so that it is possible for an
array to contain a non-zero number of zero-length lists with regular type.
A multidimensional ak.contents.NumpyArray
is equivalent to a one-dimensional
ak.layout.NumpyArray
nested within several RegularArrays, one for each
dimension. However, RegularArrays can be used to make lists of any other type.
Like ak.contents.ListArray
and ak.contents.ListOffsetArray
, a RegularArray can
represent strings if its __array__
parameter is "string"
(UTF-8 assumed) or
"bytestring"
(no encoding assumed) and it contains an ak.contents.NumpyArray
of dtype=np.uint8
whose __array__
parameter is "char"
(UTF-8 assumed) or
"byte"
(no encoding assumed).
RegularArray corresponds to an Apache Arrow FixedSizeList.
To illustrate how the constructor arguments are interpreted, the following is a
simplified implementation of __init__
, __len__
, and __getitem__
:
class RegularArray(Content):
def __init__(self, content, size, zeros_length=0):
assert isinstance(content, Content)
assert isinstance(size, int)
assert isinstance(zeros_length, int)
assert size >= 0
if size != 0:
length = len(content) // size # floor division
else:
assert zeros_length >= 0
length = zeros_length
self.content = content
self.size = size
self.length = length
def __len__(self):
return self.length
def __getitem__(self, where):
if isinstance(where, int):
if where < 0:
where += len(self)
assert 0 <= where < len(self)
return self.content[(where) * self.size : (where + 1) * self.size]
elif isinstance(where, slice) and where.step is None:
start = where.start * self.size
stop = where.stop * self.size
zeros_length = where.stop - where.start
return RegularArray(
self.content[start:stop], self.size, zeros_length
)
elif isinstance(where, str):
return RegularArray(self.content[where], self.size, self.length)
else:
raise AssertionError(where)
- ak.contents.RegularArray.is_list = True#
- ak.contents.RegularArray.is_regular = True#
- ak.contents.RegularArray.content#
- ak.contents.RegularArray.size#
- ak.contents.RegularArray.copy(self, content=UNSET, size=UNSET, zeros_length=UNSET, *, parameters=UNSET)#
- ak.contents.RegularArray.__copy__(self)#
- ak.contents.RegularArray.__deepcopy__(self, memo)#
- ak.contents.RegularArray.simplified(cls, content, size, zeros_length=0, *, parameters=None)#
- ak.contents.RegularArray.offsets#
- ak.contents.RegularArray.starts#
- ak.contents.RegularArray.stops#
- ak.contents.RegularArray._form_with_key(self, getkey)#
- ak.contents.RegularArray._to_buffers(self, form, getkey, container, backend, byteorder)#
- ak.contents.RegularArray._to_typetracer(self, forget_length)#
- ak.contents.RegularArray._touch_data(self, recursive)#
- ak.contents.RegularArray._touch_shape(self, recursive)#
- ak.contents.RegularArray.length#
- ak.contents.RegularArray.__repr__(self)#
- ak.contents.RegularArray._repr(self, indent, pre, post)#
- ak.contents.RegularArray.to_ListOffsetArray64(self, start_at_zero=False)#
- ak.contents.RegularArray.to_RegularArray(self)#
- ak.contents.RegularArray.maybe_to_NumpyArray(self)#
- ak.contents.RegularArray._getitem_nothing(self)#
- ak.contents.RegularArray._getitem_at(self, where)#
- ak.contents.RegularArray._getitem_range(self, start, stop)#
- ak.contents.RegularArray._getitem_field(self, where, only_fields=())#
- ak.contents.RegularArray._getitem_fields(self, where, only_fields=())#
- ak.contents.RegularArray._carry(self, carry, allow_lazy)#
- ak.contents.RegularArray._compact_offsets64(self, start_at_zero)#
- ak.contents.RegularArray._broadcast_tooffsets64(self, offsets)#
- ak.contents.RegularArray._getitem_next_jagged(self, slicestarts, slicestops, slicecontent, tail)#
- ak.contents.RegularArray._getitem_next(self, head, tail, advanced)#
- ak.contents.RegularArray._offsets_and_flattened(self, axis, depth)#
- ak.contents.RegularArray._mergeable_next(self, other, mergebool)#
- ak.contents.RegularArray._mergemany(self, others)#
- ak.contents.RegularArray._fill_none(self, value)#
- ak.contents.RegularArray._local_index(self, axis, depth)#
- ak.contents.RegularArray._numbers_to_type(self, name, including_unknown)#
- ak.contents.RegularArray._is_unique(self, negaxis, starts, parents, outlength)#
- ak.contents.RegularArray._unique(self, negaxis, starts, parents, outlength)#
- ak.contents.RegularArray._argsort_next(self, negaxis, starts, shifts, parents, outlength, ascending, stable)#
- ak.contents.RegularArray._sort_next(self, negaxis, starts, parents, outlength, ascending, stable)#
- ak.contents.RegularArray._combinations(self, n, replacement, recordlookup, parameters, axis, depth)#
- ak.contents.RegularArray._reduce_next(self, reducer, negaxis, starts, shifts, parents, outlength, mask, keepdims, behavior)#
- ak.contents.RegularArray._validity_error(self, path)#
- ak.contents.RegularArray._nbytes_part(self)#
- ak.contents.RegularArray._pad_none(self, target, axis, depth, clip)#
- ak.contents.RegularArray._to_backend_array(self, allow_missing, backend)#
- ak.contents.RegularArray._to_arrow(self, pyarrow, mask_node, validbytes, length, options)#
- ak.contents.RegularArray._remove_structure(self, backend, options)#
- ak.contents.RegularArray._drop_none(self)#
- ak.contents.RegularArray._recursively_apply(self, action, behavior, depth, depth_context, lateral_context, options)#
- ak.contents.RegularArray.to_packed(self)#
- ak.contents.RegularArray._to_list(self, behavior, json_conversions)#
- ak.contents.RegularArray._to_backend(self, backend)#
- ak.contents.RegularArray._is_equal_to(self, other, index_dtype, numpyarray)#