import os
import glob
import traceback
from PyQt5 import QtWidgets, QtCore
from configuration.Appconfig import Appconfig
from projManagement import Worker
from projManagement.Validation import Validation
from .NgspicetoModelica import NgMoConverter
BROWSE_LOCATION = '/home'
class OpenModelicaEditor(QtWidgets.QWidget):
def __init__(self, dir=None):
QtWidgets.QWidget.__init__(self)
self.obj_validation = Validation()
self.obj_appconfig = Appconfig()
self.projDir = dir
self.projName = os.path.basename(self.projDir)
self.ngspiceNetlist = os.path.join(
self.projDir, self.projName + ".cir.out")
self.modelicaNetlist = os.path.join(self.projDir, "*.mo")
self.map_json = Appconfig.modelica_map_json
self.grid = QtWidgets.QGridLayout()
self.FileEdit = QtWidgets.QLineEdit()
self.FileEdit.setText(self.ngspiceNetlist)
self.grid.addWidget(self.FileEdit, 0, 0)
self.browsebtn = QtWidgets.QPushButton("Browse")
self.browsebtn.clicked.connect(self.browseFile)
self.grid.addWidget(self.browsebtn, 0, 1)
self.convertbtn = QtWidgets.QPushButton("Convert")
self.convertbtn.clicked.connect(self.callConverter)
self.grid.addWidget(self.convertbtn, 2, 1)
self.loadOMbtn = QtWidgets.QPushButton("Load OMEdit")
self.loadOMbtn.clicked.connect(self.callOMEdit)
self.grid.addWidget(self.loadOMbtn, 3, 1)
# self.setGeometry(300, 300, 350, 300)
self.setLayout(self.grid)
self.show()
def browseFile(self):
temp = QtCore.QDir.toNativeSeparators(
QtWidgets.QFileDialog.getOpenFileName(
self, 'Open Ngspice Netlist', BROWSE_LOCATION
)[0]
)
if temp:
self.ngspiceNetlist = temp
self.FileEdit.setText(self.ngspiceNetlist)
def callConverter(self):
dir_name = os.path.dirname(os.path.realpath(self.ngspiceNetlist))
# file_basename = os.path.basename(self.ngspiceNetlist)
cwd = os.getcwd()
os.chdir(dir_name)
obj_NgMoConverter = NgMoConverter(self.map_json)
try:
# Getting all the require information
lines = obj_NgMoConverter.readNetlist(self.ngspiceNetlist)
# print("Complete Lines of Ngspice netlist : " +
# "lines ---------------->", lines)
optionInfo, schematicInfo = \
obj_NgMoConverter.separateNetlistInfo(lines)
# print("All option details like analysis,subckt,.ic,.model :" +
# "OptionInfo------------------->", optionInfo)
# print("Schematic connection info :schematicInfo", schematicInfo)
modelName, modelInfo, subcktName, paramInfo, transInfo,\
inbuiltModelDict = (
obj_NgMoConverter.addModel(optionInfo)
)
# print("Name of Model : " +
# "modelName-------------------->", modelName)
# print("Model Information : " +
# "modelInfo--------------------->", modelInfo)
# print("Subcircuit Name : " +
# "subcktName------------------------>", subcktName)
# print("Parameter Information : " +
# "paramInfo---------------------->", paramInfo)
# print("InBuilt Model ---------------------->", inbuiltModelDict)
modelicaParamInit = obj_NgMoConverter.processParam(paramInfo)
# print("Make modelicaParamInit from paramInfo : " +
# "processParamInit------------->", modelicaParamInit)
compInfo, plotInfo = obj_NgMoConverter.separatePlot(schematicInfo)
# print("Plot info like plot,print etc :plotInfo",plotInfo)
IfMOS = '0'
for eachline in compInfo:
# words = eachline.split()
if eachline[0] == 'm':
IfMOS = '1'
break
node, nodeDic, pinInit, pinProtectedInit = \
obj_NgMoConverter.nodeSeparate(
compInfo, '0', [], subcktName, []
)
# print("All nodes in the netlist :node---------------->", node)
# print("NodeDic which will be used for modelica :" +
# "nodeDic------------->", nodeDic)
# print("PinInit-------------->", pinInit)
# print("pinProtectedInit----------->", pinProtectedInit)
modelicaCompInit, numNodesSub = obj_NgMoConverter.compInit(
compInfo,
node,
modelInfo,
subcktName,
dir_name,
transInfo,
inbuiltModelDict
)
# print("ModelicaComponents :" +
# "modelicaCompInit----------->", modelicaCompInit)
# print("SubcktNumNodes :" +
# "numNodesSub---------------->", numNodesSub)
connInfo = obj_NgMoConverter.connectInfo(
compInfo, node, nodeDic, numNodesSub, subcktName)
# print("ConnInfo------------------>", connInfo)
# After Sub Ckt Func
if len(subcktName) > 0:
data, subOptionInfo, subSchemInfo, subModel, subModelInfo,\
subsubName, subParamInfo, modelicaSubCompInit,\
modelicaSubParam, nodeSubInterface, nodeSub, nodeDicSub,\
pinInitSub, connSubInfo = (
obj_NgMoConverter.procesSubckt(
subcktName, numNodesSub, dir_name
)
) # Adding 'numNodesSub' by Fahim
# Creating Final Output file
fileDir = os.path.dirname(self.ngspiceNetlist)
newfile = os.path.basename(self.ngspiceNetlist)
newfilename = os.path.join(fileDir, newfile.split('.')[0])
outfile = newfilename + ".mo"
out = open(outfile, "w")
out.writelines('model ' + os.path.basename(newfilename))
out.writelines('\n')
if IfMOS == '0':
out.writelines('import Modelica.Electrical.*;')
elif IfMOS == '1':
out.writelines('import BondLib.Electrical.*;')
# out.writelines('import Modelica.Electrical.*;')
out.writelines('\n')
for eachline in modelicaParamInit:
if len(paramInfo) == 0:
continue
else:
out.writelines(eachline)
out.writelines('\n')
for eachline in modelicaCompInit:
if len(compInfo) == 0:
continue
else:
out.writelines(eachline)
out.writelines('\n')
out.writelines('protected')
out.writelines('\n')
out.writelines(pinInit)
out.writelines('\n')
out.writelines('equation')
out.writelines('\n')
for eachline in connInfo:
if len(connInfo) == 0:
continue
else:
out.writelines(eachline)
out.writelines('\n')
out.writelines('end ' + os.path.basename(newfilename) + ';')
out.writelines('\n')
out.close()
os.chdir(cwd)
self.msg = QtWidgets.QMessageBox()
self.msg.setText(
"Ngspice netlist successfully converted to OpenModelica " +
"netlist"
)
self.obj_appconfig.print_info(
"Ngspice netlist successfully converted to OpenModelica " +
"netlist"
)
self.msg.exec_()
except BaseException as e:
traceback.print_exc()
print("================")
self.msg = QtWidgets.QErrorMessage()
self.msg.setModal(True)
self.msg.setWindowTitle("Conversion Error")
self.msg.showMessage(
'Unable to convert Ngspice netlist to Modelica netlist. ' +
'Check the netlist : ' + repr(e)
)
def callOMEdit(self):
if self.obj_validation.validateTool("OMEdit"):
modelFiles = glob.glob(self.modelicaNetlist)
modelFiles = ' '.join(file for file in modelFiles)
self.cmd2 = "OMEdit " + modelFiles
self.obj_workThread2 = Worker.WorkerThread(self.cmd2)
self.obj_workThread2.start()
print("OMEdit called")
self.obj_appconfig.print_info("OMEdit called")
else:
self.msg = QtWidgets.QMessageBox()
self.msgContent = (
"There was an error while opening OMEdit.
"
"Please make sure OpenModelica is installed in your"
" system.
"
"To install it on Linux : Go to OpenModelica Linux and install nightly build"
" release.
"
"To install it on Windows : Go to OpenModelica Windows and install latest version.
"
)
self.msg.setTextFormat(QtCore.Qt.RichText)
self.msg.setText(self.msgContent)
self.msg.setWindowTitle("Missing OpenModelica")
self.obj_appconfig.print_info(self.msgContent)
self.msg.exec_()