-
Notifications
You must be signed in to change notification settings - Fork 710
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Create EU DST example #308
base: master
Are you sure you want to change the base?
Changes from 2 commits
7ca75cd
e9f4efc
5b98cfd
5b81a04
fc6647c
5b55949
d88958f
56f8a79
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,59 @@ | ||||||
/* EU DST example */ | ||||||
/* version 3: dd 14-10-2024 */ | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This date format is ambiguous. Prefer the ISO date format: 2024-10-14. Or, better yet, remove the line: the history of this file is in the git repository anyways. |
||||||
|
||||||
// The RTC is kept in local winter time (standard time). This approach is key for the simplicity of this solution. | ||||||
// This code is for a DST from Last sunday in March 1:00 (am) local time until Last sunday in October 3:00 (am) local time. | ||||||
// The DST time can be changed if required, by choosing a different hour in the DateTime function (4th parameter). | ||||||
|
||||||
#include <RTClib.h> // https://github.com/adafruit/rtclib | ||||||
RTC_DS3231 rtc; | ||||||
//RTC_DS1307 rtc; | ||||||
|
||||||
#define USEDST true // Use DST (true or false) | ||||||
|
||||||
DateTime now; | ||||||
|
||||||
DateTime dstclock(DateTime n) { // Return the given (DST adjusted) date and time according to DST settings (for extensive date and time calculations) | ||||||
|
||||||
DateTime b, e; | ||||||
|
||||||
b = DateTime(n.year(), 3, 31, 1, 0, 0); // Begin of DST: set on March 31 1:000 (am) | ||||||
if (month(n) = 3) b = DateTime(n.year(), 3, 31 - b.dayOfTheWeek(), 1, 0, 0); // Begin of DST: adjusted to last sunday in March 1:00 (am) when actual month is March | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This doesn't compile. You mean:
Suggested change
|
||||||
e = DateTime(n.year(), 10, 31, 3, 0, 0); // End of DST: set on October 31 3:00 (am) | ||||||
if (month(n) = 10) e = DateTime(n.year(), 10, 31 - e.dayOfTheWeek(), 3, 0, 0); // End of DST: adjusted to last sunday in October 3:00 (am) when actual month is October | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same here:
Suggested change
|
||||||
|
||||||
if (USEDST && (n > b) && (n < e)) n = n + TimeSpan(0,1,0,0); // adjust to standard time if within summertime | ||||||
return n; | ||||||
}; | ||||||
|
||||||
DateTime getclock() { // Retrieve the (DST adjusted) date and time | ||||||
|
||||||
DateTime n, b, e; | ||||||
|
||||||
n = rtc.now(); | ||||||
b = DateTime(n.year(), 3, 31, 1, 0, 0); // Begin of DST: set on March 31 1:000 (am) | ||||||
if (month(n) = 3) b = DateTime(n.year(), 3, 31 - b.dayOfTheWeek(), 1, 0, 0); // Begin of DST: adjusted to last sunday in March 1:00 (am) when actual month is March | ||||||
e = DateTime(n.year(), 10, 31, 3, 0, 0); // End of DST: set on October 31 3:00 (am) | ||||||
if (month(n) = 10) e = DateTime(n.year(), 10, 31 - e.dayOfTheWeek(), 3, 0, 0); // End of DST: adjusted to last sunday in October 3:00 (am) when actual month is October | ||||||
|
||||||
if (USEDST && (n > b) && (n < e)) n = n + TimeSpan(0,1,0,0); // adjust to standard time if within summertime | ||||||
return n; | ||||||
}; | ||||||
|
||||||
void setclock(DateTime n) { // if the clock is set during summertime then adjust the clock to standard time | ||||||
|
||||||
if (USEDST && (n != dstclock(n)) n = n - TimeSpan(0,1,0,0); // if summertime then adjust to the standard time | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There are mismatched parentheses here:
Suggested change
|
||||||
rtc.adjust(n); // Set the clock to standard time | ||||||
}; | ||||||
|
||||||
void setup() { | ||||||
// initialise the rtc | ||||||
rtc.begin(); | ||||||
// if (rtc.lostPower()) setclock(DateTime(F(__DATE__), F(__TIME__))); // Set date and time for use with the DS3231 RTC | ||||||
if (!rtc.isrunning()) setclock(DateTime(F(__DATE__), F(__TIME__))); // Set date and time for use with the DS1307 RTC | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This doesn't compile: the class |
||||||
} | ||||||
|
||||||
void loop() { | ||||||
now = getclock(); // read the time from the RTC and adjust for DST or | ||||||
// now = dstclock(rtc.now()); // read the time from the RTC and adjust for DST | ||||||
} | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would be nice if this example did something visible, just like all the others do. The simplest would be to initialize the serial port in void loop() {
DateTime now = getclock(); // read the time from the RTC and adjust for DST
Serial.println(now.timestamp());
delay(1000);
} There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This time it compiles :-) and a nice demonstration is added. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This deserves a few more explanations, stating for instance that:
The RTC is kept in local winter time. This is not obvious at first sight, and is quite non-standard (common practice is to keep the RTC either in UTC or in local time).
This code is for CET only. It can work across Europe if one is willing to accept the DST change to be one hour off.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Very relevant suggestions.
Point 1 appears to be the key to make it a very simple procedure.
Point 2 The hour is now set to 1 and 3. This can be adapted to your local time (for instance at 2 and 4) if applicable. Therefore it is an example.
I would love to add these point to a comment in the proposed code, but have problems to find out how. (This is the very first pull request I ever do).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe a comment explaining how to do so would be of some value.