catoxliu / ml-agents-demo

Play around with ML-Agents of Unity3D and TensorFlow.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

ml-agents-demo

This is a simple repo for playing with Unity3D ML-Agents.

Simple Car

This demo will try to use ML-Agent to play a simple car game.

Assets Used in AssetStore

What I want to do

No path finding or drive along the winding path. I build up a simple endless highway on which the player should drive in traffic and dodge other vehicles, like the Arcade Game. Then I add a camera, which can generate a depth texture, on front of player's car. The goal is to train an agent to control the car depending on learning the depth texture.

What I have done

  • The first problem is that ML-Agents could not use Depth Texture as Visual Observation directly. This is one of limitations of visual observations, so I decide to just use vector observations to transfer the depth texture data. While the PPO model will deal with visual observations and vector ones in different ways. (only CNN for visual ones). I make my own custom trainer and model which will reshape vector inputs into images format and feed it into convolutional layers.
  • I tried the PPO model and got no luck. In the very beginning, I want the agent to action like human player. Every frame it collects the depth texture and then decide to turn left or right, or just stay straight. If it crashes a car or drive out the road, the agent will be reset with a negative reward, otherwise it could get a tiny reward. I tried several reward formulas and the agent would rather just stay straight forever or action randomly. I also tried "On Demand Decisions", and it changed nothing.
  • Then I suppose to simplify the game, which is that the agent only needs to tell whether there is a vehicle in front of it or not. In general, a simple depth texture classifier could get the job done. However, PPO model is not designed for this kind of tasks and I wasted another bunch of time to realize that. Thus I change the my trainer to take the reward as the label to the observation and use the same loss function and optimizer to BehavioralCloningTrainer. Finally, I got a worked agent :)
  • After learning some examples on OpenAI gym, I got more understanding about PPO model.Then I back to try to figure out a model for this. I made up a new academy with curriculum learning, which could train the model from easy level to hard one. And I choose the use a single channel ( White and Black ) texture instead of depth texture, (because I'm told that a color texture carries more 'info' than depth texture). The CNN network is the same to former one. And I also use multiple agents to speed up the trainning. After days of tuning the parameters and test, finnally I got a working model. It's still not perfect, but it's the best result I achieved right now :)

PPO Model after 1 Million steps trainning

Results

PPO Model after 1 Million steps trainning

Observation

An agent camera on front of the player car which will collect a 40*16 White and Black texture and send it as a 640-float vector observation to brain. The texture could be seen on left-top corner of the screen.

Output Actions

The PPO model only gives back a float number, which will be clamp to (-1, 1). It is used for player to steer (by a factor like 0.6).

Reward

If player hit a vehicle, reward -1. If player drive out the road (hit the invisible wall in fact), reward -1. If player pass by a vehicle, reward 1. And every step, reward the 1.0f / maxStep * square(1 - ratio). The ratio is the distance between player's center to the nearest road center divided by the half of road width. Simply speaking, the near player stay to road center, the more reward.

Trainning Config

I spent days on tuning these parameters, and this is used for this model with curriculum learning.

batch_size: 128
buffer_size: 1280
time_horizon: 64
num_layers: 1
hidden_units: 32
beta: 0.01
gamma: 0.995
lambd: 0.95
epsilon: 0.1
learning_rate: 1.0e-4
max_steps: 1.0e6

Custom Model with Only Danger Detection

Results

Results of Custom Model with Only Danger Detection

Observation

An agent camera on front of the player car which will collect a 40*16 depth texture and send it as a 640-float vector observation to brain. The depth texture could be seen on left-top corner of the screen.

Output Actions

Brain gives agent 2 discrete action: 0 for nothing ahead, 1 for danger. If 1 is received and then player car will change its track automatically.

Reward

Reward is label. So SetReward(0) if no vehicle in front of player (around 10 meters ahead, it could be adjusted) or SetReward(1). In training mode, I will let the player change its track as late as possible, which will generate more "efficient" data.

Custom Model with Danger&Tracks Detection

Results

Results of Custom Model with Danger&Tracks Detection

Observation

The same to DangerDetection one.

Output Actions

Expand action on the basis of DangerDetection. 0x00 means nothing ahead. 0x01 means ahead vehicle is on right side track. 0x10 means ahead vehicle is on middle track. 0x11 means ahead vehicle is on left track. And this time, player will only steer 1 meter per frame.

Reward

The same, reward is label.

About

Play around with ML-Agents of Unity3D and TensorFlow.


Languages

Language:C# 71.5%Language:Python 27.5%Language:Jupyter Notebook 0.8%Language:ShaderLab 0.2%Language:Batchfile 0.0%