-
Notifications
You must be signed in to change notification settings - Fork 94
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dashboard/MQTT: Current Month/Year Totals kloppen (tijdelijk) niet na middernacht #1811
Comments
Wanneer worden de dagtotalen weggeschreven in de database? Want ik vermoed dat de als range_statistics() de maand/jaar totalen gaat berekenen vlak na middernacht dat het dagtotaal van de net afgelopen dag nog niet wordt meegeteld. |
Het probleem zit 'm denk ik in de vertraging van minimaal 5 minuten voor het berekenen van de dagtotalen als je een gas meter hebt. Wat is de juiste oplossing? Het MQTT bericht laten wachten totdat de dagtotalen beschikbaar zijn? |
Bedankt voor je melding! Ik zal hier wel een keertje wat dieper naar kijken. Voor nu zou ik niet zo 123 een oorzaak weten. Ik zit op het moment ook even zonder ontwikkelomgeving, dus ik kom er een andere keer op terug.
|
De oorzaak is mij duidelijk: het eerste MQTT van de dag wordt verstuurd om 00:02 uur. Maar dan is het eerste P1 datagram voor gas nog niet binnen (die komen elke 5 minuten). Daardoor heeft de stats scheduled task de dagtotalen nog niet gemaakt. Die wacht namelijk op het eerste gas P1 telegram van de dag. Het is dus een race condition tussen range_statistics() en de daily stats scheduled task. Wat er dus gebeurt in het eerste MQTT bericht van de dag om 00:02 uur: omdat de dagtotalen van gisteren nog niet klaar zijn wordt die dag niet meegeteld. |
Ik heb er nu voor je naar kunnen kijken en de oorzaak zit iets verderop. Zowel het dashboard als die MQTT-databron gebruiken dezelfde gegevens om het huidige verbruik in te zien, ook al zijn daar nog geen dagtotalen voor. Echter is de "huidige dag" na middernacht strikt gezien een andere dag en zie je dus tijdelijk die terugval. Vermoedelijk is dat nooit iemand eerder opgevallen (of niet willen melden), want voor oudere v4-meters is dat gat zelfs niet 5 minuten, maar meer dan een uur. Gezien de aard van deze databron (wat het moet doen) ga ik het bericht niet vertragen, maar zal ik ooit een keertje kijken of ik een extra check erin kan doen die situationeel de vorige dag erbij optelt. Of het gewoon baseert op de meterstanden, maar dat vereist wat rework. |
Bedankt voor de uitleg, het is me gelukt om dit op te lossen voor de |
Het probleem met het gas dagtotaal is waarschijnlijk ontstaan door e684b6e mbt #1770 Dat komt denk ik door deze code: dsmr-reader/dsmr_stats/services.py Lines 211 to 252 in 5da612b
Stel, je hebt voor gas elk uur 4 tellerstanden:
Als je dan alle samples van een uur opvraagt krijg je er 4:
Trek je dan de eerste tellerstand van de laatste af dan mis je elk uur een sample. In dit voorbeeld krijg je elk uur als uurtotaal 3 terwijl het 4 moet zijn. De correcte manier is: vraag de samples op van uur x en uur x+1 en trek de tellerstand van het eerste sample in uur x af van de tellerstand van het eerste sample in uur x+1. Ik heb dit opgelost in de 2e commit van PR #1814 day_consumption() heeft trouwens hetzelfde off-by-one probleem dat op dezelfde manier kan worden opgelost (laatste sample van de dag wordt niet meegeteld). Laat maar weten als ik hiervoor ook een PR moet maken. |
Bedankt voor je uitgebreide onderzoek! Ik moet hier veel dieper naar kijken, want het is helaas niet een kwestie van een codewijziging om dit te fixen, maar eerder een complete refactoring. Het zit vrij diep en via #1770 was al de conclusie dat een deel op de kop moet, zoals in Voor het 1-off probleem zal ik verder ook nog onderscheid moeten maken tussen gas en elektra, want in de happy-flow is een uur verder kijken prima, maar bij onderbreking van data rond een uur- of dagwisseling, kan dat weer andersom zorgen voor foute data. |
Ik snap dat er een refactoring nodig is. Dit begon voor mij als een poging om de getallen in de MQTT berichten consequent te maken. Dat is met PR #1814 gelukt. Ik sla die getallen voor langere tijd op dus dan wil ik wel dat ze kloppen. Maar ik realiseer me nu dat de dagtotalen die DSMR-Reader opslaat ook niet juist zijn. Voor elektriciteit valt de afwijking wel mee (er mist 1 minuut per dag) maar voor DSMRv5 gas is het al erger. Dit verklaart meteen de verschillen die ik zie tussen de gasmeter in mijn CV ketel en DSMR-Reader (we koken elektrisch). Voorlopig zal ik dus moeten vertrouwen op de MQTT data ipv de dagtotalen van DSMR-Reader. |
@Roukie686868 bedankt voor je aanvulling. Er is nog momenteel geen oplossing voor omdat een structurele fix relatief veel werk is, waarbij ik vermoedelijk een paar avonden achter elkaar ermee bezig ben. Mijn voornemens was al wel om dat deze maand te doen. |
Hi Dennis,Zo geweldig zijn. DSMR reader is echt een geweldig programma. Ik heb je al vele collega’s aangeraden. Met vriendelijke groet en veel succes met het programmeren,Erik RoukensOn 10 Mar 2023, at 23:38, Dennis Siemensma ***@***.***> wrote:
@Roukie686868 bedankt voor je aanvulling. Er is nog momenteel geen oplossing voor omdat een structurele fix relatief veel werk is, waarbij ik vermoedelijk een paar avonden achter elkaar ermee bezig ben. Mijn voornemens was al wel om dat deze maand te doen.
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Steeds meer DSMR-Reader gebruikers merken dat de dag/maand/jaar totalen niet juist zijn. De refactoring die nodig blijkt is natuurlijk een grote opgave. Als je hierbij hulp nodig hebt (bijv. voor het schrijven van integratie tests) hebt dan werk ik er graag aan mee. |
Het is helaas een tweeledig probleem. Normaal heb ik in de wintermaanden veel tijd om in de avond aan dit project te werken, maar dat valt dit seizoen nog flink tegen. Anderzijds ben ik er nog niet over uit. Ik neig steeds meer naar teruggaan naar de situatie van anderhalfjaar geleden of langer. Waarbij een andere bug welliswaar speelt, maar die tenminste niet zorgt voor de dusdanige grote afwijkingen op maandbasis. Een complete refactor vereist namelijk zoveel tijd, dat ik niet weet of dat realistisch is |
Description
Ik gebruik de standaard
(Data Source) Current Month/Year Totals: Json
definitie om berichten naar MQTT te sturen. De totalen zoals current_month_electricity1, current_month_electricity1 en current_month_gas hebben in het eerste bericht JSON van de dag de waarde van een dag eerder (dus 24 geleden).In het screenshot zitten de dips op 23:00 uur omdat de grafiek in GMT is.
DSMR-reader version
5.10.3
DSMR-reader platform
Native (e.g. manual installation)
Debug info dump
No response
The text was updated successfully, but these errors were encountered: