generated from michael/webpack-base
add tips and a readme
This commit is contained in:
parent
dc7f314298
commit
fa489cdbab
@ -5,12 +5,14 @@
|
|||||||
display: flex;
|
display: flex;
|
||||||
flex-flow: row nowrap;
|
flex-flow: row nowrap;
|
||||||
|
|
||||||
.ui {
|
#ui {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-flow: row nowrap;
|
flex-flow: row nowrap;
|
||||||
align-items: flex-start;
|
align-items: flex-start;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
|
|
||||||
|
margin-bottom: 10px;
|
||||||
|
|
||||||
canvas#board {
|
canvas#board {
|
||||||
margin-right: 20px;
|
margin-right: 20px;
|
||||||
}
|
}
|
||||||
@ -25,4 +27,16 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#tips {
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
:not(:last-child) {
|
||||||
|
margin-right: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: inherit;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -78,15 +78,28 @@ const SnakePage: FC = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div id="snake">
|
<div id="snake">
|
||||||
<div className="ui">
|
<div>
|
||||||
|
<div id="ui">
|
||||||
<canvas id="board" ref={boardRef} width={BOARD_SIZE} height={BOARD_SIZE} />
|
<canvas id="board" ref={boardRef} width={BOARD_SIZE} height={BOARD_SIZE} />
|
||||||
<div className="table-container">
|
<div className="table-container">
|
||||||
<table id="snaps">
|
<table id="snaps">
|
||||||
<thead>{tableHead('Itr', 'Avg', 'Min', '20%', '40%', '60%', '80%', '90%', '95%', 'Max')}</thead>
|
<thead>
|
||||||
|
{tableHead('Itr', 'Avg', 'Min', '20%', '40%', '60%', '80%', '90%', '95%', 'Max')}
|
||||||
|
</thead>
|
||||||
<tbody>{labSnapsTRs}</tbody>
|
<tbody>{labSnapsTRs}</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div id="tips">
|
||||||
|
<div>5,000 snakes per generation</div>
|
||||||
|
<div>Press Spacebar for Slow Motion</div>
|
||||||
|
<div>
|
||||||
|
<a href="https://git.beefslab.com/michael/webai/src/branch/master/src/components/snake">
|
||||||
|
View Repo
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
35
src/components/snake/readme.md
Normal file
35
src/components/snake/readme.md
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# Snake Lab
|
||||||
|
|
||||||
|
Allows you to create neural networks that play snake.
|
||||||
|
|
||||||
|
Clone this repo, install with `npm install`, and run `make serve` to adjust the simulation.
|
||||||
|
|
||||||
|
## Configurable Options:
|
||||||
|
|
||||||
|
| option | description | default |
|
||||||
|
|--------|-------------|---------|
|
||||||
|
| SNAKES | Number of snakes per iteration | 5,000 |
|
||||||
|
| STARVE_STEPS | Number of steps without food before a snake dies of starvation | 120 |
|
||||||
|
| CULL_RATIO | Ratio of snakes that are selected against every iteration | 0.8 (80%) |
|
||||||
|
| MUTATE_RATE | Rate at which individual Perceptron weights are mutated | 0.03 (3%) |
|
||||||
|
| MUTATE_MAG | Maximum magnitude for a Perceptron weight to change if it mutates | 5.0 |
|
||||||
|
| hiddenLayerNodes | Number of nodes in each snake's hidden layer | 6 |
|
||||||
|
|
||||||
|
## Game State Features (See also: `snake-brain.ts`)
|
||||||
|
|
||||||
|
| feature | description |
|
||||||
|
|---------|-------------|
|
||||||
|
| Head Position (x, y) | The position of the snake's head |
|
||||||
|
| Apple Relative to Head (x, y) | The position of the apple relative to the snake's head |
|
||||||
|
| Distance to Tail (+/- x, +/- y) | The distance to the closest square occupied by the snake's tail in 4 directions |
|
||||||
|
|
||||||
|
## Directory Structure
|
||||||
|
|
||||||
|
| file | description |
|
||||||
|
|------|-------------|
|
||||||
|
| brain.ts | General Perceptron Neural Network |
|
||||||
|
| game-engine.ts | Canvas Rendering Tools |
|
||||||
|
| snake-brain.ts | Converts game states into feature vectors and decides movement direction |
|
||||||
|
| hashset.tsx | Hash Set implementation used for detecting cycles |
|
||||||
|
| index.tsx | UI Layer |
|
||||||
|
| canvas.ts | Game Loop & Canvas Rendering Loop |
|
Loading…
Reference in New Issue
Block a user