Energy meter pulse sensor (ambiguous) won't compile



  • Hi All

    Im trying to get the Energy meter pulse sensor sketch working but when i test the code i get the following message.
    (exit status 1
    call of overloaded 'set(volatile long unsigned int&)' is ambiguous)

    any ideas would be great

    thanks in advance

    I'm running arduino 1.6.12
    and using the development branch

    /**
     * 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-2015 Sensnology AB
     * Full contributor list: https://github.com/mysensors/Arduino/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
     * Contribution by a-lurker and Anticimex,
     * Contribution by Norbert Truchsess <norbert.truchsess@t-online.de>
     * Contribution by Ivo Pullens (ESP8266 support)
     *
     * DESCRIPTION
     * The EthernetGateway sends data received from sensors to the WiFi link.
     * The gateway also accepts input on ethernet interface, which is then sent out to the radio network.
     *
     * VERA CONFIGURATION:
     * Enter "ip-number:port" in the ip-field of the Arduino GW device. This will temporarily override any serial configuration for the Vera plugin.
     * E.g. If you want to use the defualt values in this sketch enter: 192.168.178.66:5003
     *
     * LED purposes:
     * - To use the feature, uncomment any of the MY_DEFAULT_xx_LED_PINs in your sketch, only the LEDs that is defined is used.
     * - RX (green) - blink fast on radio message recieved. In inclusion mode will blink fast only on presentation recieved
     * - TX (yellow) - blink fast on radio message transmitted. In inclusion mode will blink slowly
     * - ERR (red) - fast blink on error during transmission error or recieve crc error
     *
     * See http://www.mysensors.org/build/esp8266_gateway for wiring instructions.
     * nRF24L01+  ESP8266
     * VCC        VCC
     * CE         GPIO4
     * CSN/CS     GPIO15
     * SCK        GPIO14
     * MISO       GPIO12
     * MOSI       GPIO13
     * GND        GND
     *
     * Not all ESP8266 modules have all pins available on their external interface.
     * This code has been tested on an ESP-12 module.
     * The ESP8266 requires a certain pin configuration to download code, and another one to run code:
     * - Connect REST (reset) via 10K pullup resistor to VCC, and via switch to GND ('reset switch')
     * - Connect GPIO15 via 10K pulldown resistor to GND
     * - Connect CH_PD via 10K resistor to VCC
     * - Connect GPIO2 via 10K resistor to VCC
     * - Connect GPIO0 via 10K resistor to VCC, and via switch to GND ('bootload switch')
     *
      * Inclusion mode button:
     * - Connect GPIO5 via switch to GND ('inclusion switch')
     *
     * Hardware SHA204 signing is currently not supported!
     *
     * Make sure to fill in your ssid and WiFi password below for ssid & pass.
     */
    
    
    // Enable debug prints to serial monitor
    #define MY_DEBUG
    
    // Use a bit lower baudrate for serial prints on ESP8266 than default in MyConfig.h
    #define MY_BAUD_RATE 9600
    
    // Enables and select radio type (if attached)
    //#define MY_RADIO_NRF24
    //#define MY_RADIO_RFM69
    
    #define MY_GATEWAY_ESP8266
    
    #define MY_ESP8266_SSID "home"
    #define MY_ESP8266_PASSWORD "Password"
    
    // Enable UDP communication
    //#define MY_USE_UDP
    
    // Set the hostname for the WiFi Client. This is the hostname
    // it will pass to the DHCP server if not static.
    // #define MY_ESP8266_HOSTNAME "sensor-gateway"
    
    // Enable MY_IP_ADDRESS here if you want a static ip address (no DHCP)
    #define MY_IP_ADDRESS 192,168,1,198
    
    // If using static ip you need to define Gateway and Subnet address as well
    #define MY_IP_GATEWAY_ADDRESS 192,168,1,254
    #define MY_IP_SUBNET_ADDRESS 255,255,255,0
    
    // The port to keep open on node server mode
    #define MY_PORT 5003
    
    // How many clients should be able to connect to this gateway (default 1)
    #define MY_GATEWAY_MAX_CLIENTS 2
    
    // Controller ip address. Enables client mode (default is "server" mode).
    // Also enable this if MY_USE_UDP is used and you want sensor data sent somewhere.
    //#define MY_CONTROLLER_IP_ADDRESS 192, 168, 178, 68
    
    // Enable inclusion mode
    //#define MY_INCLUSION_MODE_FEATURE
    
    // Enable Inclusion mode button on gateway
    // #define MY_INCLUSION_BUTTON_FEATURE
    // Set inclusion mode duration (in seconds)
    //#define MY_INCLUSION_MODE_DURATION 60
    // Digital pin used for inclusion mode button
    //#define MY_INCLUSION_MODE_BUTTON_PIN  3
    
    
    // Set blinking period
    // #define MY_DEFAULT_LED_BLINK_PERIOD 300
    
    // Flash leds on rx/tx/err
    // Led pins used if blinking feature is enabled above
    //#define MY_DEFAULT_ERR_LED_PIN 16  // Error led pin
    //#define MY_DEFAULT_RX_LED_PIN  16  // Receive led pin
    //#define MY_DEFAULT_TX_LED_PIN  16  // the PCB, on board LED
    
    #if defined(MY_USE_UDP)
      #include <WiFiUdp.h>
    #endif
    
    #include <ESP8266WiFi.h>
    
    #include <MySensors.h>
    
    
    #define DIGITAL_INPUT_SENSOR 3  // The digital input you attached your light sensor.  (Only 2 and 3 generates interrupt!)
    #define PULSE_FACTOR 1000       // Nummber of blinks per KWH of your meeter
    #define SLEEP_MODE false        // Watt-value can only be reported when sleep mode is false.
    #define MAX_WATT 10000          // Max watt value to report. This filetrs outliers.
    #define CHILD_ID 1              // Id of the sensor child
    
    unsigned long SEND_FREQUENCY = 20000; // Minimum time between send (in milliseconds). We don't wnat to spam the gateway.
    double ppwh = ((double)PULSE_FACTOR)/1000; // Pulses per watt hour
    bool pcReceived = false;
    volatile unsigned long pulseCount = 0;   
    volatile unsigned long lastBlink = 0;
    volatile unsigned long watt = 0;
    unsigned long oldPulseCount = 0;   
    unsigned long oldWatt = 0;
    double oldKwh;
    unsigned long lastSend;
    MyMessage wattMsg(CHILD_ID,V_WATT);
    MyMessage kwhMsg(CHILD_ID,V_KWH);
    MyMessage pcMsg(CHILD_ID,V_VAR1);
    
    
    void setup()  
    {  
      // Fetch last known pulse count value from gw
      request(CHILD_ID, V_VAR1);
    
      // Use the internal pullup to be able to hook up this sketch directly to an energy meter with S0 output
      // If no pullup is used, the reported usage will be too high because of the floating pin
      pinMode(DIGITAL_INPUT_SENSOR,INPUT_PULLUP);
    
      attachInterrupt(digitalPinToInterrupt(DIGITAL_INPUT_SENSOR), onPulse, RISING);
      lastSend=millis();
    }
    
    void presentation() {
      // Send the sketch version information to the gateway and Controller
      sendSketchInfo("Energy Meter", "1.0");
    
      // Register this device as power sensor
      present(CHILD_ID, S_POWER);
    }
    
    void loop()     
    { 
      unsigned long now = millis();
      // Only send values at a maximum frequency or woken up from sleep
      bool sendTime = now - lastSend > SEND_FREQUENCY;
      if (pcReceived && (SLEEP_MODE || sendTime)) {
        // New watt value has been calculated  
        if (!SLEEP_MODE && watt != oldWatt) {
          // Check that we dont get unresonable large watt value. 
          // could hapen when long wraps or false interrupt triggered
          if (watt<((unsigned long)MAX_WATT)) {
            send(wattMsg.set(watt));  // Send watt value to gw 
          }  
          Serial.print("Watt:");
          Serial.println(watt);
          oldWatt = watt;
        }
      
        // Pulse cout has changed
        if (pulseCount != oldPulseCount) {
          send(pcMsg.set(pulseCount));  // Send pulse count value to gw 
          double kwh = ((double)pulseCount/((double)PULSE_FACTOR));     
          oldPulseCount = pulseCount;
          if (kwh != oldKwh) {
            send(kwhMsg.set(kwh, 4));  // Send kwh value to gw 
            oldKwh = kwh;
          }
        }    
        lastSend = now;
      } else if (sendTime && !pcReceived) {
        // No count received. Try requesting it again
        request(CHILD_ID, V_VAR1);
        lastSend=now;
      }
      
      if (SLEEP_MODE) {
        sleep(SEND_FREQUENCY);
      }
    }
    
    void receive(const MyMessage &message) {
      if (message.type==V_VAR1) {  
        pulseCount = oldPulseCount = message.getLong();
        Serial.print("Received last pulse count from gw:");
        Serial.println(pulseCount);
        pcReceived = true;
      }
    }
    
    void onPulse()     
    { 
      if (!SLEEP_MODE) {
        unsigned long newBlink = micros();  
        unsigned long interval = newBlink-lastBlink;
        if (interval<10000L) { // Sometimes we get interrupt on RISING
          return;
        }
        watt = (3600000000.0 /interval) / ppwh;
        lastBlink = newBlink;
      } 
      pulseCount++;
    }
    
    
    
    

  • Contest Winner

    @Opus40 I can't compile it for ESP because I don't have it installed. But when I change it to an RFF sensor it compiles without errors in Arduino 1.6.8 IDE.

    Could you post the compile errors?



  • hi so this is what i get from the error messages

    "

    C:\Users\opus\Desktop\GatewayESP8266_-power_meter\GatewayESP8266-_power_meter.ino: In function 'void loop()':

    GatewayESP8266_-_power_meter:189: error: call of overloaded 'set(volatile long unsigned int&)' is ambiguous

         send(wattMsg.set(watt));  // Send watt value to gw 
    
                              ^
    

    C:\Users\opus\Desktop\GatewayESP8266_-power_meter\GatewayESP8266-_power_meter.ino:189:30: note: candidates are:

    In file included from C:\Program Files (x86)\Arduino\libraries\MySensors-development/MySensors.h:322:0,

                 from C:\Users\opus\Desktop\GatewayESP8266_-_power_meter\GatewayESP8266_-_power_meter.ino:134:
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:222:12: note: MyMessage& MyMessage::set(const char*) <near match>

    MyMessage& MyMessage::set(const char* value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:222:12: note: no known conversion for argument 1 from 'volatile long unsigned int' to 'const char*'

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:234:12: note: MyMessage& MyMessage::set(bool)

    MyMessage& MyMessage::set(bool value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:241:12: note: MyMessage& MyMessage::set(uint8_t)

    MyMessage& MyMessage::set(uint8_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:256:12: note: MyMessage& MyMessage::set(uint32_t)

    MyMessage& MyMessage::set(uint32_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:263:12: note: MyMessage& MyMessage::set(int32_t)

    MyMessage& MyMessage::set(int32_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:270:12: note: MyMessage& MyMessage::set(uint16_t)

    MyMessage& MyMessage::set(uint16_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:277:12: note: MyMessage& MyMessage::set(int16_t)

    MyMessage& MyMessage::set(int16_t value) {

            ^
    

    GatewayESP8266_-_power_meter:197: error: call of overloaded 'set(volatile long unsigned int&)' is ambiguous

       send(pcMsg.set(pulseCount));  // Send pulse count value to gw 
    
                                ^
    

    C:\Users\opus\Desktop\GatewayESP8266_-power_meter\GatewayESP8266-_power_meter.ino:197:32: note: candidates are:

    In file included from C:\Program Files (x86)\Arduino\libraries\MySensors-development/MySensors.h:322:0,

                 from C:\Users\opus\Desktop\GatewayESP8266_-_power_meter\GatewayESP8266_-_power_meter.ino:134:
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:222:12: note: MyMessage& MyMessage::set(const char*) <near match>

    MyMessage& MyMessage::set(const char* value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:222:12: note: no known conversion for argument 1 from 'volatile long unsigned int' to 'const char*'

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:234:12: note: MyMessage& MyMessage::set(bool)

    MyMessage& MyMessage::set(bool value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:241:12: note: MyMessage& MyMessage::set(uint8_t)

    MyMessage& MyMessage::set(uint8_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:256:12: note: MyMessage& MyMessage::set(uint32_t)

    MyMessage& MyMessage::set(uint32_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:263:12: note: MyMessage& MyMessage::set(int32_t)

    MyMessage& MyMessage::set(int32_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:270:12: note: MyMessage& MyMessage::set(uint16_t)

    MyMessage& MyMessage::set(uint16_t value) {

            ^
    

    C:\Program Files (x86)\Arduino\libraries\MySensors-development/core/MyMessage.cpp:277:12: note: MyMessage& MyMessage::set(int16_t)

    MyMessage& MyMessage::set(int16_t value) {

            ^
    

    exit status 1
    call of overloaded 'set(volatile long unsigned int&)' is ambiguous

    "


  • Contest Winner

    @Opus40 Might be a bug in the development branch. I use the 2.0 release.

    What happens if you compile it for a normal arduino and not as a gateway? (Just comment all the gateway and esp stuff and uncomment NRF) That's what I did.


  • Admin



  • Thanks Hek that's done it, should have looked for threads on the water sensor as well. and thanks to you alsoTheoL


Log in to reply
 

Suggested Topics

  • 3
  • 5
  • 2
  • 1

0
Online

11.4k
Users

11.1k
Topics

112.7k
Posts