Implementing the Space Invaders gaming bot
In this section, we will be coding the Space Invaders game using DQN and Q-learning. For coding, we will be using the gym
, TensorFlow
, and virtualenv
libraries. You can refer to the entire code by using this GitHub link: https://github.com/jalajthanaki/SpaceInvaders_gamingbot.
We are using a convolutional neural network (CNN). Here, we have defined the CNN in a separate file. The name of this file is convnet.py
. Take a look at the following screenshot: at the following figure:
data:image/s3,"s3://crabby-images/ffedb/ffedb28191216ba37d199d8dad6ee29299239511" alt=""
Figure 11.16: Code snippet for Convnrt.py
You can refer to the code using this GitHub link: https://github.com/jalajthanaki/SpaceInvaders_gamingbot/blob/master/convnet.py.
We are defining the DQN algorithm in the dqn.py
script. You can refer to the code snippet shown in the following screenshot:
data:image/s3,"s3://crabby-images/4e6b6/4e6b6da38ed52c2243aa89b0186f79211f2492a8" alt=""
Figure 11.17: Code snippet for dqn.py
For training, we have defined our training logic in train.py
. You can refer to the code snippet shown in the following screenshot:
data:image/s3,"s3://crabby-images/1636e/1636e0d26e37fe9fb579c199e79c4ec925d9d069" alt=""
Figure 11.18: Code...