data:image/s3,"s3://crabby-images/4336a/4336a7565bb671f381d6749d2d409a81ef62d66f" alt=""
Build your own Serverless tic tac toe AI using Node.js and (a little bit of) Machine Learning
WIFI
Reactor
Open123!
cd CityJS-Workshop
yarn
yarn run dev
Setup
data:image/s3,"s3://crabby-images/0ccf9/0ccf96a3b279c131fc6cf6a74a93614262f56b59" alt=""
git clone https://github.com/<YOURREPO!>/CityJS-Workshop.git
Intros
data:image/s3,"s3://crabby-images/87a0c/87a0cec59831ff59b710287f5b964ec48b4cdc2c" alt=""
Hew Ingram
@hewingram
beapplied.com
data:image/s3,"s3://crabby-images/a832a/a832a01a2f2e105a71fdf79281107ea171a264b0" alt=""
Thomas Ankcorn
@thomasankcorn
BAE Systems AI
data:image/s3,"s3://crabby-images/e5895/e58953f369a1e2fb8ef83f55299d06cfca7aa31c" alt=""
LNUG
data:image/s3,"s3://crabby-images/e1137/e113735a0906cf2e56e3f7f1d81c28ceba3ff7ec" alt=""
A friendly monthly meetup for people using Node.js for fun or profit.
lnug.org
We are Software Engineers... not data scientists
Important caveat
cd CityJS-Workshop
yarn
yarn run dev
data:image/s3,"s3://crabby-images/0ccf9/0ccf96a3b279c131fc6cf6a74a93614262f56b59" alt=""
git clone https://github.com/<YOURREPO!>/CityJS-Workshop.git
Setup
Let's deploy your fork of the app to netlify.com
- Quickly Deploy to their global CDN
- Deploy golang or node.js functions as a service
- Super simple
- Great developer experience
data:image/s3,"s3://crabby-images/a2d67/a2d6706cec0e783911713cf180280d4ba31868e3" alt=""
Deployment
Step 1 - adding an endpoint
In
src-functions/test.js
add
exports.handler = function(event, context, callback) {
console.log('hello world')
callback(null, {
statusCode: 200,
body: "Hello, World"
});
}
Netlify will build this into an endpoint available at
/test
Step 2 - make the endpoint mildly interesting
The board is stored as an array of length 9
data:image/s3,"s3://crabby-images/af70c/af70c76387ac3a32959763eda1536507f79a2bbe" alt=""
Is stored as:
[1, -1, 0, 1, 1, 0, -1, 0, 0]
Try making the endpoint return back the "next move" (but lets just make the next move be the first available space)
Step 3 - training the neural network
Machine learning made SUPER simple
yarn add brain.js
Step 3 - training the neural network
const net = new brain.NeuralNetwork();
net.train([{input: { r: 0.03, g: 0.7, b: 0.5 }, output: { black: 1 }},
{input: { r: 0.16, g: 0.09, b: 0.2 }, output: { white: 1 }},
{input: { r: 0.5, g: 0.5, b: 1.0 }, output: { white: 1 }}]);
const output = net.run({ r: 1, g: 0.4, b: 0 });
Step 4 - make your endpoint return a better next move
exports.handler = function(event, context, callback) {
const board = JSON.parse(event.body)
const output = net.run(board);
callback(null, {
statusCode: 200,
body: output
});
}
<div @click="things">
I do things when clicked
</div>
Step 5 - make the mode toggle do something
Hook a function up to the click event
modeSwitch() {
this.resetGame()
this.mode = this.mode === "2Player" ? "ai" : "2Player"
}
Define a toggle function
BUT the data isn't there!
export async function getAIMove(board) {
return post('/.netlify/functions/neuralNet', board);
}
Step 6 - get the next move from the backend
Call the endpoint
handleClick: function(position) {
...
if(this.mode === 'ai'){
// do cool AI stuff
}
if(this.win()) {
return
}
this.$emit("turnSwitch");
}
}
Modify the handleClick function to use it
Step 7 - revel in the powerful AI you've created
Or.... not
Workshop
By hewingram
Workshop
- 205