From 6bdcf74ad91e0efaa8c2e4339f5085fde8a7982b Mon Sep 17 00:00:00 2001 From: Douglas Rumbaugh Date: Sat, 5 Apr 2025 19:08:12 -0400 Subject: working commit (temporary progress, doesn't build) --- include/framework/reconstruction/BackgroundTieringPolicy.h | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) (limited to 'include/framework/reconstruction/BackgroundTieringPolicy.h') diff --git a/include/framework/reconstruction/BackgroundTieringPolicy.h b/include/framework/reconstruction/BackgroundTieringPolicy.h index ab19e24..36556a2 100644 --- a/include/framework/reconstruction/BackgroundTieringPolicy.h +++ b/include/framework/reconstruction/BackgroundTieringPolicy.h @@ -21,8 +21,8 @@ class BackgroundTieringPolicy : public ReconstructionPolicy get_reconstruction_tasks( const Version *version, LockManager &lock_mngr) const override { @@ -34,7 +34,7 @@ public: return {}; } - level_index target_level = find_reconstruction_target(levels); + level_index target_level = find_reconstruction_target(levels, version->get_structure()->get_record_count()); assert(target_level != -1); level_index source_level = 0; @@ -68,11 +68,11 @@ public: } private: - level_index find_reconstruction_target(LevelVector &levels) const { + level_index find_reconstruction_target(LevelVector &levels, size_t reccnt) const { level_index target_level = invalid_level_idx; for (level_index i = 1; i < (level_index)levels.size(); i++) { - if (levels[i]->get_shard_count() + 1 <= capacity()) { + if (levels[i]->get_shard_count() + 1 <= capacity(reccnt)) { target_level = i; break; } @@ -81,9 +81,10 @@ private: return target_level; } - inline size_t capacity() const { return m_scale_factor; } + inline size_t capacity(size_t reccnt) const { return m_scale_factor * std::pow(std::log(reccnt), m_size_modifier); } size_t m_scale_factor; size_t m_buffer_size; + size_t m_size_modifier; }; } // namespace de -- cgit v1.2.3