-
Notifications
You must be signed in to change notification settings - Fork 98
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
Feat: Unimproved score calculation count termination #995
Comments
Hello @storm-TOS, and thanks for reporting. For the use case you described, wouldn't it make more sense to terminate on unimproved step count? That is not only independent of hardware, but also independent of all sorts of solver configuration tweaks. Depending on something as specific as unimproved score calculation count is not something I can recommend. |
Hi @triceo, thanks for sharing your insights. I did consider step count limits, but I think it would not work well in our case. I just solved the same problem twice, and these were the score calculation speeds (SCS) and step counts for each of the six phases:
As you can see, the step counts vary greatly between corresponding phases (e.g. 1030 vs 246 in the fourth phase), whereas the SCS is quite stable. (The phases are hill climbing, tabu, and alternately great deluge and simulated annealing; the final two of the six phases are admittedly mostly ornamental.) Of course, the SCS does vary with the problem input, but in our case not shockingly. Something else that may play a role is that we're doing a form of real time planning, in which the planning facts only undergo small changes, but progressively more entities get pinned. This means that score calculation is relatively stable across runs during the day, while both the doable moves and the improving moves decrease drastically in number (because of pinning and, presumably, because of solution convergence/diminished returns). We would like to use the same configuration for each run (except the very first), but terminating on step limits might get the solver stuck on an early phase for too long. I would also argue that using score calculation count limits instead of time limits is more reliable when adding/modifying constraints; this might lower the SCS, but you'd want to try out the same number of moves (if not more), assuming solution quality is the primary concern. Finally, it is easy enough to tweak any limits if we change the solver configuration at any point, but it is much more inconvenient to scale the time limits whenever something about the environment changes. |
This, I think, is the crux of the issue - that the number of score calculations equals the number of moves. We do not want our users to ever rely on that, because some of the future cool features are likely to break this assumption; such as ruin & recreate moves, or guided local search. There may come a time when a move will result in more than one score calculation. In fact, it could even be true today, because we've never guaranteed the 1:1 ratio. As far as we're concerned, score calculation speed should not be understood as a measure of solver progress, only as a measure of solver performance. |
Interesting to hear about those upcoming features! And I totally understand you don't want to mislead users into relying too much on score calculation measures. I will just leave these final considerations:
Feel free to close this issue if your conclusion is that this feature would be more harmful than beneficial. I could always fork! In any case, thank you for your time. |
@storm-TOS You bring interesting points. We'll think about it a bit more, maybe there is a better way of getting you what you need. |
Sounds good! |
Brief notes from a discussion with some of my colleagues:
|
Thanks for the update! I'll see if I can spare the time. |
Is there a reason why this has not been implemented yet? As far as I am aware, the following terminations are available:
For optimization to be as fast as possible without sacrificing final solution quality, our product relies crucially on unimproved time spent terminations. We use a sequence of short solver phases with very different configurations. If one of the earlier phases terminates too early, the final solution quality degrades severely.
Unfortunately, time based limits cause the solving process to be very dependent on hardware, resource availability, use of multi-threading and node sharing, JVM tweaks, etc. Unimproved score calculation count termination would offer much more reliability.
Since this feature would be so useful to us, I could make a case for implementing it myself. Let me know if you are interested. (I will only be able to respond after next week, though.)
The text was updated successfully, but these errors were encountered: