Skip to content
  • MySensors
  • OpenHardware.io
  • Categories
  • Recent
  • Tags
  • Popular
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Brand Logo
  1. Home
  2. My Project
  3. gw.sleep on battery powered magnet door switch

gw.sleep on battery powered magnet door switch

Scheduled Pinned Locked Moved My Project
42 Posts 13 Posters 13.2k Views 16 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • sundberg84S Offline
    sundberg84S Offline
    sundberg84
    Hardware Contributor
    wrote on last edited by sundberg84
    #2

    @Chakkie - Looks right, Do you see anything in the serial debug log when you try?

    Controller: Proxmox VM - Home Assistant
    MySensors GW: Arduino Uno - W5100 Ethernet, Gw Shield Nrf24l01+ 2,4Ghz
    MySensors GW: Arduino Uno - Gw Shield RFM69, 433mhz
    RFLink GW - Arduino Mega + RFLink Shield, 433mhz

    ChakkieC 1 Reply Last reply
    0
    • mfalkviddM Offline
      mfalkviddM Offline
      mfalkvidd
      Mod
      wrote on last edited by
      #3

      The code looks ok to me (except that you might as well set SLEEP_TIME to 0 since the loop only will report on change, regardless of the sleep time).
      Maybe add a few Serial.println statements in different parts of the loop so you can debug what happens?

      ChakkieC 1 Reply Last reply
      0
      • sundberg84S sundberg84

        @Chakkie - Looks right, Do you see anything in the serial debug log when you try?

        ChakkieC Offline
        ChakkieC Offline
        Chakkie
        wrote on last edited by
        #4

        @sundberg84

        I have added some print to debugged. It seems like the code with sleep does not verify and send the high 1 or low 0 when I open and close the contact. See the serial debug log. The repeated sleep in the log is when i open and close the contact. Normally it will send 1 or 0 " send: 204-204-0-0 s=3,c=1,t=16,pt=2,l=2,sg=0,st=ok:0"

        void loop() 
        {
          debouncer.update();
          // Get the update value
          int value = debouncer.read();
        
          if (value != oldValue) {
             // Send in the new value
             Serial.println("Trigger");
             gw.send(msg.set(value==HIGH ? 1 : 0));
             oldValue = value;
          }     
          gw.sleep(INTERRUPT,CHANGE, SLEEP_TIME);
          Serial.println("Sleep");
        
        send: 204-204-0-0 s=255,c=3,t=15,pt=2,l=2,sg=0,st=ok:0
        send: 204-204-0-0 s=255,c=0,t=17,pt=0,l=5,sg=0,st=ok:1.5.4
        send: 204-204-0-0 s=255,c=3,t=6,pt=1,l=1,sg=0,st=ok:0
        read: 0-0-204 s=255,c=3,t=6,pt=0,l=1,sg=0:M
        sensor started, id=204, parent=0, distance=1
        send: 204-204-0-0 s=3,c=0,t=0,pt=0,l=0,sg=0,st=ok:
        Trigger
        send: 204-204-0-0 s=3,c=1,t=16,pt=2,l=2,sg=0,st=ok:0
        Sleep
        Sleep
        Sleep
        Sleep
        Sleep
        Sleep
        Sleep
        Sleep
        

        Raspberry Pi 2
        Domoticz
        RFXCOM
        ZWAVE Aeon stick
        Coming soon Arduino mysensors GW

        AWIA 1 Reply Last reply
        0
        • mfalkviddM mfalkvidd

          The code looks ok to me (except that you might as well set SLEEP_TIME to 0 since the loop only will report on change, regardless of the sleep time).
          Maybe add a few Serial.println statements in different parts of the loop so you can debug what happens?

          ChakkieC Offline
          ChakkieC Offline
          Chakkie
          wrote on last edited by
          #5

          @mfalkvidd Hi thanks

          Changing the sleep time to 0 does not help. When I open and close the contact the status will not be sent. That's weird

          Raspberry Pi 2
          Domoticz
          RFXCOM
          ZWAVE Aeon stick
          Coming soon Arduino mysensors GW

          1 Reply Last reply
          0
          • sundberg84S Offline
            sundberg84S Offline
            sundberg84
            Hardware Contributor
            wrote on last edited by
            #6

            @Chakkie - add a debugline and see what value and oldvalue says.
            See if you can measure the input when you close the contact and when its open so its not a hardware failure.

            Controller: Proxmox VM - Home Assistant
            MySensors GW: Arduino Uno - W5100 Ethernet, Gw Shield Nrf24l01+ 2,4Ghz
            MySensors GW: Arduino Uno - Gw Shield RFM69, 433mhz
            RFLink GW - Arduino Mega + RFLink Shield, 433mhz

            ChakkieC 1 Reply Last reply
            1
            • ChakkieC Chakkie

              @sundberg84

              I have added some print to debugged. It seems like the code with sleep does not verify and send the high 1 or low 0 when I open and close the contact. See the serial debug log. The repeated sleep in the log is when i open and close the contact. Normally it will send 1 or 0 " send: 204-204-0-0 s=3,c=1,t=16,pt=2,l=2,sg=0,st=ok:0"

              void loop() 
              {
                debouncer.update();
                // Get the update value
                int value = debouncer.read();
              
                if (value != oldValue) {
                   // Send in the new value
                   Serial.println("Trigger");
                   gw.send(msg.set(value==HIGH ? 1 : 0));
                   oldValue = value;
                }     
                gw.sleep(INTERRUPT,CHANGE, SLEEP_TIME);
                Serial.println("Sleep");
              
              send: 204-204-0-0 s=255,c=3,t=15,pt=2,l=2,sg=0,st=ok:0
              send: 204-204-0-0 s=255,c=0,t=17,pt=0,l=5,sg=0,st=ok:1.5.4
              send: 204-204-0-0 s=255,c=3,t=6,pt=1,l=1,sg=0,st=ok:0
              read: 0-0-204 s=255,c=3,t=6,pt=0,l=1,sg=0:M
              sensor started, id=204, parent=0, distance=1
              send: 204-204-0-0 s=3,c=0,t=0,pt=0,l=0,sg=0,st=ok:
              Trigger
              send: 204-204-0-0 s=3,c=1,t=16,pt=2,l=2,sg=0,st=ok:0
              Sleep
              Sleep
              Sleep
              Sleep
              Sleep
              Sleep
              Sleep
              Sleep
              
              AWIA Offline
              AWIA Offline
              AWI
              Hero Member
              wrote on last edited by
              #7

              @Chakkie debouncer does not function when you use the sleep function. Reason is that sleep puts the internal timer which is used by debouncer to rest. Remove the debouncer routine and debounce by including a gw.wait(40) before going to sleep. This avoids a retrigger by an eventual contact bounce.

              ChakkieC 1 Reply Last reply
              1
              • sundberg84S sundberg84

                @Chakkie - add a debugline and see what value and oldvalue says.
                See if you can measure the input when you close the contact and when its open so its not a hardware failure.

                ChakkieC Offline
                ChakkieC Offline
                Chakkie
                wrote on last edited by
                #8

                @sundberg84 I have debugged a several times. I am now sure it is not a hardware failure.

                Raspberry Pi 2
                Domoticz
                RFXCOM
                ZWAVE Aeon stick
                Coming soon Arduino mysensors GW

                1 Reply Last reply
                0
                • AWIA AWI

                  @Chakkie debouncer does not function when you use the sleep function. Reason is that sleep puts the internal timer which is used by debouncer to rest. Remove the debouncer routine and debounce by including a gw.wait(40) before going to sleep. This avoids a retrigger by an eventual contact bounce.

                  ChakkieC Offline
                  ChakkieC Offline
                  Chakkie
                  wrote on last edited by
                  #9

                  @AWI Thank you so much. Yes I have came to the conclusion that the debouncer does not seems to work fine with sleep function. So I have used a method other than debouncer.

                  Here the working script below:

                  #include <MySensor.h>
                  #include <SPI.h>
                  
                  
                  #define CHILD_ID_Deur 11
                  #define CHILD_ID_Post 12
                  #define BUTTON_PIN_Deur  2  // Arduino Digital I/O pin for button/reed switch
                  #define BUTTON_PIN_Post  3  // Arduino Digital I/O pin for button/reed switch
                  
                  MySensor gw;
                  
                  
                  // Change to V_LIGHT if you use S_LIGHT in presentation below
                  MyMessage msgDeur(CHILD_ID_Deur,V_TRIPPED);
                  MyMessage msgPost(CHILD_ID_Post,V_TRIPPED);
                  
                  void setup()  
                  {  
                    gw.begin();
                  gw.sendSketchInfo("Voordeur contacts", "1.0");
                   // Setup the button
                    pinMode(BUTTON_PIN_Deur,INPUT);
                    pinMode(BUTTON_PIN_Post,INPUT);
                    // Activate internal pull-up
                    digitalWrite(BUTTON_PIN_Deur,HIGH);
                    digitalWrite(BUTTON_PIN_Post,HIGH);
                  
                    // Register binary input sensor to gw (they will be created as child devices)
                    // You can use S_DOOR, S_MOTION or S_LIGHT here depending on your usage. 
                    // If S_LIGHT is used, remember to update variable type you send in. See "msg" above.
                    gw.present(CHILD_ID_Deur, S_DOOR);
                    gw.present(CHILD_ID_Post, S_DOOR);   
                  }
                  
                  
                  //  Check if digital input has changed and send in new value
                  void loop() 
                  {
                    uint8_t value;
                    static uint8_t sentValue = 2;
                    static uint8_t sentValue2 = 2;
                  
                    // Short delay to allow buttons to properly settle
                    gw.sleep(5);
                  
                    value = digitalRead(BUTTON_PIN_Deur);
                  
                    if (value != sentValue) {
                      // Value has changed from last transmission, send the updated value
                      gw.send(msgDeur.set(value == HIGH ? 1 : 0));
                      sentValue = value;
                    }
                  
                    value = digitalRead(BUTTON_PIN_Post);
                  
                    if (value != sentValue2) {
                      // Value has changed from last transmission, send the updated value
                      gw.send(msgPost.set(value == HIGH ? 1 : 0));
                      sentValue2 = value;
                    }
                  
                  
                    // Sleep until something happens with the sensor
                    gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);// changing Secondary button to correct pin (-3) does not work. So keep it on (-2)
                    Serial.println("Sleep");
                  
                  }
                  
                  

                  Notice that the script does not work properly when I set BUTTON_PIN_Post - 3. The button pin post will not trigger. But when I change it to -2, both switches will work

                  gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);
                  

                  Raspberry Pi 2
                  Domoticz
                  RFXCOM
                  ZWAVE Aeon stick
                  Coming soon Arduino mysensors GW

                  AWIA 1 Reply Last reply
                  0
                  • ChakkieC Chakkie

                    @AWI Thank you so much. Yes I have came to the conclusion that the debouncer does not seems to work fine with sleep function. So I have used a method other than debouncer.

                    Here the working script below:

                    #include <MySensor.h>
                    #include <SPI.h>
                    
                    
                    #define CHILD_ID_Deur 11
                    #define CHILD_ID_Post 12
                    #define BUTTON_PIN_Deur  2  // Arduino Digital I/O pin for button/reed switch
                    #define BUTTON_PIN_Post  3  // Arduino Digital I/O pin for button/reed switch
                    
                    MySensor gw;
                    
                    
                    // Change to V_LIGHT if you use S_LIGHT in presentation below
                    MyMessage msgDeur(CHILD_ID_Deur,V_TRIPPED);
                    MyMessage msgPost(CHILD_ID_Post,V_TRIPPED);
                    
                    void setup()  
                    {  
                      gw.begin();
                    gw.sendSketchInfo("Voordeur contacts", "1.0");
                     // Setup the button
                      pinMode(BUTTON_PIN_Deur,INPUT);
                      pinMode(BUTTON_PIN_Post,INPUT);
                      // Activate internal pull-up
                      digitalWrite(BUTTON_PIN_Deur,HIGH);
                      digitalWrite(BUTTON_PIN_Post,HIGH);
                    
                      // Register binary input sensor to gw (they will be created as child devices)
                      // You can use S_DOOR, S_MOTION or S_LIGHT here depending on your usage. 
                      // If S_LIGHT is used, remember to update variable type you send in. See "msg" above.
                      gw.present(CHILD_ID_Deur, S_DOOR);
                      gw.present(CHILD_ID_Post, S_DOOR);   
                    }
                    
                    
                    //  Check if digital input has changed and send in new value
                    void loop() 
                    {
                      uint8_t value;
                      static uint8_t sentValue = 2;
                      static uint8_t sentValue2 = 2;
                    
                      // Short delay to allow buttons to properly settle
                      gw.sleep(5);
                    
                      value = digitalRead(BUTTON_PIN_Deur);
                    
                      if (value != sentValue) {
                        // Value has changed from last transmission, send the updated value
                        gw.send(msgDeur.set(value == HIGH ? 1 : 0));
                        sentValue = value;
                      }
                    
                      value = digitalRead(BUTTON_PIN_Post);
                    
                      if (value != sentValue2) {
                        // Value has changed from last transmission, send the updated value
                        gw.send(msgPost.set(value == HIGH ? 1 : 0));
                        sentValue2 = value;
                      }
                    
                    
                      // Sleep until something happens with the sensor
                      gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);// changing Secondary button to correct pin (-3) does not work. So keep it on (-2)
                      Serial.println("Sleep");
                    
                    }
                    
                    

                    Notice that the script does not work properly when I set BUTTON_PIN_Post - 3. The button pin post will not trigger. But when I change it to -2, both switches will work

                    gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);
                    
                    AWIA Offline
                    AWIA Offline
                    AWI
                    Hero Member
                    wrote on last edited by
                    #10

                    @Chakkie Good to hear. Using "-3" makes the interrupt number the same for _Deur and _Post. Using -2 activates both interrupt 0 and 1.
                    You'r ready for the next project..

                    ChakkieC 1 Reply Last reply
                    0
                    • mfalkviddM Offline
                      mfalkviddM Offline
                      mfalkvidd
                      Mod
                      wrote on last edited by
                      #11

                      We should really get rid of the confusing "- 2" stuff in the examples and start using DigtalPinToInterrupt instead.
                      I'm annoyed enough to see if I can create a pull request later this week.

                      ChakkieC 1 Reply Last reply
                      1
                      • AWIA AWI

                        @Chakkie Good to hear. Using "-3" makes the interrupt number the same for _Deur and _Post. Using -2 activates both interrupt 0 and 1.
                        You'r ready for the next project..

                        ChakkieC Offline
                        ChakkieC Offline
                        Chakkie
                        wrote on last edited by
                        #12

                        @AWI Thanks. By the way would you care to explain the interrupt index number? or may be a link for explanation?

                        Raspberry Pi 2
                        Domoticz
                        RFXCOM
                        ZWAVE Aeon stick
                        Coming soon Arduino mysensors GW

                        AWIA 1 Reply Last reply
                        0
                        • ChakkieC Chakkie

                          @AWI Thanks. By the way would you care to explain the interrupt index number? or may be a link for explanation?

                          AWIA Offline
                          AWIA Offline
                          AWI
                          Hero Member
                          wrote on last edited by AWI
                          #13

                          @Chakkie In a few words.. The ATMEGA has two external interrupts 0 and 1 which are connected to pins 2 and 3. ("-2" translates the pin number to the interrupt number, which is rather confusing as @mfalkvidd meant)

                          ChakkieC 1 Reply Last reply
                          0
                          • mfalkviddM mfalkvidd

                            We should really get rid of the confusing "- 2" stuff in the examples and start using DigtalPinToInterrupt instead.
                            I'm annoyed enough to see if I can create a pull request later this week.

                            ChakkieC Offline
                            ChakkieC Offline
                            Chakkie
                            wrote on last edited by
                            #14

                            @mfalkvidd Thanks for the info. Does DigitalPinTolnterrupt works better?

                            Raspberry Pi 2
                            Domoticz
                            RFXCOM
                            ZWAVE Aeon stick
                            Coming soon Arduino mysensors GW

                            1 Reply Last reply
                            0
                            • AWIA AWI

                              @Chakkie In a few words.. The ATMEGA has two external interrupts 0 and 1 which are connected to pins 2 and 3. ("-2" translates the pin number to the interrupt number, which is rather confusing as @mfalkvidd meant)

                              ChakkieC Offline
                              ChakkieC Offline
                              Chakkie
                              wrote on last edited by
                              #15

                              @AWI Thanks this clear thinks up but at the same time also confusing too.

                              So "-2" activates both 0 and 1 on pin 2 or pin 3 as you mentioned earlier. I always though it represents a pin number.

                              Raspberry Pi 2
                              Domoticz
                              RFXCOM
                              ZWAVE Aeon stick
                              Coming soon Arduino mysensors GW

                              AWIA 1 Reply Last reply
                              0
                              • ChakkieC Chakkie

                                @AWI Thanks this clear thinks up but at the same time also confusing too.

                                So "-2" activates both 0 and 1 on pin 2 or pin 3 as you mentioned earlier. I always though it represents a pin number.

                                AWIA Offline
                                AWIA Offline
                                AWI
                                Hero Member
                                wrote on last edited by
                                #16

                                @Chakkie The function digitalPinToInterrupt(pin) translates the pin number to the attached interrupt like "-2" does but in a reliable and more understandable way.

                                ChakkieC 1 Reply Last reply
                                0
                                • AWIA AWI

                                  @Chakkie The function digitalPinToInterrupt(pin) translates the pin number to the attached interrupt like "-2" does but in a reliable and more understandable way.

                                  ChakkieC Offline
                                  ChakkieC Offline
                                  Chakkie
                                  wrote on last edited by
                                  #17

                                  @AWI thanks. this looks like more promising.

                                  Raspberry Pi 2
                                  Domoticz
                                  RFXCOM
                                  ZWAVE Aeon stick
                                  Coming soon Arduino mysensors GW

                                  1 Reply Last reply
                                  0
                                  • mfalkviddM Offline
                                    mfalkviddM Offline
                                    mfalkvidd
                                    Mod
                                    wrote on last edited by
                                    #18

                                    Pull request done for the development version: https://github.com/mysensors/Arduino/pull/441

                                    1 Reply Last reply
                                    3
                                    • siodS Offline
                                      siodS Offline
                                      siod
                                      wrote on last edited by
                                      #19

                                      I would like to build the same but I am still very confused now. Could you upload some pictures so I can make myself an image of how you wirde things together?

                                      Also I don´t really understand what happens here: gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);

                                      still learning...

                                      AWIA 1 Reply Last reply
                                      0
                                      • siodS siod

                                        I would like to build the same but I am still very confused now. Could you upload some pictures so I can make myself an image of how you wirde things together?

                                        Also I don´t really understand what happens here: gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000);

                                        AWIA Offline
                                        AWIA Offline
                                        AWI
                                        Hero Member
                                        wrote on last edited by AWI
                                        #20

                                        @siod If you are using a "standard" Atmega328 (pro-mini, etc.) don't make it hard for yourself. This processor has two external interrupts (0 & 1) connected to pins 2 & 3. Taking your line of code gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000); the arguments are respectively:

                                        1. Use interrupt "0" (connected to pin 2 is BUTTON_PIN_Deur)
                                        2. Have is fired on change (i.e Rising and Falling)
                                        3. Use interrupt "1" (connected to pin 3 is BUTTON_PIN_Post)
                                        4. Have is fired on change (i.e Rising and Falling)
                                        5. Wake after every 86400000 ms (24 hrs) if no interrupt fired. To be safe you should use 86400000UL (the UL indicating that it is an Unsigned long type)
                                        siodS 1 Reply Last reply
                                        0
                                        • AWIA AWI

                                          @siod If you are using a "standard" Atmega328 (pro-mini, etc.) don't make it hard for yourself. This processor has two external interrupts (0 & 1) connected to pins 2 & 3. Taking your line of code gw.sleep(BUTTON_PIN_Deur - 2, CHANGE, BUTTON_PIN_Post - 2, CHANGE, 86400000); the arguments are respectively:

                                          1. Use interrupt "0" (connected to pin 2 is BUTTON_PIN_Deur)
                                          2. Have is fired on change (i.e Rising and Falling)
                                          3. Use interrupt "1" (connected to pin 3 is BUTTON_PIN_Post)
                                          4. Have is fired on change (i.e Rising and Falling)
                                          5. Wake after every 86400000 ms (24 hrs) if no interrupt fired. To be safe you should use 86400000UL (the UL indicating that it is an Unsigned long type)
                                          siodS Offline
                                          siodS Offline
                                          siod
                                          wrote on last edited by
                                          #21

                                          @AWI
                                          Ok thx for explanation, but that means he is using 2 reed switches, right (interrupt at pin2 and int pin3)?

                                          still learning...

                                          AWIA 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          15

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.1k

                                          Posts


                                          Copyright 2025 TBD   |   Forum Guidelines   |   Privacy Policy   |   Terms of Service
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • MySensors
                                          • OpenHardware.io
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular