Skip to main content
Log in

Mojo struct

IndexList

@register_passable(trivial) struct IndexList[size: Int, *, element_bitwidth: Int = Int(bitwidthof[AnyTrivialRegType,__mlir_type.!kgen.target]()), unsigned: Bool = False]

A base struct that implements size agnostic index functions.

Parameters

  • size (Int): The size of the tuple.
  • element_bitwidth (Int): The bitwidth of the underlying integer element type.
  • unsigned (Bool): Whether the integer is signed or unsigned.

Aliases

  • element_type = _type_of_width[::Int,::Bool](): The underlying dtype of the integer element value.

Fields

  • data (StaticTuple[SIMD[_type_of_width[::Int,::Bool](), 1], size]): The underlying storage of the tuple value.

Implemented traits

AnyType, Comparable, Copyable, EqualityComparable, ExplicitlyCopyable, GreaterThanComparable, GreaterThanOrEqualComparable, LessThanComparable, LessThanOrEqualComparable, Movable, Sized, Stringable, UnknownDestructibility, Writable

Methods

__init__

__init__() -> Self

Constructs a static int tuple of the given size.

@implicit __init__(data: StaticTuple[SIMD[_type_of_width[::Int,::Bool](), 1], size]) -> Self

Constructs a static int tuple of the given size.

Args:

  • data (StaticTuple[SIMD[_type_of_width[::Int,::Bool](), 1], size]): The StaticTuple to construct the IndexList from.

@implicit __init__(elems: Tuple[Int, Int]) -> Self

Constructs a static int tuple given a tuple of integers.

Args:

  • elems (Tuple[Int, Int]): The tuple to copy from.

@implicit __init__(elems: Tuple[Int, Int, Int]) -> Self

Constructs a static int tuple given a tuple of integers.

Args:

  • elems (Tuple[Int, Int, Int]): The tuple to copy from.

@implicit __init__(elems: Tuple[Int, Int, Int, Int]) -> Self

Constructs a static int tuple given a tuple of integers.

Args:

  • elems (Tuple[Int, Int, Int, Int]): The tuple to copy from.

@implicit __init__(*elems: Int) -> Self

Constructs a static int tuple given a set of arguments.

Args:

  • *elems (Int): The elements to construct the tuple.

@implicit __init__(elem: Int) -> Self

Constructs a static int tuple given a set of arguments.

Args:

  • elem (Int): The elem to splat into the tuple.

__init__(*, other: Self) -> Self

Copy constructor.

Args:

  • other (Self): The other tuple to copy from.

@implicit __init__(values: VariadicList[Int]) -> Self

Creates a tuple constant using the specified values.

Args:

  • values (VariadicList[Int]): The list of values.

__getitem__

__getitem__[idx: Int](self) -> Int

Gets an element from the tuple by index.

Parameters:

  • idx (Int): The element index.

Returns:

The tuple element value.

__getitem__[I: Indexer](self, idx: I) -> Int

Gets an element from the tuple by index.

Parameters:

  • I (Indexer): A type that can be used as an index.

Args:

  • idx (I): The element index.

Returns:

The tuple element value.

__setitem__

__setitem__[idx: Int](mut self, val: Int)

Sets an element in the tuple at the given static index.

Parameters:

  • idx (Int): The element index.

Args:

  • val (Int): The value to store.

__setitem__[idx: Int](mut self, val: SIMD[_type_of_width[::Int,::Bool](), 1])

Sets an element in the tuple at the given static index.

Parameters:

  • idx (Int): The element index.

Args:

  • val (SIMD[_type_of_width[::Int,::Bool](), 1]): The value to store.

__setitem__(mut self, idx: Int, val: Int)

Sets an element in the tuple at the given index.

Args:

  • idx (Int): The element index.
  • val (Int): The value to store.

__lt__

__lt__(self, rhs: Self) -> Bool

Compares this tuple to another tuple using LT comparison.

A tuple is less-than another tuple if all corresponding elements of lhs is less than rhs.

Note: This is not a lexical comparison.

Args:

  • rhs (Self): Right hand side tuple.

Returns:

The comparison result.

__le__

__le__(self, rhs: Self) -> Bool

Compares this tuple to another tuple using LE comparison.

A tuple is less-or-equal than another tuple if all corresponding elements of lhs is less-or-equal than rhs.

Note: This is not a lexical comparison.

Args:

  • rhs (Self): Right hand side tuple.

Returns:

The comparison result.

__eq__

__eq__(self, rhs: Self) -> Bool

Compares this tuple to another tuple for equality.

The tuples are equal if all corresponding elements are equal.

Args:

  • rhs (Self): The other tuple.

Returns:

The comparison result.

__ne__

__ne__(self, rhs: Self) -> Bool

Compares this tuple to another tuple for non-equality.

The tuples are non-equal if at least one element of LHS isn't equal to the corresponding element from RHS.

Args:

  • rhs (Self): The other tuple.

Returns:

The comparison result.

__gt__

__gt__(self, rhs: Self) -> Bool

Compares this tuple to another tuple using GT comparison.

A tuple is greater-than than another tuple if all corresponding elements of lhs is greater-than than rhs.

Note: This is not a lexical comparison.

Args:

  • rhs (Self): Right hand side tuple.

Returns:

The comparison result.

__ge__

__ge__(self, rhs: Self) -> Bool

Compares this tuple to another tuple using GE comparison.

A tuple is greater-or-equal than another tuple if all corresponding elements of lhs is greater-or-equal than rhs.

Note: This is not a lexical comparison.

Args:

  • rhs (Self): Right hand side tuple.

Returns:

The comparison result.

__add__

__add__(self, rhs: Self) -> Self

Performs element-wise integer add.

Args:

  • rhs (Self): Right hand side operand.

Returns:

The resulting index tuple.

__sub__

__sub__(self, rhs: Self) -> Self

Performs element-wise integer subtract.

Args:

  • rhs (Self): Right hand side operand.

Returns:

The resulting index tuple.

__mul__

__mul__(self, rhs: Self) -> Self

Performs element-wise integer multiply.

Args:

  • rhs (Self): Right hand side operand.

Returns:

The resulting index tuple.

__floordiv__

__floordiv__(self, rhs: Self) -> Self

Performs element-wise integer floor division.

Args:

  • rhs (Self): The elementwise divisor.

Returns:

The resulting index tuple.

__rfloordiv__

__rfloordiv__(self, rhs: Self) -> Self

Floor divides rhs by this object.

Args:

  • rhs (Self): The value to elementwise divide by self.

Returns:

The resulting index tuple.

__len__

__len__(self) -> Int

Returns the size of the tuple.

Returns:

The tuple size.

as_tuple

as_tuple(self) -> StaticTuple[Int, size]

Converts this IndexList to StaticTuple.

Returns:

The corresponding StaticTuple object.

canonicalize

canonicalize(self) -> IndexList[size]

Canonicalizes the IndexList.

Returns:

Canonicalizes the object.

flattened_length

flattened_length(self) -> Int

Returns the flattened length of the tuple.

Returns:

The flattened length of the tuple.

remu

remu(self, rhs: Self) -> Self

Performs element-wise integer unsigned modulo.

Args:

  • rhs (Self): Right hand side operand.

Returns:

The resulting index tuple.

write_to

write_to[W: Writer](self, mut writer: W)

Formats this IndexList value to the provided Writer.

Parameters:

  • W (Writer): A type conforming to the Writable trait.

Args:

  • writer (W): The object to write to.

__str__

__str__(self) -> String

Get the tuple as a string.

Returns:

A string representation.

cast

cast[type: DType](self) -> IndexList[size, element_bitwidth=Int(bitwidthof[::DType,__mlir_type.!kgen.target]()), unsigned=_is_unsigned[::DType]()]

Casts to the target DType.

Parameters:

  • type (DType): The type to cast towards.

Returns:

The list casted to the target type.

cast[*, element_bitwidth: Int = element_bitwidth, unsigned: Bool = unsigned](self) -> IndexList[size, element_bitwidth=element_bitwidth, unsigned=unsigned]

Casts to the target DType.

Parameters:

  • element_bitwidth (Int): The bitwidth to cast towards.
  • unsigned (Bool): The signess of the list.

Returns:

The list casted to the target type.

__hash__

__hash__[H: _Hasher](self, mut hasher: H)

Updates hasher with the underlying bytes.

Parameters:

  • H (_Hasher): The hasher type.

Args:

  • hasher (H): The hasher instance.