Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Raspi GPIO wird gesetzt, wie Ursache herausfinden?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Raspi GPIO wird gesetzt, wie Ursache herausfinden?

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      ticaki Developer @Laser last edited by

      @laser
      Wieso schreibst du 5:20 zeigst aber das log von 5:22?

      L 1 Reply Last reply Reply Quote 1
      • paul53
        paul53 @Laser last edited by paul53

        @laser sagte: Mit der Lupe arbeite ich und finde nur die gewollten Stellen.

        Suchbegriffe werden unter der Gruppe "global" nur im Expertenmodus gefunden.

        JS_Expertenmodus.JPG

        1 Reply Last reply Reply Quote 0
        • L
          Laser @ticaki last edited by Laser

          @ticaki 5:22 habe ich durch Suchen nach gpio.22 gefunden. Die Zeit 5:20 habe ich (ungenau) aus dem E-Chart ermittelt. Die Zeit, zu der ungewollt eingeschaltet wurde.

          Homoran 1 Reply Last reply Reply Quote 0
          • Homoran
            Homoran Global Moderator Administrators @Laser last edited by

            @laser dann sieh erst einmal zu, dass sämtliche Leichen verschwinden und das log nicht zugemüllt wird.

            Vorher ergibt es keinen Sinn nach etwas zu suchen, von dem es dann heisst: gibt es nicht mehr!

            L 1 Reply Last reply Reply Quote 0
            • L
              Laser @Homoran last edited by Laser

              @homoran bin ich gerade dabei! Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht. Der gpio.22 soll aber bleiben.
              javascript.0.variables.kW-Hoy war ein Schreibfehler nach einer Änderung.

              L Homoran 2 Replies Last reply Reply Quote 0
              • L
                Laser @Laser last edited by Laser

                @paul53 Auch unter dem Expertenmodus finde ich nur die Scripte, die ich benötige. Nicht den bösen "Querschießer"

                T 1 Reply Last reply Reply Quote 0
                • T
                  ticaki Developer @Laser last edited by ticaki

                  @laser
                  du könntest natürlich noch die anderen Skript posten, dann schaue ich auch mal darüber. Aber erst heute abend, bin jetzt weg 🙂

                  L 1 Reply Last reply Reply Quote 0
                  • L
                    Laser @ticaki last edited by

                    @ticaki hier das 2. Script:
                    sicher unelegant, ich bin noch in der Forschungsphase, was ich überhaupt wie machen kann um den maximalen Solarertrag zu erzielen.

                    // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
                    let ZielwertM  = 80;
                    let ZielwertA = 180;
                    
                     schedule({hour: [19], minute:[10] },   function () {
                    setState('rpi2.0.gpio.22.state'/**/,1);  //  1 ist einschalten
                    });
                     // Abends einen anderen Sollwert zur Einspeisung setzen
                    schedule({hour: [19], minute:[15] },   function () {
                    //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
                    });
                    
                     // Morgens einen anderen Sollwert zur Einspeisung setzen
                    schedule({hour: [02], minute:[15] },   function () { 
                    //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
                    });
                    
                    schedule({hour: [09, 23 ], minute:[20] },   function () { 
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
                    });
                    
                    schedule({hour: [09,10 ], minute:[27] },   function () { 
                    setState('rpi2.0.gpio.22.state'/**/,0);  //  0 ist ausschalten
                    });
                    // Anpassung der Einspeiseleistung (getaktet):
                    setInterval(Einspeisen,20000 );
                    function Einspeisen () {
                    let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
                    let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
                    console.log(" netzeinspeise: " +netzeinspeise);
                    
                    if (netzeinspeise <= (-0.01)){
                    SWLeistung = (SWLeistung -10)  // Wenn eingespeist wird, takte den SW Umrichter runter
                    if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
                    //console.log("SWL: " + SWLeistung);
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                    };   // Ende if
                    
                    // Und schnell runterfahren bei großer Leistung ins Netz:
                    if (netzeinspeise <= (-0.1)){
                    SWLeistung = (SWLeistung -100)  // Wenn eingespeist wird, takte den SW Umrichter runter
                    if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
                    //console.log("SWL: " + SWLeistung);
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                    };   // Ende if
                    
                    
                    if (netzeinspeise >= (0.01)){
                    SWLeistung = (SWLeistung +10)  // Wenn eingespeist wird, takte den SW Umrichter runter
                    if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
                    console.log("SWL+: " + SWLeistung);
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                    };   // Ende if
                    
                    // schnell hochfahren bei Verbraucher >100 Watt ein:
                    if (netzeinspeise >= (0.1)){
                    SWLeistung = (SWLeistung +100)  // Wenn eingespeist wird, takte den SW Umrichter runter
                    if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
                    console.log("SWL+: " + SWLeistung);
                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                    };   // Ende if
                    
                    };  //Ende function Einspeisen
                    
                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @Laser last edited by paul53

                      @laser
                      Zeilen 6 und 25 !!
                      Dürfte sich allerdings nicht um 5:21 Uhr auswirken.

                      L 1 Reply Last reply Reply Quote 0
                      • L
                        Laser @paul53 last edited by Laser

                        @paul53 (6 und 25) Da soll ja auch geschaltet werden. Abends ein und Morgens wieder aus.
                        Und wenn die Akkuspannung absinkt (im anderen Script).

                        paul53 1 Reply Last reply Reply Quote 0
                        • Homoran
                          Homoran Global Moderator Administrators @Laser last edited by

                          @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                          Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht.

                          dann dürfen diese Skripte aber jetzt nicht laufen.
                          Abgesehen von dem zugemüllten log, lähmt es dein System

                          1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 @Laser last edited by paul53

                            @laser sagte: Da soll ja auch geschaltet werden.

                            ... aber nicht mit Zahlen 0 / 1, sondern mit false / true.

                            L 1 Reply Last reply Reply Quote 0
                            • L
                              Laser @paul53 last edited by Laser

                              @paul53 Das kapiere ich nicht. Wieso funktioniert das überhaupt mit 0 und 1? Ursprünglich hatte ich auch true und false drin. Bis zu einer Fehlermeldung (weiß ich aber nicht mehr genau). Da habe ich in 0 und 1 geändert. Habe das wieder in true/false abgeändert.

                              paul53 1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Laser last edited by paul53

                                @laser sagte: Wieso funktioniert das überhaupt mit 0 und 1?

                                Weil gewandelt wird. Es kommt aber eine Warnung zum falschen Typ.
                                Vielleicht ist ja auch der Datenpunkttyp "boolean" falsch und er muss "number" sein?

                                L 1 Reply Last reply Reply Quote 0
                                • L
                                  Laser @paul53 last edited by Laser

                                  @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
                                  Das gehe ich noch mal intensiv durch.

                                  paul53 T 2 Replies Last reply Reply Quote 0
                                  • paul53
                                    paul53 @Laser last edited by

                                    @laser sagte: Das gehe ich noch mal intensiv durch.

                                    Auszug aus der Datei main.js des Adapters "rpi2":

                                    function writeGpio(port, value) {
                                        port = parseInt(port, 10);
                                        if (!adapter.config.gpios[port] || !adapter.config.gpios[port].enabled) {
                                            adapter.log.warn('Port ' + port + ' is not writable, because disabled.');
                                            return;
                                        } else if (adapter.config.gpios[port].input === 'in' || adapter.config.gpios[port].input === 'true' || adapter.config.gpios[port].input === true) {
                                            return adapter.log.warn('Port ' + port + ' is configured as input and not writable');
                                        }
                                    
                                        if (value === 'true')  value = true;
                                        if (value === 'false') value = false;
                                        if (value === '0')     value = false;
                                        value = !!value;
                                    

                                    Zahlen werden in Logikwerte gewandelt.

                                    1 Reply Last reply Reply Quote 1
                                    • T
                                      ticaki Developer @Laser last edited by ticaki

                                      @laser

                                      bin doch nicht weg:

                                      Em ja, das Skript macht nicht das was du willst.

                                      bitte achte beim Schreiben von Skripten auf das Einrücken, das verhindert schon mal ne Menge Fehler

                                      {
                                        code hier
                                        {
                                          code hier
                                          {
                                            code hier
                                          }
                                          code hier
                                        }
                                        code hier
                                      }
                                      

                                      dann hast du in Deinem Skript sowas

                                      if (netzeinspeise <= (-0.01))
                                      if (netzeinspeise <= (-0.1))
                                      

                                      das erste If kannste auch weg lasen da jede Zahl kleiner -0.01 auch kleiner -0.1 ist.

                                      du wolltest wohl:

                                      if (netzeinspeise <= (-0.01)){
                                      } else if (netzeinspeise <= (-0.1)){
                                      } else if (netzeinspeise >= (0.1)){
                                      } usw.
                                      
                                      L 1 Reply Last reply Reply Quote 0
                                      • L
                                        Laser @ticaki last edited by Laser

                                        @ticaki Damit wollte ich etwas gestaffelt schalten. Wenn eine kleine Netzeinspeisung vorhanden ist, verändere den Wert (Eigenverbrauch) in 5 er Schritten. Wenn ein großer Wert vorliegt, ändere den Wert in großen Schritten. Z.B. wenn morgens der Toaster eingeschaltet wird, passe den Wert schneller an. Sonst in kleinen Schritten. Ist erst mal ein Versuch, ob ich so damit leben kann. Ist beim "Brot-Toasten" am Küchentisch entstanden. Besser geht immer.
                                        Das Einrücken muß ich noch verbessern.

                                        T 1 Reply Last reply Reply Quote 0
                                        • T
                                          ticaki Developer @Laser last edited by

                                          @laser
                                          Ich zeige nur nicht optimalen Code auf. Das geht echt nicht darum irgendeine Bewertung vor zu nehmen. 🙂

                                          Zum Code, eine gestaffelte Abfrage in der nur 1 von x Möglichkeiten ausgewählt werden soll, wird mit If () else if() else usw. aufgebaut, dann trifft immer nur 1 Möglichkeit zu.

                                          Ich dachte du wolltest das erreichen.

                                          L 1 Reply Last reply Reply Quote 0
                                          • L
                                            Laser @ticaki last edited by Laser

                                            @ticaki Werde ich anpassen. Das war wirklich mit der sehr heißen Nadel gestrickt. Das gefällt mir auch nicht.
                                            @Homoran und die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                                            Homoran 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            774
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            65
                                            2624
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo