diff options
author | Ben Wagner <bungeman@google.com> | 2016-10-26 17:48:51 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2016-10-26 22:27:17 +0000 |
commit | 8508f6582fe9c8a92e81e4c434d66b9f629394bc (patch) | |
tree | 25447d1c60019db00e62d5205322d360aa1280a3 | |
parent | 9034b1376430cb9ce753b8b49ef6455e55f2afb3 (diff) |
SkTInsertionSort tweak.
'Unoptomized' insertion sort swaps the 'insert' value multiple times
inside the main loop before it finds its place. However, this has the
advantage that if the 'insert' element is already not less than any
element in the sorted partition no moves are made at all.
The 'optimized' insertion sort present before this CL moves the 'insert'
value into a temporary (creating a 'hole') and then moves already sorted
elements until the 'insert' element finds its place. This has the
disadvantage of always moving the 'insert' element out of the list and
then re-inserting it, even if this was unnecessary.
This CL further optimizes the insertion sort by moving the first test of
the main loop to before moving the 'insert' element into the temporary.
This is expected to increase the code size by a few instructions but
avoids the useless non-moves. There will actually be one fewer
comparison per element comsidered (the initial 'left < hole' predicate
is always true when entering the inner loop).
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=4022
Change-Id: I33158b7781e4dbec1f1b76c0bf43ebe169075733
Reviewed-on: https://skia-review.googlesource.com/4022
Reviewed-by: Mike Klein <mtklein@chromium.org>
Commit-Queue: Ben Wagner <bungeman@google.com>
-rw-r--r-- | src/core/SkTSort.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/src/core/SkTSort.h b/src/core/SkTSort.h index 893af8703a..e76f5c93f7 100644 --- a/src/core/SkTSort.h +++ b/src/core/SkTSort.h @@ -119,12 +119,15 @@ template <typename T> void SkTHeapSort(T array[], size_t count) { /** Sorts the array of size count using comparator lessThan using an Insertion Sort algorithm. */ template <typename T, typename C> static void SkTInsertionSort(T* left, T* right, C lessThan) { for (T* next = left + 1; next <= right; ++next) { + if (!lessThan(*next, *(next - 1))) { + continue; + } T insert = std::move(*next); T* hole = next; - while (left < hole && lessThan(insert, *(hole - 1))) { + do { *hole = std::move(*(hole - 1)); --hole; - } + } while (left < hole && lessThan(insert, *(hole - 1))); *hole = std::move(insert); } } |