The Lucas Eckels Blog

Wow, this blog hasn't seen any new content for years. You might be interested in more recent biking stuff posted on Travelogue. For older electronics geekery, carry on.

Friday, April 10, 2009

XBee Roomba problems

While developing the software to use the XBee Roomba adapter I previously described, I discovered the Roomba was spewing data.

My first guess was a bad solder joint, specifically the wire soldered to the mini-DIN connector. If that went open, the voltage divider would pull the data input to the XBee to ground. That joint wasn’t particularly great to begin with, and got pushed around when finishing assembly and using the board.. Unfortunately, I had covered the mini-DIN solder joints in hot glue in an attempt to prevent physical stress, so I couldn’t just heat up the joint and toss on a bit more solder. I replaced the connector with a spare, but the problem was still there.

That’s when I noticed that the amount of bad data didn’t seem to be change when poking at the board and wires, so it probably wasn’t a physical problem. I measured the voltage on the data input pin, and discovered it was only about 1.6V. That puts it in the undefined area of whether the XBee will consider it high or low. So I found the problem.

Different families of logic devices have different ranges of voltages that it will consider high or low, or output as high or low. Unfortunately, the Roomba doesn’t document it’s thresholds, just that it’s a 5V device. It turns out mine seems to output at about 3.4V, at least under the conditions I tested it.

I clipped off the bottom half of the voltage divider (R4), leaving a 1 kΩ resistor between the Roomba’s output and the XBee’s input, and the noise went away. So it works, but is it safe?

In short, no. But there isn’t enough documentation to design a safe divider. The XBee doesn’t give a maximum safe voltage, but the EM250 that it’s based on says Vcc + 0.3V. I’m supplying 3.3V to the XBee, so that means up to 3.6V. The Roomba doesn’t document it’s maximum output. If I divide enough to keep safe at 5V input, it wouldn’t work at the measured 3.4V.

For now, I’m living dangerously. The remaining resistor (R3) should protect against high current, which tends to be more damaging. If I damage the XBee, I’ll have to design a new board. And then come up with a use for an XBee without a working serial input.

posted by Lucas at 7:17 pm  


  1. […] to connect between the Roomba’s 5V and the XBee’s 3.3V serial interface. [edit: See my post on the problem with this design] The XBee is more than just a radio, it has a couple of […]

    Pingback by The Lucas Eckels Blog » XBee adapter for Roomba — April 10, 2009 @ 7:20 pm

  2. Hello,

    We’re you ever able to fix the problem with your xbee roomba adapter? I’m currently in the research phase of building a roomba that logs data to a remote system via the xbee and I was hoping to use your xbee roomba adapter.

    Comment by Brian — September 19, 2009 @ 7:55 am

  3. Hi Brian,

    I’ve been using the adapter I described without R3. So far, it hasn’t been a problem. I keep it plugged in continuously, although right now the only regular use is to get it out from under the couch, where the dock is located.

    Comment by Lucas — September 19, 2009 @ 10:21 am

RSS feed for comments on this post. TrackBack URI

Leave a comment

Powered by WordPress