From de8c22092dcaeafd971fe4a0ab54a944b4b83b8f Mon Sep 17 00:00:00 2001 From: PaulVua Date: Thu, 28 May 2026 09:10:09 +0200 Subject: [PATCH] =?UTF-8?q?v1.9.9:=20Sonde=20bruit=20-=20retry=20lecture?= =?UTF-8?q?=20NSRT=20MK4=20(3x)=20contre=20r=C3=A9-=C3=A9num=C3=A9ration?= =?UTF-8?q?=20USB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Le NSRT MK4 (USB CDC-ACM) se ré-énumère ~1s par cycle sur le pro150 (dmesg: USB disconnect/reconnect en boucle), ce qui faisait échouer l'ouverture de /dev/ttyACM0 et enregistrait des points isolés 0.0 "Déconnecté". On retente jusqu'à 3 fois (1s d'intervalle) avant de conclure à une déconnexion. Cause racine matérielle (alim/câble USB) à traiter en parallèle. Co-Authored-By: Claude Opus 4.7 (1M context) --- VERSION | 2 +- changelog.json | 13 +++++++++ sound_meter/NSRT_mk4_get_data.py | 46 +++++++++++++++++++------------- 3 files changed, 42 insertions(+), 19 deletions(-) diff --git a/VERSION b/VERSION index 66beabb..6ae756c 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.9.8 +1.9.9 diff --git a/changelog.json b/changelog.json index 087e7cf..3af5b08 100644 --- a/changelog.json +++ b/changelog.json @@ -1,5 +1,18 @@ { "versions": [ + { + "version": "1.9.9", + "date": "2026-05-28", + "changes": { + "features": [], + "improvements": [ + "Sonde bruit (NSRT MK4): le script de collecte retente jusqu'à 3 fois (1s d'intervalle) avant de marquer 'Déconnecté'. Absorbe les ré-énumérations USB ponctuelles de /dev/ttyACM0 (~1s) qui provoquaient des points isolés à 0.0. Si l'ouverture du port échoue on ré-ouvre, si une lecture échoue on garde le handle ouvert et on retente les lectures." + ], + "fixes": [], + "compatibility": [] + }, + "notes": "Le retry est un palliatif: la cause racine observée sur le pro150 (Device 9565AA75) est une vraie ré-énumération USB du NSRT toutes les ~10s (dmesg: 'USB disconnect' / 'new full-speed USB device' en boucle, numéro de device qui monte). À traiter côté matériel: alimentation/sous-tension du Pi (vcgencmd get_throttled), câble et connecteur USB." + }, { "version": "1.9.8", "date": "2026-05-21", diff --git a/sound_meter/NSRT_mk4_get_data.py b/sound_meter/NSRT_mk4_get_data.py index 7e7a2e2..6068da8 100644 --- a/sound_meter/NSRT_mk4_get_data.py +++ b/sound_meter/NSRT_mk4_get_data.py @@ -27,32 +27,42 @@ write_fs(frequency: int) -> sampling freq import nsrt_mk3_dev import sqlite3 +import time + +DEVICE = '/dev/ttyACM0' +MAX_RETRIES = 3 +RETRY_DELAY = 1.0 # secondes entre deux tentatives # noise_status: 0x00 = OK, 0xFF = disconnected -noise_status = 0x00 +noise_status = 0xFF leq_level_rounded = 0 weighted_level_rounded = 0 -try: - nsrt = nsrt_mk3_dev.NsrtMk3Dev('/dev/ttyACM0') +# Le NSRT MK4 (USB CDC-ACM) se ré-énumère parfois ~1s sur le bus : /dev/ttyACM0 +# disparaît brièvement et un seul échec marquait un point "Déconnecté" à tort. +# On retente : si l'OUVERTURE échoue, nsrt reste None et on ré-ouvre au tour +# suivant ; si c'est une LECTURE qui échoue, on garde le handle ouvert et on +# retente juste les lectures (pas de double-open du port). +nsrt = None +for attempt in range(1, MAX_RETRIES + 1): + try: + if nsrt is None: + nsrt = nsrt_mk3_dev.NsrtMk3Dev(DEVICE) - freq_level = nsrt.read_fs() #current sampling frequency - time_constant = nsrt.read_tau() #reads the current time constant - leq_level = nsrt.read_leq() #current running LEQ and starts the integration of a new LEQ. - weighting = nsrt.read_weighting() #weighting curve that is currently selected ( A ou C) - weighted_level = nsrt.read_level() #current running level in dB. + leq_level = nsrt.read_leq() # LEQ courant + weighted_level = nsrt.read_level() # niveau courant en dB - leq_level_rounded = round(leq_level, 2) - weighted_level_rounded = round(weighted_level, 2) + leq_level_rounded = round(leq_level, 2) + weighted_level_rounded = round(weighted_level, 2) + noise_status = 0x00 + if attempt > 1: + print(f"NSRT MK4 OK après {attempt} tentatives") + break -except Exception as e: - err_msg = str(e) - if "No such file or directory" in err_msg or "could not open port" in err_msg: - print(f"NSRT MK4 disconnected: {err_msg}") - noise_status = 0xFF - else: - print(f"NSRT MK4 error: {err_msg}") - noise_status = 0xFF + except Exception as e: + print(f"NSRT MK4 échec lecture (tentative {attempt}/{MAX_RETRIES}): {e}") + if attempt < MAX_RETRIES: + time.sleep(RETRY_DELAY) # Connect to the SQLite database conn = sqlite3.connect("/var/www/nebuleair_pro_4g/sqlite/sensors.db")