123456789101112131415161718192021222324252627282930313233343536373839404142 |
- #pragma once
- #include <c10/macros/Export.h>
- namespace c10 {
- struct TensorImpl;
- }
- namespace at {
- class TensorBase;
- // MemOverlap: Whether or not there is memory overlap
- //
- // No: Absolutely no memory overlap
- // Yes: Absolutely yes memory overlap
- // TooHard: There might be memory overlap, but it was too expensive to compute.
- //
- // NB: Please update the python test for these if you renumber them.
- enum class MemOverlap { No, Yes, TooHard };
- enum class MemOverlapStatus { Full, Partial, No, TooHard };
- TORCH_API MemOverlap has_internal_overlap(const TensorBase& t);
- TORCH_API MemOverlap has_internal_overlap(c10::TensorImpl* t);
- TORCH_API void assert_no_internal_overlap(const TensorBase& t);
- TORCH_API void assert_no_internal_overlap(c10::TensorImpl* t);
- TORCH_API MemOverlapStatus
- get_overlap_status(const TensorBase& a, const TensorBase& b);
- TORCH_API MemOverlapStatus
- get_overlap_status(c10::TensorImpl* a, c10::TensorImpl* b);
- TORCH_API void assert_no_partial_overlap(
- const TensorBase& a,
- const TensorBase& b);
- void assert_no_partial_overlap(c10::TensorImpl* a, c10::TensorImpl* b);
- TORCH_API void assert_no_overlap(const TensorBase& a, const TensorBase& b);
- TORCH_API void assert_no_overlap(c10::TensorImpl* a, c10::TensorImpl* b);
- } // namespace at
|