For a long time, I've wanted to make a project that implemented Conway's Game of Life in electronics, as a kind of creating-for-its-own-sake thing. The Game of Life (GoL) is a program that computes the 'evolution' of a population of cells on a square, 2-D plane. It has some interesting computational properties, but I was mostly interested in it because, when observed over time, the cells have a kind of ordered chaos aesthetic.
My original yen (more than a decade ago) was to just build a HUGE matrix of LEDs and use them to display the ongoing evolution via GoL of a random starting seed state. However, this is A) expensive, in both space and currency; and B) not novel any more. There have been a number of physical GoL implementations; in fact, you can buy a kit for a four-by-four matrix which can be tiled with other kits to make an arbitrarily large GoL implementation.
Playing around with the idea, I recently decided to make something out of the GoL with a triangular tessellation, rather then the usual square grid. Fortunately, there was some literature on this subject (Bays, Carter. Cellular Automata in the Triangular Tesselation. Complex Systems 8 (1994) 127-150), so I didn't have to reinvent the wheel; additionally, his work specified which GoL rules would lead to interesting behavior. He also discovered several glider patterns, so that I could incorporate them into non-random, pre-specified seed states if I so wanted.
I made a quick-and-dirty triangular tessellation display, as seen in the video below; I hooked it up to an ATXMEGA32A4U with a firmware that would start with a pattern, then allow it to evolve over time until there are no cells left, at which point it would reset to the original test state.
My goal was to create independent 5-by-5 triangular units which could be used as the faces of an icosahedron. However, this ended up requiring a LOT of microcontrollers and a LOT of by-hand jumper soldering, owing to difficulties in routing one tiny board with a big microcontroller on one side. I've since settled on a design which uses one microcontroller per four faces; this made the routing easier (in only have to solder the edges of the triangles together, with on jumpers) and significantly reduced the overall project cost, since I would only need five microcontrollers instead of 20.
At present, I have the set of boards for the matched four triangular faces designed, and the bill of materials for the faces set. I just need to double-check those boards, design the power supply circuitry for the center of the icosahedron, add a board for V2 of the turn signal gloves, finish my doctoral thesis, sit for the USPTO registration examination and start my new job. i expect to resume work on this project sometime after Labor Day. 2014.
My original yen (more than a decade ago) was to just build a HUGE matrix of LEDs and use them to display the ongoing evolution via GoL of a random starting seed state. However, this is A) expensive, in both space and currency; and B) not novel any more. There have been a number of physical GoL implementations; in fact, you can buy a kit for a four-by-four matrix which can be tiled with other kits to make an arbitrarily large GoL implementation.
Playing around with the idea, I recently decided to make something out of the GoL with a triangular tessellation, rather then the usual square grid. Fortunately, there was some literature on this subject (Bays, Carter. Cellular Automata in the Triangular Tesselation. Complex Systems 8 (1994) 127-150), so I didn't have to reinvent the wheel; additionally, his work specified which GoL rules would lead to interesting behavior. He also discovered several glider patterns, so that I could incorporate them into non-random, pre-specified seed states if I so wanted.
I made a quick-and-dirty triangular tessellation display, as seen in the video below; I hooked it up to an ATXMEGA32A4U with a firmware that would start with a pattern, then allow it to evolve over time until there are no cells left, at which point it would reset to the original test state.
My goal was to create independent 5-by-5 triangular units which could be used as the faces of an icosahedron. However, this ended up requiring a LOT of microcontrollers and a LOT of by-hand jumper soldering, owing to difficulties in routing one tiny board with a big microcontroller on one side. I've since settled on a design which uses one microcontroller per four faces; this made the routing easier (in only have to solder the edges of the triangles together, with on jumpers) and significantly reduced the overall project cost, since I would only need five microcontrollers instead of 20.
At present, I have the set of boards for the matched four triangular faces designed, and the bill of materials for the faces set. I just need to double-check those boards, design the power supply circuitry for the center of the icosahedron, add a board for V2 of the turn signal gloves, finish my doctoral thesis, sit for the USPTO registration examination and start my new job. i expect to resume work on this project sometime after Labor Day. 2014.
No comments:
Post a Comment