

I’m currently in New York for this year’s ITP Camp,ย a 4 week unconference and technology playground for busy people. Held every June at ITP it brings together a diverse group of makers, artists, musicians, and creatives of all sortsโto make stuff, hearย speakers at the cutting edge in technology and art, and collaborate with peopleย they just wouldn’t normally meet.
It’s also a place to get things done that you haven’t managed to find time for and probably wouldn’t otherwise, and that was why last week I sat downโalong with Tom Igoe, Don Coleman, Sandeep Mistry,ย Guan Yang,ย JB Kimย and othersโfor a two day long Bluetooth LE doc-a-thon.
All of us haveย been working with Bluetooth LE devicesโalong with Don and Sandeep I’m writing a book for Make: on Bluetooth LE, cellphones and sensors, while Guan and JB have a startup building Bluetooth LE devicesโbut all of us agreed that getting started using Bluetooth LE was much harder than it should be, and that a lot of great work people were doing was getting dropped on the floor (or worse yet done again) because people didn’t know it existed. We decided to sit down and do something about that.
So as part of our doc-a-thon we gathered together documentation, videos, and code examplesย which we hoped would do just that.
How is Bluetooth LE different?
Bluetooth LE is very different from classic Bluetooth, in fact pretty much the only thing that is the same is the name.
Tom Igoeย andย Don Colemanย give an overview of Bluetooth Low Energy.
You’re probably used to thinking about radios as sort of like a serial connection working similarly to a phone call between two phonesโonce you establish a connection, each person talks as the other listens and vice versa. They stay connected, even if neither is saying anything, until oneย hangs up and the call is ended.
In systems like these, data is transferred using a queue, and when data is read by the receiver, it’s erased from the queue, just as once my words reach your ears over the phone, they’re out of the communications channel. Effectively this is how โClassicโ Bluetooth works.
Bluetooth LE is very different. Instead of communicating via a point-to-point connectionย like a phone, a Bluetooth LE radio acts like a community bulletin board,ย withย each radio acting as either a board or a reader of the board.
If your radio is a bulletin boardโcalled a peripheral device in Bluetooth LE parlanceโit posts data on its board for everyone in the community to read. If your radio is a readerโcalled a central device in Bluetooth LE termsโit can read from any of the boards (the peripheral devices) that have information which it cares about.
If you donโt like that analogy, you can also think of peripheral devices as the servers in a client-server transaction.ย Similarly, central devices are the clients of the Bluetooth LE world because they read information from the peripherals.
But I like serial connections?
Most (perhaps all?)ย of the Bluetooth LE radios breakout boards available toย makers right nowโtheย RedBearLab BLE miniย and theย Adafruit Bluefruit LEย for instanceโpretend to look like serialย devices for simplicity’s sake and present a UART service to the user. Effectively these radios are “faking” old style serial communication on top of the underlying bulletin board paradigm. It’s a hack, and actually not a good hack.
While itย simplifies things from the Arduino side of things, by using the radioย in this wayย you’re negating the “low energy” part of Bluetooth LE. The radios will be constantly on all the time, and if your project is battery based,ย that’s a big problem.
Tom Igoeย andย Don Colemanย talk about services and Bluetooth LE.
Imagine a example where you want to control an LED connected to an Arduino board from our phone via Bluetooth LE. If we use a serial connection that connection will be open continuously, but it’s only going to get used periodicallyโwhen we send a 1 or a 0 over the air to the Arduino board to turn the LED on, or off.
As an alternative, you can heavily reduce the power consumption of your project by using Bluetooth LE like it’s supposed to be used and implementing a custom service for the radio connected to the Arduino to advertise its ability to turn the LED on or off.
Returning to ourย ย bulletin board example we’re creating a board (the service) which has a post-it note attached (known as a characteristic in Bluetooth LE parlance) which we can both read, letting us know if the LED is on or off,ย or write toโallowing us to control the LED.
Building a custom service
Unfortunately until recently building custom services for Bluetooth LE has actually been fairly complicated and not for the faint hearted. However it’s getting simpler as there’s now several good tools to do most of the heavy lifting for you.
In light of that weย decided to look at one platformโthe Nordic Semiconductor nRF8001 radioโand figure out a complete toolchain that would allow you to build a custom service for the radio, and make use of that service from an Arduino project. We picked this particular radio because it’s readily availableย and there is good library support.
The first thing you need to do when dealing with the nRF8001 is install Nordic’s nRFGo Studio,ย and while nRFGoย is a MS Window’s application, it runs just fine on the Mac under OS X using Wine. This application is the tool you need to create the configuration file for the Bluetooth LE services that the radioย will advertise, and as a by product it also creates a services.h header file that you’ll need as part of your Arduino project.
The “smart light switch”
We wanted to build something with multiple services, so we decided to build a “smart” light switchย where you could not just turn the lightย on, or off, via Bluetooth LE but get the current status of the light switch (which also could independently control the light) and get notified when the switch was toggled.
Controlling a light via Bluetooth LE.
The nice thing about this example is how simple it is, beyond the Arduino board and the nRF8001 radioโwe decided to use the Adafruit Bluefruit LEย breakout boardโyou really only need a few wires, resistors and other commonly available parts.
Building the services.h configuration file using nRFGo Studio is probably the trickiestย part of the whole toolchain, and we spent a lot of time figuring out the easiest way to allow you to include the generated services.h file inside your Arduino project, instead of having to include it inside the nRF8001 Arduino library.
While it meant a pull request for the library maintainer, and a few manual modifications to the services.h file,ย in the end we got it working, and this means that you work entirely within the Arduino IDE once you’ve generated your services configuration.
More details, and all the source code for the example projects, are available on Github as part of the documentation and code examples we put upย during the doc-a-thon.
Conclusion
There now a huge number of off-the-shelf Bluetooth LE devicesย ranging from wearables to locks, from dronesย toย lightbulbsโand of course the there’s always the now ubiquitous iBeaconโbut there’s also a growing number of developer boards that mean making use of these off-the-shelf devices from your Arduino project (or becoming one) is also getting simpler. Hopefully our doc-a-thonย is going to prove to beย helpful to speed that process, and as it’s all up on Github contributions are of course very welcome.
ADVERTISEMENT