Added support for adaptive orbit feedback and spectral analysis

This commit is contained in:
2023-05-31 11:57:13 +02:00
parent b82b023f33
commit f22a17852c
8 changed files with 327 additions and 437 deletions

View File

@ -1,67 +1,51 @@
import sys
import os
import datetime
import h5py
# add other classes
#sys.path.append('/sf/bd/packages/SFBD/src')
class Load:
def __init__(self, logger = None, program = 'SFBD', version = 'v1.0.0'):
self.program = program
self.version = version
self.author ='S. Reiche'
self.file = None
if logger == None:
logging.basicConfig(level=logging.INFO,
format='%(levelname)-8s %(message)s')
self.logger = logging.getLogger(self.program)
self.logger.info('Load class started at %s' % datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S'))
self.logger.info('Version: %s ' % self.version)
self.logger.info('Host: %s' % socket.gethostname())
else:
self.logger = logger
def open(self,filename):
self.file = h5py.File(filename, "r")
def close(self):
if self.file is not None:
self.file.close()
self.file = None
def loadDataset(filename):
hid = h5py.File(filename, "r")
snap = loadSnap(hid)
data = loadData(hid)
act = loadActuator(hid)
hid.close()
return data,act,snap
def loadSnap(self):
snap={}
if not 'experiment' in self.file.keys():
return snap
for key1 in self.file['experiment'].keys():
for key2 in self.file['experiment'][key1].keys():
val = self.file['experiment'][key1][key2][()]
snap[key1+':'+key2]={'val':val}
return snap
def loadSnap(hid):
snap={}
if not 'experiment' in hid.keys():
return None
for key1 in hid['experiment'].keys():
if isinstance(hid['experiment'][key1],h5py.Group):
for key2 in hid['experiment'][key1].keys():
val = hid['experiment'][key1][key2][()]
snap[key1+':'+key2]=val
else:
snap[key1]=hid['experiment'][key1][()]
return snap
def loadData(self,scanrun=1):
run='scan_%d' % scanrun
data = {}
for key1 in self.file[run]['data'].keys():
for key2 in self.file[run]['data'][key1].keys():
val = self.file[run]['data'][key1][key2][()]
def loadData(hid,scanrun=1):
run='scan_%d' % scanrun
data = {}
for key1 in hid[run]['data'].keys():
if isinstance(hid[run]['data'][key1],h5py.Group):
for key2 in hid[run]['data'][key1].keys():
val = hid[run]['data'][key1][key2][()]
data[key1+':'+key2]=val
return data
else:
data[key1]=hid[run]['data'][key1][()]
return data
def loadActuator(self,scanrun=1):
run='scan_%d' % scanrun
data = {}
if 'actuators' in self.file[run]['method'].keys():
for key1 in self.file[run]['method']['actuators'].keys():
for key2 in self.file[run]['method']['actuators'][key1].keys():
val = self.file[run]['method']['actuators'][key1][key2][()]
def loadActuator(hid,scanrun=1):
run='scan_%d' % scanrun
data = {}
if 'actuators' in hid[run]['method'].keys():
for key1 in hid[run]['method']['actuators'].keys():
if isinstance(hid[run]['method']['actuators'],h5py.Group):
for key2 in hid[run]['method']['actuators'][key1].keys():
val = hid[run]['method']['actuators'][key1][key2][()]
data[key1+':'+key2]={'val':val}
return data
else:
data[key1]=hid[run]['method']['actuators'][key1][()]
return data