mirror of
https://github.com/pytorch/pytorch.git
synced 2025-10-20 21:14:14 +08:00
This reverts commit ca3b2bfbe3945c756a67a784aaa7d9891698c59b. Pull Request resolved: https://github.com/pytorch/pytorch/pull/84806 Approved by: https://github.com/Chillee
44 lines
1.4 KiB
C++
44 lines
1.4 KiB
C++
#include <c10/core/UndefinedTensorImpl.h>
|
|
#include <c10/util/Exception.h>
|
|
|
|
namespace c10 {
|
|
|
|
// should this use the globalContext? Can it get a context passed in somehow?
|
|
UndefinedTensorImpl::UndefinedTensorImpl()
|
|
: TensorImpl(DispatchKey::Undefined, caffe2::TypeMeta(), c10::nullopt) {
|
|
set_storage_access_should_throw();
|
|
// TODO: accessing the sizes on an undefined tensor is not meaningful
|
|
// and should error too, but empirically it does not!
|
|
set_custom_sizes_strides(SizesStridesPolicy::CustomStrides);
|
|
}
|
|
|
|
bool UndefinedTensorImpl::is_contiguous_custom(MemoryFormat format) const {
|
|
return is_contiguous_default(format);
|
|
}
|
|
IntArrayRef UndefinedTensorImpl::strides_custom() const {
|
|
TORCH_CHECK(false, "strides() called on an undefined Tensor");
|
|
}
|
|
SymIntArrayRef UndefinedTensorImpl::sym_strides_custom() const {
|
|
TORCH_CHECK(false, "sym_strides() called on an undefined Tensor");
|
|
}
|
|
|
|
#ifdef DEBUG
|
|
bool UndefinedTensorImpl::has_storage() const {
|
|
TORCH_INTERNAL_ASSERT_DEBUG_ONLY(
|
|
!storage_, "UndefinedTensorImpl assumes that storage_ is never set");
|
|
return false;
|
|
}
|
|
#endif
|
|
|
|
void UndefinedTensorImpl::set_storage_offset(int64_t) {
|
|
TORCH_CHECK(false, "set_storage_offset() called on an undefined Tensor");
|
|
}
|
|
|
|
const char* UndefinedTensorImpl::tensorimpl_type_name() const {
|
|
return "UndefinedTensorImpl";
|
|
}
|
|
|
|
UndefinedTensorImpl UndefinedTensorImpl::_singleton;
|
|
|
|
} // namespace c10
|