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. Troubleshooting
  3. Relay shows up in mysensors.json but not in gui [homeassistant]

Relay shows up in mysensors.json but not in gui [homeassistant]

Scheduled Pinned Locked Moved Troubleshooting
18 Posts 4 Posters 1.2k Views 4 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.
  • B Offline
    B Offline
    bereska
    wrote on last edited by
    #4

    i have the same very problem adding a water mater pulse sensor with the following sketch from mysensors.org

    /*
     * The MySensors Arduino library handles the wireless radio link and protocol
     * between your home built sensors/actuators and HA controller of choice.
     * The sensors forms a self healing radio network with optional repeaters. Each
     * repeater and gateway builds a routing tables in EEPROM which keeps track of the
     * network topology allowing messages to be routed to nodes.
     *
     * Created by Henrik Ekblad <henrik.ekblad@mysensors.org>
     * Copyright (C) 2013-2018 Sensnology AB
     * Full contributor list: https://github.com/mysensors/MySensors/graphs/contributors
     *
     * Documentation: http://www.mysensors.org
     * Support Forum: http://forum.mysensors.org
     *
     * This program is free software; you can redistribute it and/or
     * modify it under the terms of the GNU General Public License
     * version 2 as published by the Free Software Foundation.
     *
     *******************************
     *
     * REVISION HISTORY
     * Version 1.0 - Henrik Ekblad
     * Version 1.1 - GizMoCuz
     *
     * DESCRIPTION
     * Use this sensor to measure volume and flow of your house water meter.
     * You need to set the correct pulsefactor of your meter (pulses per m3).
     * The sensor starts by fetching current volume reading from gateway (VAR 1).
     * Reports both volume and flow back to gateway.
     *
     * Unfortunately millis() won't increment when the Arduino is in
     * sleepmode. So we cannot make this sensor sleep if we also want
     * to calculate/report flow.
     * http://www.mysensors.org/build/pulse_water
     */
    
    // Enable debug prints to serial monitor
    #define MY_DEBUG
    
    // Enable and select radio type attached
    #define MY_RADIO_RF24
    #define MY_NODE_ID 6
    //#define MY_RADIO_NRF5_ESB
    //#define MY_RADIO_RFM69
    //#define MY_RADIO_RFM95
    
    #include <MySensors.h>
    
    #define DIGITAL_INPUT_SENSOR 3                  // The digital input you attached your sensor.  (Only 2 and 3 generates interrupt!)
    
    #define PULSE_FACTOR 1000                       // Number of blinks per m3 of your meter (One rotation/liter)
    
    #define SLEEP_MODE false                        // flowvalue can only be reported when sleep mode is false.
    
    #define MAX_FLOW 40                             // Max flow (l/min) value to report. This filters outliers.
    
    #define CHILD_ID 1                              // Id of the sensor child
    
    uint32_t SEND_FREQUENCY =
        30000;           // Minimum time between send (in milliseconds). We don't want to spam the gateway.
    
    MyMessage flowMsg(CHILD_ID,V_FLOW);
    MyMessage volumeMsg(CHILD_ID,V_VOLUME);
    MyMessage lastCounterMsg(CHILD_ID,V_VAR1);
    
    double ppl = ((double)PULSE_FACTOR)/1000;        // Pulses per liter
    
    volatile uint32_t pulseCount = 0;
    volatile uint32_t lastBlink = 0;
    volatile double flow = 0;
    bool pcReceived = false;
    uint32_t oldPulseCount = 0;
    uint32_t newBlink = 0;
    double oldflow = 0;
    double volume =0;
    double oldvolume =0;
    uint32_t lastSend =0;
    uint32_t lastPulse =0;
    
    void setup()
    {
      // initialize our digital pins internal pullup resistor so one pulse switches from high to low (less distortion)
      pinMode(DIGITAL_INPUT_SENSOR, INPUT_PULLUP);
    
      pulseCount = oldPulseCount = 0;
    
      // Fetch last known pulse count value from gw
      request(CHILD_ID, V_VAR1);
    
      lastSend = lastPulse = millis();
    
      attachInterrupt(digitalPinToInterrupt(DIGITAL_INPUT_SENSOR), onPulse, FALLING);
    }
    
    void presentation()
    {
      // Send the sketch version information to the gateway and Controller
      sendSketchInfo("Water Meter", "1.1");
    
      // Register this device as Water flow sensor
      present(CHILD_ID, S_WATER);
    }
    
    void loop()
    {
      uint32_t currentTime = millis();
    
      // Only send values at a maximum frequency or woken up from sleep
      if (SLEEP_MODE || (currentTime - lastSend > SEND_FREQUENCY)) {
        lastSend=currentTime;
    
        if (!pcReceived) {
          //Last Pulsecount not yet received from controller, request it again
          request(CHILD_ID, V_VAR1);
          return;
        }
    
        if (!SLEEP_MODE && flow != oldflow) {
          oldflow = flow;
    
          Serial.print("l/min:");
          Serial.println(flow);
    
          // Check that we don't get unreasonable large flow value.
          // could happen when long wraps or false interrupt triggered
          if (flow<((uint32_t)MAX_FLOW)) {
            send(flowMsg.set(flow, 2));                   // Send flow value to gw
          }
        }
    
        // No Pulse count received in 2min
        if(currentTime - lastPulse > 120000) {
          flow = 0;
        }
    
        // Pulse count has changed
        if ((pulseCount != oldPulseCount)||(!SLEEP_MODE)) {
          oldPulseCount = pulseCount;
    
          Serial.print("pulsecount:");
          Serial.println(pulseCount);
    
          send(lastCounterMsg.set(pulseCount));                  // Send  pulsecount value to gw in VAR1
    
          double volume = ((double)pulseCount/((double)PULSE_FACTOR));
          if ((volume != oldvolume)||(!SLEEP_MODE)) {
            oldvolume = volume;
    
            Serial.print("volume:");
            Serial.println(volume, 3);
    
            send(volumeMsg.set(volume, 3));               // Send volume value to gw
          }
        }
      }
      if (SLEEP_MODE) {
        sleep(SEND_FREQUENCY);
      }
    }
    
    void receive(const MyMessage &message)
    {
      if (message.type==V_VAR1) {
        uint32_t gwPulseCount=message.getULong();
        pulseCount += gwPulseCount;
        flow=oldflow=0;
        Serial.print("Received last pulse count from gw:");
        Serial.println(pulseCount);
        pcReceived = true;
      }
    }
    
    void onPulse()
    {
      if (!SLEEP_MODE) {
        uint32_t newBlink = micros();
        uint32_t interval = newBlink-lastBlink;
    
        if (interval!=0) {
          lastPulse = millis();
          if (interval<500000L) {
            // Sometimes we get interrupt on RISING,  500000 = 0.5 second debounce ( max 120 l/min)
            return;
          }
          flow = (60000000.0 /interval) / ppl;
        }
        lastBlink = newBlink;
      }
      pulseCount++;
    }
    

    Node 6 as Water Meter shows up in mysensors.json and homeassistant logs but fails to appear in GUI.
    Thank you for your help

    1 Reply Last reply
    0
    • M Offline
      M Offline
      mcchots
      wrote on last edited by mcchots
      #5

      From my limited use with sensors other then temperature, sometimes items don't appear in the GUI on Home Assistant until they send some data.

      Also check in the States section of Developer Tools at what data HA has acquired from your sensor.

      Beyond that, you might have to ask on the Home Assistant forums.

      B 1 Reply Last reply
      0
      • M mcchots

        From my limited use with sensors other then temperature, sometimes items don't appear in the GUI on Home Assistant until they send some data.

        Also check in the States section of Developer Tools at what data HA has acquired from your sensor.

        Beyond that, you might have to ask on the Home Assistant forums.

        B Offline
        B Offline
        bereska
        wrote on last edited by
        #6

        @mcchots thank you, that's what I thought, too. Let me rig it up on my water meter and see if starts sending any data

        1 Reply Last reply
        0
        • J Offline
          J Offline
          Jens Jensen
          wrote on last edited by Jens Jensen
          #7

          So I too was having this issue and pulling my hair out trying to understand what was wrong.
          The homeassistant/mysensor doc page says you have to send intial values, but the important nuanced point is that ALL possible value types must have an initial value sent for a given sensor type.

          In my example, I could not figure out why my motion sensor (S_MOTION) was not registering in HA UI - I was sending an initial (V_TRIPPED) state.

          However, S_MOTION sensors can have both V_TRIPPED and V_ARMED.
          ref: https://www.mysensors.org/download/serial_api_20#presentation
          Once I sent an initial value for V_ARMED, it started working - whew!

          So check carefully that you are sending some initial value for EVERY possible value type of your sensor type.

          B 1 Reply Last reply
          0
          • J Jens Jensen

            So I too was having this issue and pulling my hair out trying to understand what was wrong.
            The homeassistant/mysensor doc page says you have to send intial values, but the important nuanced point is that ALL possible value types must have an initial value sent for a given sensor type.

            In my example, I could not figure out why my motion sensor (S_MOTION) was not registering in HA UI - I was sending an initial (V_TRIPPED) state.

            However, S_MOTION sensors can have both V_TRIPPED and V_ARMED.
            ref: https://www.mysensors.org/download/serial_api_20#presentation
            Once I sent an initial value for V_ARMED, it started working - whew!

            So check carefully that you are sending some initial value for EVERY possible value type of your sensor type.

            B Offline
            B Offline
            bereska
            wrote on last edited by
            #8

            @jens-jensen thank you for your input
            could you have a look at my sketch above and point me in the right direction on what needs to be changed/added?
            I see this part which looks good to me:

            MyMessage flowMsg(CHILD_ID,V_FLOW);
            MyMessage volumeMsg(CHILD_ID,V_VOLUME);
            MyMessage lastCounterMsg(CHILD_ID,V_VAR1);```
            thanks
            J 1 Reply Last reply
            0
            • B bereska

              @jens-jensen thank you for your input
              could you have a look at my sketch above and point me in the right direction on what needs to be changed/added?
              I see this part which looks good to me:

              MyMessage flowMsg(CHILD_ID,V_FLOW);
              MyMessage volumeMsg(CHILD_ID,V_VOLUME);
              MyMessage lastCounterMsg(CHILD_ID,V_VAR1);```
              thanks
              J Offline
              J Offline
              Jens Jensen
              wrote on last edited by Jens Jensen
              #9

              @bereska
              looks mostly correct, althought I would take a look at the example here to use their technique for ensuring you send initial values for V_FLOW and V_VOLUME.
              ref: https://www.home-assistant.io/components/mysensors/

              From your sketch, it seems possible that either may not be sent right away, e.g. if volume or flow is not changing, etc.

              Also, where in HA UI are you looking? I had to add my sensor to one of my lovelace cards. Still getting the hang of the new UI (but definitely better than it was before). I also saw it in developer, states under current entities

              B 1 Reply Last reply
              0
              • J Jens Jensen

                @bereska
                looks mostly correct, althought I would take a look at the example here to use their technique for ensuring you send initial values for V_FLOW and V_VOLUME.
                ref: https://www.home-assistant.io/components/mysensors/

                From your sketch, it seems possible that either may not be sent right away, e.g. if volume or flow is not changing, etc.

                Also, where in HA UI are you looking? I had to add my sensor to one of my lovelace cards. Still getting the hang of the new UI (but definitely better than it was before). I also saw it in developer, states under current entities

                B Offline
                B Offline
                bereska
                wrote on last edited by
                #10

                @jens-jensen thank you, like you said the sketch looks ok. Yet this only sensor fails to appear in HA, neither on dashboard nor in states or unused entities. The only thing I have noticed though is that this sketch is missing this part:

                Bounce debouncer = Bounce();
                bool state = false;
                bool initialValueSent = false;
                

                maybe that's the key to this problem?

                B 1 Reply Last reply
                0
                • B bereska

                  @jens-jensen thank you, like you said the sketch looks ok. Yet this only sensor fails to appear in HA, neither on dashboard nor in states or unused entities. The only thing I have noticed though is that this sketch is missing this part:

                  Bounce debouncer = Bounce();
                  bool state = false;
                  bool initialValueSent = false;
                  

                  maybe that's the key to this problem?

                  B Offline
                  B Offline
                  bereska
                  wrote on last edited by
                  #11

                  this is HA log:

                  2019-07-04 23:24:05 DEBUG (MainThread) [homeassistant.components.mqtt] Received message on mygateway1-out/6/255/3/0/11: b'Water Meter',
                  2019-07-04 23:24:05 DEBUG (MainThread) [mysensors.gateway_mqtt] Receiving 6;255;3;0;11;Water Meter,
                  2019-07-04 23:24:23 DEBUG (MainThread) [homeassistant.components.mqtt] Received message on mygateway1-out/6/255/3/0/11: b'Water Meter',
                  2019-07-04 23:24:23 DEBUG (MainThread) [mysensors.gateway_mqtt] Receiving 6;255;3;0;11;Water Meter

                  1 Reply Last reply
                  0
                  • J Offline
                    J Offline
                    Jens Jensen
                    wrote on last edited by
                    #12

                    Looking at your HA log, do you see that both V_FLOW and V_VOLUME values are sent after some time?

                    With the sketch, their idea is that you use initialValueSent to send initial values (for all types) only once (at first boot) in loop section.

                    B 1 Reply Last reply
                    0
                    • J Jens Jensen

                      Looking at your HA log, do you see that both V_FLOW and V_VOLUME values are sent after some time?

                      With the sketch, their idea is that you use initialValueSent to send initial values (for all types) only once (at first boot) in loop section.

                      B Offline
                      B Offline
                      bereska
                      wrote on last edited by
                      #13

                      @jens-jensen said in Relay shows up in mysensors.json but not in gui [homeassistant]:

                      V_FLOW and V_VOLUME values are sent after some time

                      no, V_FLOW and V_VOLUME values are NOT sent after some time
                      how to i modify the sketch to make it happen?

                      J 1 Reply Last reply
                      0
                      • B bereska

                        @jens-jensen said in Relay shows up in mysensors.json but not in gui [homeassistant]:

                        V_FLOW and V_VOLUME values are sent after some time

                        no, V_FLOW and V_VOLUME values are NOT sent after some time
                        how to i modify the sketch to make it happen?

                        J Offline
                        J Offline
                        Jens Jensen
                        wrote on last edited by
                        #14

                        @bereska
                        look at how the reference sketch in the homeassistant mysensors page works.
                        I starts with a bool initialValueSent set to false.
                        It checks for this in loop, and if not already set to true, it will send initial values, then set initialValueSent = false, so that it never runs again (until sensor is restarted).

                        Also regarding your sketch logic, should it periodically send values of all sensors (like at least once per hour, per day, etc)? You may want to look at that as well.

                        1 Reply Last reply
                        0
                        • J Offline
                          J Offline
                          Jens Jensen
                          wrote on last edited by
                          #15

                          ok, I think i have also may have found a bug in the HA mysensors implementation, i.e. if you name your sketch with some reserved names, it never registers in HA.

                          I.e.
                          sendSketchInfo("motion_sensor", "1.0"); won't work in HA
                          but sendSketchInfo("motion_sensor_foo", "1.0"); shows up :(
                          I didn't see any mention of this in https://www.home-assistant.io/components/mysensors/
                          Maybe it's a bug (should mysensors ha component rename it or prefix with some namespace, etc; or should this be documented in guide - and then what are the reserved names which we cannot name sketches to?)

                          1 Reply Last reply
                          0
                          • J Offline
                            J Offline
                            Jens Jensen
                            wrote on last edited by
                            #16

                            nm, I seems like it eventually sends the sketch name

                            B 1 Reply Last reply
                            0
                            • J Jens Jensen

                              nm, I seems like it eventually sends the sketch name

                              B Offline
                              B Offline
                              bereska
                              wrote on last edited by
                              #17

                              @jens-jensen it does send and register the name, no problem.

                              1 Reply Last reply
                              0
                              • B Offline
                                B Offline
                                bereska
                                wrote on last edited by
                                #18

                                i can't get this sensor to show up in HA. Any ideas anyone?

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


                                14

                                Online

                                11.7k

                                Users

                                11.2k

                                Topics

                                113.0k

                                Posts


                                Copyright 2019 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