A Battleship playing script I wrote for fun. It generates random Battleship starting locations and then systematically seeks them out! Play it online here
I was inspired by one of my favorite programming related websites - Data Genetics, which describes on a high level a system of alternately Hunting for ships until you hit one, then Targeting the ship until it sinks. Lacking any actual implementation, I created my own based in Python and Numpy.
data:image/s3,"s3://crabby-images/117ae/117ae1829e0a34c3e7d64be1f2fbb7c476a0dfa4" alt="A display showing the program's view of the board, the actual state, and the probabilities of ships being in a given cell"
data:image/s3,"s3://crabby-images/0cf2e/0cf2e93a1b3d212aa65717f70e9201ea20ee16c9" alt="A graph of varying shades showing relative probabilities of a ship being in any position."
Hunting Mode
This code consists primarily of counting. It takes each ship that hasn’t sunk yet and tries to place it in every possible position across the board. If I shot at a cell and it missed, then a ship cannot be placed in any position overlapping a miss marker. It also cannot overlap a sunk ship. The result is that for each cell I have a number representing how many ships can be fit across the cell, which I interpret as a likelihood. I take just the most likely positions and throw out the rest. I then randomly choose among the most likely and shoot. This process repeats indefinitely until I hit a ship and go into targeting mode.
data:image/s3,"s3://crabby-images/2e7bf/2e7bfa7dcf5211991b349fc46cfcd35ba18f77d7" alt="Shows probabilities of ships"
data:image/s3,"s3://crabby-images/8d779/8d7794cddcd2b1a1fda85aeb95fdbe99e6a1d4cf" alt="The actual locations of ships"
Targeting Mode
Once a new ship is hit every subsequent hit goes to tracking the ship down until it is sunk. This works by adding the neighbors of the hit cell to a list. I then weight this list based on the likelihood of a ship being placed across the board. Once I fully sink a ship I return to Hunting mode until all ships are sunk.
data:image/s3,"s3://crabby-images/f22be/f22bef7f3c51e84587f3499ddd8adc5726846030" alt="Targeting mode showing the hits, misses, and where the program wants to aim next, either left or right of the hits"
Optimizations & Techniques
While in hunting mode, it isn’t necessary to search every cell. For instance, every ship is at least 2 cells long - this means that I can ignore half the board (like shooting white tiles on a chessboard) since once I hit one part of a ship on a ‘white’ cell, I can find the others. I can extend this logic further by adjusting for the shortest remaining ship left. If the shortest ship is 5 cells long the pattern is searching the diagonal of every 5x5 block of cells and ignoring the others until targeting mode kicks in.