David Pilling |
Main »
LoggerStarted August 22nd, 2014 The idea is that the logger powers up once an hour and receives data from all the sensors, saves it in EEPROM and then goes back to sleep. The logger is left permanently connected to a PC which is turned on during working hours, in that situation data can be uploaded to the PC and the batteries recharged; when the PC is turned off the logger uses battery power. The 'real time' Oregon displays work in a different way; they appear to power up when each sensor is predicted to transmit. These are the parts of the system:
Arduino Pro Mini Photos show Arduino Pro Mini and cut track; click for full size The Pro Mini has no USB interface, instead it has pins for a TTL serial interface. The lack of USB is an advantage because it allows me to insert the power oring components between the Arduino and the USB interface. I use one standard interrupt for the Real Time Clock, another for the radio receiver. But I also need one for spotting when the USB voltage is lost, to gain this I used the PCChangeInt library. I used the Serial Command library to give me commands for talking to the logger from the standard Arduino IDE serial window. These let me adjust the clock and read values from the memory. The idea is to have a 'base' time and a period for how often data is saved. Every reading can then be identified by a number - the number of periods that have elapsed since the base time. Readings wrap around in memory. Doing things this way there is no need to store a time for each reading. The AVR ATMega chip has some EEPROM of its own, this is used to store settings, for example the base time and period. USB serial interface Photo shows USB interface; click for full size Real Time Clock My idea was to power the RTC board from an Arduino output pin when I needed to. But I found that powering up the board (after the first time) would make I2C hang. I got round that by editing the twi library and removing the code which enables pull ups for the I2C pins. The plan was to put the Arduino to sleep and then use the RTC interrupt output to wake it. The RTC has an FET that pulls down when an alarm goes off. However that won't work because of the pull up resistors (one of which is on the FET interrupt output). They're all joined together (obviously at the Vcc end), and with Vcc disconnected they act as one large pull down resistor. The Arduino's built in pull up is not strong enough to overcome this, and even if it was I don't want to waste lots of power. I cut a track on the RTC PCB to remove the pull up resistor on the interrupt pin. These RTC boards are apparently not designed to use little power whilst periodically waking up a system. Photos show RTC back, front and cut track; click for full size One vendor had (it has now vanished) an archive which contains datasheets, code, and a schematic. The Edward Mallon underwater sensor blog page addresses similar issues. The code in the vendor archive for controlling the RTC is from Eric Ayars, and I have used this. I found a bug fix on the web which I applied and I have also fixed another problem with it. The vendor archive code for writing to the memory chip is apparently from Using Arduino with an I2C EEPROM and uses the Wire library, a lot is made in various places of only being able to write 28 bytes at a time. The Wire library has a 32 byte buffer, and uses 2 bytes of it for the address to write to. Fixing this means creating your own local wire library, and changing the buffer size in the header from 32 to 34. However the Wire library is built on the twi library, that also has a 32 byte limit. I made a local copy of the Wire library called wire2 and put in it renamed copies of wire.h, wire.cpp, twi.h and twi.c from C:\Program Files (x86)\Arduino\hardware\arduino\avr\libraries\Wire and the utilities folder inside it.
The battery To put it another way "cheap ebay clock boards are fire hazard!". When I got the board I thought low current charging would do little harm as with other primary cells and ran the board connected to a five volt supply for many months - there was no sign of the battery getting hot. Eventually I examined the battery and found it had a voltage of 3.7 V which was held for days. Does this mean it really was a rechargeable lithium cell, or had the months of charging changed it. Another similar unused board had an identical battery with a voltage around 3.3 V, typical of a CR2032. If one were to run these boards on 3.3 V I would not expect the battery to be charged due the diode forward voltage drop. Eventually I disconnected the resistor in the charging circuit on the board (top right marked 201) and fitted a genuine CR2032 battery. Why I did that is another story... Accuracy was originally similar to that of a cheap quartz clock, 5 seconds per 24 hours. Adding a clock crystal to the Pro Mini (see Arduino 32768) and not bothering with the RTC would have been simpler and given the same result. However the DS3231 is supposed to be much more accurate than this (see this discussion) because it features a temperature compensated crystal oscillator (TCXO). The manufacturer datasheet claims a couple of minutes per year (a third of a second per day) over a wide temperature range. There are 31.5 million seconds in a year, the error over a narrower temperature range is quoted as 2 ppm. Comment on the web often expects ebay DS3231 boards to be substandard yet they're usually found to be accurate. There is a register to trim the clock frequency to cope with crystal ageing (aging) which has a range of +/- 127 0.1ppm units or just over +/- 1 second per day. I've made a trivial extension to the library to allow this register to be written and read. I noted that whilst the PC was supplying power the clock was accurate, only when left on its own battery did it gain. That led me to measure the battery voltage and discover it was 3.7 V. After disconnecting the charging circuit and installing a new battery the clock kept much better time. Change of clock frequency with voltage is quoted as 1 ppm; the change in voltage from 3.7 to 3.3 V would not be enough to explain the gain of 5 seconds per day. 3.7 V is also an acceptable value for the battery voltage. The maker of the DS3231 has a note Power Considerations for Accurate Real-Time Clocks which explains how often the chip attempts to compensate for the temperature. The minimum and default period for temperature compensation is every 64 seconds. I tried various things, and thought about fluctuations in voltage or temperature, but the only conclusion I came to is that the CR2032 being charged to 3.7 V makes the clock run fast, whilst a 3.3 V battery without the charging circuit gives amazingly accurate time keeping. Eventually I configured the DS3231 1 Hz square wave output and used the code on my GPS page to measure its variation. I found that a few seconds after the change to battery power (presumably the next temperature compensation event) the clock would speed up when using the 3.7 V battery. Construction The next set show the three boards. Photo 2 is of the RTC and 433 MHz receiver board. Photo 3 the Arduino Pro Mini and USB interface board - the right hand jumper is used to isolate the reset line to the Arduino, the top jumper allows operation without the power supply board. Photo 4 shows the power supply board which has the battery charging circuit (two transistors top left) and power or circuit (four transistors bottom right). The white polarised connectors are known as KF2510-3P; commonly used for fans on PC motherboards; it seems one standard is to have the middle pin positive. The right hand one is for the battery; the middle one takes in power from the USB interface and supplies power to the rest of the project; the left hand one has pins for measuring the battery voltage, signalling if USB power is present and enabling battery charging. PC Application Software I used a lot of freely available software. Credit to the people who wrote it and made it available.
|
David Pilling's Wiki Set view |
Page last modified on March 13, 2019, at 02:08 AM - Powered by PmWiki pmwiki-2.3.31 (pmwiki-2.3.31) |