kjetilsn Skrevet 18. oktober 2018 Del Skrevet 18. oktober 2018 (endret) Hei, Etter å ha fått inn data fra AMS måler til Home Assistant, blitt tibber kunde, og fått AMS måler over på time for time hos BKK, var det dags for å prøve å spare strøm ved å flytte laster til tider på døgnet der strømmen er billig. Ønsket en måte å måle hvor mye besparelse er dag for dag og per måned. Har nå laget følgende automasjon og sensorer i Home Assistant som bruker ekstern MQQT for mellomlagring av verdier. Har tatt utgangspunkt i eksempler for akkumulering, feks denne og denne Bruker "hovedtelleverket" til AMS måleren som oppdateres hver time, dette passer fint overens med tibber sensoren som også oppdateres hver time. tibber sensoren til Home assistant gir deg max, min, og "current" KWt pris, men ikke gjennomsnitt per dag, jukset dette til med å ta gjennomsnitt av maks og min verdi, vet at dette ikke bli helt eksakt, da en kan ha reelt gjennomsnitt som ligger nært max eller min. Har kun kjørt dette et døgn nå, så vær obs på at det kan være feil her, og det finnes nok smartere måter å gjør dette på. Tilbakemeldinger/forslag til forbedring mottas med takk: ## Edit## Endret fra sensor til automasjon som kjører en gang i time for differansekostnad, da det ble feilutslag hver time som vanlig sensor: Automation: #### Record AMS count last hour to MQQT #### - alias: 'Record AMS value last hour' trigger: platform: time minutes: 55 seconds: 00 action: service: mqtt.publish data_template: topic: 'ha/total_ams_last_hour' retain: true payload: '{"day_1":"{{states.sensor.ams_count.state}}"}' ## AMS total telleverk #### Actual energy cost per hour #### - alias: 'Record acutal energy cost' trigger: platform: time minutes: 02 seconds: 00 action: service: mqtt.publish data_template: topic: 'ha/actual_ergy_cost' retain: true payload: '{"day_1":"{{ (((states.sensor.ams_count.state | float) - (states.sensor.ams_total_last_hour.state | float)) * ((states.sensor.electricity_price_"your adress".state | float) + ('Nettleie'))) | round(2) + (states.sensor.actual_energy_cost.state | round (2)) }}"}' #### "Average" energy cost #### - alias: 'Record acutal energy cost' trigger: platform: time minutes: 02 seconds: 00 action: service: mqtt.publish data_template: topic: 'ha/average_ergy_cost' retain: true payload: '{"day_1":"{{ (((states.sensor.ams_count.state | float) - (states.sensor.ams_total_last_hour.state | float)) * ((((states.sensor.electricity_price_"your_adress".attributes.max_price | float) + (states.sensor.electricity_price_"your_adress".attributes.min_price | float)) / 2) + ('Nettleie'))) | round(2) + (states.sensor.average_energy_cost.state | round (2)) }}"}' #### Record Actual cost at midnight #### - alias: 'Record acutal cost at midnight' trigger: platform: time at: '00:00:01' action: service: mqtt.publish data_template: topic: 'ha/total_actual_energy_cost_midnight' retain: true payload: '{"day_1":"{{states.sensor.actual_energy_cost.state}}"}' #### Record Average cost at midnight #### - alias: 'Record average cost at midnight' trigger: platform: time at: '00:00:01' action: service: mqtt.publish data_template: topic: 'ha/total_average_energy_cost_midnight' retain: true payload: '{"day_1":"{{states.sensor.average_energy_cost.state}}"}' #### "Strømmbesparelse i dag #### - alias: 'Record diff avg actual energy cost' trigger: platform: time minutes: 05 seconds: 00 action: service: mqtt.publish data_template: topic: 'ha/energy_cost_saving_today' retain: true payload: '{"day_1":"{{ ((states.sensor.average_energy_cost_today.state | float) - (states.sensor.actual_energy_cost_today.state | float )) | round(2) }}"}' Sensors: ############# MQTT AMS Last Hour ###################### - platform: mqtt state_topic: 'ha/total_ams_last_hour' name: 'AMS total last hour' unit_of_measurement: 'KWt' value_template: '{{ value_json.day_1 }}' ############# MQTT Actual energy cost ###################### - platform: mqtt state_topic: 'ha/average_ergy_cost' name: 'Average energy cost' unit_of_measurement: 'NOK' value_template: '{{ value_json.day_1 }}' ############ MQTT Actual energy cost ###################### - platform: mqtt state_topic: 'ha/actual_ergy_cost' name: 'Actual energy cost' unit_of_measurement: 'NOK' value_template: '{{ value_json.day_1 }}' ############ MQTT Actual energy cost midnight ############## - platform: mqtt state_topic: 'ha/total_actual_energy_cost_midnight' name: 'Actual energy cost midnight' unit_of_measurement: 'NOK' value_template: '{{ value_json.day_1 }}' ############ MQTT Average energy cost midnight ############## - platform: mqtt state_topic: 'ha/total_average_energy_cost_midnight' name: 'Average energy cost midnight' unit_of_measurement: 'NOK' value_template: '{{ value_json.day_1 }}' ############ MQTT Cost saving today ############## - platform: mqtt state_topic: 'ha/energy_cost_saving_today' name: 'Strømmbesparelse i dag' unit_of_measurement: 'NOK' value_template: '{{ value_json.day_1 }}' Endret 20. oktober 2018 av kjetilsn Ending i logikk 2 Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
Hassi Skrevet 4. mars 2019 Del Skrevet 4. mars 2019 (endret) Liker det du har laget i HA. Er selv litt i FOU for tiden men har funnet en fantastisk pallette til Node Red som fikser daglig oppdatering av spottpriser fra Nordpool. Dette gir meg full oversikt over dagens priser og kan med litt automasjon oppdatere hva du betaler for energibruken time for time. I tillegg ved å bruke en Min / Max sensor kan du få eksakt snittpris for dagen. En god erstatting for Tibber å den er i tillegg gratis. Endret 4. mars 2019 av Hassi 2 Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
gbjøru Skrevet 13. mars 2019 Del Skrevet 13. mars 2019 På 4.3.2019 den 6.44, Hassi skrev: Er selv litt i FOU for tiden men har funnet en fantastisk pallette til Node Red som fikser daglig oppdatering av spottpriser fra Nordpool. Dette gir meg full oversikt over dagens priser og kan med litt automasjon oppdatere hva du betaler for energibruken time for time. I tillegg ved å bruke en Min / Max sensor kan du få eksakt snittpris for dagen. En god erstatting for Tibber å den er i tillegg gratis. Kunne du tenke deg å dele denne Node Red Sekvensen? Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
Hassi Skrevet 14. mars 2019 Del Skrevet 14. mars 2019 [{"id":"e2e4fe1d.7c595","type":"tab","label":"Nordpool-data","disabled":false,"info":""},{"id":"aeee093.bf433f8","type":"nordpool","z":"e2e4fe1d.7c595","baseUrl":"http://www.nordpoolspot.com/api","area":"Bergen","currency":"NOK","page":"10","start":"P1D","duration":"PT1H","name":"Nordpool","x":120,"y":440,"wires":[["83998c36.5f1e"]]},{"id":"83998c36.5f1e","type":"function","z":"e2e4fe1d.7c595","name":"","func":"var msg24 = msg.payload.map(function (p) {\n return {payload: p};\n});\nreturn msg24;","outputs":24,"noerr":0,"x":370,"y":440,"wires":[["725c4f1d.8fd22"],["94fda574.976d48"],["41d0ac4a.b03bc4"],["3a190524.5a2bda"],["15dd54db.94427b"],["2d36f6dd.805bca"],["5a13129c.9b921c"],["1672f088.3bfe7f"],["f8199855.d51778"],["ea5de329.d15cb"],["34434fb0.6f35b"],["4fb8e53b.51fb5c"],["dd1b0791.e89778"],["1bcfdddc.502802"],["136ee9ac.613226"],["b721cf7f.4adce"],["1740d567.08029b"],["1ce40579.edba9b"],["876cc91a.08ccd8"],["abe06a61.25f758"],["271c8a17.f96176"],["5284e3bd.9e068c"],["c3dee96c.c99548"],["458b73aa.5cd84c"]]},{"id":"725c4f1d.8fd22","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris1","qos":"","retain":"true","broker":"c50624a.016f3d8","x":790,"y":120,"wires":[]},{"id":"94fda574.976d48","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris2","qos":"","retain":"true","broker":"c50624a.016f3d8","x":990,"y":120,"wires":[]},{"id":"41d0ac4a.b03bc4","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris3","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1190,"y":120,"wires":[]},{"id":"3a190524.5a2bda","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris4","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1390,"y":120,"wires":[]},{"id":"15dd54db.94427b","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris5","qos":"","retain":"true","broker":"c50624a.016f3d8","x":810,"y":240,"wires":[]},{"id":"2d36f6dd.805bca","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris6","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1010,"y":240,"wires":[]},{"id":"5a13129c.9b921c","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris7","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1210,"y":240,"wires":[]},{"id":"1672f088.3bfe7f","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris8","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1410,"y":240,"wires":[]},{"id":"f8199855.d51778","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris9","qos":"","retain":"true","broker":"c50624a.016f3d8","x":790,"y":320,"wires":[]},{"id":"ea5de329.d15cb","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris10","qos":"","retain":"true","broker":"c50624a.016f3d8","x":990,"y":320,"wires":[]},{"id":"34434fb0.6f35b","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris11","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1190,"y":320,"wires":[]},{"id":"4fb8e53b.51fb5c","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris12","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1390,"y":320,"wires":[]},{"id":"dd1b0791.e89778","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris13","qos":"","retain":"true","broker":"c50624a.016f3d8","x":830,"y":440,"wires":[]},{"id":"1bcfdddc.502802","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris14","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1030,"y":440,"wires":[]},{"id":"136ee9ac.613226","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris15","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1230,"y":440,"wires":[]},{"id":"b721cf7f.4adce","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris16","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1430,"y":440,"wires":[]},{"id":"1740d567.08029b","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris17","qos":"","retain":"true","broker":"c50624a.016f3d8","x":790,"y":520,"wires":[]},{"id":"1ce40579.edba9b","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris18","qos":"","retain":"true","broker":"c50624a.016f3d8","x":990,"y":520,"wires":[]},{"id":"876cc91a.08ccd8","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris19","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1190,"y":520,"wires":[]},{"id":"abe06a61.25f758","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris20","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1390,"y":520,"wires":[]},{"id":"271c8a17.f96176","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris21","qos":"","retain":"true","broker":"c50624a.016f3d8","x":710,"y":740,"wires":[]},{"id":"5284e3bd.9e068c","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris22","qos":"","retain":"true","broker":"c50624a.016f3d8","x":910,"y":740,"wires":[]},{"id":"c3dee96c.c99548","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris23","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1110,"y":740,"wires":[]},{"id":"458b73aa.5cd84c","type":"mqtt out","z":"e2e4fe1d.7c595","name":"","topic":"nordpool/timepris24","qos":"","retain":"true","broker":"c50624a.016f3d8","x":1310,"y":740,"wires":[]},{"id":"f64d1e2f.118ec","type":"inject","z":"e2e4fe1d.7c595","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"59 23 * * *","once":false,"onceDelay":0.1,"x":110,"y":180,"wires":[["aeee093.bf433f8"]]},{"id":"60846d89.6a04b4","type":"inject","z":"e2e4fe1d.7c595","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"00 00 * * *","once":false,"onceDelay":0.1,"x":110,"y":220,"wires":[["aeee093.bf433f8"]]},{"id":"58a64689.d146f8","type":"inject","z":"e2e4fe1d.7c595","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"01 00 * * *","once":false,"onceDelay":0.1,"x":110,"y":260,"wires":[["aeee093.bf433f8"]]},{"id":"c50624a.016f3d8","type":"mqtt-broker","z":"","name":"","broker":"localhost","port":"1883","clientid":"","usetls":false,"compatmode":true,"keepalive":"60","cleansession":true,"birthTopic":"","birthQos":"0","birthPayload":"","closeTopic":"","closeQos":"0","closePayload":"","willTopic":"","willQos":"0","willPayload":""}] 1 Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
gbjøru Skrevet 14. mars 2019 Del Skrevet 14. mars 2019 Beklager men jeg er ganske fersk på Node Red. Hvordan får du Nordpool noden inn? Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
Hassi Skrevet 15. mars 2019 Del Skrevet 15. mars 2019 Ingenting å beklage. Prøv å se om du kan installere via følgende metode? https://github.com/Ell-i/node-red-contrib-nordpool/blob/master/README.md Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
monsivar Skrevet 7. januar 2021 Del Skrevet 7. januar 2021 På 15.3.2019 den 4.47, Hassi skrev: Ingenting å beklage. Prøv å se om du kan installere via følgende metode? https://github.com/Ell-i/node-red-contrib-nordpool/blob/master/README.md Min NR kjører i Supervisor i HA, hvordan installere man noden da? Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
gbjøru Skrevet 11. januar 2021 Del Skrevet 11. januar 2021 På 7.1.2021 den 15.19, monsivar skrev: Min NR kjører i Supervisor i HA, hvordan installere man noden da? Jeg tror denne metoden som vist i YT skal virke hos deg.https://youtu.be/Wlwe5Xry5cA Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
monsivar Skrevet 11. januar 2021 Del Skrevet 11. januar 2021 Takk skal du ha Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
kjetilsn Skrevet 12. januar 2021 Forfatter Del Skrevet 12. januar 2021 Da var det kaldt igjen og strømmen ble dyr.. Brukte litt tid på å få riktig kostnad på alle varmeenheter bassert på timepris, der jeg tidligere brukte et fastsatt gjennomsnitt. Summerer dette og trekker det fra AMS kostnaden får å få "nøyaktig" Total, varme, og forbrukskostnad. Også nyttig for å se hvilke av rommene i huset som er "syndere". Bruker to måter å hente uk KWt per time fra de forskjellig rommene da de fleste termostater er førstgenerasjon heatit, som ikke har energimåling. Her teller jeg hvor lenge de er innkopblet per time bassert på zwave node event, regner ut effekt og summerer dette til en KWh teller, slik at det blir likt som termostater og veggplugger som har energimåling. Eksempel under et et rom, og med automasjon og sensorer for å lage telleverk som beskrevet over, for enheter med energimåling så blir det da noe enklere. MQTT sensors: - platform: mqtt state_topic: 'ha/kwh_counter_stue' name: 'Kwh count Stue' unit_of_measurement: 'KWh' - platform: mqtt state_topic: 'ha/nok_counter_stue' name: 'NOK count Stue' unit_of_measurement: 'NOK' - platform: mqtt state_topic: 'ha/nok_counter_stue_midnight' name: 'NOK count Stue midnight' unit_of_measurement: 'NOK' - platform: mqtt state_topic: 'ha/nok_counter_stue_yesterday' name: 'NOK count Stue yesterday' unit_of_measurement: 'NOK' Template sensor for å telle KWh per time - platform: template sensors: kwh_stue_last_hour: friendly_name: 'Kwh Stue last hour' value_template: '{%- if not (is_state("sensor.heat_on_stue_last_hour","unknown") )-%} {{ ((((states.sensor.heat_on_stue_last_hour.state | float ) * ( 2121 )) / (1000))) | round(2) }} {%- endif -%}' unit_of_measurement: "kWh" Automation for KWh tellerverk: - alias: 'Mqtt Publish KW counter Stue' trigger: platform: time_pattern minutes: 59 action: service: mqtt.publish data_template: topic: 'ha/kwh_counter_stue' retain: true payload: '{{ ((states.sensor.kwh_stue_last_hour.state | float) + (states.sensor.kwh_count_stue.state | float)) | round(2) }}' Automation for Kostnadstelleverk: - alias: 'Mqtt publish NOK counter Stue' trigger: platform: time_pattern minutes: 59 seconds: 59 action: service: mqtt.publish data_template: topic: 'ha/nok_counter_stue' retain: true payload: '{{ ((states.sensor.kwh_stue_last_hour.state | float) * ((states.sensor.electricity_price_none.state | float) + ((states.input_number.nettleie.state | float))) + (states.sensor.nok_count_stue.state | float)) | round(2) }}' Automation Mqtt publish kostandstelleverk midnatt: - alias: 'Mqtt publish NOK count @ midnight Stue' trigger: platform: time at: '23:59:50' action: service: mqtt.publish data_template: topic: 'ha/nok_counter_stue_midnight' retain: true payload: '{{states.sensor.nok_count_stue.state}}' template sensor for dagens kostnad: - platform: template sensors: nok_count_stue_today: friendly_name: 'Oppvarmingskostnad Stue i dag' value_template: '{%- if not (is_state("sensor.nok_count_stue_midnight","unknown") or is_state("sensor.nok_count_stue","unknown") )-%} {{ ((states.sensor.nok_count_stue.state | float) - (states.sensor.nok_count_stue_midnight.state | float )) | round (2) }} {%- endif -%}' unit_of_measurement: "NOK" Automation; mqtt publisere dagens kosnad ved midnatt for gårsdagsforbruk: - alias: 'Mqtt publish NOK count yesterday Stue' trigger: platform: time at: '23:59:50' action: service: mqtt.publish data_template: topic: 'ha/nok_counter_stue_yesterday' retain: true payload: '{{states.sensor.nok_count_stue_today.state}}' Så er det bare å lage sensorer for å summere, trekke fra osv, om en ønsker det. (gårsdagsverdier i kortet under er feil, grunnet fikling i går) 1 Siter Lenke til kommentar Del på andre sider Flere delingsvalg…
Anbefalte innlegg
Bli med i samtalen
Du kan publisere innhold nå og registrere deg senere. Hvis du har en konto, logg inn nå for å poste med kontoen din.