I’m working on a board game algorithm where a large tree is traversed using recursion, however, it’s not behaving as expected. How do I handle this and what are you experiences with these situations?
To make things worse, it’s using alpha-beta pruning which means entire parts of the tree are never visited, as well that it simply stops recursion when certain conditions are met. I can’t change the search-depth to a lower number either, because while it’s deterministic, the outcome does vary by how deep is searched and it may behave as expected at a lower search-depth (and it does).
Now, I’m not gonna ask you “where is the problem in my code?” but I am looking for general tips, tools, visualizations, anything to debug code like this. Personally, I’m developing in C#, but any and all tools are welcome. Although I think that this may be most applicable to imperative languages.
Logging. Log in your code extensively. In my experience, logging is THE solution for these types of problems. when it’s hard to figure out what your code is doing, logging it extensively is a very good solution, as it lets you output from within your code what the internal state is; it’s really not a perfect solution, but as far as I’ve seen, it works better than using any other method.