rbnet.util.TupleTMap
- class rbnet.util.TupleTMap(arrs, *args, **kwargs)[source]
Bases:
TMap
A tuple of
TMap
objects. All getters/setters of attributes and items return/take tuples of values. Internally, aTupleTMap
object actually maintains a tuple ofTMap
objects and delegates all calls to these objects.Public Data Attributes:
Inherited from
TMap
n
Size of the triangular map, i.e., the width at the triangle base.
arr
Underlying storage container.
value_shape
Shape of the values stored in the map.
linearise_blocks
lslice
A convenience property that uses
get_lslice()
andset_lslice()
as getter and setter, respectively.dslice
A convenience property that uses
get_dslice()
andset_dslice()
as getter and setter, respectively.sslice
A convenience property that uses
get_sslice()
andset_sslice()
as getter and setter, respectively.eslice
A convenience property that uses
get_eslice()
andset_eslice()
as getter and setter, respectively.sblock
A convenience property that uses
get_sblock()
andset_sblock()
as getter and setter, respectively.eblock
A convenience property that uses
get_eblock()
andset_eblock()
as getter and setter, respectively.Public Methods:
__init__
(arrs, *args, **kwargs)__getattribute__
(item)Return getattr(self, name).
__setattr__
(key, value)Implement setattr(self, name, value).
__getitem__
(item)Get the item corresponding to (start, end) or the sub-map corresponding to slice start:end.
__setitem__
(key, value)Set the item corresponding to (start, end).
Inherited from
TMap
size_from_n
(n)Calculate the size N of the underlying 1D array for a given width
n
of the triangular map: .n_from_size
(n)Calculate width
n
of the map given the size N of the underlying 1D array: .get_reindex_from_start_end_to_top_down
(n)For a map of width
n
, get an index array of length to reindex from start-end order to top-down order.reindex_from_start_end_to_top_down
(arr)Reindex
arr
from start-end order to top-down order.get_reindex_from_top_down_to_start_end
(n)For a map of width
n
, get an index array of length to reindex from top-down order to start-end order.reindex_from_top_down_to_start_end
(arr)Reindex
arr
from top-down order to start-end order.__init__
(arr[, linearise_blocks, _n])depth
(start, end)Compute the depth d corresponding to (start, end): d = n - (end - start).
level
(*args)Compute the level from depth or (start, end).
linear_from_start_end
(start, end)Compute the linear index (in the underlying 1D array) corresponding to a (start, end) pair.
__getitem__
(item)Get the item corresponding to (start, end) or the sub-map corresponding to slice start:end.
__setitem__
(key, value)Set the item corresponding to (start, end).
copy
()Copy the map.
top
([depth])Return the sub-map corresponding to the top-most levels.
linear_start_end_from_level
(level)Compute the linear 1D start and end index corresponding to all values in the respective level of the map.
get_lslice
(level)Slice the map at the given level, returning a view of the values.
set_lslice
(level, value)get_dslice
(depth)Slice the map at the given depth, returning a view of the values.
set_dslice
(depth, value)get_sslice
(item)Return a slice for the given start index.
set_sslice
(key, value)Like get_sslice but set value instead of returning values.
get_eslice
(item)Return a slice for the given end index.
set_eslice
(key, value)Like get_eslice but set value instead of returning values.
get_sblock
(item)Return a block of sslices down from the specified level.
set_sblock
(key, value)Like get_sblock but set value.
get_eblock
(item)Return a block of eslices down from the specified level.
set_eblock
(key, value)Like get_sblock but set value.
flatten
([order])Return map in linear order.
__repr__
()Return repr(self).
__str__
()Return a string representation of the map, consisting of consecutive dslices.
pretty
([cut, str_func, detach_pytorch, scf, ...])Pretty-print a triangular map.
Private Data Attributes:
Inherited from
TMap
_flatten_regex
Private Methods:
Inherited from
TMap
_to_int
(i)Convert i to integer, no matter whether it is a single number or a numpy array.
_unpack_item
(item)_is_pytorch
()_check
(start, end)Check whether 0 <= start < end < n.
_end_indices_for_sslice
(start)Compute the end indices corresponding to a slice at the give start index.
_start_indices_for_eslice
(end)Compute the start indices corresponding to a slice at the give end index.
_get_sblock_index
(item)_get_eblock_index
(item)