I would prefer to get rid of the special case because it's more code, and even
with it, we still have to get the general case correct in corner cases where the
set of candidates runs empty, e.g. because we have included all possible
patterns. (By "empty" here I mean "logically empty", e.g. full of 0 entries.)
To avoid problems like in issue408, one thing we could try to do is break up the
hill_climbing method into smaller chunks. I think it is so large that it is very
easy to introduce bugs at the moment.
|