aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar Ben Wagner <bungeman@google.com>2016-10-26 17:48:51 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2016-10-26 22:27:17 +0000
commit8508f6582fe9c8a92e81e4c434d66b9f629394bc (patch)
tree25447d1c60019db00e62d5205322d360aa1280a3
parent9034b1376430cb9ce753b8b49ef6455e55f2afb3 (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.h7
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);
}
}