Very late.
But I think this will be useful for those that landed here after a search.
I modified the code a bit created by supajason
Because the code provided did not return a consistent result:
Mainly due to the nomenclature used.
I also added some functionality.
Hope it is useful!