Batch GCD is an algorithm which was created by D. J. Bernstein to be able to attempt to factor RSA keys, cf. FactHacks: Batch gcd. It has successfully been used in the paper Mining Your Ps and Qs: Detection of Widespread Weak Keys in Network Devices to factor real world keys.
Wondering what was the proper way to parallelize such problems and ran into the Fork/Join idea from Doug Lea's paper, A Java Fork/Join Framework. Batch GCD is a prime candidate for this kind of parallelization since the algorithm involves two tree traversals.
In order to check whether this works there's a simple main
method that can
either solves Nat McHugh's ssh key factoring
challenge
or factor real world moduli from the Sonar SSL certificates
dataset (see:
./src/main/resources/certs/extract-moduli.sh
in order to download/extract
some moduli yourself).
Unit tests will be written one day, but so far it was more fun to play with real world moduli.
If you're looking for more resources on Batch GCD or Fork Join, you might find those links helpful:
Running the project should be a matter of runing the following:
./gradlew run