24 #ifndef TVM_TIR_BUFFER_H_
25 #define TVM_TIR_BUFFER_H_
103 v->Visit(
"data", &
data);
104 v->Visit(
"dtype", &
dtype);
105 v->Visit(
"shape", &
shape);
109 v->Visit(
"name", &
name);
113 v->Visit(
"span", &
span);
167 PrimExpr elem_offset,
String name,
int data_alignment,
int offset_factor,
280 return this == other;
285 static constexpr
const char*
_type_key =
"tir.DataProducer";
314 std::string name,
int data_alignment,
315 int offset_factor,
bool compact,
316 std::string memory_scope =
"");
Runtime Array container types.
Visitor class to get the attributes of an AST/IR node. The content is going to be called for each fie...
Definition: reflection.h:52
Managed reference class to IntImmNode.
Definition: expr.h:520
Reference to PrimExprNode.
Definition: expr.h:114
A Reducer class to reduce the structural equality result of two objects.
Definition: structural_equal.h:124
A Reducer class to reduce the structural hash value.
Definition: structural_hash.h:110
void DefHash(const ObjectRef &key) const
Push hash of key to the current sequence of hash values.
Definition: structural_hash.h:187
Definition: source_map.h:120
Array, container representing a contiguous sequence of ObjectRefs.
Definition: array.h:289
Runtime primitive data type.
Definition: data_type.h:42
static DataType Float(int bits, int lanes=1)
Construct an float type.
Definition: data_type.h:190
static DataType Int(int bits, int lanes=1)
Construct an int type.
Definition: data_type.h:176
static DataType Handle(int bits=64, int lanes=1)
Construct a handle type.
Definition: data_type.h:222
Base class of all object reference.
Definition: object.h:517
base class of all object containers.
Definition: object.h:169
Optional container that to represent to a Nullable variant of T.
Definition: optional.h:51
Reference to string objects.
Definition: string.h:98
Node to represent a buffer.
Definition: buffer.h:49
String name
optional name of the buffer
Definition: buffer.h:84
static constexpr const char * _type_key
Definition: buffer.h:150
Span span
Span that points to the original source code. Reserved debug information.
Definition: buffer.h:98
BufferNode()
constructor
Definition: buffer.h:100
BufferType buffer_type
buffer type
Definition: buffer.h:93
Var data
The pointer to the head of the data.
Definition: buffer.h:56
static constexpr const bool _type_has_method_sequal_reduce
Definition: buffer.h:151
Array< PrimExpr > shape
The type of the buffer prior to flattening.
Definition: buffer.h:65
void SHashReduce(SHashReducer hash_reduce) const
Definition: buffer.h:126
void VisitAttrs(AttrVisitor *v)
Definition: buffer.h:102
PrimExpr elem_offset
The offset in terms of number of dtype elements (including lanes)
Definition: buffer.h:81
static constexpr const bool _type_has_method_shash_reduce
Definition: buffer.h:152
TVM_DECLARE_FINAL_OBJECT_INFO(BufferNode, Object)
int offset_factor
Factor of elem_offset field, elem_offset is guaranteed to be multiple of offset_factor.
Definition: buffer.h:91
Array< IntImm > axis_separators
Separators between input axes when generating flattened output axes.
Definition: buffer.h:74
int data_alignment
Alignment requirement of data pointer in bytes.
Definition: buffer.h:86
TVM_OBJECT_ENABLE_SCRIPT_PRINTER()
Array< PrimExpr > strides
The strides of each dimension This can be an empty array, indicating array is contiguous.
Definition: buffer.h:79
DataType DefaultIndexType() const
Definition: buffer.h:138
DataType dtype
data type in the content of the tensor
Definition: buffer.h:58
Array< PrimExpr > ElemOffset(Array< PrimExpr > index) const
Determine the offset in the buffer of the given index.
bool SEqualReduce(const BufferNode *other, SEqualReducer equal) const
Definition: buffer.h:116
Buffer is a symbolic n-darray structure. It is a composition of primitive symbolic types,...
Definition: buffer.h:162
Stmt vstore(Array< PrimExpr > begin, PrimExpr value) const
Create a Stmt that does a vector store at begin index.
Array< PrimExpr > OffsetOf(Array< PrimExpr > index) const
Determine the offset in the buffer of the given index.
String scope() const
Return the storage scope associated with this buffer.
TVM_DEFINE_OBJECT_REF_COW_METHOD(BufferNode)
PrimExpr vload(Array< PrimExpr > begin, DataType dtype) const
Create an Expr that does a vector load at begin index.
Buffer MakeStrideView() const
Return a new buffer that is equivalent with current one but always add stride field.
Buffer(Var data, DataType dtype, Array< PrimExpr > shape, Array< PrimExpr > strides, PrimExpr elem_offset, String name, int data_alignment, int offset_factor, BufferType buffer_type, Array< IntImm > axis_separators={}, Span span=Span())
Buffer MakeSlice(Array< PrimExpr > begins, Array< PrimExpr > extents) const
Make a new symbolic buffer representing a slice of the buffer.
TVM_DEFINE_OBJECT_REF_METHODS(Buffer, ObjectRef, BufferNode)
Buffer GetFlattenedBuffer() const
Get a flattened version of the buffer.
PrimExpr access_ptr(int access_mask, DataType ptr_type=DataType::Handle(), int content_lanes=1, PrimExpr offset=IntImm(DataType::Int(32), 0), Optional< PrimExpr > input_extent=NullOpt) const
Get access ptr to the entire buffer.
Base node for data producers.
Definition: buffer.h:258
static constexpr const bool _type_has_method_sequal_reduce
Definition: buffer.h:286
static constexpr const char * _type_key
Definition: buffer.h:285
TVM_DECLARE_BASE_OBJECT_INFO(DataProducerNode, Object)
virtual DataType GetDataType() const =0
Get the data type of the result.
void SHashReduce(SHashReducer hash_reduce) const
Definition: buffer.h:283
static constexpr const bool _type_has_method_shash_reduce
Definition: buffer.h:287
bool SEqualReduce(const DataProducerNode *other, SEqualReducer equal) const
Definition: buffer.h:278
virtual Array< PrimExpr > GetShape() const =0
Get the shape of the result.
virtual String GetNameHint() const =0
Get the name hint of the data producer.
virtual ~DataProducerNode()
destructor.
Definition: buffer.h:261
Managed reference to DataProducerNode.
Definition: buffer.h:295
TVM_DEFINE_OBJECT_REF_METHODS(DataProducer, ObjectRef, DataProducerNode)
Container of all statements.
Definition: stmt.h:59
a named variable in TIR
Definition: var.h:88
tvm::Span Span
Definition: base.h:65
constexpr const char * axis_separators
Marks the physical axis separators.
Definition: stmt.h:1454
Buffer decl_buffer(Array< PrimExpr > shape, DataType dtype=DataType::Float(32), String name="buffer", String storage_scope="", Array< IntImm > axis_separators={}, Span span=Span())
Construct a new buffer given shape, and dtype.
BufferType
buffer type
Definition: buffer.h:42
@ kAutoBroadcast
Definition: buffer.h:45
@ kDefault
Definition: buffer.h:43
tir::Buffer BufferWithOffsetAlignment(Array< PrimExpr > shape, DataType dtype, std::string name, int data_alignment, int offset_factor, bool compact, std::string memory_scope="")
Creates TIR Buffer for provided parameters.
Tensor shape(const Tensor &src, DataType dtype, const std::string name="T_shape", const std::string tag=kInjective)
Get the shape of input tensor.
Definition: transform.h:1766
runtime implementation for LibTorch/TorchScript.
Definition: analyzer.h:36
PrimExpr equal(PrimExpr a, PrimExpr b, Span span=Span())
equal
constexpr runtime::NullOptType NullOpt
Definition: optional.h:169
Runtime String container types.