summaryrefslogtreecommitdiff
path: root/src/kicadtoNgspice/Convert.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/kicadtoNgspice/Convert.py')
-rw-r--r--src/kicadtoNgspice/Convert.py105
1 files changed, 97 insertions, 8 deletions
diff --git a/src/kicadtoNgspice/Convert.py b/src/kicadtoNgspice/Convert.py
index c0d98548..20597651 100644
--- a/src/kicadtoNgspice/Convert.py
+++ b/src/kicadtoNgspice/Convert.py
@@ -1,10 +1,13 @@
import os
import sys
-
+import shutil
import TrackWidget
class Convert:
+ """
+ This class has all the necessary function required to convert kicad netlist to ngspice netlist.
+ """
def __init__(self,sourcelisttrack,source_entry_var,schematicInfo):
print "Start Conversion"
self.sourcelisttrack = sourcelisttrack
@@ -14,6 +17,9 @@ class Convert:
def addSourceParameter(self):
+ """
+ This function add the source details to schematicInfo
+ """
print "Adding Source parameter"
#print "SourceListTrack : ",self.sourcelisttrack
#print "Schematic Info ",self.schematicInfo
@@ -112,6 +118,9 @@ class Convert:
def analysisInsertor(self,ac_entry_var,dc_entry_var, tran_entry_var,set_checkbox,ac_parameter,dc_parameter,tran_parameter,ac_type):
+ """
+ This function creates an analysis file in current project
+ """
self.ac_entry_var = ac_entry_var
self.dc_entry_var = dc_entry_var
self.tran_entry_var = tran_entry_var
@@ -145,6 +154,9 @@ class Convert:
self.writefile.close()
def converttosciform(self, string_obj):
+ """
+ This function is used for scientific conversion.
+ """
self.string_obj = string_obj
if self.string_obj[0] == 'm':
return "e-03"
@@ -158,6 +170,9 @@ class Convert:
return "e-00"
def defaultvalue(self, value):
+ """
+ This function select default value as 0 if Analysis widget do not hold any value.
+ """
self.value= value
if self.value == '':
return 0
@@ -166,7 +181,9 @@ class Convert:
def addModelParameter(self,schematicInfo):
- print "Schematic info after adding source detail",schematicInfo
+ """
+ This function add the Ngspice Model details to schematicInfo
+ """
#Create object of TrackWidget
self.obj_track = TrackWidget.TrackWidget()
@@ -176,7 +193,7 @@ class Convert:
modelParamValue = []
for line in self.obj_track.modelTrack:
- print "Model Track :",line
+ #print "Model Track :",line
if line[2] == 'transfo':
try:
start=line[5]
@@ -214,8 +231,8 @@ class Convert:
end = line[6]
addmodelLine=".model "+ line[3]+" "+line[2]+"("
for key,value in line[9].iteritems():
- print "Tags: ",key
- print "Value: ",value
+ #print "Tags: ",key
+ #print "Value: ",value
#Checking for default value and accordingly assign param and default.
if ':' in key:
key = key.split(':')
@@ -258,6 +275,78 @@ class Convert:
return schematicInfo
-
-
- \ No newline at end of file
+
+ def addDeviceLibrary(self,schematicInfo,kicadFile):
+ """
+ This function add the library details to schematicInfo
+ """
+ print "Adding Device library to Schematic info file"
+
+ (projpath,filename) = os.path.split(kicadFile)
+
+ print "Project Path",projpath
+
+ deviceLibList = self.obj_track.deviceModelTrack
+ deviceLine = {} #Key:Index, Value:with its updated line in the form of list
+ includeLine = [] #All .include line list
+
+ if not deviceLibList:
+ print "No Library Added in the schematic"
+ pass
+ else:
+ for eachline in schematicInfo:
+ words = eachline.split()
+ if words[0] in deviceLibList:
+ print "Found Library line"
+ index = schematicInfo.index(eachline)
+ completeLibPath = deviceLibList[words[0]]
+ (libpath,libname) = os.path.split(completeLibPath)
+ print "Library Path :",libpath
+ #Copying library from devicemodelLibrary to Project Path
+ #Special case for MOSFET
+ if eachline[0] == 'm':
+ #For mosfet library name come along with MOSFET dimension information
+ tempStr = libname.split(':')
+ libname = tempStr[0]
+ dimension = tempStr[1]
+ #Replace last word with library name
+ words[-1] = libname.split('.')[0]
+ #Appending Dimension of MOSFET
+ words.append(dimension)
+ deviceLine[index] = words
+ includeLine.append(".include "+libname)
+
+ src = completeLibPath.split(':')[0]
+ dst = projpath
+ shutil.copy2(src, dst)
+ else:
+ #Replace last word with library name
+ words[-1] = libname.split('.')[0]
+ deviceLine[index] = words
+ includeLine.append(".include "+libname)
+
+ src = completeLibPath
+ dst = projpath
+ shutil.copy2(src,dst)
+
+ else:
+ pass
+
+
+ #Adding device line to schematicInfo
+ for index,value in deviceLine.iteritems():
+ #Update the device line
+ strLine = " ".join(str(item) for item in value)
+ schematicInfo[index] = strLine
+
+ #This has to be second i.e after deviceLine details
+ #Adding .include line to Schematic Info at the start of line
+ for item in list(set(includeLine)):
+ schematicInfo.insert(0,item)
+
+
+
+
+
+ return schematicInfo
+ \ No newline at end of file