summaryrefslogtreecommitdiff
path: root/DockWidgets/DockWidgetDistillationColumn.py
diff options
context:
space:
mode:
Diffstat (limited to 'DockWidgets/DockWidgetDistillationColumn.py')
-rw-r--r--DockWidgets/DockWidgetDistillationColumn.py385
1 files changed, 0 insertions, 385 deletions
diff --git a/DockWidgets/DockWidgetDistillationColumn.py b/DockWidgets/DockWidgetDistillationColumn.py
deleted file mode 100644
index 07cd5ba..0000000
--- a/DockWidgets/DockWidgetDistillationColumn.py
+++ /dev/null
@@ -1,385 +0,0 @@
-import os, sys
-
-from PyQt5.QtCore import *
-from PyQt5.QtWidgets import *
-from PyQt5.QtGui import *
-from PyQt5.uic import loadUiType
-import pandas as pd
-from functools import partial
-from collections import defaultdict
-
-from ComponentSelector import *
-from DockWidgets.DistillationColumnStagewiseResults import DistillationColumnStagewiseResults
-from Graphics import *
-
-ui_dialog,_ = loadUiType('DockWidgets/DockWidgetDistillationColumn.ui')
-
-
-class DockWidgetDistillationColumn(QDockWidget, ui_dialog):
-
- def __init__(self,name,comptype,obj,container,parent=None):
- QDockWidget.__init__(self,parent)
- self.setupUi(self)
- self.setWindowTitle(obj.name)
- self.name=name
- self.obj=obj
- self.type = comptype
- self.input_dict = []
- self.pushButton_2.clicked.connect(self.param)
- self.dict = []
- self.input_params_list()
- self.name_type = None
- self.container = container
- self.stage_res_table = DistillationColumnStagewiseResults()
- self.stageResultsButton.clicked.connect(self.showStagewiseResults)
-
- # input data tab
-
- def input_params_list(self):
- try:
- print("input_params_list ", self.input_dict)
-
- # tab 1
-
- l1 = QLineEdit()
- l1.setFixedWidth(80)
- l1.setText(str(self.obj.variables['Nt']['value']))
- self.lay1.addWidget(QLabel(self.obj.variables['Nt']['name'] + " :"), 0 ,0, alignment=Qt.AlignLeft)
- self.lay1.addWidget(l1,0,1, alignment=Qt.AlignLeft)
- self.input_dict.append(l1)
-
- for i in range(self.obj.variables['Ni']['value']):
- print(i)
- l = QLineEdit()
- l.setFixedWidth(80)
- if len(self.obj.variables['InT_s']['value']) is not 0:
- l.setText(str(self.obj.variables['InT_s']['value'][i]))
- self.lay1.addWidget(QLabel(self.obj.variables['InT_s']['name'] +" " + str(i+1) + " location :"),2*(i+1),0, alignment=Qt.AlignLeft)
- self.lay1.addWidget(l,2*(i+1),1, alignment=Qt.AlignLeft)
- self.input_dict.append(l)
-
- # tab 2
- self.l4.setText(self.obj.variables['Ctype']['name']+":")
-
- self.u1.setText(self.obj.variables['Ctype']['unit'])
- self.l5.setText(self.obj.variables['Pcond']['name']+":")
- self.le5.setText(str(self.obj.variables['Pcond']['value']))
- self.u2.setText(self.obj.variables['Pcond']['unit'])
- self.l6.setText(self.obj.variables['C_Spec']['name']+":")
- self.le6.setText(str(self.obj.variables['C_Spec']['value']))
- self.l7.setText("Compounds :")
-
- self.cb5.addItem("Total")
- self.cb5.addItem("Partial")
- self.cb5.setCurrentText(self.obj.variables['Ctype']['value'])
-
- for j in self.obj.Cspec_list:
- self.cb1.addItem(str(j))
- self.cb1.setCurrentText(self.obj.variables['C_Spec']['type'])
- for j in self.obj.compounds:
- self.cb2.addItem(str(j))
- self.cb2.setCurrentText(self.obj.variables['C_Spec']['comp'])
-
- self.cb2.setDisabled(True)
- self.cb1.currentIndexChanged.connect(self.fun2)
-
- self.le5.setFixedWidth(80)
- self.le6.setFixedWidth(80)
- self.le7.setFixedWidth(80)
- self.le8.setFixedWidth(80)
- self.cb1.setFixedWidth(180)
- self.cb2.setFixedWidth(80)
- self.cb3.setFixedWidth(180)
- self.cb4.setFixedWidth(80)
- self.cb5.setFixedWidth(80)
- self.u2.setAlignment(Qt.AlignLeft)
- self.u3.setAlignment(Qt.AlignLeft)
-
- self.input_dict.append(self.cb5)
- self.input_dict.append(self.le5)
- self.input_dict.append(self.cb1)
- self.input_dict.append(self.cb2)
- self.input_dict.append(self.le6)
-
- # tab3
- self.l8.setText(self.obj.variables['Preb']['name']+":")
- self.le7.setText(str(self.obj.variables['Preb']['value']))
- self.u3.setText(self.obj.variables['Preb']['unit'])
- self.l9.setText(self.obj.variables['R_Spec']['name']+":")
- self.le8.setText(str(self.obj.variables['R_Spec']['value']))
- self.l10.setText('Compounds')
-
- for j in self.obj.Rspec_list:
- self.cb3.addItem(str(j))
- self.cb3.setCurrentText(self.obj.variables['R_Spec']['type'])
- for j in self.obj.compounds:
- self.cb4.addItem(str(j))
- self.cb4.setCurrentText(self.obj.variables['R_Spec']['comp'])
- self.cb4.setDisabled(True)
- self.cb3.currentIndexChanged.connect(self.fun3)
-
- self.input_dict.append(self.le7)
- self.input_dict.append(self.cb3)
- self.input_dict.append(self.cb4)
- self.input_dict.append(self.le8)
-
- self.lines = [line.rstrip('\n') for line in open('thermopackage.txt')]
- for j in self.lines:
- self.cbTP.addItem(str(j))
- self.cbTP.setCurrentText(self.obj.variables['thermo_package']['value'])
-
- self.input_dict.append(self.cbTP)
-
- # self.input_dict = [self.le1, self.le2, self.le3, self.cb5, self.le5, self.cb1, self.cb2, self.le6, self.le7, self.cb3, self.cb4, self.le8]
-
- except Exception as e:
- print(e)
-
- def update_compounds(self):
- self.cb2.clear()
- self.cb4.clear()
- for j in self.obj.compounds:
- self.cb2.addItem(str(j))
- self.cb2.setCurrentText(self.obj.variables['C_Spec']['comp'])
- for j in self.obj.compounds:
- self.cb4.addItem(str(j))
- self.cb4.setCurrentText(self.obj.variables['R_Spec']['comp'])
-
- def fun2(self):
- if self.cb1.currentText() == 'Compound Molar Fraction' or self.cb1.currentText() == 'Compound Molar Flow (mol/s)':
- self.cb2.setDisabled(False)
- else:
- self.cb2.setDisabled(True)
-
- def fun3(self):
- if self.cb3.currentText() == 'Compound Molar Fraction' or self.cb3.currentText() == 'Compound Molar Flow (mol/s)':
- self.cb4.setDisabled(False)
- else:
- self.cb4.setDisabled(True)
-
- def Show_Error(self):
- QMessageBox.about(self, 'Important', "Please fill all fields with data")
-
- def param(self):
- try:
- self.dict= []
- temp = 0
- print("param.input_dict ", self.input_dict)
- self.dict.append(int(self.input_dict[0].text()))
-
- for i in range(self.obj.variables['Ni']['value']):
- self.dict.append(int(self.input_dict[i+1].text()))
- temp = i + 1
- print(temp)
-
- # print(temp)
- # print(self.input_dict[temp+1])
- self.dict.append(self.input_dict[temp+1].currentText())
- # print(temp+1)
- self.dict.append(int(self.input_dict[temp+2].text()))
- #print(temp+2)
- self.dict.append(self.input_dict[temp+3].currentText())
- #print(temp+3)
- self.dict.append(self.input_dict[temp+4].currentText())
- #print(temp+4)
- self.dict.append(int(self.input_dict[temp+5].text()))
- #print(temp+5)
- self.dict.append(int(self.input_dict[temp+6].text()))
- #print(temp+6)
- self.dict.append(self.input_dict[temp+7].currentText())
- #print(temp+7)
- self.dict.append(self.input_dict[temp+8].currentText())
- #print(temp+8)
- self.dict.append(int(self.input_dict[temp+9].text()))
- #print(temp+9)
- self.dict.append(self.input_dict[temp+10].currentText())
- #print(temp + 10)
-
- #print("param ", self.dict)
- self.obj.param_setter(self.dict)
- if(self.isVisible()):
- currentVal = self.parent().container.graphics.graphicsView.horizontalScrollBar().value()
- self.parent().container.graphics.graphicsView.horizontalScrollBar().setValue(currentVal-189)
- self.hide()
-
- except Exception as e:
- print(e)
-
- def showStagewiseResults(self):
- self.stage_res_table.show()
-
- @staticmethod
- def showResult(lst):
- # DockWidget1.flag = True
- for i in lst:
- try:
- i.results_category(i.name)
- except AttributeError:
- pass
-
- def clear_results(self):
- self.tableWidget.setRowCount(0)
- self.stage_res_table.T_table.setRowCount(0)
- self.stage_res_table.T_table.setColumnCount(0)
- self.stage_res_table.x_pc_table.setRowCount(0)
- self.stage_res_table.x_pc_table.setColumnCount(0)
-
- # result data tab
- def results_category(self,name):
- flag = True
- try:
- #print("Under result category name ", name)
- result = self.container.result
- obj = self.container.fetch_object(name)
- self.tableWidget.setRowCount(0)
- variKeys = obj.result_parameters
- #print(variKeys)
- for i, val in enumerate(variKeys):
- propertyname = name + '.' + val
- #print(i, val, propertyname)
- if propertyname in result[0]:
- ind = result[0].index(propertyname)
- resultval = str(result[-1][ind])
- obj.variables[val]['value'] = result[-1][ind]
- #print("######Resultsfetch####", val, resultval)
- rowPosition = self.tableWidget.rowCount()
- self.tableWidget.insertRow(rowPosition)
- self.tableWidget.setItem(rowPosition, 0, QTableWidgetItem(obj.variables[val]['name']))
- self.tableWidget.setItem(rowPosition, 1, QTableWidgetItem(resultval))
- self.tableWidget.setItem(rowPosition, 2, QTableWidgetItem(obj.variables[val]['unit']))
- self.tableWidget.resizeColumnsToContents()
-
- # Stagewise Results
- Nt = self.obj.variables['Nt']['value']
- Nc = len(self.obj.compounds)
- # initializing temporary arrays
- Stages_T = [None for i in range(Nt)]
- # Can be uncommented when F_p and F_pc implemented in modelica table
- # Stages_F_p = [[None for i in range(3)] for j in range(Nt)]
- # Stages_F_pc = [[[None for i in range(3)] for j in range(Nc)] for k in range(Nt)]
- Stages_x_pc = [[[None for i in range(3)] for j in range(Nc)] for k in range(Nt)]
-
- Stages_res_varikeys = ['T']
- for i in range(Nc):
- for j in range(3):
- Stages_res_varikeys.append('x_pc[' + str(j + 1) + ',' + str(i + 1) + ']')
-
- for v in Stages_res_varikeys:
- propertyname = name + '.condenser.' + v
- if propertyname in result[0]:
- ind = result[0].index(propertyname)
- if v == 'T':
- Stages_T[0] = result[-1][ind]
- # Can be uncommented when F_p is implemented in modelica model
- # elif v == 'F_p':
- # if result[0][ind][result[0][ind].index('[') + 1] == '1':
- # Stages_F_p[0][0] = result[-1][ind]
- # elif result[0][ind][result[0][ind].index('[') + 1] == '2':
- # Stages_F_p[0][1] = result[-1][ind]
- # else:
- # Stages_F_p[0][2] = result[-1][ind]
- else:
- #print(ind)
- phase_no = int(result[0][ind][result[0][ind].index('[') + 1])
- comp_no = int(result[0][ind][result[0][ind].index(']') - 1])
- Stages_x_pc[0][comp_no - 1][phase_no - 1] = result[-1][ind]
- # Can be uncommented and improved when F_pc implemented in modelica model
- # if v == 'F_pc':
- # Stages_F_pc[0][comp_no - 1][phase_no - 1] = result[-1][ind]
- # else:
- # Stages_x_pc[0][comp_no - 1][phase_no - 1] = result[-1][ind]
-
- for i in range(1, Nt - 1):
- propertyname = name + '.tray[' + str(i) + '].' + v
- if propertyname in result[0]:
- ind = result[0].index(propertyname)
- if v == 'T':
- Stages_T[i] = result[-1][ind]
- # Can be uncommented when F_p implemented in modelica model
- # elif v == 'F_p':
- # if result[0][ind][result[0][ind].index('[') + 1] == '1':
- # Stages_F_p[i][0] = result[-1][ind]
- # elif result[0][ind][result[0][ind].index('[') + 1] == '2':
- # Stages_F_p[i][1] = result[-1][ind]
- # else:
- # Stages_F_p[i][2] = result[-1][ind]
- else:
- # print(ind)
- # print(result[0][ind])
- phase_no = int(result[0][ind].split('.')[-1][result[0][ind].split('.')[-1].index('[') + 1])
- comp_no = int(result[0][ind].split('.')[-1][result[0][ind].split('.')[-1].index(']') - 1])
- Stages_x_pc[i][comp_no - 1][phase_no - 1] = result[-1][ind]
- # Can be uncommented when F_pc implemented in modelica model
- # if v == 'F_pc':
- # Stages_F_pc[i][comp_no - 1][phase_no - 1] = result[-1][ind]
- # else:
- # Stages_x_pc[i][comp_no - 1][phase_no - 1] = result[-1][ind]
-
- propertyname = name + '.reboiler.' + v
- if propertyname in result[0]:
- ind = result[0].index(propertyname)
- if v == 'T':
- Stages_T[-1] = result[-1][ind]
- # Can be uncommented when F_p implemented in modelica model
- # elif v == 'F_p':
- # if result[0][ind][result[0][ind].index('[') + 1] == '1':
- # Stages_F_p[-1][0] = result[-1][ind]
- # elif result[0][ind][result[0][ind].index('[') + 1] == '2':
- # Stages_F_p[-1][1] = result[-1][ind]
- # else:
- # Stages_F_p[-1][2] = result[-1][ind]
- else:
- print(ind)
- phase_no = int(result[0][ind][result[0][ind].index('[') + 1])
- comp_no = int(result[0][ind][result[0][ind].index(']') - 1])
- Stages_x_pc[-1][comp_no - 1][phase_no - 1] = result[-1][ind]
- # Can be uncommented when F_pc implemented in modelica model
- # if v == 'F_pc':
- # Stages_F_pc[-1][comp_no - 1][phase_no - 1] = result[-1][ind]
- # else:
- # Stages_x_pc[-1][comp_no - 1][phase_no - 1] = result[-1][ind]
-
- # Assigning temp variables to obj variabes
- self.obj.variables['Stages.T']['value'] = Stages_T
- # Can be uncommented when F_p and F_pc implemented in modelica model
- # self.obj.variables['Stages.F_p']['value'] = Stages_F_p
- # self.obj.variables['Stages.F_pc']['value'] = Stages_F_pc
- self.obj.variables['Stages.x_pc']['value'] = Stages_x_pc
-
- # filling stagewise result table
- tables = [self.stage_res_table.T_table, self.stage_res_table.x_pc_table]
- # Can be uncommented when F_p and F_pc implemented in modelica model
- # tables = [self.stage_res_table.T_table, self.stage_res_table.F_p_table, self.stage_res_table.F_pc_table, self.stage_res_table.x_pc_table]
-
- for t in tables:
- t.setRowCount(Nt)
- t.setVerticalHeaderItem(0, QTableWidgetItem('Condenser'))
- t.setVerticalHeaderItem(Nt -1, QTableWidgetItem('Reboiler'))
- for i in range(1, Nt - 1):
- t.setVerticalHeaderItem(i, QTableWidgetItem('Stage ' + str(i)))
-
- T_table = self.stage_res_table.T_table
- T_table.setColumnCount(1)
- for i in range(Nt):
- T_table.setItem(i, 0, QTableWidgetItem(Stages_T[i]))
-
- x_pc_table = self.stage_res_table.x_pc_table
- x_pc_table.setColumnCount(2*Nc)
- for i in range(Nc):
- x_pc_table.setHorizontalHeaderItem(2*i, QTableWidgetItem(self.obj.compounds[i] + '(Vapor)'))
- x_pc_table.setHorizontalHeaderItem(2*i + 1, QTableWidgetItem(self.obj.compounds[i] + '(Liquid)'))
-
- for i in range(Nt):
- for j in range(Nc):
- x_pc_table.setItem(i, 2*j, QTableWidgetItem(Stages_x_pc[i][j][1]))
- x_pc_table.setItem(i, 2 * j + 1, QTableWidgetItem(Stages_x_pc[i][j][2]))
-
- for t in tables:
- t.resizeColumnsToContents()
- except Exception as e:
- print(e)
-
- def closeEvent(self,event):
- scrollHVal = self.parent().container.graphics.graphicsView.horizontalScrollBarVal
- currentVal = self.parent().container.graphics.graphicsView.horizontalScrollBar().value()
- self.parent().container.graphics.graphicsView.horizontalScrollBar().setValue(currentVal-189) \ No newline at end of file