2022-07-12 21:10:37 -04:00
|
|
|
#!/usr/bin/python3
|
2022-07-13 17:21:48 -04:00
|
|
|
|
|
|
|
import IsegLibrary as iseg
|
2022-07-12 21:10:37 -04:00
|
|
|
import os
|
|
|
|
import datetime
|
|
|
|
import csv
|
2022-07-13 17:21:48 -04:00
|
|
|
import socket
|
2022-08-08 12:45:52 -04:00
|
|
|
import sys
|
2022-08-30 14:24:16 -04:00
|
|
|
import time
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2024-03-11 12:45:09 -04:00
|
|
|
import influxdb_client
|
|
|
|
from influxdb_client import InfluxDBClient, Point, WritePrecision
|
|
|
|
from influxdb_client.client.write_api import SYNCHRONOUS, ASYNCHRONOUS
|
|
|
|
|
|
|
|
#------ database
|
|
|
|
with open('ISEG_TOKEN.txt', 'r') as f:
|
|
|
|
token = f.readline()
|
|
|
|
|
|
|
|
org = "FSUFoxLab"
|
|
|
|
ip = "https://fsunuc.physics.fsu.edu/influx/"
|
|
|
|
write_client = influxdb_client.InfluxDBClient(url=ip, token=token, org=org)
|
|
|
|
bucket = "ISEG"
|
|
|
|
write_api = write_client.write_api(write_options=ASYNCHRONOUS)
|
|
|
|
|
2022-07-13 17:21:48 -04:00
|
|
|
#assign a port, to prevent the script run mulitple time
|
|
|
|
s = socket.socket()
|
|
|
|
host = socket.gethostname()
|
|
|
|
port = 4305
|
|
|
|
s.bind((host,port))
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-08-08 12:45:52 -04:00
|
|
|
nArg = len(sys.argv)
|
|
|
|
|
|
|
|
print ( nArg)
|
|
|
|
|
|
|
|
if nArg > 1 :
|
|
|
|
IP = sys.argv[1]
|
|
|
|
else :
|
|
|
|
IP = input('Mpod IP address to connect : ')
|
2022-08-08 12:24:23 -04:00
|
|
|
|
2022-08-22 10:48:27 -04:00
|
|
|
databaseIP="128.186.111.107"
|
|
|
|
pushToDB = False
|
|
|
|
|
2022-07-12 21:10:37 -04:00
|
|
|
#===================== GUI
|
|
|
|
import PySimpleGUI as sg
|
|
|
|
|
2022-08-08 12:45:52 -04:00
|
|
|
sg.theme('DarkPurple5')
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
header = ["name", "HV [V]", "Current [mA]"]
|
|
|
|
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod = iseg.Mpod(IP)
|
|
|
|
if mpod.isConnected == False:
|
|
|
|
exit()
|
|
|
|
|
2022-08-09 12:12:47 -04:00
|
|
|
print("============ GUI start")
|
2022-08-08 12:45:52 -04:00
|
|
|
|
2022-08-08 12:24:23 -04:00
|
|
|
chList = mpod.GetChList()
|
|
|
|
hvList = mpod.GetAllHV() # get all V
|
|
|
|
iList = mpod.GetAllCurrent() # get all current
|
|
|
|
outVList = mpod.GetAllOutputHV()
|
|
|
|
outIList = mpod.GetAllLC()
|
|
|
|
onOffList = mpod.GetAllOnOff()
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-07-15 17:07:51 -04:00
|
|
|
modChList = iseg.SplitChList(chList)
|
|
|
|
|
|
|
|
nMod = len(modChList)
|
2022-07-14 20:55:08 -04:00
|
|
|
nChannel = len(chList)
|
2022-08-30 14:24:16 -04:00
|
|
|
updateTime = 1 #sec
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
fileName = ''
|
|
|
|
|
2022-07-15 17:07:51 -04:00
|
|
|
layoutTab = []
|
2022-08-30 14:24:16 -04:00
|
|
|
isAllOn = []
|
2022-07-15 17:07:51 -04:00
|
|
|
for k in range(0, nMod):
|
|
|
|
layoutTab.append([])
|
2022-08-30 14:24:16 -04:00
|
|
|
isAllOn.append(True)
|
|
|
|
baseI = 0
|
|
|
|
for kk in range(0, k):
|
|
|
|
baseI += len(modChList[kk])
|
|
|
|
for j in range(0, len(modChList[k])) :
|
|
|
|
i = baseI + j
|
|
|
|
if( onOffList[i] == False ):
|
|
|
|
isAllOn[k] = False
|
2022-07-15 17:07:51 -04:00
|
|
|
|
|
|
|
for k in range(0, nMod):
|
|
|
|
baseI = 0
|
|
|
|
for kk in range(0, k):
|
|
|
|
baseI += len(modChList[kk])
|
|
|
|
|
|
|
|
## i know it is stupid to have this every time, but pysimplegui request a non-used array
|
|
|
|
layoutTab[k].append([
|
|
|
|
sg.Text("Name", size = 8, justification = "center" ),
|
|
|
|
sg.Text("CH", size = 4, justification = "center" ),
|
|
|
|
sg.Text("On/Off", size = 6, justification = "center"),
|
|
|
|
sg.Text("Set V [V]", size = 8, justification = "center" ),
|
|
|
|
sg.Text("Set I [mA]", size = 9, justification = "center" ),
|
|
|
|
sg.Text("Out V [V]", size = 8, justification = "center" ),
|
|
|
|
sg.Text("Out I [uA]", size = 10, justification = "center" )
|
|
|
|
])
|
2022-08-30 13:37:54 -04:00
|
|
|
|
|
|
|
layoutTab[k].append([
|
|
|
|
sg.Text("", size = 8, justification = "center" ),
|
|
|
|
sg.Text("All", size = 4, justification = "center" ),
|
2022-08-30 14:24:16 -04:00
|
|
|
sg.Checkbox('', default = isAllOn[k], size = 3, enable_events = True, key=("c-ALL%d" % k)),
|
2022-08-30 13:37:54 -04:00
|
|
|
sg.Input(default_text=("" ), size = 8, justification = "right", enable_events=True, key=("v-ALL%d" % k) ),
|
|
|
|
sg.Input(default_text=("" ), size = 9, justification = "right", enable_events=True, key=("i-ALL%d" % k) ),
|
|
|
|
])
|
|
|
|
|
2022-07-15 17:07:51 -04:00
|
|
|
for j in range(0, len(modChList[k])) :
|
|
|
|
i = baseI + j
|
|
|
|
layoutTab[k].append(
|
|
|
|
[
|
|
|
|
sg.Input(default_text='', size = 8, justification = "left", key=("n%d" % chList[i])),
|
|
|
|
sg.Text("u"+str(chList[i]), size = 4, justification = "center" ),
|
|
|
|
sg.Checkbox('', default = onOffList[i], size = 3, enable_events = True, key=("c%d" % chList[i])),
|
|
|
|
sg.Input(default_text=("%.3f" % hvList[i]), size = 8, justification = "right", enable_events=True, key=("v%d" % chList[i]) ),
|
|
|
|
sg.Input(default_text=("%.3f" % (iList[i]*1000)), size = 9, justification = "right", enable_events=True, key=("i%d" % chList[i]) ),
|
|
|
|
sg.Input(default_text=("%.3f" % outVList[i]), size = 8, justification = "right", enable_events=True, key=("a%d" % chList[i]), readonly = True ),
|
|
|
|
sg.Input(default_text=("%.3f" % (outIList[i]*1e6)), size = 10, justification = "right", enable_events=True, key=("b%d" % chList[i]), readonly = True )
|
|
|
|
]
|
|
|
|
)
|
|
|
|
|
|
|
|
layoutTabGroup = []
|
|
|
|
layoutTabGroup.append([])
|
|
|
|
for k in range(0, nMod):
|
|
|
|
layoutTabGroup[0].append(sg.Tab("Mod-%0d" % k, layoutTab[k]))
|
|
|
|
|
2022-07-12 21:10:37 -04:00
|
|
|
layout = [
|
2022-08-08 12:24:23 -04:00
|
|
|
[
|
|
|
|
sg.Text("IP :", size = 27, justification = "right"),
|
|
|
|
sg.Input(IP, size = 16, justification = "right", readonly = True),
|
|
|
|
],
|
2022-08-22 10:48:27 -04:00
|
|
|
[
|
|
|
|
sg.Text("Database IP :", size = 27, justification = "right"),
|
|
|
|
sg.Input(databaseIP, size = 16, justification = "right", key='-DatabaseIP-', readonly = False),
|
2022-08-31 13:26:28 -04:00
|
|
|
sg.Checkbox('Enable Database', key='-DatabaseEnable-', enable_events=True)
|
2022-08-22 10:48:27 -04:00
|
|
|
],
|
2022-07-12 21:10:37 -04:00
|
|
|
[
|
2022-07-13 14:52:41 -04:00
|
|
|
sg.Text("refresh period [sec] :", size = 27, justification = "right"),
|
2022-07-12 21:10:37 -04:00
|
|
|
sg.Input(updateTime, size = 8, justification = "right", enable_events=True, key=("-Refresh-"))
|
2022-07-15 17:07:51 -04:00
|
|
|
]
|
|
|
|
,
|
|
|
|
[
|
|
|
|
sg.TabGroup(layoutTabGroup)
|
|
|
|
]
|
|
|
|
]
|
|
|
|
|
2022-07-12 21:10:37 -04:00
|
|
|
layout.append([sg.FileSaveAs('Save As', target = '-Save-', initial_folder='~', file_types = (('csv file','*.csv'),)),
|
|
|
|
sg.FileBrowse('Load', target = '-Load-', initial_folder='~', file_types = (('csv file','*.csv'),)),
|
|
|
|
sg.Input(default_text=fileName, expand_x = True, justification = "left", readonly = True, enable_events=True, key="-Save-" ),
|
|
|
|
sg.Input('', visible = False, enable_events=True, key="-Load-" )
|
|
|
|
])
|
2022-07-13 17:21:48 -04:00
|
|
|
|
|
|
|
comboList = ["Get Rise Rate [V/s]", "Get Fall Rate [V/s]", "Set Rise Rate [V/s]", "Set Fall Rate [V/s]"]
|
|
|
|
layout.append([sg.Combo(comboList, default_value = comboList[0], size = 20, enable_events=True, key="-VRateCombo-"),
|
|
|
|
sg.Text("Ch:", size = 3),
|
|
|
|
sg.Combo(chList, default_value = chList[0], size = 4, enable_events=True, key="-VRateCh-"),
|
|
|
|
sg.Input('', size = 6, justification = "right", enable_events=True, key="-VRate-")
|
|
|
|
])
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-07-13 17:21:48 -04:00
|
|
|
window = sg.Window('Iseg HV Control & Monitor', layout, finalize = True, keep_on_top = True)
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-08-30 13:37:54 -04:00
|
|
|
for k in range(0, nMod):
|
|
|
|
window[("i-ALL%d" % k)].bind("<Return>", "_EnterALL")
|
2022-08-30 14:24:16 -04:00
|
|
|
window[("i-ALL%d" % k)].bind("<KP_Return>", "_EnterALL")
|
|
|
|
window[("v-ALL%d" % k)].bind("<Return>", "_EnterALL")
|
2022-08-30 13:37:54 -04:00
|
|
|
window[("v-ALL%d" % k)].bind("<KP_Enter>", "_EnterALL")
|
2022-07-17 13:16:36 -04:00
|
|
|
for i in range(0, nChannel):
|
2022-08-30 13:37:54 -04:00
|
|
|
window[("v%d" % chList[i])].bind("<Return>", "_EnterCh")
|
|
|
|
window[("i%d" % chList[i])].bind("<Return>", "_EnterCh")
|
|
|
|
window[("v%d" % chList[i])].bind("<KP_Enter>", "_EnterCh")
|
|
|
|
window[("i%d" % chList[i])].bind("<KP_Enter>", "_EnterCh")
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
# Event Loop to process "events" and get the "values" of the inputs
|
|
|
|
while True:
|
2022-07-13 14:52:41 -04:00
|
|
|
event, values = window.read(timeout = updateTime * 1000, timeout_key = "_TIMEOUT_") ## this pause for 20 sec and wait for event
|
2022-07-12 21:10:37 -04:00
|
|
|
#print(event)
|
|
|
|
#print(values)
|
|
|
|
#print(datetime.datetime.now())
|
|
|
|
|
|
|
|
if event == "-Refresh-" :
|
|
|
|
updateTime = int(window[event].get());
|
|
|
|
|
|
|
|
if event in (None, 'Exit'):
|
|
|
|
break
|
|
|
|
|
|
|
|
if event[0:1] == 'c' :
|
2022-08-30 13:37:54 -04:00
|
|
|
if event[0:2] == 'c-':
|
|
|
|
mod = int(event[5:])
|
|
|
|
for ch in modChList[mod]:
|
|
|
|
mpod.SwitchOnHV(int(ch), int(window[event].get()))
|
|
|
|
window[("c%d" % ch)].update(window[event].get())
|
2022-08-30 14:24:16 -04:00
|
|
|
window.refresh()
|
|
|
|
#time.sleep(0.1)
|
2022-08-30 13:37:54 -04:00
|
|
|
else :
|
|
|
|
ID = event[1:]
|
|
|
|
mpod.SwitchOnHV(int(ID), int(window[event].get()))
|
2022-08-30 14:24:16 -04:00
|
|
|
mod = int(int(ID)/100)
|
|
|
|
#--- check is all On
|
|
|
|
isAllOn[mod] = True
|
|
|
|
for ch in modChList[mod]:
|
|
|
|
if( window[("c%d" % ch)].get() == False ):
|
|
|
|
isAllOn[mod] = False
|
|
|
|
window[("c-ALL%d" % mod)].update(isAllOn[mod]);
|
2022-08-30 13:37:54 -04:00
|
|
|
|
2022-07-12 21:10:37 -04:00
|
|
|
if event == '-Save-' :
|
|
|
|
fileName = values["Save As"]
|
|
|
|
outfile = open(fileName, "w")
|
|
|
|
csv_writer = csv.writer(outfile)
|
|
|
|
for i in range(0, nChannel):
|
|
|
|
papap = [window[("n%d" % chList[i])].get(), "u"+str(chList[i]), window[("v%d" % chList[i])].get(), window[("i%d" % chList[i])].get()]
|
|
|
|
csv_writer.writerow( papap )
|
|
|
|
outfile.close();
|
|
|
|
|
|
|
|
if event == "-Load-" :
|
|
|
|
fileName = window["-Load-"].get()
|
|
|
|
window['-Save-'].update(fileName)
|
|
|
|
infile = open(fileName, "r")
|
|
|
|
csv_reader = csv.reader(infile)
|
|
|
|
i = 0
|
|
|
|
for row in csv_reader:
|
|
|
|
window[("n%d" % chList[i])].update(row[0])
|
|
|
|
window[("v%d" % chList[i])].update(row[2])
|
|
|
|
window[("i%d" % chList[i])].update(row[3])
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod.SetHV(chList[i], float(row[2]))
|
|
|
|
mpod.SetCurrent(chList[i], float(row[3])/1000)
|
2022-07-12 21:10:37 -04:00
|
|
|
i += 1
|
|
|
|
|
2022-07-13 17:21:48 -04:00
|
|
|
if event in ["-VRateCombo-", "-VRateCh-", "-VRate-"]:
|
|
|
|
item = window["-VRateCombo-"].get()
|
|
|
|
ch = window["-VRateCh-"].get()
|
|
|
|
val = window["-VRate-"].get()
|
|
|
|
if item == comboList[0]:
|
2022-08-08 12:24:23 -04:00
|
|
|
window["-VRate-"].update("%.3f" % float(mpod.GetHVRiseRate(int(ch))))
|
2022-07-13 17:21:48 -04:00
|
|
|
if item == comboList[1]:
|
2022-08-08 12:24:23 -04:00
|
|
|
window["-VRate-"].update("%.3f" % float(mpod.GetHVFallRate(int(ch))))
|
2022-07-13 17:21:48 -04:00
|
|
|
if item == comboList[2]:
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod.SetHVRiseRate(ch, val)
|
|
|
|
window["-VRate-"].update("%.3f" % float(mpod.GetHVRiseRate(int(ch))))
|
2022-07-13 17:21:48 -04:00
|
|
|
if item == comboList[3]:
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod.SetHVFallRate(ch, val)
|
|
|
|
window["-VRate-"].update("%.3f" % float(mpod.GetHVFallRate(int(ch))))
|
2022-08-30 13:37:54 -04:00
|
|
|
|
|
|
|
haha = event.find('_EnterCh')
|
2022-07-12 21:10:37 -04:00
|
|
|
if haha > 0 :
|
|
|
|
ID = event[:haha]
|
|
|
|
ch = int(ID[1:])
|
|
|
|
if event[0:1] == 'v' :
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod.SetHV(ch, float(window[ID].get()))
|
|
|
|
window[ID].update("%.3f" % mpod.GetHV(ch))
|
2022-08-30 14:24:16 -04:00
|
|
|
print(("v-ALL%d" % int(ch/100)))
|
|
|
|
window[("v-ALL%d" % int(ch/100))].update("")
|
2022-07-12 21:10:37 -04:00
|
|
|
if event[0:1] == 'i' :
|
2022-08-08 12:24:23 -04:00
|
|
|
mpod.SetCurrent(ch, float(window[ID].get())/1000.)
|
|
|
|
window[ID].update("%.3f" % (mpod.GetCurrent(ch)*1000))
|
2022-08-30 14:24:16 -04:00
|
|
|
print(("i-ALL%d" % int(ch/100)))
|
|
|
|
window[("i-ALL%d" % int(ch/100))].update("")
|
2022-08-30 13:37:54 -04:00
|
|
|
|
|
|
|
jaja = event.find('_EnterALL')
|
|
|
|
if jaja > 0 :
|
|
|
|
ID = event[:jaja]
|
|
|
|
mod = int(ID[5:])
|
2022-08-30 14:24:16 -04:00
|
|
|
val = float(window[ID].get());
|
2022-08-30 13:37:54 -04:00
|
|
|
if event[0:1] == 'v' :
|
|
|
|
for ch in modChList[mod]:
|
2022-08-30 14:24:16 -04:00
|
|
|
mpod.SetHV(ch, val)
|
|
|
|
window[ID].update("%.3f" % val)
|
2022-08-30 13:37:54 -04:00
|
|
|
window[("v%d" % ch)].update("%.3f" % mpod.GetHV(ch))
|
2022-08-30 14:24:16 -04:00
|
|
|
window.refresh()
|
|
|
|
#time.sleep(0.1)
|
2022-08-30 13:37:54 -04:00
|
|
|
if event[0:1] == 'i' :
|
|
|
|
for ch in modChList[mod]:
|
2022-08-30 14:24:16 -04:00
|
|
|
mpod.SetCurrent(ch, val/1000.)
|
|
|
|
window[ID].update("%.3f" % val)
|
2022-08-30 13:37:54 -04:00
|
|
|
window[("i%d" % ch)].update("%.3f" % (mpod.GetCurrent(ch)*1000))
|
2022-08-30 14:24:16 -04:00
|
|
|
window.refresh()
|
|
|
|
#time.sleep(0.1)
|
2022-08-30 13:37:54 -04:00
|
|
|
|
2022-08-22 10:48:27 -04:00
|
|
|
if event == "-DatabaseEnable-" :
|
|
|
|
pushToDB = window["-DatabaseEnable-"].get()
|
|
|
|
window["-DatabaseIP-"].update(disabled=pushToDB)
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
if event == "_TIMEOUT_" :
|
2022-08-08 12:24:23 -04:00
|
|
|
outVList = mpod.GetAllOutputHV()
|
|
|
|
outIList = mpod.GetAllLC()
|
2022-08-30 14:24:16 -04:00
|
|
|
#onOffList = mpod.GetAllOnOff()
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-08-22 10:48:27 -04:00
|
|
|
pushToDB = window["-DatabaseEnable-"].get()
|
|
|
|
if pushToDB :
|
2024-03-11 12:45:09 -04:00
|
|
|
points = []
|
|
|
|
#tempFile = open("temp.dat", "w")
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
for i in range(0, nChannel):
|
|
|
|
window[("a%d" % chList[i])].update("%.3f" % outVList[i])
|
|
|
|
window[("b%d" % chList[i])].update("%.3f" % (outIList[i]*1e6))
|
2022-08-30 14:24:16 -04:00
|
|
|
|
2022-07-12 21:10:37 -04:00
|
|
|
#==== To DataBase
|
2022-08-22 10:48:27 -04:00
|
|
|
if pushToDB :
|
2024-03-11 12:45:09 -04:00
|
|
|
points.append(Point("Voltage").tag("Ch",int(chList[i])).field("value",float(outVList[i])))
|
|
|
|
points.append(Point("LeakageCurrent").tag("Ch",int(chList[i])).field("value",float(outIList[i])))
|
|
|
|
|
|
|
|
#tempFile.write("Voltage,Ch=%d value=%f\n" % (chList[i], outVList[i]))
|
|
|
|
#tempFile.write("LeakageCurrent,Ch=%d value=%f\n" % (chList[i], outIList[i]*1e6))
|
2022-07-12 21:10:37 -04:00
|
|
|
|
2022-08-22 10:48:27 -04:00
|
|
|
if pushToDB:
|
2024-03-11 12:45:09 -04:00
|
|
|
#tempFile.close()
|
|
|
|
write_api.write(bucket=bucket, org=org, record=points)
|
|
|
|
#os.system("curl -XPOST http://%s:8086/write?db=testing --data-binary @temp.dat" % databaseIP )
|
2022-07-12 21:10:37 -04:00
|
|
|
|
|
|
|
|
|
|
|
window.close()
|
|
|
|
|