summaryrefslogtreecommitdiff
path: root/Bin_Phase_env.py
diff options
context:
space:
mode:
authorPriyam Nayak2020-10-05 11:17:04 +0530
committerGitHub2020-10-05 11:17:04 +0530
commitb790cb7e0940e859578d7e85aadc962c07570793 (patch)
treeaf3894fbbb0594294620241639679c433858bd89 /Bin_Phase_env.py
parentb31cf75d9362412e755fce76f61d73eab1e7da14 (diff)
parentcefac083d8a23787a1c1792a0d87ca08637fd3c4 (diff)
downloadChemical-Simulator-GUI-b790cb7e0940e859578d7e85aadc962c07570793.tar.gz
Chemical-Simulator-GUI-b790cb7e0940e859578d7e85aadc962c07570793.tar.bz2
Chemical-Simulator-GUI-b790cb7e0940e859578d7e85aadc962c07570793.zip
Merge pull request #8 from pravindalve/master
Partial fix for issue #5 and issue #7, requirements.txt added
Diffstat (limited to 'Bin_Phase_env.py')
-rw-r--r--Bin_Phase_env.py68
1 files changed, 11 insertions, 57 deletions
diff --git a/Bin_Phase_env.py b/Bin_Phase_env.py
index a63ba1c..d9975fe 100644
--- a/Bin_Phase_env.py
+++ b/Bin_Phase_env.py
@@ -4,16 +4,16 @@ import numpy as np
import os
import csv
from subprocess import Popen, PIPE
+
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
-from PyQt5.QtGui import QTextDocument ,QTextCursor ,QTextCharFormat ,QFont ,QPixmap
-from PyQt5.uic import loadUiType
-from PyQt5.QtCore import Qt
-#import PyQt5.QtGuiApplication
from PyQt5.QtGui import *
import PyQt5.QtGui as QtGui
import PyQt5.QtCore as QtCore
import PyQt5.QtWidgets as QtWidgets
+from PyQt5.uic import loadUiType
+
+
import pyqtgraph as pg
import pyqtgraph.exporters
@@ -65,7 +65,6 @@ class BinPhaseEnv(QWidget,ui_dialog):
self.points = QLineEdit()
self.points.setText("40")
self.formLayout.addRow(QLabel("Number of data points"),self.points)
- #print("T-XY")
def P_xy(self):
self.radioButton_2.setChecked(True)
@@ -81,7 +80,6 @@ class BinPhaseEnv(QWidget,ui_dialog):
self.points.setText("40")
self.formLayout.addRow(QLabel("T(K)"),self.first)
self.formLayout.addRow(QLabel("Number of data points"),self.points)
- #print("")
def get_omc_path(self):
try:
@@ -97,9 +95,7 @@ class BinPhaseEnv(QWidget,ui_dialog):
print("The OpenModelica compiler is missing in the System path please install it" )
raise
- def plot(self):
- #print(self.type)
-
+ def plot(self):
try:
val = int(self.first.text(),10)
except:
@@ -120,12 +116,6 @@ class BinPhaseEnv(QWidget,ui_dialog):
self.comp2 = self.comboBox_2.currentText()
self.thermoPack = self.comboBox_3.currentText()
- # print(val)
- # print(data_points)
- # print(self.comp1)
- # print(self.comp2)
- # print(self.thermoPack)
-
self.data.append("model Graph\n")
self.data.append("import data = Simulator.Files.Chemsep_Database;\n")
self.data.append("parameter data."+self.comp1+" comp1;\n")
@@ -144,8 +134,6 @@ class BinPhaseEnv(QWidget,ui_dialog):
mosFile.write("loadFile(\"Graph.mo\");\n")
mosFile.write("simulate(Graph, outputFormat=\"csv\", stopTime=1.0, numberOfIntervals=1);\n")
- print(self.data)
-
self.resdata = []
self.omc_path = self.get_omc_path()
simpath = self.plot_mos_path
@@ -164,62 +152,43 @@ class BinPhaseEnv(QWidget,ui_dialog):
self.rows = []
with open (csvpath,'r') as resultFile:
- self.resdata = []
- print("opened")
- csvreader = csv.reader(resultFile,delimiter=',')
- for row in csvreader:
- print("124125")
- self.resdata.append(row)
- self.rows.append(row)
-
- print("SIMULATION DONE")
+ self.resdata = []
+ csvreader = csv.reader(resultFile,delimiter=',')
+ for row in csvreader:
+ self.resdata.append(row)
+ self.rows.append(row)
if self.type=='T':
for k in range(len(self.rows[0])):
if self.rows[0][k][0]=='P':
self.datay.append(float(self.rows[1][k]))
- #print(col)
length = len(self.rows[0][k])
if self.rows[0][k][0]=='x' and self.rows[0][k][length-2]=='1':
self.datax1.append(float(self.rows[1][k]))
- # k+=1
if self.rows[0][k][0]=='y' and self.rows[0][k][length-2]=='1':
self.datax2.append(float(self.rows[1][k]))
- #k+=1
- #k+=1
else:
for k in range(len(self.rows[0])):
if self.rows[0][k][0]=='T':
self.datay.append(float(self.rows[1][k]))
- #print(col)
- #print(self.rows[0][k])
length = len(self.rows[0][k])
if self.rows[0][k][0]=='x' and self.rows[0][k][length-2]=='1':
-
self.datax1.append(float(self.rows[1][k]))
- # k+=1
if self.rows[0][k][0]=='y' and self.rows[0][k][length-2]=='1':
self.datax2.append(float(self.rows[1][k]))
- #k+=1
plt = pg.PlotWidget()
plt.showGrid(x=True,y=True)
plt.addLegend()
plt.setXRange(0,1)
- # print("SIZE UP AHEAD")
- # print(len(self.datay))
- # print(len(self.datax1))
- # print(len(self.datax2))
- # print("SIZES DONE")
c1 = plt.plot(self.datax1, self.datay,pen=pg.mkPen('b',width = 1), name='dew points')
c2 = plt.plot(self.datax2, self.datay,pen=pg.mkPen('r',width = 1), name='bubble points')
view_box = plt.plotItem.vb
self.tool_tip = ""
def press_event(evt):
- #print("HELLO")
a = 10
pos = evt
mousepoint = view_box.mapSceneToView(pos)
@@ -229,7 +198,6 @@ class BinPhaseEnv(QWidget,ui_dialog):
screen = QGuiApplication.primaryScreen()
image = screen.grabWindow(QApplication.desktop().winId()).toImage()
colour = QtGui.QColor(image.pixel(find_color.x(),find_color.y()))
- #print("red:{}, green:{}, blue:{}".format(colour.red(),colour.green(),colour.blue()))
if colour.red()==255 or colour.blue()==255:
self.lineEdit_x.setText(str(round(mousepoint.x(),3)))
@@ -242,31 +210,17 @@ class BinPhaseEnv(QWidget,ui_dialog):
self.tool_tip = ""
QApplication.setOverrideCursor(QCursor(QtCore.Qt.ArrowCursor))
- #self.prev = None
def entered(items):
for i in items:
- #print(i.__class__.__name__)
if i.__class__.__name__ =="LegendItem":
self.lineEdit_x.setText("")
self.lineEdit_y.setText("")
QApplication.setOverrideCursor(QCursor(QtCore.Qt.ArrowCursor))
else:
i.setToolTip(self.tool_tip)
- # print(items)
- #proxy = pg.SignalProxy(plt.scene().sigMouseMoved, rateLimit = 60, slot = press_event)
+
plt.scene().sigMouseMoved.connect(press_event)
plt.scene().sigMouseHover.connect(entered)
- #c1.setAcceptHoverEvents(True)
- #c2.setAcceptHoverEvents(True)
-
- # def hoverEnterEvent(c1,event):
- # print("Object ZONE")
-
- # def hoverEnterEvent(c2,event):
- # print("Object ZONE")
-
- #c1.hoverMoveEvent.connect(item)
- #c2.hoverMoveEvent.connect(item)
plt.setLabel('left',self.other+self.otherunit,units = '')
plt.setLabel('bottom',self.comp1+'(mol. frac.)',units = '')