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) /
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_) / 1
ns
84 <<
"ns] " << std::right << std::setw(10) <<
obj.second.name_ <<
" "
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) {
106 std::pair<std::chrono::high_resolution_clock::time_point, MemoryObject>(
107 std::chrono::high_resolution_clock::now(),
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>
123 obj.pretty_print(
os);
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
constexpr bool is_SplineType_v
Alias to the value of is_SplineType.
Definition bspline.hpp:3243
std::ostream & operator<<(std::ostream &os, const Boundary< Spline > &obj)
Print (as string) a Boundary object.
Definition boundary.hpp:1978
struct iganet::@0 Log
Logger.
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