rasolar/log_veml6070.py

99 lines
2.6 KiB
Python
Raw Permalink Normal View History

2019-06-25 08:38:03 -07:00
#!/usr/bin/env python
import numpy as np
2019-06-30 12:40:44 -07:00
import os, serial,time,socket,sys,json
2019-06-25 08:38:03 -07:00
from meas_data import meas_data
# import the server implementation
# import ADC
2019-10-18 10:12:04 -07:00
sensor="veml6070"
2019-07-26 22:48:13 -07:00
pathname = os.path.dirname(sys.argv[0])
abspath=os.path.abspath(pathname)
2019-06-25 08:38:03 -07:00
2019-10-18 10:12:04 -07:00
idfile=abspath+"/id.json"
id_conf=0
try:
idf=open(idfile,"r")
id_conf=json.load(idf)['id']
idf.close()
except:
id_conf=0
2019-07-26 22:48:13 -07:00
configfile=abspath+"/config.json"
2019-10-18 10:12:04 -07:00
try:
cf=open(configfile,"r")
except:
cf=open(configfile+".template","r")
2019-06-25 08:38:03 -07:00
log_conf=json.load(cf)
cf.close()
2019-11-18 09:33:33 -08:00
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":3,"store_dir":"/home/pi/log/","multiplicator":1000,"sensor":"VEML6070","sigma":3}
2019-06-25 08:38:03 -07:00
for n in parameter:
if n in log_conf:
parameter[n]=log_conf[n]
bveml=False
2019-10-18 10:12:04 -07:00
if sensor in log_conf:
2019-06-25 08:38:03 -07:00
bveml=True
2019-10-18 10:12:04 -07:00
if "enable" in log_conf[sensor]:
if log_conf[sensor]['enable'] == 0:
2019-06-25 08:38:03 -07:00
bveml=False
if bveml:
import veml6070
2019-10-18 10:12:04 -07:00
parameter["i2c"]=1
if "port" in log_conf[sensor]:
parameter["i2c"]=int(log_conf[sensor]['port'])
2019-06-25 08:38:03 -07:00
try:
2019-10-18 10:12:04 -07:00
veml = veml6070.Veml6070(i2c_bus=parameter["i2c"])
2019-06-25 08:38:03 -07:00
except:
bveml=False
else:
tsl_sigma=parameter['sigma']
for n in parameter:
if n in log_conf:
parameter[n]=log_conf[n]
2019-10-18 10:12:04 -07:00
if "sigma" in log_conf[sensor]:
parameter['sigma']=int(log_conf[sensor]['sigma'])
if parameter['sigma'] < 1:
parameter['sigma']=1
parameter["var_name"]="uv"
tsl_data=meas_data(parameter)
2019-07-02 05:17:52 -07:00
bmqtt=False
if "mqtt" in log_conf:
bmqtt=True
lcmq=log_conf['mqtt']
mbroker=""
if 'broker' in lcmq:
mbroker=lcmq['broker']
else:
bmqtt=False
mport=1883
if 'port' in lcmq:
mport=lcmq['port']
if bmqtt:
2019-07-02 09:52:51 -07:00
tsl_data.set_mqtt(broker=mbroker,port=mport)
2019-06-25 08:38:03 -07:00
if "sqlserver" in log_conf:
2019-08-02 10:37:56 -07:00
hostname="localhost"
port=8080
2019-06-25 08:38:03 -07:00
tsl_data.set_sql(host=hostname,port=port)
2019-10-18 10:12:04 -07:00
if "opensensemap" in log_conf[sensor]:
2019-06-25 08:38:03 -07:00
osm=log_conf['veml6070']['opensensemap']
if "sensebox_id" in osm:
sid=osm['sensebox_id']
if "sensors" in osm:
if "uv" in osm['sensors']:
tsl_data.set_sensebox(sid,osm['sensors']['uv'])
if bveml:
while True:
# read bme280 (temperature, humidity, pressure)
veml.set_integration_time(veml6070.INTEGRATIONTIME_1T)
2019-06-30 12:40:44 -07:00
tsl_data.append(veml.get_uva_light_intensity())
2019-06-25 08:38:03 -07:00
time.sleep(parameter['wait'])
# close the client
print("done")