-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.html
132 lines (131 loc) · 7.33 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
<html>
<head>
<meta charset="UTF-8">
<link rel="stylesheet" type="text/css" href="index.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.1.9/p5.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjs/7.2.0/math.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.4/Chart.min.js"></script>
<script src="src/utils.js"></script>
<script src="src/demo-base.js"></script>
<script src="src/neat/connection-gene.js"></script>
<script src="src/neat/node-gene.js"></script>
<script src="src/neat/genome.js"></script>
<script src="src/neat/innovation-entry.js"></script>
<script src="src/neat/innovation-history.js"></script>
<script src="src/neat/species.js"></script>
<script src="src/neat/population.js"></script>
<script src="src/game/space-object.js"></script>
<script src="src/game/ship.js"></script>
<script src="src/game/laser.js"></script>
<script src="src/game/asteroid.js"></script>
<script src="src/game/sensor.js"></script>
<script src="src/game/game.js"></script>
<script src="src/controls.js"></script>
<script src="src/sketch.js"></script>
</head>
<body>
<div class="container">
<div class="element section">
<h1>Asteroids</h1>
<p>
Asteroids is a space-themed multidirectional shooter arcade game where the player controls a single spaceship in an asteroid field which is periodically traversed by flying saucers.
The object of the game is to shoot and destroy the asteroids and saucers, while not colliding with either. Though in this case the saucer is omitted.
</p><br>
<p>
Each spaceship contains a unique brain called a Neural Network which takes a predetermined series of inputs and processes them to obtain a series of outputs.
The values of these outputs determine which of these four actions the spaceship takes: move forward, turn left, turn right or shoot.
</p><br>
<p>
Based on each spaceship's performance each game, the top performers are selected and reproduced in a process that is based off of real life evolution called Neuroevolution.
Each top performer produces offspring with minor mutations in their "genetic" code. Because these mutations are random, they are mostly bad and can lead to offspring performing worse.
However, with a large enough population, every once in a while a good mutation will occur, which will result in that network becoming dominant and produce offspring of their own.
</p><br>
<p>
This app has 3 sections:
</p>
<ol>
<li>
Evolution - This is where you can watch the Neural Networks train and evolve.
I would recommend fast-forwarding through at least the first few generations and then using the replay section to view the top performers.
Because the mutations are random and can have effects ranging from catastrophically bad to a mild improvement, you can basically ignore everything except the top performers.
It also shows some statistics about the current evolutionary state of the population.
</li>
<li>
Replay - This is where you go to choose a replay to watch.
You can choose the top performer based on either their game score, or their fitness score (a background calculation that can be changed in settings).
Use the charts to see which generations did well and seem interesting.
</li>
<li>
Settings - There are a number of settings here that can alter the way the neural network evolves. Change a few settings around and see what happens!
You can also disable the view of the Neural Network and Sensors here.
</li>
</ol>
<h2>Evolution</h2>
<p>
The Neural Networks of the spaceships are categorized into a number of species which help protect innovative mutations and give them time to reach their full potential.
A combination of factors such as how many of nodes they have in common, how the nodes are connected and the strength of those connections help determine how different networks are from each other.
The threshold where networks are considered different species is known as the Compatibility Threshold. Here it auto adjusts to maintain between 3 and 20 species.
</p>
<div class="row">
<div id='nSpeciesLbl' class="column" style="width:15%"></div>
<div id='compatThreshLbl' class="column" style="width:22%"></div>
<div id='genomeDistLbl' class="column" style="width:30%"></div>
</div>
<p>
When an entire population of spaceships have completed their games and reproduced, they have completed a single generation.
As more generations take place, the Neural Networks will grow to be more complex and are able to produce more sophisticated behaviors.
</p>
<div class="row">
<div id='generationLbl' class="column" style="width:15%"></div>
<div id='gameLbl' class="column" style="width:20%"></div>
<div id='scoreLbl' class="column" style="width:10%"></div>
<div id='genSkipLbl' class="column" style="width:23%"></div>
<div id='genSkipInp' class="sliderCol" style="width:20%"></div>
</div>
<div id="cv" style="margin-bottom: 1em"></div>
<h2>Replays</h2>
<p>Use this replay feature to observe the behaviour of the top performing networks for each generation.</p>
<div class="row">
<div class="column" style="width:3%"><p>Type: </p></div>
<div id='replayTypeInp' class="column" style="width:20%"></div>
<div id='replayGenInp' class="column" style="width:20%"></div>
<div id='replayGenPlayPauseInp' style="height:100%; display: flex; align-items: center;"></div>
</div>
<div class="row" style="height:275px;">
<div class="column"><canvas id="chartcv1"></canvas></div>
<div class="column"><canvas id="chartcv2"></canvas></div>
</div>
<h2>Settings</h2>
<div class="row">
<div id='initiallyFullyConnectCb' class="column" style="width:40%"></div>
<div id='showNNCb' class="column" style="width:20%"></div>
<div id='showRaysCb' class="column" style="width:20%"></div>
</div>
<div class="row">
<div id='popSizeLbl' class="column"></div>
<div id='popSizeInp' class="column"></div>
</div>
<div class="row">
<div id='nRaysLbl' class="column"></div>
<div id='nRaysInp' class="column"></div>
</div>
<div class="row">
<div id='lifetimeMultInp' class="column" style="width:33%"></div>
<div id='scoreMultInp' class="column" style="width:33%"></div>
</div>
<div class="row">
<div id='weightMutInp' class="column" style="width:33%"></div>
<div id='newConInp' class="column" style="width:33%"></div>
<div id='newNodeInp' class="column" style="width:33%"></div>
</div>
</div>
</div>
</body>
<footer>
<div class="container">
<h6>
* Link to code repository: <a href="https://immodal.github.io/asteroids/">https://immodal.github.io/asteroids/</a>.
</h6>
</div>
</footer>
</html>