2013-06-14 06:44:34 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- encoding: utf-8 -*-
|
2013-07-10 16:36:07 +00:00
|
|
|
import os
|
|
|
|
import sys
|
2013-06-14 06:44:34 +00:00
|
|
|
import re
|
|
|
|
import signal
|
|
|
|
|
|
|
|
from PyQt4.QtCore import *
|
|
|
|
from PyQt4.QtGui import *
|
2014-02-25 13:55:29 +00:00
|
|
|
import matplotlib
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-03-19 18:48:15 +00:00
|
|
|
from mathlib import fit_anneal, fit_lbfgsb, fit_odr_cmplx
|
2013-07-12 14:11:29 +00:00
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
matplotlib.use('agg')
|
|
|
|
|
|
|
|
|
|
|
|
from matplotlib import pyplot
|
|
|
|
from matplotlib.colors import hex2color
|
2013-07-17 11:00:24 +00:00
|
|
|
#matplotlib.rc_file("default.mplrc")
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
import numpy as N
|
|
|
|
|
|
|
|
import QDSMain
|
|
|
|
|
2014-03-19 18:48:15 +00:00
|
|
|
from data import Data, Conductivity, Peak
|
2014-02-25 13:55:29 +00:00
|
|
|
import pyqtgraph as pg
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
#import yaff
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-03-19 18:48:15 +00:00
|
|
|
from CustomWidgets import ParameterWidget
|
|
|
|
|
2014-03-18 18:48:39 +00:00
|
|
|
USE_CROSSH=False
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
class AppWindow(QMainWindow):
|
|
|
|
def __init__(self, parent=None):
|
|
|
|
super(AppWindow, self).__init__(parent)
|
|
|
|
self.ui = QDSMain.Ui_MainWindow()
|
|
|
|
self.ui.setupUi(self)
|
|
|
|
self.picked_artist = None
|
|
|
|
self.data = None
|
|
|
|
|
|
|
|
self.Conductivity = None
|
|
|
|
|
|
|
|
self._lines = dict()
|
|
|
|
|
|
|
|
self.peakId = 0
|
|
|
|
self.peakBoxes = {}
|
2013-07-10 16:36:07 +00:00
|
|
|
|
2014-03-19 18:48:15 +00:00
|
|
|
self.parameterWidget = ParameterWidget()
|
|
|
|
self.ui.dockWidget_3.setWidget(self.parameterWidget)
|
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
## menubar
|
|
|
|
fileMenu = self.menuBar().addMenu("File")
|
2013-07-10 16:36:07 +00:00
|
|
|
openFile = QAction("&Open", self)
|
2013-06-14 06:44:34 +00:00
|
|
|
openFile.setShortcut(QKeySequence.Open)
|
|
|
|
openFile.triggered.connect(self.openFile)
|
|
|
|
fileMenu.addAction(openFile)
|
2014-02-25 13:55:29 +00:00
|
|
|
|
|
|
|
saveFile = QAction("&Save Fit Result", self)
|
|
|
|
saveFile.setShortcut(QKeySequence.Save)
|
|
|
|
saveFile.triggered.connect(self.saveFitResult)
|
|
|
|
fileMenu.addAction(saveFile)
|
|
|
|
|
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
# fitting methods
|
2013-07-10 16:36:07 +00:00
|
|
|
fitMenu = self.menuBar().addMenu("Standard Fits")
|
2013-06-14 06:44:34 +00:00
|
|
|
# lm
|
2013-07-10 16:36:07 +00:00
|
|
|
fit_lmAction = QAction("&Levenberg-Marquardt", self)
|
|
|
|
fit_lmAction.setShortcut(QKeySequence("Ctrl+F"))
|
2013-06-14 06:44:34 +00:00
|
|
|
fitMenu.addAction(fit_lmAction)
|
|
|
|
# lbfgsb
|
2013-07-10 16:36:07 +00:00
|
|
|
fit_lbfgsbAction = QAction("&L-BFGS-B", self)
|
2013-06-14 06:44:34 +00:00
|
|
|
fitMenu.addAction(fit_lbfgsbAction)
|
|
|
|
# Simulated Annealing
|
2013-07-10 16:36:07 +00:00
|
|
|
fit_annealAction = QAction("&Simulated Annealing", self)
|
2013-06-14 06:44:34 +00:00
|
|
|
fitMenu.addAction(fit_annealAction)
|
2013-07-10 16:36:07 +00:00
|
|
|
# YAFF
|
|
|
|
yaffMenu = self.menuBar().addMenu("YAFF")
|
|
|
|
start_yaff = QAction("&Startparam.", self)
|
|
|
|
yaffMenu.addAction(start_yaff)
|
|
|
|
fit_yaff = QAction("&Fit", self)
|
|
|
|
yaffMenu.addAction(fit_yaff)
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
self.signalMapper = QSignalMapper(self)
|
|
|
|
for i, fit_action in enumerate([fit_lmAction, fit_lbfgsbAction, fit_annealAction
|
2013-07-10 16:36:07 +00:00
|
|
|
]):
|
|
|
|
self.signalMapper.setMapping(fit_action, i)
|
2013-06-14 06:44:34 +00:00
|
|
|
fit_action.triggered.connect(self.signalMapper.map)
|
|
|
|
self.signalMapper.mapped.connect(self.fitData)
|
|
|
|
|
|
|
|
# save fitted values
|
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
#self.ui.actionSave_FitResult.triggered.connect(self.saveFitResult)# replaced by menu
|
|
|
|
|
|
|
|
self.data = Data()
|
|
|
|
|
|
|
|
self.fit_boundary = pg.LinearRegionItem(brush=QColor(254,254,254,10))
|
2014-03-05 15:59:35 +00:00
|
|
|
self.ui.graphicsView.addItem(self.data.data_curve_imag)
|
|
|
|
self.ui.graphicsView.addItem(self.data.data_curve_real)
|
2014-03-05 17:30:00 +00:00
|
|
|
self.ui.graphicsView.addItem(self.data.fitted_curve_imag)
|
|
|
|
self.ui.graphicsView.addItem(self.data.fitted_curve_real)
|
2014-03-18 18:48:39 +00:00
|
|
|
|
|
|
|
# cross hair
|
|
|
|
if USE_CROSSH:
|
|
|
|
#self.poslabel = pg.LabelItem(justify='right')
|
|
|
|
self.horizontalLine = pg.InfiniteLine(angle=0)
|
|
|
|
self.verticalLine = pg.InfiniteLine(angle=90)
|
|
|
|
|
|
|
|
#self.ui.graphicsView.plotItem.addItem(self.poslabel)
|
|
|
|
self.ui.graphicsView.addItem(self.horizontalLine)
|
|
|
|
self.ui.graphicsView.addItem(self.verticalLine)
|
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
self.ui.graphicsView.addItem(self.fit_boundary)
|
|
|
|
self.ui.graphicsView.setLogMode(x=True, y=True)
|
|
|
|
self.ui.graphicsView.showGrid(x=True, y=True)
|
|
|
|
self.ui.graphicsView.setLabel("bottom","Frequency",units="Hz")
|
|
|
|
self.ui.graphicsView.setLabel("left", "Dielectric loss", units="Debye")
|
2014-03-18 18:48:39 +00:00
|
|
|
self.ui.graphicsView.disableAutoRange()
|
|
|
|
|
2014-03-19 18:48:15 +00:00
|
|
|
#self.peak_box_layout = QGridLayout()
|
|
|
|
#self.ui.scrollAreaWidgetContents.setLayout(self.peak_box_layout)
|
2014-03-18 18:48:39 +00:00
|
|
|
##self.huh = pg.SignalProxy(, slot=self.mPE)
|
|
|
|
sc = self.ui.graphicsView.scene()
|
|
|
|
sc.sigMouseClicked.connect(self.mousePress)
|
|
|
|
|
|
|
|
sc.sigMouseMoved.connect(self.updateCrosshair)
|
|
|
|
|
|
|
|
|
|
|
|
def updateCrosshair(self,evt):
|
|
|
|
vb = self.ui.graphicsView.getPlotItem().vb
|
|
|
|
pos = vb.mapSceneToView(evt)
|
|
|
|
self.last_pos = pos
|
|
|
|
if USE_CROSSH:
|
|
|
|
self.horizontalLine.setBounds([self.data.frequency.min(), self.data.frequency.max()])
|
|
|
|
self.horizontalLine.setPos(pos.y())
|
|
|
|
self.verticalLine.setPos(pos.x())
|
|
|
|
#self.poslabel.setText("<span style='font-size: 12pt'>f=%0.1f Hz <span style='color: red'>e=%0.1f</span>"\
|
|
|
|
# % (pos.x(),pos.y()))
|
|
|
|
|
|
|
|
def mousePress(self, evt):
|
|
|
|
vb = self.ui.graphicsView.getPlotItem().vb
|
|
|
|
data_pos = self.last_pos
|
|
|
|
|
|
|
|
if self.ui.actionAdd_Peak.isChecked() and not self.ui.actionAdd_Cond.isChecked():
|
|
|
|
self.addPeak(data_pos)
|
|
|
|
self.ui.actionAdd_Peak.setChecked(False)
|
|
|
|
if self.ui.actionAdd_Cond.isChecked() and not self.ui.actionAdd_Peak.isChecked():
|
|
|
|
self.addCond(data_pos)
|
|
|
|
self.ui.actionAdd_Cond.setChecked(False)
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2013-07-17 11:00:24 +00:00
|
|
|
def saveFitResult(self):
|
2013-07-10 16:36:07 +00:00
|
|
|
"""
|
|
|
|
Saving fit parameters to fitresults.log
|
|
|
|
including temperature
|
|
|
|
"""
|
2014-02-25 13:55:29 +00:00
|
|
|
self.saveFitFigure()
|
2013-06-14 06:44:34 +00:00
|
|
|
if not os.path.exists("fitresults.log"):
|
2013-07-10 16:36:07 +00:00
|
|
|
f = open("fitresults.log", "w")
|
2013-06-14 06:44:34 +00:00
|
|
|
else:
|
2013-07-10 16:36:07 +00:00
|
|
|
f = open("fitresults.log", "a")
|
2013-07-17 11:00:24 +00:00
|
|
|
# write header
|
2014-03-05 15:59:35 +00:00
|
|
|
f.write("#%7s"%('T'))
|
|
|
|
parfmt = "%8.2f" # T formatting
|
2013-07-17 11:00:24 +00:00
|
|
|
# if self.Conductivity != None: pass# always true
|
2014-03-05 15:59:35 +00:00
|
|
|
f.write("%9s%9s%9s " % ("e_s", "sig", "pow_sig"))
|
|
|
|
parfmt += "%9.3g%9.3g%9.2f " # conductivity formatting
|
2013-07-17 11:00:24 +00:00
|
|
|
for i, pb in enumerate(self.peakBoxes):
|
|
|
|
enum_peak = ("e_inf_%i" % i, "tau_%i" % i, "alpha_%i" % i, "beta_%i" % i)
|
2014-03-05 15:59:35 +00:00
|
|
|
f.write("%9s%9s%9s%9s " % enum_peak)
|
|
|
|
print enum_peak
|
|
|
|
parfmt += "%9.3g%9.3g%9.2f%9.2f" # peak formatting
|
|
|
|
f.write("fit_xlow fit_xhigh") # TODO: store limits
|
|
|
|
parfmt += "%9.3g%9.3g"
|
2013-07-17 11:00:24 +00:00
|
|
|
f.write('\n')
|
|
|
|
f.flush()
|
|
|
|
#f.write("%3.2f "%(self.data.meta["T"]))
|
2013-06-14 06:44:34 +00:00
|
|
|
pars = list(self.fitresult)
|
2013-07-10 16:36:07 +00:00
|
|
|
pars.insert(0, self.data.meta["T"])
|
2014-03-05 15:59:35 +00:00
|
|
|
pars.append(self.data.fit_limits[0])
|
|
|
|
pars.append(self.data.fit_limits[1])
|
2013-07-17 11:00:24 +00:00
|
|
|
N.savetxt(f, N.array([pars, ]), fmt=parfmt, delimiter=" ")
|
2013-06-14 06:44:34 +00:00
|
|
|
f.close()
|
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
def saveFitFigure(self):
|
2014-03-05 15:59:35 +00:00
|
|
|
fig = pyplot.figure(figsize=(3.54, 2.75))
|
2014-02-25 13:55:29 +00:00
|
|
|
font = {'family' : 'sans serif',
|
|
|
|
'weight' : 'normal',
|
2014-03-05 15:59:35 +00:00
|
|
|
'size' : 8}
|
2014-02-25 13:55:29 +00:00
|
|
|
|
|
|
|
matplotlib.rc('font', **font)
|
2014-03-05 15:59:35 +00:00
|
|
|
|
|
|
|
pyplot.loglog(self.data.frequency, self.data.epsilon.imag, 'bo', markersize=3, label="Data")
|
|
|
|
pyplot.loglog(self.data.frequency, self.data.epsilon_fit, 'r-', lw=1, label="Fit")
|
2014-02-25 13:55:29 +00:00
|
|
|
|
|
|
|
for i,peak in enumerate(self.peakBoxes):
|
|
|
|
f,eps = peak.get_data()
|
|
|
|
color = hex2color(str(peak.get_color().name()))
|
2014-03-05 15:59:35 +00:00
|
|
|
pyplot.loglog(f,eps, ls="--", color=color , lw=0.75, label="Peak %i"%i)
|
2014-02-25 13:55:29 +00:00
|
|
|
|
|
|
|
if self.Conductivity != None:
|
|
|
|
f,eps = self.Conductivity.get_conductivity()
|
|
|
|
color = hex2color(str(self.Conductivity.get_color().name()))
|
2014-03-05 15:59:35 +00:00
|
|
|
pyplot.loglog(f,eps, ls="-.", color=color, lw=0.75, label="Cond.")
|
2014-02-25 13:55:29 +00:00
|
|
|
f,eps = self.Conductivity.get_epsilon_static()
|
2014-03-05 15:59:35 +00:00
|
|
|
pyplot.loglog(f,eps, ls=":", color=color, lw=0.75, label=r'$\epsilon_0$')
|
2014-02-25 13:55:29 +00:00
|
|
|
|
2014-03-05 15:59:35 +00:00
|
|
|
for i in (0,1): pyplot.axvline(x=self.data.fit_limits[i], color='g', ls="--")
|
|
|
|
pyplot.legend(title = "T=%.1f K"%(self.data.meta["T"]))
|
2014-02-25 13:55:29 +00:00
|
|
|
pyplot.grid()
|
|
|
|
pyplot.xlabel('f/Hz')
|
|
|
|
pyplot.ylabel('eps"')
|
2014-03-05 15:59:35 +00:00
|
|
|
pyplot.savefig(os.path.splitext(self.filepath)[0]+".png")
|
2014-02-25 13:55:29 +00:00
|
|
|
fig.clear()
|
|
|
|
|
2013-07-10 16:36:07 +00:00
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
def addCond(self, pos):
|
2014-03-19 18:48:15 +00:00
|
|
|
win = self.parameterWidget
|
|
|
|
win.setWindowFlags(win.windowFlags() | Qt.WindowStaysOnTopHint)
|
2013-06-14 06:44:34 +00:00
|
|
|
if self.Conductivity != None:
|
|
|
|
return
|
|
|
|
self.statusBar().showMessage("Click on graph")
|
2014-02-25 13:55:29 +00:00
|
|
|
self.Conductivity = Conductivity(mpl=self.ui.graphicsView, limits=self.data.fit_limits)
|
2013-06-14 06:44:34 +00:00
|
|
|
self.Conductivity.changedData.connect(self.updatePlot)
|
2014-03-19 18:48:15 +00:00
|
|
|
#print pos.x(), pos.y(),"test", 10**pos.x(),10**pos.y()
|
|
|
|
cond_par = [0, 10**(pos.y() + pos.x())*2*N.pi , 1.0]
|
|
|
|
self.Conductivity.setParameter(beta=cond_par)
|
|
|
|
self.parameterWidget.vlayout.insertWidget(1,self.Conductivity.widget)
|
2013-06-14 06:44:34 +00:00
|
|
|
self.Conductivity.widget.ui.removeButton.clicked.connect(self.delCond)
|
2014-03-19 18:48:15 +00:00
|
|
|
self.parameterWidget.vlayout.update()
|
|
|
|
self.parameterWidget.showNormal()
|
|
|
|
self.parameterWidget.raise_()
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
def delCond(self):
|
|
|
|
self.cond_param = None
|
|
|
|
self.cond = None
|
2014-02-25 13:55:29 +00:00
|
|
|
self.ui.graphicsView.removeItem(self.Conductivity.mpl_line)
|
|
|
|
self.ui.graphicsView.removeItem(self.Conductivity.mpl_line_static)
|
2013-06-14 06:44:34 +00:00
|
|
|
del self.Conductivity
|
|
|
|
self.Conductivity = None
|
|
|
|
self.updatePlot()
|
|
|
|
|
|
|
|
|
|
|
|
def addPeak(self, pos):
|
2014-03-19 18:48:15 +00:00
|
|
|
|
|
|
|
win = self.parameterWidget
|
|
|
|
win.setWindowFlags(win.windowFlags() | Qt.WindowStaysOnTopHint)
|
|
|
|
id_list = [ self.peakBoxes[key] for key in self.peakBoxes.keys()]
|
|
|
|
self.peakId = 1
|
|
|
|
while self.peakId in id_list:
|
|
|
|
self.peakId += 1
|
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
self.statusBar().showMessage("Select Peak Position")
|
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
peak = Peak(id=self.peakId, mpl=self.ui.graphicsView, limits=self.data.fit_limits)
|
2013-06-14 06:44:34 +00:00
|
|
|
# connect to delPeak
|
|
|
|
peak.widget.ui.removeButton.clicked.connect(self.delPeak)
|
2014-03-19 18:48:15 +00:00
|
|
|
#peak.widget.ui.removeButton.clicked.connect(self.delPeak)
|
2013-06-14 06:44:34 +00:00
|
|
|
peak.changedData.connect(self.updatePlot)
|
2014-03-19 18:48:15 +00:00
|
|
|
# delta_eps=(10**pos.y())*2, tau=1 / (2*N.pi*10**pos.x()), a=1, b=1
|
|
|
|
new_peak = [2*10**pos.y(), 1 / (2*N.pi*10**pos.x()), 1, 1]
|
|
|
|
peak.setParameter(beta = new_peak)
|
|
|
|
|
|
|
|
self.peakBoxes[peak] = self.peakId
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
for i,pb in enumerate(self.peakBoxes.keys()):
|
2014-03-19 18:48:15 +00:00
|
|
|
self.parameterWidget.vlayout.insertWidget(1,pb.widget)
|
|
|
|
self.parameterWidget.vlayout.update()
|
|
|
|
self.parameterWidget.showNormal()
|
|
|
|
self.parameterWidget.raise_()
|
2013-07-10 16:36:07 +00:00
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
def delPeak(self):
|
2013-07-10 16:36:07 +00:00
|
|
|
for i, peak in enumerate(self.peakBoxes.keys()):
|
2013-06-14 06:44:34 +00:00
|
|
|
if peak.widget.isHidden():
|
2014-02-25 13:55:29 +00:00
|
|
|
self.ui.graphicsView.removeItem(peak.mpl_line)
|
2014-03-19 18:48:15 +00:00
|
|
|
self.parameterWidget.vlayout.removeWidget(peak.widget)
|
|
|
|
self.peakBoxes.pop(peak)
|
|
|
|
self.parameterWidget.vlayout.update()
|
2013-06-14 06:44:34 +00:00
|
|
|
self.updatePlot()
|
|
|
|
|
|
|
|
def fitData(self, method):
|
|
|
|
if self.Conductivity != None:
|
|
|
|
start_parameter = list(self.Conductivity.getParameter())
|
2013-07-10 16:36:07 +00:00
|
|
|
fixed_params = [i for i in self.Conductivity.getFixed()]
|
2013-06-14 06:44:34 +00:00
|
|
|
else:
|
2013-07-10 16:36:07 +00:00
|
|
|
start_parameter = [0, 0, 1]
|
|
|
|
fixed_params = [0, 0, 0]
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
for pb in self.peakBoxes.keys():
|
2013-07-10 16:36:07 +00:00
|
|
|
[start_parameter.append(i) for i in pb.getParameter()]
|
|
|
|
[fixed_params.append(i) for i in pb.getFixed()]
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-03-05 15:59:35 +00:00
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
log10fmin, log10fmax = self.fit_boundary.getRegion()
|
2014-03-05 15:59:35 +00:00
|
|
|
self.data.set_fit_xlimits(10**log10fmin, 10**log10fmax)
|
2014-03-19 18:48:15 +00:00
|
|
|
fit_methods = [fit_odr_cmplx, fit_lbfgsb, fit_anneal]
|
2013-07-10 16:36:07 +00:00
|
|
|
print "StartParameter", start_parameter
|
|
|
|
print "FixedParameter", fixed_params
|
2013-06-14 06:44:34 +00:00
|
|
|
print "Limits (xmin, xmax, ymin, ymax)", self.data.fit_limits
|
|
|
|
_freq, _fit = self.data.get_data()
|
2014-03-19 18:48:15 +00:00
|
|
|
|
|
|
|
# build function list
|
|
|
|
funcs = ["static","power"] if self.Conductivity != None else []
|
|
|
|
for pb in self.peakBoxes.keys():
|
|
|
|
funcs.append("hn")
|
|
|
|
newres = fit_methods[method](_freq, _fit, start_parameter, fixed_params, funcs)
|
|
|
|
print "Set fit data"
|
|
|
|
self.data.set_fit(newres.beta, funcs)
|
|
|
|
self.ui.statusbar.showMessage(" ".join(newres.stopreason))
|
|
|
|
result = newres.beta
|
2014-03-05 15:59:35 +00:00
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
self.fitresult = result
|
2013-07-10 16:36:07 +00:00
|
|
|
for i, pb in enumerate(self.peakBoxes.keys()):
|
2014-03-19 18:48:15 +00:00
|
|
|
beta_peak = newres.beta [3 + i*4 : 3 + (i + 1)*4]
|
|
|
|
sd_beta_peak = newres.sd_beta[3 + i*4 : 3 + (i + 1)*4]
|
|
|
|
pb.setParameter(beta = beta_peak, sd_beta = sd_beta_peak)
|
2013-06-14 06:44:34 +00:00
|
|
|
if self.Conductivity != None:
|
2014-03-19 18:48:15 +00:00
|
|
|
self.Conductivity.setParameter(beta = newres.beta[:3], sd_beta = newres.sd_beta[:3])
|
2013-07-10 16:36:07 +00:00
|
|
|
#print "*** FIT RESULTS ***"
|
|
|
|
#print u"\u03c3"
|
|
|
|
#print u"\u0394\u03b5"
|
2013-06-14 06:44:34 +00:00
|
|
|
self.updatePlot()
|
2013-07-10 16:36:07 +00:00
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
def openFile(self):
|
2014-03-18 18:48:39 +00:00
|
|
|
#path = unicode(QFileDialog.getOpenFileName(self, "Open file"))
|
|
|
|
path = "MCM42PG0_199.96K.dat"
|
2014-03-05 15:59:35 +00:00
|
|
|
self.filepath=path
|
2014-03-18 18:48:39 +00:00
|
|
|
# TODO analyize file (LF,MF, HF) and act accordingly
|
2013-06-14 06:44:34 +00:00
|
|
|
data = N.loadtxt(path, skiprows=4)
|
2014-02-25 13:55:29 +00:00
|
|
|
self.setWindowTitle(os.path.basename(path))
|
2013-06-14 06:44:34 +00:00
|
|
|
numpat = re.compile('\d+\.\d+')
|
|
|
|
try:
|
2013-07-10 16:36:07 +00:00
|
|
|
Temp = None
|
2013-06-14 06:44:34 +00:00
|
|
|
for line in open(path).readlines():
|
|
|
|
if re.search("Fixed", line) or re.search("Temp", line):
|
2013-07-10 16:36:07 +00:00
|
|
|
print "Found line with Fixed or Temp"
|
2013-06-14 06:44:34 +00:00
|
|
|
Temp = float(re.search(numpat, line).group())
|
2013-07-10 16:36:07 +00:00
|
|
|
print "Temperature found in file:", Temp
|
2013-06-14 06:44:34 +00:00
|
|
|
break
|
2013-07-10 16:36:07 +00:00
|
|
|
if Temp == None: raise ValueError
|
2013-06-14 06:44:34 +00:00
|
|
|
except:
|
2013-07-10 16:36:07 +00:00
|
|
|
Temp = QInputDialog.getDouble(self, "No temperature found in data set", "Temperature/K:", value=0.00)[0]
|
|
|
|
# mask the data to values > 0 (loglog plot)
|
|
|
|
mask = (data[:, 1] > 0) & (data[:, 2] > 0) #& (data[:,2]>1e-3) & (data[:,0] > 1e-2)
|
|
|
|
_freq = data[mask, 0]
|
|
|
|
_die_stor = data[mask, 1]
|
|
|
|
_die_loss = data[mask, 2]
|
2014-02-25 13:55:29 +00:00
|
|
|
self.data.set_data(_freq, _die_stor, _die_loss)
|
2013-07-10 16:36:07 +00:00
|
|
|
self.data.meta["T"] = Temp
|
2014-02-25 13:55:29 +00:00
|
|
|
self.fit_boundary.setRegion([N.log10(_freq.min()), N.log10(_freq.max())])
|
2014-03-18 18:48:39 +00:00
|
|
|
self.ui.graphicsView.enableAutoRange()
|
2013-06-14 06:44:34 +00:00
|
|
|
self.updatePlot()
|
2014-03-18 18:48:39 +00:00
|
|
|
self.ui.graphicsView.disableAutoRange()
|
2013-06-14 06:44:34 +00:00
|
|
|
|
2014-02-25 13:55:29 +00:00
|
|
|
|
2013-06-14 06:44:34 +00:00
|
|
|
def updatePlot(self):
|
2014-03-05 17:30:00 +00:00
|
|
|
|
2014-03-18 18:48:39 +00:00
|
|
|
# assemble fit function
|
|
|
|
funcs = ["static", "power"]
|
|
|
|
p0 = self.Conductivity.getParameter() if self.Conductivity is not None else [0.0, 0.0, 1.0]
|
2014-03-05 17:30:00 +00:00
|
|
|
for peak in self.peakBoxes.keys():
|
|
|
|
params = peak.getParameter()
|
|
|
|
p0.extend(params)
|
|
|
|
funcs.append("hn")
|
|
|
|
|
2014-03-18 18:48:39 +00:00
|
|
|
# calculate fit
|
2014-03-05 17:30:00 +00:00
|
|
|
self.data.set_fit(p0, funcs)
|
2014-03-18 18:48:39 +00:00
|
|
|
|
|
|
|
# replot data and fit, TODO: replot only if data changed
|
2014-03-05 17:30:00 +00:00
|
|
|
self.data.data_curve_real.setData(self.data.frequency, self.data.epsilon.real)
|
2014-03-18 18:48:39 +00:00
|
|
|
self.data.data_curve_imag.setData(self.data.frequency, self.data.epsilon.imag)
|
2014-03-05 17:30:00 +00:00
|
|
|
if len(self.peakBoxes) > 0 or self.Conductivity != None:
|
2014-03-18 18:48:39 +00:00
|
|
|
self.data.fitted_curve_real.setData(self.data.frequency, self.data.epsilon_fit.real)
|
|
|
|
self.data.fitted_curve_imag.setData(self.data.frequency, self.data.epsilon_fit.imag)
|
2014-02-25 13:55:29 +00:00
|
|
|
|
|
|
|
def sigint_handler(*args):
|
|
|
|
"""Handler for the SIGINT signal (CTRL + C).
|
|
|
|
"""
|
|
|
|
sys.stderr.write('\r')
|
|
|
|
if QMessageBox.question(None, '', "Are you sure you want to quit?",
|
|
|
|
QMessageBox.Yes | QMessageBox.No,
|
2014-03-18 18:48:39 +00:00
|
|
|
QMessageBox.Yes) == QMessageBox.Yes:
|
2014-02-25 13:55:29 +00:00
|
|
|
QApplication.quit()
|
2013-06-14 06:44:34 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
signal.signal(signal.SIGINT, sigint_handler)
|
|
|
|
app = QApplication(sys.argv)
|
|
|
|
timer = QTimer()
|
|
|
|
timer.start(1000) # Check every second for Strg-c on Cmd line
|
|
|
|
timer.timeout.connect(lambda: None)
|
|
|
|
main = AppWindow()
|
|
|
|
main.showMaximized()
|
|
|
|
main.raise_()
|
|
|
|
sys.exit(app.exec_())
|