From 218e74ab31196ef4e6cb90443f063d758a8cec3c Mon Sep 17 00:00:00 2001 From: Dnomd343 Date: Sun, 15 Jan 2023 03:39:14 +0800 Subject: [PATCH] perf: AllCases search speed --- src/all_cases/all_cases.cc | 40 ++++++-------------------------------- 1 file changed, 6 insertions(+), 34 deletions(-) diff --git a/src/all_cases/all_cases.cc b/src/all_cases/all_cases.cc index eae9596..8d09350 100644 --- a/src/all_cases/all_cases.cc +++ b/src/all_cases/all_cases.cc @@ -113,60 +113,32 @@ void AllCases::build_data() { // find all cases uint32_t sum = 0; for (uint32_t head = 0; head < 16; ++head) { // address of 2x2 block -// for (uint32_t head = 0; head < 1; ++head) { // address of 2x2 block if ((head & 0b11) == 0b11) { continue; // invalid 2x2 address } /// head -> 0/1/2 / 4/5/6 / 8/9/10 / 12/13/14 data[head].reserve(ALL_CASES_SIZE[head]); // memory pre-allocated -// for (const auto &range : *BasicRanges::fetch()) { // check base on 2x2 address and range - -// printf("%08X -> ", Common::range_reverse(range)); - -// if (check_case(head, range) == 0) { -// ++sum; -// } -// printf("ok\n"); -// data[head].emplace_back(Common::range_reverse(range)); // found valid case -// } else { -// printf("error\n"); -// } - -// } - -// continue; uint32_t ret; - auto br = BasicRanges::fetch(); for (auto i = 0; i < br->size(); ++i) { -// printf("%d: %08X -> ", i, Common::range_reverse(br->at(i))); + auto rev = Common::range_reverse((*br)[i]); - if ((ret = check_case(head, br->at(i))) == 0) { + if ((ret = check_case(head, (*br)[i])) == 0) { ++sum; // printf("%08X\n", Common::range_reverse(br->at(i))); -// printf("ok\n"); } else { -// printf("error\n"); auto delta = (uint32_t)1 << (32 - ret * 2); - auto mask = 0xFFFFFFFF << (32 - ret * 2); - auto next_at_least = (Common::range_reverse(br->at(i)) & mask) + delta; -// printf("next at least: %08X\n", next_at_least); - - for (;;) { - ++i; - if (Common::range_reverse(br->at(i)) >= next_at_least) { - --i; - break; - } -// std::cout << "skip -> next" << std::endl; - } + auto next = (rev & ~(delta - 1)) + delta; + + while (Common::range_reverse((*br)[++i]) < next); + --i; }