ACDC_KNOSYS-2021/FUSION/properties.py

126 lines
4.5 KiB
Python
Raw Normal View History

2021-10-04 18:31:00 +08:00
import logging, subprocess
import math
import threading, random
class Properties(object):
useKliepCVSigma = 0
kliepDefSigma = 0.00
kliepParEta = 0.0
kliepParLambda = 0.00
kliepParB = 0
kliepParThreshold = 0.0
useSvmCVParams = 1
svmDefGamma = 0.0001
svmDefC = 131072
ENSEMBLE_SIZE = 0
CONFTHRESHOLD = 0.0
CONFCUTOFF = 0.0
IDENTIFIER = ''
OUTFILENAME = ''
TEMPDIR = ''
LOGFILE = ''
MAXVAR = 0
BASEDIR = ''
SRCAPPEND = ''
TRGAPPEND = ''
logger = None
GAMMA = 0.0
CUSHION = 0
SENSITIVITY = 0.0
MAX_WINDOW_SIZE = 0
INITIAL_DATA_SIZE = 0
enableForceUpdate = 0
forceUpdatePeriod = 0
def __init__(self, propfilename, datasetName):
dict = {}
with open(propfilename) as f:
for line in f:
(key,val) = line.split('=')
dict[key.strip()] = val.strip()
self.__class__.useKliepCVSigma=int(dict['useKliepCVSigma'])
self.__class__.kliepDefSigma = float(dict['kliepDefSigma'])
self.__class__.kliepParEta = float(dict['kliepParEta'])
self.__class__.kliepParLambda = float(dict['kliepParLambda'])
self.__class__.kliepParB = int(dict['kliepParB'])
self.__class__.kliepParThreshold = -math.log(float(dict['sensitivity']))
self.__class__.useSvmCVParams=int(dict['useSvmCVParams'])
self.__class__.svmDefGamma=float(dict['svmDefGamma'])
self.__class__.svmDefC=int(dict['svmDefC'])
self.__class__.svmKernel=str(dict['kernel'])
self.__class__.ENSEMBLE_SIZE = int(dict['ensemble_size'])
self.__class__.CONFTHRESHOLD = float(dict['confthreshold'])
self.__class__.CONFCUTOFF = float(dict['confcutoff'])
self.__class__.MAXVAR = 0
self.__class__.BASEDIR = dict['baseDir']
self.__class__.SRCAPPEND = dict['srcfileAppend']
self.__class__.TRGAPPEND = dict['trgfileAppend']
self.__class__.GAMMA = float(dict['gamma'])
self.__class__.CUSHION = int(dict['cushion'])
self.__class__.SENSITIVITY = float(dict['sensitivity'])
self.__class__.MAX_WINDOW_SIZE = int(dict['maxWindowSize'])
self.__class__.INITIAL_DATA_SIZE = int(dict['initialDataSize'])
self.__class__.enableForceUpdate = int(dict['enableForceUpdate'])
self.__class__.forceUpdatePeriod = int(dict['forceUpdatePeriod'])
self.__class__.IDENTIFIER = datasetName + '_' + str(self.__class__.INITIAL_DATA_SIZE) \
+ '_' + str(self.__class__.MAX_WINDOW_SIZE)
self.__class__.OUTFILENAME = self.__class__.IDENTIFIER + '_' + dict['output_file_name']
self.__class__.TEMPDIR = dict['tempDir']
self.__class__.LOGFILE = self.__class__.IDENTIFIER + '_' + dict['logfile']
if self.__class__.logger: self.__class__.logger = None
self.__class__.logger = self.__setupLogger()
#self.__class__.PY4JPORT = random.randint(25333, 30000)
#t = threading.Thread(target=self.__startCPDJava)
#t.daemon = True
#t.start()
def __startCPDJava(self):
subprocess.call(['java', '-jar', 'change_point.jar', str(self.__class__.GAMMA), str(self.__class__.SENSITIVITY), str(self.__class__.MAX_WINDOW_SIZE), str(self.__class__.CUSHION), str(self.__class__.CONFCUTOFF), str(self.__class__.PY4JPORT)])
def __setupLogger(self):
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)
sh = logging.StreamHandler()
sh.setLevel(logging.INFO)
logger.addHandler(sh)
handler = logging.FileHandler(self.__class__.LOGFILE)
handler.setLevel(logging.INFO)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
logger.addHandler(handler)
return logger
def summary(self):
line = 'Parameter values are as follows:'
line += '\nuseKliepCVSigma = ' + str(self.useKliepCVSigma)
line += '\nkliepDefSigma = ' + str(self.kliepDefSigma)
line += '\nkliepParEta = ' + str(self.kliepParEta)
line += '\nkliepParLambda = ' + str(self.kliepParLambda)
line += '\nkliepParB = ' + str(self.kliepParB)
line += '\nkliepParThreshold = ' + str(self.kliepParThreshold)
line += '\nuseSvmCVParams = ' + str(self.useSvmCVParams)
line += '\nsvmDefGamma = ' + str(self.svmDefGamma)
line += '\nsvmDefC = ' + str(self.svmDefC)
line += '\nsvmKernel = ' + str(self.svmKernel)
line += '\ninitialWindowSize = ' + str(self.INITIAL_DATA_SIZE)
line += '\nmaxWindowSize = ' + str(self.MAX_WINDOW_SIZE)
line += '\nenableForceUpdate = ' + str(self.enableForceUpdate)
line += '\nforceUpdatePeriod = ' + str(self.forceUpdatePeriod)
line += '\nensemble_size = ' + str(self.ENSEMBLE_SIZE)
line += '\nMaximum Num Variables = ' + str(self.MAXVAR)
line += '\nOutput File = ' + str(self.OUTFILENAME)
return line