-
Notifications
You must be signed in to change notification settings - Fork 558
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Change list.sort to use Hoare partitioning #1146
base: main
Are you sure you want to change the base?
Conversation
wren-lang#1141 identified two problems with the existing implementation, namely that is was very slow when presented with lists which were already sorted or all the same. The purpose of this PR is to fix these problems by switching from Lomuto to Hoare partitioning. As far as 'random' lists are concerned, the figures in the above issue indicate that there will be no noticeable change in performance for small lists and possibly a small improvement for large lists. This change will be invisible to users as only two private methods are affected. No change is required to either the documentation or tests.
How do I change wren_core.wren.inc to match these changes? It says not to edit it as it will be generated automatically but that doesn't seem to have happened here. |
util/wren_to_c_string.py src/vm/wren_core.wren.inc src/vm/wren_core.wren But wait I have some minor style code to submit, before you rebase your change. |
Ah, so there's a Python utility to do this which we need to run manually. OK, thanks I'll do that later after we've agreed any changes. I've based the implementation here on the Wikipedia pseudo-code which is said to be taken from the 'Introduction to Algorithms' book by T.H.Cormen and others. As it uses Also, don't forget that we can't change the comparator function here from a simple true/false to three-state as it will break existing code which uses a custom comparator. It's not necessary to do so in any case as quicksort is an unstable algorithm and so the order of elements comparing equal is not guaranteed to be maintained. |
Any suggested changes here? If not, I'll regenerate |
Well there the minor code changes, in the reviews. Else there is the proposition in the reviews, that could maybe simplify code a little. Thought I didn't checked if it was safe. |
What reviews are those? The only comment you made about the code in #1141 was:
I couldn't see how it could be optimized myself because we have no choice but to use a comparator function. |
Look at the pull request log. There are 3 reviews opened. 2 about minor
code style, with missing space around binary operators. And 1 about a
possible improvement, where I wonder if adding an early check, could avoid
to have 3 condition, instead of 1. Last one is an open question.
|
Well there must be something wrong somewhere as github is telling me there are Are you sure you've posted them and they're not just in draft? |
OK, thanks, I've incorporated all three of your points into the PR. Everything seems to be working fine including the degenerate cases when the list is empty or has only one element. |
Seems good enough. |
Well, back in the day, sorting implementations would typically use insertion sort for small lists (less than 10 elements say) and quicksort for larger lists. We could still do that here (inserton sort is only about 12 lines) but with modern hardware you'd only notice the difference if, say, you were sorting a large number of small lists in a loop. Frankly, I doubt whether it's worth it for core. |
#1141 identified two problems with the existing implementation, namely that is was very slow when presented with lists which were already sorted or all the same.
The purpose of this PR is to fix these problems by switching from Lomuto to Hoare partitioning. As far as 'random' lists are concerned, the figures in the above issue indicate that there will be no noticeable change in performance for small lists and possibly a small improvement for large lists.
This change will be invisible to users as only two private methods are affected. No change is required to either the documentation or tests.