commons-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Gabriele Rossi" <>
Subject [MATH][MATH-1451] Infinite loop for CycleCrossover with duplicates
Date Fri, 16 Feb 2018 21:11:48 GMT
I posted following issue and was suggested to mail here by Gilles:

I've found an infinite loop when recombining two integers Chromosomes admitting duplicates
with CycleCrossover class.

For example, recombining example Chromosomes it works fine, but, if you substitute all "8"
with "7", you run into an infinite loop while mating.
I attached to the issue the self-contained unit test (JUnit) for a better comprehension (issue
a mvn clean install to run).

I'd suggest to either:
- reduce scope to permutations not allowing duplicates (strictly ordered), which should be
stated by documentation and checked as a precondition by code.
- patch it, creating a CycleCrossoverDuplicates: I quickly applied a patch, which I'd be happy
to provide, nonetheless could be less efficient than original algorithm due to more complex
checks. And programmed by someone who has no knowledge of this code, either :)

Let me know if I can contribute in any way.

Thanks for your attention,

Gabriele Rossi

To unsubscribe, e-mail:
For additional commands, e-mail:

View raw message