pytorch/c10/util/SmallBuffer.h
Peter Bell 2a78f6376c TensorIterator: Reduce serial_for_each static overhead (#58909)
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/58909

Test Plan: Imported from OSS

Reviewed By: mruberry

Differential Revision: D28776507

Pulled By: ngimel

fbshipit-source-id: 4f0283d03b26aa5785b687b78d77e6b0efcbaf65
2021-05-30 21:08:54 -07:00

69 lines
1.2 KiB
C++

#pragma once
#include <type_traits>
/** Helper class for allocating temporary fixed size arrays with SBO.
*
* This is intentionally much simpler than SmallVector, to improve performace at
* the expense of many features:
* - No zero-initialization for numeric types
* - No resizing after construction
* - No copy/move
* - No non-trivial types
*/
namespace c10 {
template <typename T, size_t N>
class SmallBuffer {
static_assert(std::is_pod<T>::value, "SmallBuffer is intended for POD types");
T storage_[N];
size_t size_;
T* data_;
public:
SmallBuffer(size_t size) : size_(size) {
if (size > N) {
data_ = new T[size];
} else {
data_ = &storage_[0];
}
}
~SmallBuffer() {
if (size_ > N) {
delete[] data_;
}
}
T& operator[](int64_t idx) {
return data()[idx];
}
const T& operator[](int64_t idx) const {
return data()[idx];
}
T* data() {
return data_;
}
const T* data() const {
return data_;
}
size_t size() const {
return size_;
}
T* begin() {
return data_;
}
const T* begin() const {
return data_;
}
T* end() {
return data_ + size_;
}
const T* end() const {
return data_ + size_;
}
};
} // namespace c10