simple_sequence.h#

namespace ONNX_LIGHT_NAMESPACE
namespace onnx_backend_test
struct Sequence#
#include <simple_sequence.h>

Sequence — minimal runtime tensor sequence used by backend test cases and reference kernel implementations.

Companion to :cpp:struct:Tensor: where Tensor carries a single tensor value, Sequence carries an ordered list of tensors that share a common element type. Sequence is intentionally separate from TensorProto / SequenceProto and from :cpp:class:onnx_optim::OptimSequence: it is the runtime value of a sequence-typed graph edge (analogous to Tensor being the runtime value of a tensor-typed edge), without any protobuf dependency.

The struct owns its underlying Tensor elements: copying or destroying the Sequence copies or destroys its elements too.

Public Functions

Sequence() = default#
inline Sequence(std::string n, int32_t et, std::vector<Tensor> v)#
inline std::size_t size() const noexcept#

Number of tensors in the sequence.

inline bool empty() const noexcept#

true when the sequence contains no tensors.

inline const Tensor &at(std::size_t i) const#

Random access to the i-th tensor; throws std::out_of_range if i is out of bounds.

inline Tensor &at(std::size_t i)#

Public Members

std::string name#

Optional name of the sequence (input/output name in the test model). May be left empty for intermediate values.

int32_t elem_type = 0#

Element data type shared by every tensor stored in values, expressed as a TensorProto::DataType integer value. Equals TensorProto::DataType::UNDEFINED (0) when values is empty and the element type cannot be inferred.

std::vector<Tensor> values#

Tensor elements of the sequence, in order. All elements must share elem_type; element shapes may differ between elements.