TribeDuino is a proof of concept that uses an Arduino to read a Korg Monotribe audio-encoded firmware file. It doesn't do anything with the data except calculate a checksum to prove that it read it correctly. The program works by connecting an Arduino to an MP3 player of some kind via an audio patch cable, and then playing the firmware audio file so that the Arduino can hear it.
UPDATE: Want to program Arduinos with sound? See Audioino!
The firmware uses frequency-shift keying, or FSK, to encode its data. In FSK, you pick a point on a sine wave (like the peak), and measure how much time elapses between peaks. Over time, variations in the peak-to-peak period represent data. The Korg firmware uses binary FSK, which means that there are only two possible period lengths. A short period is a binary one, and a long period is a binary zero.
There is a 342-short-bit gap between packets that would seem pointless for a PC that's decoding the sound file offline. But for an Arduino or Monotribe that is reading the audio stream real-time, it's a much-needed 75-millisecond break during which the device can do something interesting with the packet it just decoded, such as writing it to flash memory, without falling behind for the next packet.
The effective bitrate is very close to 2400 baud (calculated using a 33,024-byte final firmware file, 8 bits per byte, and an audio runtime of about 1:50). That figure is not entirely comparable to a real 2400-baud modem for various reasons.
Upload the sketch to the Arduino.
Get an audio jack. I used one that I probably got from Sparkfun.
Connect the back part of the barrel to GND, then the tip to A0.
Plug your audio source (computer, iPod, whatever) to the jack. I got good checksums on an iPhone and a laptop.
Crank the volume all the way up.
Open up the serial monitor @57600.
Start playing MONOTRIBE_SYS_0201.m4a when you see "Ready for sound file..." in the serial monitor window.
After about 2 minutes you should see a success message, and you can compare the generated checksum to the one created by the Python file included with this distribution. We don't print status messages during decoding because Serial.print() is way too slow to use during that time-critical phase.
Turn the volume all the way up. Don't worry, it won't hurt the Arduino.
Turn off %&$@! webpages that play ads with sounds. I wasted about an hour before I figured out this was happening.
If you're going the iPhone route, make sure iTunes didn't re-encode the m4a to 128Kbps AAC, which almost works but doesn't.
Try again. The sketch is not too solid.
By Mike Tsao.
This project wouldn't have been possible without the hard work of these folks:
arms22. I actually didn't look at this code at all, but it served as a compelling existence proof of an Arduino soft modem.
After Hack A Day mentioned this project, a commenter pointed out the Audioino project, which does the same thing but has an ATmega bootloader as well as an IDE to generate new sound files. Check it out!
Korg, if you're reading this, feel free to send me a Monotribe. Thanks.
So What Exactly Is The Concept That This Proves?
I got interested in this project because I want to build an Arduino development environment that works with minimal hardware. It'd be cool to be able to develop a sketch on a smartphone web browser or non-jailbroken tablet, then program the Arduino using just the headphone jack. The Arduino would still need a power source, and to debug with the IDE the connection would have to be bidirectional. But this is a start.