v1.9.9: Sonde bruit - retry lecture NSRT MK4 (3x) contre ré-énumération USB
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) <noreply@anthropic.com>
This commit is contained in:
@@ -1,5 +1,18 @@
|
|||||||
{
|
{
|
||||||
"versions": [
|
"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",
|
"version": "1.9.8",
|
||||||
"date": "2026-05-21",
|
"date": "2026-05-21",
|
||||||
|
|||||||
@@ -27,32 +27,42 @@ write_fs(frequency: int) -> sampling freq
|
|||||||
|
|
||||||
import nsrt_mk3_dev
|
import nsrt_mk3_dev
|
||||||
import sqlite3
|
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 = OK, 0xFF = disconnected
|
||||||
noise_status = 0x00
|
noise_status = 0xFF
|
||||||
leq_level_rounded = 0
|
leq_level_rounded = 0
|
||||||
weighted_level_rounded = 0
|
weighted_level_rounded = 0
|
||||||
|
|
||||||
try:
|
# Le NSRT MK4 (USB CDC-ACM) se ré-énumère parfois ~1s sur le bus : /dev/ttyACM0
|
||||||
nsrt = nsrt_mk3_dev.NsrtMk3Dev('/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
|
leq_level = nsrt.read_leq() # LEQ courant
|
||||||
time_constant = nsrt.read_tau() #reads the current time constant
|
weighted_level = nsrt.read_level() # niveau courant en dB
|
||||||
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_rounded = round(leq_level, 2)
|
leq_level_rounded = round(leq_level, 2)
|
||||||
weighted_level_rounded = round(weighted_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:
|
except Exception as e:
|
||||||
err_msg = str(e)
|
print(f"NSRT MK4 échec lecture (tentative {attempt}/{MAX_RETRIES}): {e}")
|
||||||
if "No such file or directory" in err_msg or "could not open port" in err_msg:
|
if attempt < MAX_RETRIES:
|
||||||
print(f"NSRT MK4 disconnected: {err_msg}")
|
time.sleep(RETRY_DELAY)
|
||||||
noise_status = 0xFF
|
|
||||||
else:
|
|
||||||
print(f"NSRT MK4 error: {err_msg}")
|
|
||||||
noise_status = 0xFF
|
|
||||||
|
|
||||||
# Connect to the SQLite database
|
# Connect to the SQLite database
|
||||||
conn = sqlite3.connect("/var/www/nebuleair_pro_4g/sqlite/sensors.db")
|
conn = sqlite3.connect("/var/www/nebuleair_pro_4g/sqlite/sensors.db")
|
||||||
|
|||||||
Reference in New Issue
Block a user