Mojo struct
ManagedTensorSlice
@register_passable(trivial)
struct ManagedTensorSlice[mut: Bool, input: IO, dtype: DType, rank: Int, //, io_spec: IOSpec[mut, input], *, static_spec: StaticTensorSpec[dtype, rank]]
A view of a tensor that does not own the underlying allocated pointer. When the object lifetime ends it does not free the underlying pointer. Conversely, if a ManagedTensorSlice is created, it will not extend the life of the underlying pointer.
Therefore, the user must take care to keep the pointer alive until the last
use of a ManagedTensorSlice instance. This class is useful for writing
custom operations where memory is managed by an external runtime like in
MAX's inference stack.
Implemented traits
AnyType,
Copyable,
DevicePassable,
ImplicitlyCopyable,
Movable,
Stringable,
UnknownDestructibility,
Writable
Aliases
__copyinit__is_trivial
alias __copyinit__is_trivial = True
__del__is_trivial
alias __del__is_trivial = True
__moveinit__is_trivial
alias __moveinit__is_trivial = True
address_space
alias address_space = static_spec.address_space
alignment
alias alignment = static_spec.alignment
device_type
alias device_type = LayoutTensor[dtype, static_spec.to_layout[dtype, rank](), MutableAnyOrigin]
exclusive
alias exclusive = static_spec.exclusive
Methods
__init__
__init__(ptr: UnsafePointer[Scalar[dtype]], slices: InlineArray[Slice, rank], slicer_spec: RuntimeTensorSpec[dtype, rank]) -> Self
Initializes a ManagedTensorSlice from a pointer, array of slices and tensor spec.
In general, custom operations should not create ManagedTensorSlice
instances, but instead use the ones provided by the MAX inference
engine.
__init__(ptr: UnsafePointer[Scalar[dtype]], shape: IndexList[rank]) -> Self
Initializes a ManagedTensorSlice from a pointer and shape.
In general, custom operations should not create ManagedTensorSlice
instances, but instead use the ones provided by the MAX inference
engine.
__init__(ptr: UnsafePointer[Scalar[dtype]], shape: IndexList[rank], strides: IndexList[rank]) -> Self
Initializes a ManagedTensorSlice from a pointer, shape, and strides.
In general, custom operations should not create ManagedTensorSlice
instances, but instead use the ones provided by the MAX inference
engine.
__getitem__
__getitem__(self, indices: IndexList[rank]) -> Scalar[dtype]
Gets the value at the specified indices.
Args:
- indices (IndexList): The indices of the value to retrieve.
Returns:
Scalar: The value at the specified indices.
__getitem__(self, *indices: Int) -> Scalar[dtype]
Gets the value at the specified indices.
Args:
- *indices (Int): The indices of the value to retrieve.
Returns:
Scalar: The value at the specified indices.
__setitem__
__setitem__(self, *indices: Int, *, val: Scalar[dtype])
Stores the value at the specified indices.
Args:
__setitem__(self, indices: IndexList[rank], val: Scalar[dtype])
Stores the value at the specified indices.
Args:
get_type_name
get_device_type_name
spec
spec(self) -> RuntimeTensorSpec[dtype, rank]
Gets the TensorSpec of this tensor slice, which provides meta-data about the tensor slice.
Returns:
RuntimeTensorSpec: The static TensorSpec for this tensor slice.
shape
shape(self) -> IndexList[rank]
Gets the shape of this tensor slice, as an IndexList.
Returns:
IndexList: The shape of this tensor slice.
dim_size
dim_size(self, index: Int) -> Int
Gets the size of a given dimension of this tensor slice using a run time value.
Args:
- index (Int): The zero-based index of the dimension.
Returns:
Int: The size of the tensor slice in the given dimension.
dim_size[index: Int](self) -> Int
Gets the size of a given dimension of this tensor slice using a compile time value.
Parameters:
- index (Int): The zero-based index of the dimension.
Returns:
Int: The size of the tensor slice in the given dimension.
strides
strides(self) -> IndexList[rank]
Gets the strides of this tensor slice, as an IndexList.
Returns:
IndexList: The strides of this tensor slice.
stride_length
stride_length(self, index: Int) -> Int
Gets the length of the stride of a given dimension of this tensor slice using a run time value.
Args:
- index (Int): The zero-based index of the dimension.
Returns:
Int: The size of the tensor slice in the given dimension.
stride_length[index: Int](self) -> Int
Gets the length of the stride of a given dimension of this tensor slice using a compile time value.
Parameters:
- index (Int): The zero-based index of the dimension.
Returns:
Int: The size of the tensor slice in the given dimension.
size
size(self) -> Int
Computes the tensor slice's number of elements.
Returns:
Int: The total number of elements in the tensor slice.
unsafe_ptr
unsafe_ptr[_dtype: DType = dtype](self) -> UnsafePointer[Scalar[_dtype]]
Get the pointer stored in this tensor slice.
Since this method obtains the pointer stored in this tensor slice, it can modify the invariants of this tensor slice and lead to unexpected behavior. It should be used with caution.
Parameters:
- _dtype (DType): The type of theUnsafePointerin this tensor slice.
Returns:
UnsafePointer: The UnsafePointer which contains the data for this tensor slice.
load
load[width: Int, _rank: Int, element_alignment: Int = 1](self, index: IndexList[_rank]) -> SIMD[dtype, width]
Gets data from this tensor slice as a SIMD.
Parameters:
- width (Int): The width of theSIMDvalue. This must be large enough to contain the data from this tensor slice.
- _rank (Int): The rank of the tensor slice.
- element_alignment (Int): Indicate the alignment of the pointer stored to memory. This is needed to issue vector load for GPUs with strict alignment requirements.
Args:
- index (IndexList): AnIndexListof size_rankto indicate the dimension of the tensor slice to obtain data from.
Returns:
SIMD: Data from this tensor slice at dimension index.
store
store[width: Int, _rank: Int, element_alignment: Int = 1](self: ManagedTensorSlice[io_spec, static_spec=static_spec], index: IndexList[_rank], val: SIMD[dtype, width])
Sets data in this tensor slice from a SIMD.
Parameters:
- width (Int): The width of theSIMDvalue.
- _rank (Int): The rank of the tensor slice.
- element_alignment (Int): Indicate the alignment of the pointer stored to memory. This is needed to issue vector store for GPUs with strict alignment requirements.
Args:
with_layout
with_layout[new_rank: Int, //, new_static_shape: DimList, new_static_strides: DimList](self, new_runtime_shape: IndexList[new_rank], new_runtime_strides: IndexList[new_rank], offset_ptr: OptionalReg[UnsafePointer[Scalar[dtype]]] = None) -> ManagedTensorSlice[io_spec, static_spec=static_spec.with_layout[dtype, rank, new_rank](new_static_shape, new_static_strides)]
Returns:
to_layout_tensor
to_layout_tensor(self) -> LayoutTensor[dtype, static_spec.to_layout[dtype, rank](), MutableAnyOrigin]
Returns:
LayoutTensor
write_to
write_to(self, mut writer: T)
Formats this buffer to the provided Writer.
Args:
- writer (T): The object to write to.
__repr__
__repr__(self) -> String
Gets the buffer as a string.
Returns:
String: A compact string representation of the buffer.
__str__
__str__(self) -> String
Gets the buffer as a string.
Returns:
String: A compact string of the buffer.
Was this page helpful?
Thank you! We'll create more content like this.
Thank you for helping us improve!
