log_bme680.py 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. #!/usr/bin/env python
  2. import numpy as np
  3. import os, serial,time,socket,sys,json
  4. from meas_data import meas_data
  5. # import the server implementation
  6. sensor="bme680"
  7. pathname = os.path.dirname(sys.argv[0])
  8. abspath=os.path.abspath(pathname)
  9. idfile=abspath+"/id.json"
  10. id_conf=0
  11. try:
  12. idf=open(idfile,"r")
  13. id_conf=json.load(idf)['id']
  14. idf.close()
  15. except:
  16. id_conf=0
  17. configfile=abspath+"/config.json"
  18. try:
  19. cf=open(configfile,"r")
  20. except:
  21. cf=open(configfile+".template","r")
  22. log_conf=json.load(cf)
  23. cf.close()
  24. parameter={"device":socket.gethostname(),"deviceid":"FF","mean_count":5,"ring_length":10,"wait":0.5,"cycle":10,"check_last":15,"check_last_shrinking":0.9,"gpg_keyid":"","digits":5,"store_dir":"/home/pi/log/","multiplicator":1000,"sensor":"BME680","sigma":3}
  25. for n in parameter:
  26. if n in log_conf:
  27. parameter[n]=log_conf[n]
  28. # config of bme680 sensor
  29. # use pip install bme680 for library
  30. meas_types=["temperature","humidity","pressure","voc"]
  31. bbme=False
  32. if sensor in log_conf:
  33. bbme=True
  34. if "enable" in log_conf[sensor]:
  35. if log_conf[sensor]['enable'] == 0:
  36. bbme=False
  37. bmqtt=False
  38. if "mqtt" in log_conf:
  39. bmqtt=True
  40. lcmq=log_conf['mqtt']
  41. mbroker=""
  42. if 'broker' in lcmq:
  43. mbroker=lcmq['broker']
  44. else:
  45. bmqtt=False
  46. mport=1883
  47. if 'port' in lcmq:
  48. mport=lcmq['port']
  49. if bbme:
  50. import bme680
  51. for n in parameter:
  52. if n in log_conf[sensor]:
  53. parameter[n]=log_conf[sensor][n]
  54. if "port" in log_conf[sensor]:
  55. bme_port=log_conf[sensor]['port']
  56. else:
  57. bme_port=1
  58. if "address" in log_conf[sensor]:
  59. parameter["i2c"]=int(log_conf[sensor]['address'],16)
  60. else:
  61. parameter["i2c"]=0x77
  62. try:
  63. sensor=bme680.BME680(i2c_addr=parameter["i2c"])
  64. except:
  65. bbme=False
  66. else:
  67. sensor.set_humidity_oversample(bme680.OS_2X)
  68. sensor.set_temperature_oversample(bme680.OS_2X)
  69. sensor.set_pressure_oversample(bme680.OS_2X)
  70. sensor.set_filter(bme680.FILTER_SIZE_3)
  71. sensor.set_gas_status(bme680.ENABLE_GAS_MEAS)
  72. sensor.set_gas_heater_temperature(320)
  73. sensor.set_gas_heater_duration(150)
  74. sensor.select_gas_heater_profile(0)
  75. bme_sigma=3
  76. if "sigma" in log_conf[sensor]:
  77. parameter["sigma"]=int(log_conf[sensor]['sigma'])
  78. if parameter["sigma"] < 1:
  79. parameter["sigma"]=1
  80. partemp=parameter
  81. partemp["var_name"]="temperature"
  82. bme_temp=meas_data(partemp)
  83. parhum=parameter
  84. parhum["var_name"]="humidity"
  85. bme_hum=meas_data(parhum)
  86. parpress=parameter
  87. parpress["var_name"]="pressure"
  88. bme_press=meas_data(parpress)
  89. parvoc=parameter
  90. parvoc["var_name"]="voc"
  91. bme_voc=meas_data(parpress)
  92. if ("mqtt" in log_conf[sensor]) and bmqtt:
  93. bme_temp.set_mqtt(broker=mbroker,port=mport)
  94. bme_hum.set_mqtt(broker=mbroker,port=mport)
  95. bme_press.set_mqtt(broker=mbroker,port=mport)
  96. if "sqlserver" in log_conf:
  97. hostname="banana"
  98. if "host" in log_conf['sqlserver']:
  99. hostname=log_conf['sqlserver']['host']
  100. port=24048
  101. if "port" in log_conf['sqlserver']:
  102. port=int(log_conf['sqlserver']['port'])
  103. bme_temp.set_sql(host=hostname,port=port)
  104. bme_hum.set_sql(host=hostname,port=port)
  105. bme_press.set_sql(host=hostname,port=port)
  106. bme_voc.set_sql(host=hostname,port=port)
  107. if "opensensemap" in log_conf[sensor]:
  108. osm=log_conf['bme680']['opensensemap']
  109. if "sensebox_id" in osm:
  110. sid=osm['sensebox_id']
  111. if "sensors" in osm:
  112. if "temperature" in osm['sensors']:
  113. bme_temp.set_sensebox(sid,osm['sensors']['temperature'])
  114. if "humidity" in osm['sensors']:
  115. bme_hum.set_sensebox(sid,osm['sensors']['humidity'])
  116. if "pressure" in osm['sensors']:
  117. bme_press.set_sensebox(sid,osm['sensors']['pressure'])
  118. if "voc" in osm['sensors']:
  119. bme_voc.set_sensebox(sid,osm['sensors']['voc'])
  120. if bbme:
  121. while True:
  122. # read bme280 (temperature, humidity, pressure)
  123. if sensor.get_sensor_data():
  124. bme_temp.append(sensor.data.temperature)
  125. bme_hum.append(sensor.data.humidity)
  126. bme_press.append(sensor.data.pressure)
  127. # print(sensor.data.temperature)
  128. if sensor.data.heat_stable:
  129. bme_voc.append(sensor.data.gas_resistance)
  130. # print(sensor.data.gas_resistance)
  131. time.sleep(parameter['wait'])
  132. # close the client
  133. print("done")