Tags:
create new tag
view all tags

Exercise 8: RTC and data logging

Introduction

The ESP32 has a real time clock implemented on chip. This will however only work as long as the ESP32 is powered. It may therefore be interesting to employ an external RTC like the DS1307, backed up with a battery, to keep time even when the ESP32 is powered off or in deep sleep mode.

Getting the current (GMT) time from the internet is easy when using the ntptime module. We can make use of this to setup our RTC with the correct time.

Exercise 1: Set the ESP32 to the current time read from the Internet

The module ntptime allows you to get the current UTC time from the NTP server. It's function settime() sets the time of the ESP32 real time clock. Write a module that connects to the Internet through Wifi and that sets up the ESP32 with the current UTC time

Check with the ESP32 RTC module that the time was correctly set.

Exercise 2: Set the ESP32 RTC manually

If you do not have Internet access you can still set up the ESP32 RTC manually.

Ask the user for the current date and time and set the real time clock in the ESP32 correspondingly. Read back the time a little later and print it out. Use a parser similar to the one we wrote in session 1, exercise 2, for the calculator to check user input.

Be careful about the parameters passed into rtc.datetime((currentTime)). currentTime is a Python tuple with the following members: yyyy mm dd ww hh mm ss us where

  • yyyy: 4 digits for the year
  • mm: 2 digits for the month
  • dd: 2 digits for the day
  • ww: 2 digits for the day in the week. In fact these data do not seem to be used!
  • hh: the hour
  • mm: minutes
  • ss: seconds
  • us: microseconds (I always put these to 0)
You can actually calculate the ww parameter: the day in the week. You find the algorithm in
https://artofmemory.com/blog/how-to-calculate-the-day-of-the-week-4203.html

In my solution I wrote a module esp32RTC with the following functions:

  • rtcSetUserTime(): This asks the user for date and in in the form yyyy mm dd hh mm ss
    It then calls parse, another function of the esp32RTC module checking user input and parsing it.
    rtcSetUserTime finally creates a machine.RTC instance and sets the RTC with rtc.datetime()
  • rtcSetTime(year,month,day,hours,minutes,secs): takes the parameters year,month,day ... and tries to set the RTC time without any checks
  • rtcGetTime(): returns the current time as a tuple (yyyy,mm,dd,hh,mm,ss)
  • dayOfWeek(year,month,day): returns the code for the weekday (0=sun,6=sat)
  • dayOfWeekString(dayCode); returns a humanly readable string to the day of the week: "sun"..."sat"

Here is a screen dumps showing a session controlling the ESP32 RTC:

esp32RTC.png

Exercise 3: Set and read the time on the DS1307 I2C Real Time Clock

The disadvantage of getting the current time from the ESP32 RTC is that time is lost when the ESP32 is powered off. The DS1307 RTC however is batttery backed and time is kept even when the rest of the system is shut down.

Here is a photo of the DS1307 RTC shield:

rtc-1.png

As you can see, it features the DS1307 RTC chip itself but also an SD card reader. This board can therefore be used to generate a time stamp of the measurement, which can be saved, together with the measurement data, on an SD card file. Since SD cards have very high capacity, data can be taken over many hours without filling the file system.

Do the same thing as exercise 1 and 2 but use the DS1307 RTC instead of the ESP32 internal RTC.

You will need the DS1307 data sheet and the ds1307 driver found at github.

Exercise 4: Synchronize the clocks

Write a module with 2 functions synchronizing the clocks:

  • synchronize the ds1307 clock with the ESP32RTC time
  • synchronize the ESP32RTC with the ds3017 time

Exercise 5: Mount the SD card

Write a script to mount the SD card on the RTC and data logger module on "/sd". Create a directory /sd/data and check that is has been created as expected.

Exercise 6: Data logging

Write a script that

  • sets up the ESP32 RTC using ntptime
  • reads temperature and humidity values from the SHT30 every 5 s
  • write the time stamp and temperature and humidity values for the file /sd/data/sht30Data.txt
  • transfer the data to the PC and analyze them
The binary of MicroPython contains an ftp server named uftpd. You can start it by simply importing the module:

import uftpd

After that you can transfer the file with ftp to your PC

Concerning the time stamp there is a difference between MicroPython and CPython: MicroPython starts counting at 2000-01-01 while CPython uses Unix epoch, which starts at 1970-01-01.

timeStampCPython = timeStampMicroPython + time.UNIX_TIME which is the constant 946677600

MPY epoch is 2000-01-01 instead of unix epoch, which is 1970-01-01.

-- Uli Raich - 2020-05-06

Comments

Topic attachments
I Attachment History Action Size Date Who Comment
Texttxt cetTime.py.txt r1 manage 0.8 K 2020-05-25 - 10:00 UliRaich  
Texttxt dayOfWeek.py.txt r1 manage 1.7 K 2020-05-25 - 10:00 UliRaich  
PNGpng esp32RTC.png r1 manage 43.5 K 2020-05-06 - 20:01 UliRaich  
Texttxt esp32RTC.py.txt r1 manage 4.5 K 2020-05-25 - 10:00 UliRaich  
PNGpng rtc-1.png r1 manage 112.9 K 2020-05-25 - 17:47 UliRaich  
Edit | Attach | Watch | Print version | History: r9 < r8 < r7 < r6 < r5 | Backlinks | Raw View | Raw edit | More topic actions
Topic revision: r9 - 2020-07-26 - UliRaich
 
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 2008-2020 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback