A few weeks ago, I took the copy of MENACE that I built to Manchester Science Festival, where it played around 300 games against the public while learning to play Noughts and Crosses. The group of us operating MENACE for the weekend included Matt Parker, who made two videos about it. Special thanks go to Matt, plus Katie Steckles, Alison Clarke, Andrew Taylor, Ashley Frankland, David Williams, Paul Taylor, Sam Headleand, Trent Burton, and Zoe Griffiths for helping to operate MENACE for the weekend.
As my original post about MENACE explains in more detail, MENACE is a machine built from 304 matchboxes that learns to play Noughts and Crosses. Each box displays a possible position that the machine can face and contains coloured beads that correspond to the moves it could make. At the end of each game, beads are added or removed depending on the outcome to teach MENACE to play better.


On Saturday, MENACE was set up with 8 beads of each colour in the first move box; 3 of each colour in the second move boxes; 2 of each colour in third move boxes; and 1 of each colour in the fourth move boxes. I had only included one copy of moves that are the same due to symmetry.
The plot below shows the number of beads in MENACE's first box as the day progressed.


Originally, we were planning to let MENACE learn over the course of both days, but it learned more quickly than we had expected on Saturday, so we reset is on Sunday, but set it up slightly differently. On Sunday, MENACE was set up with 4 beads of each colour in the first move box; 3 of each colour in the second move boxes; 2 of each colour in third move boxes; and 1 of each colour in the fourth move boxes. This time, we left all the beads in the boxes and didn't remove any due to symmetry.
The plot below shows the number of beads in MENACE's first box as the day progressed.

The data

You can download the full set of data that we collected over the weekend here. This includes the first two moves and outcomes of all the games over the two days, plus the number of beads in each box at the end of each day. If you do something interesting (or non-interesting) with the data, let me know!

Similar posts

Visualising MENACE's learning
Building MENACEs for other games
MENACE in fiction


Comments in green were written by me. Comments in blue were not written by me.
WRT the comment 2017-11-17, and exactly one year later, I had the same thing happen whilst running MENACE in a 'Resign' loop for a few hours, unattended. When I returned, the orange overlay had appeared, making the screen quite difficult to read on an iPad.
On the JavaScript version, MENACE2 (a second version of MENACE which learns in the same way, to play against the original) keeps setting the 6th move as NaN, meaning it cannot function. Is there a fix for this?
what would happen if you loaded the boxes slightly differently. if you started with one bead corresponding to each move in each box. if the bead caused the machine to lose you remove only that bead. if the game draws you leave the bead in play if the bead causes a win you put an extra bead in each of the boxes that led to the win. if the box becomes empty you remove the bead that lead to that result from the box before
Hi, I was playing with MENACE, and after a while the page redrew with a Dragon Curves design over the top. MENACE was still working alright but it was difficult to see what I was doing due to the overlay. I did a screen capture of it if you want to see it.
 Add a Comment 

I will only use your email address to reply to your comment (if a reply is needed).

Allowed HTML tags: <br> <a> <small> <b> <i> <s> <sup> <sub> <u> <spoiler> <ul> <ol> <li>
To prove you are not a spam bot, please type "ddo" backwards in the box below (case sensitive):


Show me a random blog post

Jul 2020

Happy τ+e-6 Approximation Day!

May 2020

A surprising fact about quadrilaterals
Interesting tautologies

Mar 2020

Log-scaled axes

Feb 2020

PhD thesis, chapter ∞
PhD thesis, chapter 5
PhD thesis, chapter 4
PhD thesis, chapter 3
Inverting a matrix
PhD thesis, chapter 2

Jan 2020

PhD thesis, chapter 1
Gaussian elimination
Matrix multiplication
Christmas (2019) is over
▼ show ▼
▼ show ▼
▼ show ▼
▼ show ▼
▼ show ▼
▼ show ▼
▼ show ▼
▼ show ▼


manchester science festival matrix of cofactors propositional calculus hexapawn convergence approximation chebyshev graphs chess game of life puzzles a gamut of games inverse matrices logic radio 4 bodmas sound news squares preconditioning matt parker captain scarlet frobel royal institution big internet math-off christmas menace folding paper manchester twitter arithmetic data visualisation plastic ratio binary people maths the aperiodical geogebra latex nine men's morris python exponential growth dragon curves harriss spiral london underground braiding mathslogicbot reuleaux polygons game show probability light logs interpolation golden spiral video games dataset boundary element methods golden ratio mathsjam christmas card bubble bobble go craft bempp final fantasy graph theory flexagons world cup advent calendar sorting polynomials countdown wave scattering quadrilaterals gaussian elimination books draughts football gerry anderson pac-man speed fractals royal baby electromagnetic field geometry palindromes stickers tmip programming pythagoras error bars realhats machine learning phd weak imposition mathsteroids misleading statistics computational complexity pi matrix multiplication trigonometry accuracy chalkdust magazine wool tennis triangles games matrix of minors rugby noughts and crosses numerical analysis martin gardner folding tube maps javascript signorini conditions map projections estimation statistics london ternary finite element method matrices reddit determinants platonic solids raspberry pi pizza cutting oeis data simultaneous equations php rhombicuboctahedron asteroids talking maths in public hannah fry coins inline code sobolev spaces cross stitch pi approximation day european cup ucl national lottery sport hats dates cambridge probability curvature weather station


Show me a random blog post
▼ show ▼
© Matthew Scroggs 2012–2020