CodeTrace: Use std::set::lower_bound() over std::lower_bound()

std::set's lower_bound() is optimized better than the generic
implementation of std::lower_bound()

std::lower_bound() works best on random access iterators, where the
number of comparisons can be logarithmic. However, since std::set's
iterators are bidirectional iterators, the comparisons will actually be
linear in practice when using std::lower_bound().

So, we can use std::set's version which is guaranteed to be logarithmic.
This commit is contained in:
Lioncash 2024-01-23 17:15:21 -05:00
parent f2292467ad
commit 6cb3389696

View File

@ -53,12 +53,11 @@ u32 GetMemoryTargetSize(std::string_view instr)
bool CompareMemoryTargetToTracked(const std::string& instr, const u32 mem_target,
const std::set<u32>& mem_tracked)
{
// This function is hit often and should be optimized.
auto it_lower = std::lower_bound(mem_tracked.begin(), mem_tracked.end(), mem_target);
const auto it_lower = mem_tracked.lower_bound(mem_target);
if (it_lower == mem_tracked.end())
return false;
else if (*it_lower == mem_target)
if (*it_lower == mem_target)
return true;
// If the base value doesn't hit, still need to check if longer values overlap.