A Robot for Timo —
Here at FlightCar Engineering we’re a very small team, and one of us — Timo Zimmermann — works remotely from Heidelberg, Germany. Timo’s an expert in the web framework we use, Django, and is awesome to work with: mixing together good humour, an enjoyment of teaching and learning, and deep technical expertise.
One day a link to Double Robotics got passed around our internal chat room — it’s an unexpected use of Segway technology, putting an iPad on top of a mobile robot and letting a remote participant drive the robot around while video chatting. We keep a video chat with Timo open while at work, so we were pretty interested in this.
There wouldn’t be much point in FlightCar buying one of these robots; our local developers fit around a single desk. Still, it would be useful to be able to video chat with Timo and have him be able to choose which of us to “look” at, as well as being able to join in with office conversations in general. Could we come up with something much simpler that still has most of the advantages of the Double robot in our situation?
I have a little electronics experience (from my time at One Laptop Per Child, as well as a previous fun personal project) and recently received a Kickstarter backer RFduino. Alex Fringes and I decided to go ahead and build a basic, stable/unmoving telepresence device as a present for Timo. Here’s what we did:
|$140||Bescor MP-101 pan head with power supply and remote control|
|$68||RFduino “teaser kit” + prototyping shield + single AAA battery shield|
|$29||Rosco 8″ Snake Arm|
|$13||Rotolight Male 1/4″ to 1/4″ adapter|
|$15||Grifiti Nootle iPad mini Tripod Mount|
Total: $265 USD
I’m not counting the cost of the iPad (the Double Robotics robot costs $2500 and doesn’t include an iPad either), or the tripod we’re putting the Bescor pan head on top of (I had a monopod already, and basic tripods are very cheap), but everything else we used is listed above. Here’s the final result:
How it works
The pan head is easy to control programmatically. It has a 7-pin port on the back, and four of the pins correspond directly to up/down/left/right — to move in a direction, you just apply voltage to that pin until you want to stop. This is a perfect match for an Arduino-style microcontroller; Arduino is a hobbyist electronics platform that makes it easy to cheaply prototype new hardware creations, by giving you I/O pins you can attach wires to and a simple programming interface. Local electronics hacker and Tiny Museum-cofounder Steve Pomeroy helped out by determining the pinout and soldering between the remote control port’s pins and our RFduino’s prototyping board, and Alex set to work writing the code that would run on the RFduino and iPads. We ended up with an architecture like this:
So, to expand on the diagram: Timo moves his iPhone, the orientation is sensed and passed on to our local iPad via the nodejs bridge (which exists just to proxy through NAT), which converts it into a single letter “r”, “l”, “u”, “d”, or “s” (for stop) and then the RFduino reads a character at a time over Bluetooth Low Energy and sends a voltage pulse to the appropriate pin. We chose iPhone orientation sensing as the control mechanism at Timo’s end, but you could also use explicit direction buttons, or even something like face detection.
We decided to hide the fact that we were building this from Timo and introduced it to him as a surprise, coincidentally on Valentine’s Day. We love you Timo!
Finally, we’ve put all of the code we wrote — for the RFduino, the nodejs bridge, and the local and remote iOS apps — under an open source license on GitHub, so we’ve shared everything we know about how to build these devices. We’d be very happy if other people can help improve the features we’ve started on and find a cheaper way to build more of these!
(By the way, we’re hiring for a Lead Front End Engineer in Cambridge, MA at the moment!)
How are you finding BTLE? I’ve had… non great experiences with BT in the past, and initial attempts to use BTLE haven’t shaken my prejudice against the protocol. Did it all work swimmingly with the iDevices and what not?
Hi Dan! It hasn’t been great. The company behind RFduino is named “Open Source RF”, yet the BLE stack they ship is closed source, and their API on top of it is new, feature-sparse, and flaky. (Mainly flaky during initial association, which isn’t a huge problem for this use case.)
They spent a few months violating the GPL by shipping AVRDUDE binaries with no intent to provide source (they eventually ripped out AVRDUDE altogether rather than provide source), and as a result Linux is poorly supported for uploading code to the device. Next time I’d skip the RFduino and try to use different BLE hardware.
The AAA battery sure does power the device for a long time, though.
That’s a bummer all round. I would have hoped that people marketing something as “*duino” would be a little more hip. It’s not like avrdude has some super secret special awesome in it!
I wish BT wasn’t so damned flaky. Does it have trouble associating even if you use “Just Works” mode?
Pingback: Telepresence Robot Proves It’s A Small World After All
Pair this with google glass on Timo’s end, and it would be perfect. He can look around and have his hands free.
What is the pin configuration from the rfduino to bescor? The bescor is a 7 pin DIN so I’m wonder what pins you are connecting to.
Hi Garrett — you can find a pinout for the Bescor online. (Though if I recall, it didn’t quite match up with my unit and we ended up instead probing the output pins of the remote control while pressing its direction buttons.)
Yup that was the case for me as well which is why I was asking about it. Thanks Chris… I’ll tinker around.
So cool! Have you should put this onto Hackaday! P.S. In my company we use just use dropcams