<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Pete, <div><br></div><div>Good point on accuracy. The Maxim <a href="http://datasheets.maximintegrated.com/en/ds/DS1339-DS1339U.pdf">data sheet for the DS1339 </a>does not give an accuracy (at least that I could see). But I want to make sure I understand how to convert ppm to something I can understand.</div><div><br></div><div>Using your data point for the DS1307, 20 parts per million would be 20/1,000,000 or 0.002% and if there are 86,400 seconds in a day, that is 1.728 seconds a day in “drift”. </div><div><br></div><div>Am I thinking about that right? I put these sensors out for a week (the non-cellular version) and I could expect 12 seconds drift. </div><div><br></div><div>Thanks,</div><div><br></div><div>Chip</div><div><br></div><div><br><div><div><div>On Sep 11, 2014, at 1:33 PM, <a href="mailto:triembed-request@triembed.org">triembed-request@triembed.org</a> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite">Send TriEmbed mailing list submissions to<br><span class="Apple-tab-span" style="white-space:pre"> </span><a href="mailto:triembed@triembed.org">triembed@triembed.org</a><br><br>To subscribe or unsubscribe via the World Wide Web, visit<br><span class="Apple-tab-span" style="white-space:pre"> </span>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br>or, via email, send a message with subject or body 'help' to<br><span class="Apple-tab-span" style="white-space:pre"> </span>triembed-request@triembed.org<br><br>You can reach the person managing the list at<br><span class="Apple-tab-span" style="white-space:pre"> </span>triembed-owner@triembed.org<br><br>When replying, please edit your Subject line so it is more specific<br>than "Re: Contents of TriEmbed digest..."<br><br><br>Today's Topics:<br><br> 1. Re: Basic I2C Question (Pete Soper)<br> 2. Re: Basic I2C Question (Jon Wolfe)<br> 3. Re: Basic I2C Question (Pete Soper)<br><br><br>----------------------------------------------------------------------<br><br>Message: 1<br>Date: Thu, 11 Sep 2014 13:24:32 -0400<br>From: Pete Soper <pete@soper.us><br>To: triembed@triembed.org<br>Subject: Re: [TriEmbed] Basic I2C Question<br>Message-ID: <5411DAD0.70508@soper.us><br>Content-Type: text/plain; charset=ISO-8859-1; format=flowed<br><br>The Atmega builtin pullups are very weak (high value). In addition to <br>the issue with long distance (i.e. more capacitance in the "transmission <br>line" created by the PC traces and/or cables) that Rod mentioned folks <br>should know that speed can figure into the equation. If for some reason <br>the I2C is going to be run at 400khz vs the default 100khz then lower <br>value pullups become critical in addition to mindfulness about the lower <br>limit on load capacitance.<br><br>The ST M41T62 clock chip is pretty cool, and it can be arranged to <br>generate interrupts when an alarm expires. But it's basic accuracy is <br>like a DS1307 (roughly 20-30ppm). It has excellent support for on the <br>fly calibration to get the error down to a fraction of one ppm, but <br>there would have to be initial measurement of drift at a few <br>temperatures and then the driver would have to be able to monitor <br>temperature to tweak things as you go along, especially in your setting <br>where the temp can swing a lot. I started a driver for this chip but its <br>only 80% complete (you can do all the usual stuff with it and peek/poke <br>the register values very conveniently, but a list of very smart features <br>to do with minimizing power consumption is undone) I have a breakout <br>board you could try out immediately and parts to build a few more. (If I <br>can succeed in building the "calibrator' I'm designing now I'll be able <br>to calibrate this clock chip for any given temperature to within 100ppb <br>with one second of square wave samples).<br><br>If your logger is doing smart stuff like talking to mother ship via the <br>cell network it should be straight forward to calibrate the clock <br>periodically, shouldn't it? If you can get a "fix" on actual time of day <br>periodically you can determine how to calibrate your processor's <br>reckoning of time and make your own alarm clock(s) with software iff <br>your sleep modes are not so deep that the timer involved with millis is <br>powered down. There is easy library support for translating the free <br>running timer (the thing that drives "millis()") into date/time info.<br><br>But I suspect you're aiming to do things the other way around and use <br>the RTC alarm clock to wake the cpu up?<br><br>-Pete<br><br>On 09/11/2014 08:28 AM, Charles McClelland wrote:<br><blockquote type="cite">First, I wanted to thank Paul for the excellent presentation on interrupts. I now have a Watch Dog Timer routine which is saving me from having to put a clock on one project.<br><br>On my other project though, I still need a clock. And since I am already using an I2C bus, I thought I could simply add one to that bus. That way I will have two I2C sensors connected to an Arduino (ATMEGA328). My question is how to best implement the pull-up the resistors. Should I put resistors on each (perhaps 10k since they will effectively be in parallel) or should I put one set of pull up resistors on the main board for both? It seems like the latter is the better approach but I did not know if there was some reason to do one over the other.<br><br>On a related note, I need a 3.3V I2C Real Time Clock with Alarms - I am looking at the DS1339 and hoping I can use some of the DS1307 library since they are both from Maxim. Any other suggestions?<br><br>Thanks,<br><br>Chip<br><br><br><br>_______________________________________________<br>Triangle, NC Embedded Computing mailing list<br>TriEmbed@triembed.org<br>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br>TriEmbed web site: http://TriEmbed.org<br></blockquote><br><br><br><br>------------------------------<br><br>Message: 2<br>Date: Thu, 11 Sep 2014 13:25:53 -0400<br>From: Jon Wolfe <jonjwolfe@anibit.com><br>To: Charles McClelland <chip@mcclellands.org>, Adam Haile<br><span class="Apple-tab-span" style="white-space:pre"> </span><email@adamhaile.net><br>Cc: TriEmbed Discussion <triembed@triembed.org><br>Subject: Re: [TriEmbed] Basic I2C Question<br>Message-ID: <qh0murv7j077ct0v25w2cw8c.1410456353334@email.android.com><br>Content-Type: text/plain; charset="utf-8"<br><br>What I've done on my i2c device boards is to leave unpopulated placeholders for pullups on the pcb.<br><br><div>-------- Original message --------</div><div>From: Charles McClelland <chip@mcclellands.org> </div><div>Date:09/11/2014 11:28 AM (GMT-05:00) </div><div>To: Adam Haile <email@adamhaile.net> </div><div>Cc: TriEmbed Discussion <triembed@triembed.org> </div><div>Subject: Re: [TriEmbed] Basic I2C Question </div><div><br></div>Adam,?<br><br>Thank you for the response your and Jon?s note raises another question:<br><br>Is there an advantage to putting resistors on the circuit board versus simply using the Arduino?s internal pull-ups? ?Power savings or - as Jon mentioned - the ability to tune for performance?<br><br>On the RTC - here is my reader?s digest version of the bewildering variety that Maxim offers:?<br><span class="Apple-tab-span" style="white-space:pre"> </span>- DS1337 - Great but no battery backup to keep clock set when I change the batteries<br><span class="Apple-tab-span" style="white-space:pre"> </span>- DS1338 - Adds battery backup but drops alarms<br><span class="Apple-tab-span" style="white-space:pre"> </span>- DS1339 - Battery backup, alarms and an alarm pin - and it is cheaper than the DS1338. ?<br><br>I am hoping the library / commands for all three will be similar and similar. ?Thoughts?<br><br>thanks,<br><br>Chip<br><br><br>On Sep 11, 2014, at 8:50 AM, Adam Haile <email@adamhaile.net> wrote:<br><br>There's no need for them at all.<br>I2C only needs pull up resistors on the bus as a whole, NOT for each device.<br>Also, the Wire library in Arduino automatically enables the internal pullup resistors when you call begin(). You can also do the same by setting a pin as an input and then writing HIGH to it, but Wire takes care of it for you.<br><br>Sure, having extra won't help but you certainly don't need more than one set.<br><br>For the RTC, check out the DS1337, it is the DS1307's big brother and includes alarms. However, there are no alarm pins, you just have to poll for if the alarm is "going off". But there is lots of code out there already for the DS1337. If you need alarm interrupts, I'm not sure what to use... nothing I'm familiar with that has separate alarm pins.<br><br>On Thu, Sep 11, 2014 at 8:28 AM, Charles McClelland <chip@mcclellands.org> wrote:<br>First, I wanted to thank Paul for the excellent presentation on interrupts.? I now have a Watch Dog Timer routine which is saving me from having to put a clock on one project.<br><br>On my other project though, I still need a clock.? And since I am already using an I2C bus, I thought I could simply add one to that bus.? That way I will have two I2C sensors connected to an Arduino (ATMEGA328).? My question is how to best implement the pull-up the resistors.? Should I put resistors on each (perhaps 10k since they will effectively be in parallel) or should I put one set of pull up resistors on the main board for both?? It seems like the latter is the better approach but I did not know if there was some reason to do one over the other.<br><br>On a related note, I need a 3.3V I2C Real Time Clock with Alarms - I am looking at the DS1339 and hoping I can use some of the DS1307 library since they are both from Maxim.? Any other suggestions?<br><br>Thanks,<br><br>Chip<br><br><br><br>_______________________________________________<br>Triangle, NC Embedded Computing mailing list<br>TriEmbed@triembed.org<br>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br>TriEmbed web site: http://TriEmbed.org<br><br><br>-------------- next part --------------<br>An HTML attachment was scrubbed...<br>URL: <http://mail.triembed.org/pipermail/triembed_triembed.org/attachments/20140911/a3526f25/attachment-0001.html><br><br>------------------------------<br><br>Message: 3<br>Date: Thu, 11 Sep 2014 13:33:01 -0400<br>From: Pete Soper <pete@soper.us><br>To: triembed@triembed.org<br>Subject: Re: [TriEmbed] Basic I2C Question<br>Message-ID: <5411DCCD.90501@soper.us><br>Content-Type: text/plain; charset="iso-8859-1"; Format="flowed"<br><br>An oscilloscope would allow measuring the actual the slew rate <br>accurately enough to determine if you've got some headroom or if things <br>are on the ragged edge.<br><br>But the load capacitance of the sensors should be in their data sheets, <br>so adding those up gives you a start on knowing the total load. And <br>there are online calculators for estimating the capacitance of PCB <br>traces. But just taking it to a 'scope' would close the gap between <br>theory and reality. :-)<br><br>-Pete<br><br>On 09/11/2014 11:46 AM, Jeff Highsmith wrote:<br><blockquote type="cite">Rodney,<br><br>Can bus capacitance be easily measured? I've got five I2C sensors <br>hooked up to the project I'm working on, though all within a square <br>foot. Can I just put my multimeter in capacitance mode and measure <br>across SDA and SCL when the circuit is off?<br><br>Thanks!<br>Jeff :)<br><br><br>On Sep 11, 2014, at 11:39 , Rodney Radford wrote:<br><br><blockquote type="cite">As long as the I2C devices are close to the microprocessor, you do <br>not need additional pull up resistors.<br><br>However, as you increase the distance (say to an extra sensor board), <br>the long wires add additional capacitance to the I2C lines, turning <br>those sharp edges into something that looks more like a sine wave. <br>The same occurs as you add more devices as each device has it's own <br>internal capacitance. The additional pull up resistors help correct <br>this, allowing you to put your sensors further away (or add more <br>sensors).<br><br>So if you are going off-board with your sensors, yes, i would <br>definitely recommend adding pull up resistors. The lower the value of <br>the resistors, the more pull up you get and the sharper your edges <br>become - at the increase of additional current required for your <br>device, so it is a trade off.<br><br>I worked on a setup years ago where I used I2C as a communication bus <br>for a large aquarium monitoring system where I had I2C temperature <br>sensors in each aquarium, I2C port expanders to drive small 2x16 line <br>LCD displays, and port expanders to control turning on heaters to <br>each aquarium. The aquariums were in an external storage shed that <br>was not insulated, so by measuring the external temperature we could <br>start increasing the water temperature as the external temperature <br>dropped, to prevent the water from getting too cold before the <br>heaters cut in. In hind site, it may have been easier to insulate <br>the shed, but the system worked well for years. I was running I2C <br>lines over CAT-5 30' and it worked like a charm. I did optoisolate <br>the I2C lines back to the computer (which was a Windows PC that was <br>bit-banging the I2C out the PC's parallel port) to prevent lightning <br>of other high static charges from damaging the port.<br><br>Of course now I would replace all of that with a few small <br>microprocessors and a Raspberry Pi, but this was back in the <br>early/mid 90s...<br><br>On Thu, Sep 11, 2014 at 11:28 AM, Charles McClelland <br><chip@mcclellands.org <mailto:chip@mcclellands.org>> wrote:<br><br> Adam,<br><br> Thank you for the response your and Jon's note raises another<br> question:<br><br> Is there an advantage to putting resistors on the circuit board<br> versus simply using the Arduino's internal pull-ups? Power<br> savings or - as Jon mentioned - the ability to tune for performance?<br><br> On the RTC - here is my reader's digest version of the<br> bewildering variety that Maxim offers:<br> - DS1337 - Great but no battery backup to keep clock set when I<br> change the batteries<br> - DS1338 - Adds battery backup but drops alarms<br> - DS1339 - Battery backup, alarms and an alarm pin - and it is<br> cheaper than the DS1338.<br><br> I am hoping the library / commands for all three will be similar<br> and similar. Thoughts?<br><br> thanks,<br><br> Chip<br><br><br> On Sep 11, 2014, at 8:50 AM, Adam Haile <email@adamhaile.net<br> <mailto:email@adamhaile.net>> wrote:<br><br><blockquote type="cite"> There's no need for them at all.<br> I2C only needs pull up resistors on the bus as a whole, NOT for<br> each device.<br> Also, the Wire library in Arduino automatically enables the<br> internal pullup resistors when you call begin(). You can also do<br> the same by setting a pin as an input and then writing HIGH to<br> it, but Wire takes care of it for you.<br><br> Sure, having extra won't help but you certainly don't need more<br> than one set.<br><br> For the RTC, check out the DS1337, it is the DS1307's big<br> brother and includes alarms. However, there are no alarm pins,<br> you just have to poll for if the alarm is "going off". But there<br> is lots of code out there already for the DS1337. If you need<br> alarm interrupts, I'm not sure what to use... nothing I'm<br> familiar with that has separate alarm pins.<br><br> On Thu, Sep 11, 2014 at 8:28 AM, Charles McClelland<br> <chip@mcclellands.org <mailto:chip@mcclellands.org>> wrote:<br><br> First, I wanted to thank Paul for the excellent presentation<br> on interrupts. I now have a Watch Dog Timer routine which<br> is saving me from having to put a clock on one project.<br><br> On my other project though, I still need a clock. And since<br> I am already using an I2C bus, I thought I could simply add<br> one to that bus. That way I will have two I2C sensors<br> connected to an Arduino (ATMEGA328). My question is how to<br> best implement the pull-up the resistors. Should I put<br> resistors on each (perhaps 10k since they will effectively<br> be in parallel) or should I put one set of pull up resistors<br> on the main board for both? It seems like the latter is the<br> better approach but I did not know if there was some reason<br> to do one over the other.<br><br> On a related note, I need a 3.3V I2C Real Time Clock with<br> Alarms - I am looking at the DS1339 and hoping I can use<br> some of the DS1307 library since they are both from Maxim. <br> Any other suggestions?<br><br> Thanks,<br><br> Chip<br><br><br><br> _______________________________________________<br> Triangle, NC Embedded Computing mailing list<br> TriEmbed@triembed.org <mailto:TriEmbed@triembed.org><br> http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br> TriEmbed web site: http://TriEmbed.org <http://triembed.org/><br><br><br></blockquote><br><br> _______________________________________________<br> Triangle, NC Embedded Computing mailing list<br> TriEmbed@triembed.org <mailto:TriEmbed@triembed.org><br> http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br> TriEmbed web site: http://TriEmbed.org <http://TriEmbed.org/><br><br><br>_______________________________________________<br>Triangle, NC Embedded Computing mailing list<br>TriEmbed@triembed.org <mailto:TriEmbed@triembed.org><br>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br>TriEmbed web site: http://TriEmbed.org<br></blockquote><br><br><br>_______________________________________________<br>Triangle, NC Embedded Computing mailing list<br>TriEmbed@triembed.org<br>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br>TriEmbed web site: http://TriEmbed.org<br></blockquote><br>-------------- next part --------------<br>An HTML attachment was scrubbed...<br>URL: <http://mail.triembed.org/pipermail/triembed_triembed.org/attachments/20140911/5febbe04/attachment.html><br><br>------------------------------<br><br>Subject: Digest Footer<br><br>_______________________________________________<br>TriEmbed mailing list<br>TriEmbed@triembed.org<br>http://mail.triembed.org/mailman/listinfo/triembed_triembed.org<br><br><br>------------------------------<br><br>End of TriEmbed Digest, Vol 16, Issue 12<br>****************************************<br></blockquote></div><br></div></div></body></html>