BrickUsingMultipleModules: Unterschied zwischen den Versionen
(Switch to english, manuals, pictures from make) |
(→Make Rhein-Main 2017) |
||
(5 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
− | BrickUsingMultipleModules (short: | + | BrickUsingMultipleModules (short: '''BUMM''') is a riddle game themed around bomb defusals. After an evening of playing [http://www.keeptalkinggame.com/ Keep talking and nobody explodes], I was sure that this had to be transferred to hardware. The goal of defusing multiple modules is the same, but the hardware implementation calls for some serious changes. Cutting wires was out of the question, since nobody was found to replace them for a new round. Maybe someone will build a robot arm for that in the future. |
== Pictures == | == Pictures == | ||
Zeile 36: | Zeile 36: | ||
Image:BUMM gui.png|Remote control with countdown, life counter, serial number, configuration and status for each module | Image:BUMM gui.png|Remote control with countdown, life counter, serial number, configuration and status for each module | ||
</gallery> | </gallery> | ||
+ | |||
+ | === Basic test video === | ||
+ | https://streamable.com/lxtuu | ||
== Background == | == Background == | ||
Zeile 51: | Zeile 54: | ||
All material, be it gamemaster scripts, arduino code, *.tex for manuals or svg files for lasercutting are available on [https://github.com/hackffm/BrickUsingMultipleModules github]. | All material, be it gamemaster scripts, arduino code, *.tex for manuals or svg files for lasercutting are available on [https://github.com/hackffm/BrickUsingMultipleModules github]. | ||
+ | |||
+ | == Modules == | ||
+ | |||
+ | === Gates module === | ||
+ | The gates module has 7 LEDs, 4 toggle switches and a push button (looking like a switch). | ||
+ | Depending on the status of the LEDs, the toggle switches have to be set correctly, then the RUN button has to be pressed. | ||
+ | There are two instances of the manual, which both evaluate to the same instructions. | ||
+ | The one which gave the module its name has a big network of binary NAND/NOR gates which take the LEDs as inputs and give output levels that correspond to the switch states. | ||
+ | For the less nerdy players, there is a second manual, which lists a lot of rules which reference other rules depending on the LED state. | ||
+ | |||
+ | A random gate network is generated using python and visualized using PyGraphViz. | ||
+ | Then all possible outcomes are calculated and placed in a big lookup table, which is stored on the arduino. | ||
+ | The rules are created by reading the lookup table and pruning. | ||
+ | Higher difficulties are achieved by creating larger networks, which depend on more LED states. | ||
+ | |||
+ | === Blink module === | ||
+ | The blink module has a red and a green LED, which blink in a specific pattern. | ||
+ | Depending on this pattern, a push button below either the red or green LED has to be pressed. | ||
+ | Correct solutions are taken from a lookup table (both on the arduino and in the manual). | ||
+ | Higher difficulties require multiple iterations and increase the blink frequency and pattern length (and therefore lookup table size). | ||
+ | |||
+ | === Planned === | ||
+ | * PCB: Lots of resistors dumped onto a board. Find the correct pins to bridge using resistor color codes. | ||
+ | * Balance: Two dots chase each other. One has randomly varying speed, the other's speed is controlled using a potentiometer. If one catches the other, it goes boom. | ||
+ | * High stakes: Spray cold water onto the handler on explosion or failures. Alternative: One button which has to stay pressed the whole time (also makes handling harder) gets wired to a shocker. | ||
== Manuals == | == Manuals == | ||
Zeile 60: | Zeile 88: | ||
=== Make Rhein-Main 2017 === | === Make Rhein-Main 2017 === | ||
− | + | Bringing a bomb mockup to a fair - what could possibly go wrong? BUMM was present on the [https://make-rhein-main.de/ Make Rhein-Main 2017]. There is also a short [https://streamable.com/bikcu clip]. | |
+ | |||
+ | The BUMM was placed in a small chamber built just for this weekend. It is made of a wooden frame with black stretch foil. Of course, we also needed warning tape. | ||
+ | Communication is done using a field telephone to the booth, where the manuals were located. | ||
+ | As an eye catcher, we made a live video feed using extra crappy cables for an analog S-Video camera. | ||
+ | |||
<gallery> | <gallery> | ||
Image:BUMM MRM2017 chamber.jpg|Chamber for the BUMM | Image:BUMM MRM2017 chamber.jpg|Chamber for the BUMM | ||
− | Image:BUMM MRM2017.jpg|Inside the chamber there is also a video camera | + | Image:BUMM MRM2017.jpg|Inside the chamber there is also a video camera for live feed and an FF-OB/ZB field telephone to our booth |
Image:BUMM MRM notes.jpg|Lots of notes have been taken | Image:BUMM MRM notes.jpg|Lots of notes have been taken | ||
</gallery> | </gallery> | ||
+ | |||
+ | == Links == | ||
+ | * [https://github.com/hackffm/BrickUsingMultipleModules Github repository] |
Aktuelle Version vom 20. März 2017, 22:03 Uhr
BrickUsingMultipleModules (short: BUMM) is a riddle game themed around bomb defusals. After an evening of playing Keep talking and nobody explodes, I was sure that this had to be transferred to hardware. The goal of defusing multiple modules is the same, but the hardware implementation calls for some serious changes. Cutting wires was out of the question, since nobody was found to replace them for a new round. Maybe someone will build a robot arm for that in the future.
Inhaltsverzeichnis
Pictures
Front panels
Backsides
Complete Brick
Details
Basic test video
Background
Each module has its own arduino and is connected to a parallel bus backplane (speaking 5V UART at 19200 baud). Each module contains its own logic and only tells the gamemaster whether it has been defused and if any manipulations (mistakes) were detected.
The gamemaster is a Raspberry Pi running a python script. Apart from the game logic and audio output, it opens a TCP socket which can be used to control the game remotely. The network protocol is based on tree structures serialized to JSON and terminated with NULL.
All lookuptables and manuals are generated completely automatic from config files using python and make.
All material, be it gamemaster scripts, arduino code, *.tex for manuals or svg files for lasercutting are available on github.
Modules
Gates module
The gates module has 7 LEDs, 4 toggle switches and a push button (looking like a switch). Depending on the status of the LEDs, the toggle switches have to be set correctly, then the RUN button has to be pressed. There are two instances of the manual, which both evaluate to the same instructions. The one which gave the module its name has a big network of binary NAND/NOR gates which take the LEDs as inputs and give output levels that correspond to the switch states. For the less nerdy players, there is a second manual, which lists a lot of rules which reference other rules depending on the LED state.
A random gate network is generated using python and visualized using PyGraphViz. Then all possible outcomes are calculated and placed in a big lookup table, which is stored on the arduino. The rules are created by reading the lookup table and pruning. Higher difficulties are achieved by creating larger networks, which depend on more LED states.
Blink module
The blink module has a red and a green LED, which blink in a specific pattern. Depending on this pattern, a push button below either the red or green LED has to be pressed. Correct solutions are taken from a lookup table (both on the arduino and in the manual). Higher difficulties require multiple iterations and increase the blink frequency and pattern length (and therefore lookup table size).
Planned
- PCB: Lots of resistors dumped onto a board. Find the correct pins to bridge using resistor color codes.
- Balance: Two dots chase each other. One has randomly varying speed, the other's speed is controlled using a potentiometer. If one catches the other, it goes boom.
- High stakes: Spray cold water onto the handler on explosion or failures. Alternative: One button which has to stay pressed the whole time (also makes handling harder) gets wired to a shocker.
Manuals
Make Rhein-Main 2017
Bringing a bomb mockup to a fair - what could possibly go wrong? BUMM was present on the Make Rhein-Main 2017. There is also a short clip.
The BUMM was placed in a small chamber built just for this weekend. It is made of a wooden frame with black stretch foil. Of course, we also needed warning tape. Communication is done using a field telephone to the booth, where the manuals were located. As an eye catcher, we made a live video feed using extra crappy cables for an analog S-Video camera.