Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. Windanzeige mit Ventus W132 & Wemos D1 Mini

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    511

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.6k

Windanzeige mit Ventus W132 & Wemos D1 Mini

Geplant Angeheftet Gesperrt Verschoben Hardware
45 Beiträge 14 Kommentatoren 11.2k Aufrufe 17 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • H Offline
    H Offline
    hugo1215
    schrieb am zuletzt editiert von hugo1215
    #27

    hallo @premo
    danke das du dein Script zur verfügung stellst. Werde es mal ausprobieren. WO stelle ich die Impulse in deinem Script ein. Ein bisschen erfahrung habe ich aber nicht genug.
    Denn Link von Github kenne ich schon leider klappt es damit nicht.

    Gruß

    premoP 1 Antwort Letzte Antwort
    0
    • C claus1993

      @hugo1215

      sorry dann kann ich leider nicht weiterhelfen. Sollte mir etwas einfallen würde ich mich melden.

      H Offline
      H Offline
      hugo1215
      schrieb am zuletzt editiert von
      #28

      @claus1993 sagte in Windanzeige mit Ventus W132 & Wemos D1 Mini:

      @hugo1215

      sorry dann kann ich leider nicht weiterhelfen. Sollte mir etwas einfallen würde ich mich melden.

      Hallo @claus1993,
      habe den Fehler gefunden. Bei den Board Verwaltung im Arduino Programm muss die Version 2.4.1 installiert sein. Dann klappt es.
      Bekomme jetzt auch die Daten in Iobroker. Soweit so gut. Kann man die Daten auch schneller Abrufen und nicht nur alle 30 sek??
      Gruß

      C ? 2 Antworten Letzte Antwort
      0
      • H hugo1215

        @claus1993 sagte in Windanzeige mit Ventus W132 & Wemos D1 Mini:

        @hugo1215

        sorry dann kann ich leider nicht weiterhelfen. Sollte mir etwas einfallen würde ich mich melden.

        Hallo @claus1993,
        habe den Fehler gefunden. Bei den Board Verwaltung im Arduino Programm muss die Version 2.4.1 installiert sein. Dann klappt es.
        Bekomme jetzt auch die Daten in Iobroker. Soweit so gut. Kann man die Daten auch schneller Abrufen und nicht nur alle 30 sek??
        Gruß

        C Offline
        C Offline
        claus1993
        schrieb am zuletzt editiert von
        #29

        @hugo1215 freut mich das es jetzt läuft. Was eine Verkürzung der Abfragezeit betrifft meine ich gelesen zu haben das der Skript Vergleichswerte zur Berechnung benötigt. Wenn dem so ist müsste man den Skript und die Berechnung anpassen.

        H 1 Antwort Letzte Antwort
        0
        • C claus1993

          @hugo1215 freut mich das es jetzt läuft. Was eine Verkürzung der Abfragezeit betrifft meine ich gelesen zu haben das der Skript Vergleichswerte zur Berechnung benötigt. Wenn dem so ist müsste man den Skript und die Berechnung anpassen.

          H Offline
          H Offline
          hugo1215
          schrieb am zuletzt editiert von
          #30

          @claus1993 hast du einen Tip wo ich schauen kann??
          Gruß

          1 Antwort Letzte Antwort
          0
          • H hugo1215

            hallo @premo
            danke das du dein Script zur verfügung stellst. Werde es mal ausprobieren. WO stelle ich die Impulse in deinem Script ein. Ein bisschen erfahrung habe ich aber nicht genug.
            Denn Link von Github kenne ich schon leider klappt es damit nicht.

            Gruß

            premoP Online
            premoP Online
            premo
            schrieb am zuletzt editiert von
            #31

            @hugo1215 sagte in Windanzeige mit Ventus W132 & Wemos D1 Mini:

            WO stelle ich die Impulse in deinem Script ein.

            In der "myconfig_samples.h"
            In der Zeile 16
            const float number_reed = 1

            1 Antwort Letzte Antwort
            0
            • C claus1993

              @mwyraz

              Habe mal alles in einen Sketch kopiert und ihn dann überprüfen lassen.

              Beim kopieren habe ich die define und include untereinander geschrieben. Den Rest der einzelnen Sketche habe ich dann darunter kopiert. Zusätzlich habe ich die define für die Userberechtigungen in den Sketch kopiert. Im Endeffekt habe ich aus 4 einzelnen Sketchen einen einzigen erstellt.

              /**
               * Ein ESP8622 NodeMCU Develompent Board, welches Sensorwerte via MQTT verschickt
               * http://frightanic.com/iot/comparison-of-esp8266-nodemcu-development-boards/
               * 
               * Umbau eines W132 Windsensors von ELV
               * 
               * - Abtrennen des 433 MHZ-Senders, welcher mit 3 Leitungen (Schwarz, Rot, Blau) an der Logik-Platine angeschlossen ist
               * - Anschließen des ESP-8266
               *   - Schwarz -> GND
               *   - Rot -> 3.3V
               *   - Blau -> D2
               * 
               * Eine Beschreibung des Protokoll ist unter http://www.tfd.hu/tfdhu/files/wsprotocol/auriol_protocol_v20.pdf zu finden, hilfreich ist auch https://sourceforge.net/p/wmrx00/discussion/855158/thread/b3a47730/
               * - Bits und Sync-Signale werden über die Abstände der fallenden Flanke codiert
               * - diese Implementierung nutzt dazu einen Interrupt auf der fallenden Flanke
               */
              
              
              #define MQTT_ALIVE_TOPIC "sensor/%s/alive"
              #define MQTT_DATA_TOPIC "sensor/%s/%s"
              #define MQTT_KEEPALIVE 10
              
              #define WIFI_SSID "mywifi"
              #define WIFI_PASSWORD "topsecret"
              #define MQTT_HOST "10.10.10.1"
              #define MQTT_PORT 1883
              #define MQTT_USERNAME "sensor"
              #define MQTT_PASSWORD "secret"
              
              #include <common_wifi.h>
              #include <common_mqtt.h>
              #include <esp_pins.h>
              #include <ESP8266WiFi.h>
              #include <WiFiUdp.h>
              #include <private_wifi.h>
              #include <PubSubClient.h>
              
              #define PIN_ANEMOMETER D2
              
              void setup_wifi() {
                delay(10);
                // We start by connecting to a WiFi network
                Serial.println();
                Serial.print("Connecting to ");
                Serial.println(WIFI_SSID);
              
                WiFi.mode(WIFI_STA); // disable hotspot
                WiFi.begin(WIFI_SSID,WIFI_PASSWORD);
                wdt_reset(); // Watchdock resetten
              
                while (WiFi.status() != WL_CONNECTED) {
                  delay(500);
                  Serial.print(".");
                }
              
                Serial.println("");
                Serial.println("WiFi connected");
                Serial.println("IP address: ");
                Serial.println(WiFi.localIP());
              }
              
              extern const char* MQTT_FALSE = "0";
              
              extern const char* MQTT_TRUE = "1";
              
              
              
              WiFiClient wifiClient;
              
              PubSubClient mqttClient(wifiClient);
              
              
              
              char MQTT_CLIENT_ID[15];
              
              
              
              void setup_mqtt() {
              
                mqttClient.setServer(MQTT_HOST, MQTT_PORT);
              
                byte mac[6];
              
                WiFi.macAddress(mac);
              
                sprintf(MQTT_CLIENT_ID, "ESP8266_%02X%02X%02X", mac[3], mac[4], mac[5]);
              
              }
              
              
              
              void connect_mqtt(char* MQTT_TOPIC) {
              
                // Loop until we're reconnected
              
                while (!mqttClient.connected()) {
              
                  Serial.print("Attempting MQTT connection...");
              
                  // Attempt to connect
              
              #if defined(MQTT_ALIVE_TOPIC)
              
                  byte mac[6];
              
                  WiFi.macAddress(mac);
              
                  char aliveTopicId[7];
              
                  sprintf(aliveTopicId, "%02X%02X%02X", mac[3], mac[4], mac[5]);
              
                  char aliveTopic[255];
              
                  sprintf(aliveTopic, MQTT_ALIVE_TOPIC, aliveTopicId);
              
                  if (mqttClient.connect(MQTT_CLIENT_ID, MQTT_USERNAME, MQTT_PASSWORD, aliveTopic, 1, 1, MQTT_FALSE)) {
              
                    Serial.println("connected with last will and testament enabled");
              
                    mqttClient.publish(aliveTopic,MQTT_TRUE,1);
              
                    Serial.print("Sent alive message to ");
              
                    Serial.println(aliveTopic);
              
              #else
              
                  if (mqttClient.connect(MQTT_CLIENT_ID, MQTT_USERNAME, MQTT_PASSWORD)) {
              
                    Serial.println("connected");
              
              #endif
              
                    if (MQTT_TOPIC && mqttClient.subscribe(MQTT_TOPIC,1)) {
              
                      Serial.print("Subscribed to ");
              
                      Serial.println(MQTT_TOPIC);
              
                    }
              
                  } else {
              
                    Serial.print("failed, rc=");
              
                    Serial.print(mqttClient.state());
              
                    Serial.println(" try again in 5 seconds");
              
                    // Wait 5 seconds before retrying
              
                    delay(5000);
              
                    wdt_reset();
              
                  }
              
                }
              
              }
              
              volatile unsigned long lastTrigger;
              
              byte mac[6];
              char sensorId[7];
              char topicBuffer[255];
              char messageBuffer[255];
              
              byte bitPos=-1;
              byte messageNum=-1;
              // there are always sent 6 messages. For temperature/humidity, the message is repeatet 6 times. For wind, 2 messages are repeatet 3 times each
              int message1Bits[36];
              int message2Bits[36];
              
              bool verifyChecksum(int bits[]) {
                int checksum=0xf;
                for (int i=0;i<8;i++) {
                  checksum-=bits[i*4]|bits[i*4+1]<<1|bits[i*4+2]<<2|bits[i*4+3]<<3;
                }
                checksum&=0xf;
                int expectedChecksum=bits[32]|bits[33]<<1|bits[34]<<2|bits[35]<<3;
                return checksum==expectedChecksum;
              }
              
              void decodeMessages() {
                if (!verifyChecksum(message1Bits)) {
                  Serial.println("Checksum mismatch in message #1");
                  return;
                }
                
              /*  
                Serial.println("---");
                for (int i=0;i<36;i++) {
                  Serial.print(message1Bits[i]);
                  Serial.print(" ");
                }
                Serial.println();
                for (int i=0;i<36;i++) {
                  Serial.print(message2Bits[i]);
                  Serial.print(" ");
                }
                Serial.println();
                */
                
                if (message1Bits[9]==1 && message1Bits[10]==1) { // wind data (2 messages)
              
                  if (!verifyChecksum(message2Bits)) {
                    Serial.println("Checksum mismatch in message #1");
                    return;
                  }
                  
                  float windSpeed=(message1Bits[24]    | message1Bits[25]<<1 | message1Bits[26]<<2 | message1Bits[27]<<3 |
                                   message1Bits[28]<<4 | message1Bits[29]<<5 | message1Bits[30]<<6 | message1Bits[31]<<7)*0.2f;
                  Serial.print("Average wind speed: ");
                  Serial.print(windSpeed);
                  Serial.println(" m/s");
              
                  sprintf(topicBuffer, MQTT_DATA_TOPIC, sensorId, "wind_speed");
                  String value = String(windSpeed,1);
                  value.toCharArray(messageBuffer,255);
                  mqttClient.publish(topicBuffer,(byte*)messageBuffer,strlen(messageBuffer));
              
              
                  float windGust=(message2Bits[24]    | message2Bits[25]<<1 | message2Bits[26]<<2 | message2Bits[27]<<3 |
                                  message2Bits[28]<<4 | message2Bits[29]<<5 | message2Bits[30]<<6 | message2Bits[31]<<7)*0.2f;
                  Serial.print("Max wind speed: ");
                  Serial.print(windGust);
                  Serial.println(" m/s");
              
                  sprintf(topicBuffer, MQTT_DATA_TOPIC, sensorId, "wind_gust");
                  value = String(windGust,1);
                  value.toCharArray(messageBuffer,255);
                  mqttClient.publish(topicBuffer,(byte*)messageBuffer,strlen(messageBuffer));
              
                  int windDirection=(message2Bits[15]    | message2Bits[16]<<1 | message2Bits[17]<<2 | message2Bits[18]<<3 |
                                     message2Bits[19]<<4 | message2Bits[20]<<5 | message2Bits[21]<<6 | message2Bits[22]<<7 |
                                     message2Bits[23]<<8);
                  Serial.print("Wind direction: ");
                  Serial.print(windDirection);
                  Serial.println(" °");
              
                  sprintf(topicBuffer, MQTT_DATA_TOPIC, sensorId, "wind_direction");
                  value = String(windDirection);
                  value.toCharArray(messageBuffer,255);
                  mqttClient.publish(topicBuffer,(byte*)messageBuffer,strlen(messageBuffer));
                  
                } else {  // temperature/humidity in both messages
                  int temperatureRaw=(message1Bits[12]    | message1Bits[13]<<1 | message1Bits[14]<<2 | message1Bits[15]<<3 |
                                      message1Bits[16]<<4 | message1Bits[17]<<5 | message1Bits[18]<<6 | message1Bits[19]<<7 | 
                                      message1Bits[20]<<8 | message1Bits[21]<<9 | message1Bits[22]<<10| message1Bits[23]<<11);
                  if (temperatureRaw& 0x800) temperatureRaw+=0xF000; // negative number, 12 to 16 bit
                  float temperature=temperatureRaw*0.1f;
                  Serial.print("Temperature: ");
                  Serial.print(temperature);
                  Serial.println(" °C");
              
                  sprintf(topicBuffer, MQTT_DATA_TOPIC, sensorId, "temp");
                  String value = String(temperature,1);
                  value.toCharArray(messageBuffer,255);
                  mqttClient.publish(topicBuffer,(byte*)messageBuffer,strlen(messageBuffer));
                  
                  int humidity=(message1Bits[24] | message1Bits[25]<<1 | message1Bits[26]<<2 | message1Bits[27]<<3 )+
                               (message1Bits[28] | message1Bits[29]<<1 | message1Bits[30]<<2 | message1Bits[31]<<3 )*10;
                  Serial.print("Humidity: ");
                  Serial.print(humidity);
                  Serial.println(" %");
              
                  sprintf(topicBuffer, MQTT_DATA_TOPIC, sensorId, "humi");
                  value = String(humidity);
                  value.toCharArray(messageBuffer,255);
                  mqttClient.publish(topicBuffer,(byte*)messageBuffer,strlen(messageBuffer));
                  
                }
                
              }
              
              void dataTrigger() {
                unsigned long now=micros();
                unsigned long duration=now-lastTrigger;
                lastTrigger=now;
              
                if (duration>30000) { // a news block of messages begins
                  messageNum=0;
                }
              
                if (duration>7000) { // ~9 ms = sync signal
                  if (bitPos==36) { // we got a full message
                    if (messageNum==0) { // 1st message completed
                      messageNum=1;
                    } else if (messageNum==1) { // 2nd message completed
                      decodeMessages();
                      messageNum=-1;
                    }
                  }
                  bitPos=0; // Nachricht begonnen
                  return;
                }
              
                if (messageNum<0) return; // ignore repeated messages
                if (bitPos<0) return; // invalid message, ignored
              
                if (messageNum==0) {
                  message1Bits[bitPos]=(duration>3300); // 2.2ms=LOW, 4.4ms = HIGH bits
                } else {
                  message2Bits[bitPos]=(duration>3300); // 2.2ms=LOW, 4.4ms = HIGH bits
                }
                bitPos++;
                if (bitPos>36) bitPos=-1; // message too long -> invalid
              }
              
              void setup() {
                wdt_enable(WDTO_8S); // Watchdog muss alle 8 Sekunden resettet werden
                Serial.begin(115200);
                Serial.println("Initializing");
              
                WiFi.macAddress(mac);
                sprintf(sensorId, "%02X%02X%02X", mac[3], mac[4], mac[5]);
              
                setup_wifi();
                wdt_reset(); // Watchdog resetten
                setup_mqtt();
                wdt_reset(); // Watchdog resetten
                
                pinMode(PIN_ANEMOMETER,INPUT);
                attachInterrupt(digitalPinToInterrupt(PIN_ANEMOMETER), dataTrigger, FALLING);
              
                wdt_reset(); // Watchdog resetten
              
                Serial.println("Starting");
              }
              
              void loop() {
                wdt_reset(); // Watchdog resetten
                connect_mqtt(0);
                wdt_reset(); // Watchdog resetten
                mqttClient.loop();
              }
              

              Beim Prüfen bekomme ich folgende Fehlerantwort; "common_wifi.h: No such file or Directory"

              Woran kann das liegen?

              Danke für deine Unterstützung!

              M Offline
              M Offline
              Meldb
              schrieb am zuletzt editiert von
              #32

              @claus1993 Hallo ich habe auch dein Skipt verwendet. Super danke erstmal das du es hier zu verfügung gestellt hat. Jetzt habe ich noch eine Frage weiter oben habt ihr über den Regensensor W174 geschrieben habt ihr das auch an dem Wemo mit dem Skript? Oder wie habt ihr das gemacht?

              C 1 Antwort Letzte Antwort
              0
              • M Meldb

                @claus1993 Hallo ich habe auch dein Skipt verwendet. Super danke erstmal das du es hier zu verfügung gestellt hat. Jetzt habe ich noch eine Frage weiter oben habt ihr über den Regensensor W174 geschrieben habt ihr das auch an dem Wemo mit dem Skript? Oder wie habt ihr das gemacht?

                C Offline
                C Offline
                claus1993
                schrieb am zuletzt editiert von
                #33

                @Meldb
                Jepp der läuft mit einem Wemos D1 Mini.

                M 1 Antwort Letzte Antwort
                0
                • C claus1993

                  @Meldb
                  Jepp der läuft mit einem Wemos D1 Mini.

                  M Offline
                  M Offline
                  Meldb
                  schrieb am zuletzt editiert von
                  #34

                  @claus1993 Hallo ich habe heute mein Sensor W132 bekommen ich bekomme immer den gleichen Temperatur u. Luftfeuchte Wert ist das bei dir auch so?

                  C 1 Antwort Letzte Antwort
                  0
                  • M Meldb

                    @claus1993 Hallo ich habe heute mein Sensor W132 bekommen ich bekomme immer den gleichen Temperatur u. Luftfeuchte Wert ist das bei dir auch so?

                    C Offline
                    C Offline
                    claus1993
                    schrieb am zuletzt editiert von claus1993
                    #35

                    @Meldb
                    Habe den Sensor mal angeklemmt und sehe das sich nur die Werte für den Wind ändern. Bei Temperatur und Humity ist schon weit längeren unverändert und wird bei einem Update auch nicht kurz grün. Kann die leider nicht sagen woran das liegt. Vielleicht gibt es den ein oder anderen Experten der den Code lesen kann und dort einen Fehler findet.

                    1 Antwort Letzte Antwort
                    0
                    • H hugo1215

                      @claus1993 sagte in Windanzeige mit Ventus W132 & Wemos D1 Mini:

                      @hugo1215

                      sorry dann kann ich leider nicht weiterhelfen. Sollte mir etwas einfallen würde ich mich melden.

                      Hallo @claus1993,
                      habe den Fehler gefunden. Bei den Board Verwaltung im Arduino Programm muss die Version 2.4.1 installiert sein. Dann klappt es.
                      Bekomme jetzt auch die Daten in Iobroker. Soweit so gut. Kann man die Daten auch schneller Abrufen und nicht nur alle 30 sek??
                      Gruß

                      ? Offline
                      ? Offline
                      Ein ehemaliger Benutzer
                      schrieb am zuletzt editiert von Ein ehemaliger Benutzer
                      #36

                      @hugo1215 said in Windanzeige mit Ventus W132 & Wemos D1 Mini:

                      habe den Fehler gefunden. Bei den Board Verwaltung im Arduino Programm muss die Version 2.4.1 installiert sein. Dann klappt es.

                      @mwyraz
                      Vielleicht könnte man den Punkt mit der Version 2.4.1 auf GitHub hinzufügen?

                      1 Antwort Letzte Antwort
                      0
                      • ? Offline
                        ? Offline
                        Ein ehemaliger Benutzer
                        schrieb am zuletzt editiert von
                        #37

                        Wie versorgt ihr das Teil mit Strom? Die Batterien halten ja nicht allzulange.

                        C 1 Antwort Letzte Antwort
                        0
                        • ? Ein ehemaliger Benutzer

                          Wie versorgt ihr das Teil mit Strom? Die Batterien halten ja nicht allzulange.

                          C Offline
                          C Offline
                          claus1993
                          schrieb am zuletzt editiert von
                          #38

                          @Brainbug said in Windanzeige mit Ventus W132 & Wemos D1 Mini:

                          Wie versorgt ihr das Teil mit Strom? Die Batterien halten ja nicht allzulange.

                          Die Versorgung erfolgt über den D1 Mini und dort über ein USB Netzteil.

                          1 Antwort Letzte Antwort
                          0
                          • ? Offline
                            ? Offline
                            Ein ehemaliger Benutzer
                            schrieb am zuletzt editiert von
                            #39

                            Die Temperatur Messung ist seltsam, morgens um 10 kommen Daten bis Abends um kurz vor 20 Uhr dann nichts mehr bis am nächsten Tag. Wie wenn im Code eine Zeit definiert wäre...

                            1 Antwort Letzte Antwort
                            0
                            • C Offline
                              C Offline
                              cap
                              schrieb am zuletzt editiert von
                              #40

                              Hallo zusammen,

                              ich versuche mit dem Code wir im Post von @claus1993 mein W132 mit dem D1 mini zum Laufen zu bringen. Das Kompilieren und Flashen geht, das Ding verbindet sich auch mit dem WiFi, jedoch bekomme ich im Serial Monitor die Fehlermeldung

                              ISR not in IRAM!
                              

                              Hier die komplette Fehlermeldung:

                              18:08:30.418 -> ...
                              18:08:31.404 -> WiFi connected
                              18:08:31.404 -> IP address: 
                              18:08:31.404 -> 192.168.---.---
                              18:08:31.404 -> ISR not in IRAM!
                              18:08:31.404 -> 
                              18:08:31.404 -> User exception (panic/abort/assert)
                              18:08:31.452 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
                              18:08:31.452 -> 
                              18:08:31.452 -> Abort called
                              18:08:31.452 -> 
                              18:08:31.452 -> >>>stack>>>
                              18:08:31.452 -> 
                              18:08:31.452 -> ctx: cont
                              18:08:31.452 -> sp: 3ffffef0 end: 3fffffc0 offset: 0000
                              18:08:31.452 -> 3ffffef0:  00000009 0000002e 3ffef7d4 40205879  
                              18:08:31.452 -> 3fffff00:  000000fe 00000000 00000000 00000000  
                              18:08:31.452 -> 3fffff10:  00000000 00000000 00000000 00ff0000  
                              18:08:31.452 -> 3fffff20:  5ffffe00 5ffffe00 00000000 00000000  
                              18:08:31.452 -> 3fffff30:  00000002 00000004 3ffee970 40204e16  
                              18:08:31.452 -> 3fffff40:  40100476 3ffee990 3ffe8844 40204e28  
                              18:08:31.452 -> 3fffff50:  40232ddd 0000000e 3ffee970 40205335  
                              18:08:31.452 -> 3fffff60:  00000000 000000d6 3ffee85d 40203c68  
                              18:08:31.498 -> 3fffff70:  3ffe862b 3ffee954 3ffee970 3ffeeabc  
                              18:08:31.498 -> 3fffff80:  3ffee990 3ffee85d 3ffee970 402053e4  
                              18:08:31.498 -> 3fffff90:  3ffee990 3ffee85d 3ffee970 4020181f  
                              18:08:31.498 -> 3fffffa0:  3fffdad0 00000000 3ffeea7c 40204798  
                              18:08:31.498 -> 3fffffb0:  feefeffe feefeffe 3ffe84f0 40100d71  
                              18:08:31.498 -> <<<stack<<<
                              18:08:31.498 -> 
                              18:08:31.498 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
                              18:08:31.498 -> 
                              18:08:31.498 ->  ets Jan  8 2013,rst cause:2, boot mode:(3,6)
                              18:08:31.498 -> 
                              18:08:31.498 -> load 0x4010f000, len 3584, room 16 
                              18:08:31.546 -> tail 0
                              18:08:31.546 -> chksum 0xb0
                              18:08:31.546 -> csum 0xb0
                              18:08:31.546 -> v2843a5ac
                              18:08:31.546 -> ~ld
                              18:08:31.594 -> Initializing
                              18:08:31.594 -> 
                              18:08:31.594 -> Connecting to CONTACT-wifi
                              18:08:32.117 -> .
                              

                              Das läuft dann so in Dauerschleife unendlich weiter.

                              Hat jemand vielleicht eine Idee woran es liegen kann? Würde mich auf eure Hilfe sehr freuen.

                              Danke und Gruß
                              Christo

                              R 1 Antwort Letzte Antwort
                              0
                              • C cap

                                Hallo zusammen,

                                ich versuche mit dem Code wir im Post von @claus1993 mein W132 mit dem D1 mini zum Laufen zu bringen. Das Kompilieren und Flashen geht, das Ding verbindet sich auch mit dem WiFi, jedoch bekomme ich im Serial Monitor die Fehlermeldung

                                ISR not in IRAM!
                                

                                Hier die komplette Fehlermeldung:

                                18:08:30.418 -> ...
                                18:08:31.404 -> WiFi connected
                                18:08:31.404 -> IP address: 
                                18:08:31.404 -> 192.168.---.---
                                18:08:31.404 -> ISR not in IRAM!
                                18:08:31.404 -> 
                                18:08:31.404 -> User exception (panic/abort/assert)
                                18:08:31.452 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
                                18:08:31.452 -> 
                                18:08:31.452 -> Abort called
                                18:08:31.452 -> 
                                18:08:31.452 -> >>>stack>>>
                                18:08:31.452 -> 
                                18:08:31.452 -> ctx: cont
                                18:08:31.452 -> sp: 3ffffef0 end: 3fffffc0 offset: 0000
                                18:08:31.452 -> 3ffffef0:  00000009 0000002e 3ffef7d4 40205879  
                                18:08:31.452 -> 3fffff00:  000000fe 00000000 00000000 00000000  
                                18:08:31.452 -> 3fffff10:  00000000 00000000 00000000 00ff0000  
                                18:08:31.452 -> 3fffff20:  5ffffe00 5ffffe00 00000000 00000000  
                                18:08:31.452 -> 3fffff30:  00000002 00000004 3ffee970 40204e16  
                                18:08:31.452 -> 3fffff40:  40100476 3ffee990 3ffe8844 40204e28  
                                18:08:31.452 -> 3fffff50:  40232ddd 0000000e 3ffee970 40205335  
                                18:08:31.452 -> 3fffff60:  00000000 000000d6 3ffee85d 40203c68  
                                18:08:31.498 -> 3fffff70:  3ffe862b 3ffee954 3ffee970 3ffeeabc  
                                18:08:31.498 -> 3fffff80:  3ffee990 3ffee85d 3ffee970 402053e4  
                                18:08:31.498 -> 3fffff90:  3ffee990 3ffee85d 3ffee970 4020181f  
                                18:08:31.498 -> 3fffffa0:  3fffdad0 00000000 3ffeea7c 40204798  
                                18:08:31.498 -> 3fffffb0:  feefeffe feefeffe 3ffe84f0 40100d71  
                                18:08:31.498 -> <<<stack<<<
                                18:08:31.498 -> 
                                18:08:31.498 -> --------------- CUT HERE FOR EXCEPTION DECODER ---------------
                                18:08:31.498 -> 
                                18:08:31.498 ->  ets Jan  8 2013,rst cause:2, boot mode:(3,6)
                                18:08:31.498 -> 
                                18:08:31.498 -> load 0x4010f000, len 3584, room 16 
                                18:08:31.546 -> tail 0
                                18:08:31.546 -> chksum 0xb0
                                18:08:31.546 -> csum 0xb0
                                18:08:31.546 -> v2843a5ac
                                18:08:31.546 -> ~ld
                                18:08:31.594 -> Initializing
                                18:08:31.594 -> 
                                18:08:31.594 -> Connecting to CONTACT-wifi
                                18:08:32.117 -> .
                                

                                Das läuft dann so in Dauerschleife unendlich weiter.

                                Hat jemand vielleicht eine Idee woran es liegen kann? Würde mich auf eure Hilfe sehr freuen.

                                Danke und Gruß
                                Christo

                                R Offline
                                R Offline
                                RalfB
                                schrieb am zuletzt editiert von
                                #41

                                @cap Hallo Cristo,

                                ich hatte das gleiche Problem und so gelöst:

                                Du must in der Funktionsdefinition von dataTrigger ICACHE_RAM_ATTR voran stellen:

                                void ICACHE_RAM_ATTR dataTrigger(){

                                Jetzt gibt es die Fehlermeldung nicht mehr und er sendet fleißig Daten. Bitte frage mich nicht, was die Ergänzung bewirkt - ich weiß es nicht. Ich habe das nur irgendwo gegoogelt und getestet.....

                                Gruß

                                Ralf

                                Viele Grüße

                                Ralf

                                1 Antwort Letzte Antwort
                                0
                                • M mwyraz

                                  Ich habe den Sketch fertig, funktioniert prima. Es verwendet noch eine Wifi/Mqtt Wrapper-Bibliothek von mir aber sollte ohne großen Aufwand mit den Original-MQTT+Wifi-Bibliotheken laufen.

                                  Das Gist habe ich aktualisiert: https://gist.github.com/micw/098709efc83a9d9ebf16d14cea4ca38e

                                  Die Libs sind ansosten auch hier zu finden:
                                  https://github.com/micw/ArduinoProjekte/tree/master/libraries/common
                                  https://github.com/micw/ArduinoProjekte/tree/master/libraries/private
                                  esp_pins.h braucht man denke ich inzwischen nicht mehr.

                                  K Offline
                                  K Offline
                                  kodibrain
                                  schrieb am zuletzt editiert von
                                  #42

                                  @mwyraz Vielen Dank für den Sketch! Du hast nicht zufällig Interesse daran noch den W174 Regenmesser darin zu integrieren? Eigentlich würde ein Counter ja schon reichen :)

                                  Fred FreundF 1 Antwort Letzte Antwort
                                  0
                                  • K kodibrain

                                    @mwyraz Vielen Dank für den Sketch! Du hast nicht zufällig Interesse daran noch den W174 Regenmesser darin zu integrieren? Eigentlich würde ein Counter ja schon reichen :)

                                    Fred FreundF Offline
                                    Fred FreundF Offline
                                    Fred Freund
                                    schrieb am zuletzt editiert von
                                    #43

                                    Hallo,
                                    ich weiss dieses Topic ist sehr alt, aber ich denke es waere nicht schlecht wenn es hier weitergeht.

                                    Also den wemos direkt an den W132 anzuschliessen und MQTT, bzw. mit einem ESP32 das funktioniert.

                                    Habe jetzt eine andere Loesung gefunden die ich einmal probieren moechte:

                                    Sie funktioniert auch mit einem wemos und einem 433Mhz Empfaenger welches gleichzeitig den Regensensor auch ausliest und die Werte zur Verfuegung stellt. Das auf der Seite gezeigte Example funktioniert ganz gut.

                                    SensorID 236
                                    Wind direction: 90°
                                    Wind gust: 0.00m/s
                                    0.00km/h
                                    ------------
                                    SensorID 65
                                    Rain volume: 3.00mm
                                    ------------
                                    SensorID 65
                                    Rain volume: 3.00mm
                                    
                                    

                                    Hier der Zwer2k WeatherStationDataRx (wird auch direkt im Arduino Library search vorgeschlagen)

                                    Das Ziel ist es diese Daten als MQTT im IOBROKER zur Verfuegung zu haben. Fuer mich ist der Vorteil das Regen und Windmesser einfach mit Batterien versorgt werden koennen und Daten dh. Regemenge zur Verfuegung stellen.

                                    Wenn ich das Example laufen lasse scheint es das die Void Setup oft durchlaufen wird und ich weiss nicht wieso.
                                    im Serial Monitor finde ich viele WeatherStationDataRx Test , habe den text schon geaendert dh. void setup wird oft durchlaufen und stammt von dieser.

                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    WeatherStationDataRx Test
                                    
                                    

                                    Weiters schaffe ich die sofortige Verbindung bei bekannten IDs nicht.

                                    WeatherStationDataRx wsdr(DATA_PIN, false, ARMUseAsConfirmation, false);
                                    
                                    void PairedDeviceAdded(byte newID)
                                    {
                                    #if defined(ESP8266) || defined(ESP32)
                                        Serial.printf("New device paired %d\r\n", newID);
                                    #else
                                        Serial.print("New device paired ");
                                        Serial.println(newID, DEC);
                                    #endif
                                    
                                        wsdr.pair(PairedDeviceAdded);
                                    
                                        // If you already have a sensor ID for your device, you can set it as follows.
                                        //byte myDeviceIDs[] = {236, 65};
                                        //wsdr.pair(myDeviceIDs, sizeof(myDeviceIDs));
                                        byte myDeviceIDs[] = {236, 65};
                                        wsdr.pair(myDeviceIDs, sizeof(myDeviceIDs));
                                    }
                                    

                                    Ich hoffe jemand findet dies hier nuetzlich und ich finde hier Hilfe bei euch!

                                    many Thx for your support,
                                    Vielen Dank!

                                    Fred FreundF 1 Antwort Letzte Antwort
                                    0
                                    • Fred FreundF Fred Freund

                                      Hallo,
                                      ich weiss dieses Topic ist sehr alt, aber ich denke es waere nicht schlecht wenn es hier weitergeht.

                                      Also den wemos direkt an den W132 anzuschliessen und MQTT, bzw. mit einem ESP32 das funktioniert.

                                      Habe jetzt eine andere Loesung gefunden die ich einmal probieren moechte:

                                      Sie funktioniert auch mit einem wemos und einem 433Mhz Empfaenger welches gleichzeitig den Regensensor auch ausliest und die Werte zur Verfuegung stellt. Das auf der Seite gezeigte Example funktioniert ganz gut.

                                      SensorID 236
                                      Wind direction: 90°
                                      Wind gust: 0.00m/s
                                      0.00km/h
                                      ------------
                                      SensorID 65
                                      Rain volume: 3.00mm
                                      ------------
                                      SensorID 65
                                      Rain volume: 3.00mm
                                      
                                      

                                      Hier der Zwer2k WeatherStationDataRx (wird auch direkt im Arduino Library search vorgeschlagen)

                                      Das Ziel ist es diese Daten als MQTT im IOBROKER zur Verfuegung zu haben. Fuer mich ist der Vorteil das Regen und Windmesser einfach mit Batterien versorgt werden koennen und Daten dh. Regemenge zur Verfuegung stellen.

                                      Wenn ich das Example laufen lasse scheint es das die Void Setup oft durchlaufen wird und ich weiss nicht wieso.
                                      im Serial Monitor finde ich viele WeatherStationDataRx Test , habe den text schon geaendert dh. void setup wird oft durchlaufen und stammt von dieser.

                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      WeatherStationDataRx Test
                                      
                                      

                                      Weiters schaffe ich die sofortige Verbindung bei bekannten IDs nicht.

                                      WeatherStationDataRx wsdr(DATA_PIN, false, ARMUseAsConfirmation, false);
                                      
                                      void PairedDeviceAdded(byte newID)
                                      {
                                      #if defined(ESP8266) || defined(ESP32)
                                          Serial.printf("New device paired %d\r\n", newID);
                                      #else
                                          Serial.print("New device paired ");
                                          Serial.println(newID, DEC);
                                      #endif
                                      
                                          wsdr.pair(PairedDeviceAdded);
                                      
                                          // If you already have a sensor ID for your device, you can set it as follows.
                                          //byte myDeviceIDs[] = {236, 65};
                                          //wsdr.pair(myDeviceIDs, sizeof(myDeviceIDs));
                                          byte myDeviceIDs[] = {236, 65};
                                          wsdr.pair(myDeviceIDs, sizeof(myDeviceIDs));
                                      }
                                      

                                      Ich hoffe jemand findet dies hier nuetzlich und ich finde hier Hilfe bei euch!

                                      Fred FreundF Offline
                                      Fred FreundF Offline
                                      Fred Freund
                                      schrieb am zuletzt editiert von
                                      #44

                                      Wollte nur mitteilen das ich es hinbekommen habe , also mit einem WEMOS die Daten per 433Mhz abfragen fuer Wind und Regensensor.

                                      Wenn es wer braucht gebt bescheid.
                                      LG

                                      many Thx for your support,
                                      Vielen Dank!

                                      1 Antwort Letzte Antwort
                                      0
                                      • H hugo1215

                                        Hallo @claus1993,
                                        also normal funktionieren die Exports. Habe 4 Wemos laufen wo ESP EASY läuft mit meinem Einstellungen.
                                        Hatte einen Kleine Fehler gefunden. hehe. Wass aber passiert ist das es sich immer wieder mit meinem WLAN verbinden will das hat er auch macht immer ein Reconnect und somit kommt er nicht zum verbinden mit dem MQTT server und kann dann im weiteren Verlauf nicht die Daten vom Windmesser weiterleiten.
                                        Gruß

                                        H Offline
                                        H Offline
                                        Homer-S
                                        schrieb am zuletzt editiert von
                                        #45

                                        @hugo1215 said in Windanzeige mit Ventus W132 & Wemos D1 Mini:

                                        also normal funktionieren die Exports. Habe 4 Wemos laufen wo ESP EASY läuft mit meinem Einstellungen.
                                        Hatte einen Kleine Fehler gefunden. hehe. Wass aber passiert ist das es sich immer wieder mit meinem WLAN verbinden will das hat er auch macht immer ein Reconnect und somit kommt er nicht zum verbinden mit dem MQTT server und kann dann im weiteren Verlauf nicht die Daten vom Windmesser weiterleiten.
                                        Gruß

                                        Hallo @hugo1215 darf ich dich fragen, wie dein ESPEasy konfiguriert ist? Ich bekomme schon Werte von meinem Puls Counter angezeigt, aber wie verarbeitest du die Pulswerte weiter?

                                        Danke

                                        1 Antwort Letzte Antwort
                                        0
                                        Antworten
                                        • In einem neuen Thema antworten
                                        Anmelden zum Antworten
                                        • Älteste zuerst
                                        • Neuste zuerst
                                        • Meiste Stimmen


                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        393

                                        Online

                                        32.5k

                                        Benutzer

                                        81.8k

                                        Themen

                                        1.3m

                                        Beiträge
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                        ioBroker Community 2014-2025
                                        logo
                                        • Anmelden

                                        • Du hast noch kein Konto? Registrieren

                                        • Anmelden oder registrieren, um zu suchen
                                        • Erster Beitrag
                                          Letzter Beitrag
                                        0
                                        • Home
                                        • Aktuell
                                        • Tags
                                        • Ungelesen 0
                                        • Kategorien
                                        • Unreplied
                                        • Beliebt
                                        • GitHub
                                        • Docu
                                        • Hilfe