36 std::map<std::chrono::high_resolution_clock::time_point, MemoryObject>
46 std::chrono::high_resolution_clock::time_point
init_;
51 return std::to_string(bytes) +
"b";
52 else if (bytes < 1024ull * 1024ull)
53 return std::to_string(bytes /
double(1024)) +
"kb";
54 else if (bytes < 1024ull * 1024ull * 1024ull)
55 return std::to_string(bytes /
double(1024 * 1024)) +
"mb";
56 else if (bytes < 1024ull * 1024ull * 1024ull * 1024ull)
57 return std::to_string(bytes /
double(1024 * 1024 * 1024)) +
"gb";
59 return std::to_string(bytes /
double(1024) /
double(1024) /
double(1024) /
68 init_(
std::chrono::high_resolution_clock::now()) {}
79 using namespace std::literals;
81 os <<
"Memory debugger (ID=" << std::to_string(
id) <<
")\n";
83 os <<
"[" << std::right << std::setw(10) << (obj.first -
init_) / 1ns
84 <<
"ns] " << std::right << std::setw(10) << obj.second.name_ <<
" "
85 << std::right << std::setw(10) <<
convert_bytes(obj.second.bytes_)
87 os <<
"[ Total ] " << std::right << std::setw(10) <<
counter_ <<
" "
92 template <
typename T>
void add(
const std::string &name,
const T &obj) {
96 std::pair<std::chrono::high_resolution_clock::time_point, MemoryObject>(
97 std::chrono::high_resolution_clock::now(),
102 void add(
const std::string &name,
const torch::Tensor &tensor) {
104 bytes_ += tensor.element_size() * tensor.numel();
106 std::pair<std::chrono::high_resolution_clock::time_point, MemoryObject>(
107 std::chrono::high_resolution_clock::now(),
108 MemoryObject(name, tensor.element_size() * tensor.numel())));
112 template <
typename T, std::
size_t N>
113 void add(
const std::string &name,
const std::array<T, N> &array) {
114 for (std::size_t i = 0; i < N; ++i)
115 add(name + std::to_string(i), array[i]);
120template <std::
size_t id>
128static MemoryDebugger<std::numeric_limits<std::size_t>::max()>
131#define register_memory(obj) ::iganet::global_memory_debugger.add(#obj, obj)
Memory debugger.
Definition memory.hpp:24
void add(const std::string &name, const std::array< T, N > &array)
Registers std::array to memory debugger.
Definition memory.hpp:113
void add(const std::string &name, const T &obj)
Registers generic type to memory debugger.
Definition memory.hpp:92
void clear()
Clears memory debugger.
Definition memory.hpp:71
MemoryDebugger()
Default constructor.
Definition memory.hpp:66
std::chrono::high_resolution_clock::time_point init_
Reference time point.
Definition memory.hpp:46
int64_t counter_
Counter holding the number of registered objects.
Definition memory.hpp:40
std::string convert_bytes(int64_t bytes) const
Converts bytes into best human-readable unit.
Definition memory.hpp:49
int64_t bytes_
Counter holding the memory of registered objects in bytes.
Definition memory.hpp:43
std::map< std::chrono::high_resolution_clock::time_point, MemoryObject > objects_
Map holding the list of registered objects.
Definition memory.hpp:37
void pretty_print(std::ostream &os=Log(log::info)) const
Returns a string representation of the memory debugger.
Definition memory.hpp:78
void add(const std::string &name, const torch::Tensor &tensor)
Registers torch::Tensor to memory debugger.
Definition memory.hpp:102
Definition boundary.hpp:22
static MemoryDebugger< std::numeric_limits< std::size_t >::max()> global_memory_debugger
System-wide memory debugger.
Definition memory.hpp:129
struct iganet::@0 Log
Logger.
std::ostream & operator<<(std::ostream &os, const Boundary< Spline > &obj)
Print (as string) a Boundary object.
Definition boundary.hpp:1963
Memory object.
Definition memory.hpp:27
int64_t bytes_
Definition memory.hpp:29
MemoryObject(const std::string &name, int64_t bytes)
Definition memory.hpp:31
std::string name_
Definition memory.hpp:28