Syncing Arduino with GPS time

Most people have little need to synchronize clocks to the minute, much less to the millisecond….. but if you do need it, here is how to get millisecond (ms) accuracy in absolute time with Arduino using GPS.

We start with the 1pps signal from the GPS receiver.  The 1pps signal is available from most GPS modules, but double check if you are ordering one for this purpose.  1pps stands for 1 pulse per second.  The pulse is a very short (20 uS = 20/1,000,000 seconds) pulse whose rising edge coincides with the beginning of a second in GPS time.

For some reason, the GPS shield I got from spark fun, did not connect to the 1pps signal even though it had a spot for it.  Checking further showed that only one of the three GPS headers was connected to the 1pps signal.  I red-wired the missing link.

 

I hooked this 1pps signal into digital pin 2 (INT0) so that I could use the hardware interrupt to capture the rising edge of that pulse.  Using this as the absolute 1 second reference, we can measure the drift of the DS3231 real time clock chip.  This is the same chip that is used in the ChronoDot.

I did this by hooking up the 1Hz square wave to digital pin 3 (INT1) and used interrupts to measure time drift DS3231.  My initial test showed it to be loosing about second per year to the GPS time.  Not bad considering they only claim to be accurate to about a minute per year.  Another way to look at the drift is that it will take about 6 hours to loose a milli second (1/1000 of a second).   As long as we can sync with GPS once every 6 hours, we should be able to maintain timing precision and accuracy to a millisecond.

2011 WyoLum Innovation Grant Winners!

And the 2011 WyoLum Innovation grants go to…

Erin Kennedy for her project RoboBrrd and Hunter Scott for the Peregrine Board.  They each will receive $1000.

We had such a hard time limiting the awards to just two winners we ended up with 4 finalists, each receiving $250:

Georg Ottinger — OggStreamer,

Frank Zhao — ReflowToaster,

Jeffrey Stattler — VirtualIntervention,

Travis Dynes — BeeTracker

 

Continue reading

Bits is bits!

So the DOOMSDAY! clock needs to be somewhat weatherproof. With this in mind, we decided to forego any buttons that we’d need to access from the outside of the clock and instead use an infrared remote control that I had laying around from Paralax.

I just now got the ‘duino reading the pulse sequences consistently thanks to some help from the internets.

The first stop was AdaFruit Industries where I picked up a few IR sensors. I know there are a few different vendors out there, but I wanted to make sure that the sensor would work with the code and Ada as a super tutorial that got us up and running quickly.  The sample code in the tutorial continually looks for pulses coming in on the IR pin and measures the “pulse widths” or time durations of the electrical pulses coming from the sensor.  Each button press triggers a train of pulses that are each measured in turn.  The message is determined by the series of pulse widths.

The image below depicts the pulse widths sequentially on a plot for a single button press to illustrate the point.  The blue line shows the on/off durations, the green line just indicates the on durations (or pulse widths).

Where the top image show the raw pulse times, the bottom image indicates weather the each pulse width was above (indicating a binary 1) or below a threshold  (indicating a binary 0) of 1000 uS (1/1000 of a second).  After studying the pulse trains from each button press on my remote, I learned that they all start with the same start and stop sequences with a varying message occurring in the green zone.

So this is enough to get some IR action up and running.  But I didn’t want to tie up the ‘duino checking for pulses when 99.99% of the time, there will be no pulses.  Seems like a waste and when the processor gets busy, the response time will lag.

Interrupts are ideal in these situations.  So much so, it is even worth the hassle of learning how to use them.  They can be tricky to implement and debug, but with the right help, it was not to hard in this case.  The right help came from this page in the Arduino Playground.

Normally, I would use one of the Arduino predefined hardware interrupts on digital pins 2 and 3.  They are very straight forward to use.  In my case however, the hardware interrupt pins were already taken and I had to resort to the PCINT pins.  The ATMEGA328 (heart of Arduino) allows hardware interrupts on each and every pin.  Which brings us to this page on the Playground which shows how.

The idea is to write an interrupt handler that only gets called when a specified event occurs.  In this case, the event is a change on the IR sensor pin.  The rest of the code can be be written without much attention to the interrupt handling.  So if the pin goes from low to high, we start a pulse timer.  When it goes from high to low, we compute the elapsed time from the start of the pulse: the pulse width.  The rest of the interrupt handler checks the pulse width to see if it is above or below the bit threshold and deals with the resulting bit.

What pops out, when a message is sandwiched by a valid START_SEQ and STOP_SEQ, is a 10-bit numerical value which we can use to trigger higher level events and actions.

Here is some test code that makes it happen.

2011 WyoLum Innovation Applications

Thank you everyone who submitted for the 2011 WyoLum innovation grants.  The application period is now closed.

Here’s a list of all public entries:

Project Name Applicant
OggStreamer Georg Ottinger
Paparizzi Dmitri Belimov
BUSnet Rob Gray
ReflowToaster Frank Zhao
WirelessHandSensor Mushfiqur Sarker
RoboBrrd Erin Kennedy
VirtualIntervention Jeffrey Stattler
MPFabber David William Harper
PeregrineBoard Hunter Scott
OpenSmartMeter Al Senin
TotalUserInterface Alexandru Bogdan
ArduinoSchoolBoard Adrian Stefan
CarbonFiberTrumpet Kyle Bartholomew
BeeTracker Travis Dynes
UniMoto Joe Langevin

Good luck!!

 

Stand Alone Bootloader

So I’m trying out the “stand alone” boot-loader-loader by by Bill Westfield (“WestfW”).  This is an amazing sketch that can load any program to another ATMEGA328 kind of like ArduinoISP except it is much, much faster and is not required to be connected to a computer.  AdaFruit industries sells a kit (with a nice tutorial) that comes with everything you need to turn your Arduino into an “optiLoader” (excepting a few wires and a reset button).

When I tried to use it for the first time the red led came on and the buzzer started screaming.  It didn’t sound good.  It turns out the “device signature” was wrong.  Changing line 5 of images.cpp to the code read off the chip (14 in this case, F in another, 300 in another) the program loaded in less than a second.  This takes over a minute the avr-dude way.

The next obvious step here is to be able to load any program from an SD card.