From 1d976dd965430143a609c876a7652b7c70c0e7df Mon Sep 17 00:00:00 2001 From: Sidharth Suresh Date: Sat, 9 Nov 2024 13:08:32 +0100 Subject: [PATCH] =?UTF-8?q?move=20\=C2=B4slotMemoryCost=20inside=20the=20c?= =?UTF-8?q?lass\=C2=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/util/HashSet.h | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/src/util/HashSet.h b/src/util/HashSet.h index f638df2ad7..43812260cc 100644 --- a/src/util/HashSet.h +++ b/src/util/HashSet.h @@ -22,20 +22,6 @@ using std::string; namespace ad_utility { -// `slotMemoryCost` represents the per-slot memory cost of a node hash set. -// It accounts for the memory used by a slot in the hash table, which typically -// consists of a pointer (used for node storage) plus any additional control -// bytes required for maintaining the hash set's structure and state. -// This value helps estimate and manage memory consumption for operations that -// involve slots, such as insertion and rehashing. -// -// The value is defined as `sizeof(void*) + 1` bytes, where: -// - `sizeof(void*)` represents the size of a pointer on the platform (usually 4 -// bytes for 32-bit and 8 bytes for 64-bit systems). -// - `+ 1` accounts for an extra control byte used for state management in the -// hash set. -constexpr size_t slotMemoryCost = sizeof(void*) + 1; - // Wrapper for HashSets (with elements of type T) to be used everywhere // throughout code for the semantic search. This wrapper interface is not // designed to be complete from the beginning. Feel free to extend it at need. @@ -69,6 +55,20 @@ class CustomHashSetWithMemoryLimit { SizeGetter sizeGetter_; size_t currentSlotSize_; + // `slotMemoryCost` represents the per-slot memory cost of a node hash set. + // It accounts for the memory used by a slot in the hash table, which + // typically consists of a pointer (used for node storage) plus any additional + // control bytes required for maintaining the hash set's structure and state. + // This value helps estimate and manage memory consumption for operations that + // involve slots, such as insertion and rehashing. + // + // The value is defined as `sizeof(void*) + 1` bytes, where: + // - `sizeof(void*)` represents the size of a pointer on the platform (usually + // 4 bytes for 32-bit and 8 bytes for 64-bit systems). + // - `+ 1` accounts for an extra control byte used for state management in the + // hash set. + constexpr static size_t slotMemoryCost = sizeof(void*) + 1; + public: CustomHashSetWithMemoryLimit( detail::AllocationMemoryLeftThreadsafe memoryLeft,