summaryrefslogtreecommitdiff
path: root/src/kicadtoNgspice/Processing.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/kicadtoNgspice/Processing.py')
-rw-r--r--src/kicadtoNgspice/Processing.py121
1 files changed, 76 insertions, 45 deletions
diff --git a/src/kicadtoNgspice/Processing.py b/src/kicadtoNgspice/Processing.py
index a175ac8b..efc30c16 100644
--- a/src/kicadtoNgspice/Processing.py
+++ b/src/kicadtoNgspice/Processing.py
@@ -103,7 +103,8 @@ class PrcocessNetlist:
pw = ' Enter pulse width (seconds): '
tp = ' Enter period (seconds): '
sourcelist.append(
- [index, compline, words[3], Title, v1, v2, td, tr, tf, pw, tp])
+ [index, compline, words[3],
+ Title, v1, v2, td, tr, tf, pw, tp])
elif words[3] == "sine":
Title = "Add parameters for sine source " + compName
@@ -113,11 +114,13 @@ class PrcocessNetlist:
td = ' Enter delay time (seconds): '
theta = ' Enter damping factor (1/seconds): '
sourcelist.append(
- [index, compline, words[3], Title, vo, va, freq, td, theta])
+ [index, compline, words[3],
+ Title, vo, va, freq, td, theta])
elif words[3] == "pwl":
Title = "Add parameters for pwl source " + compName
- t_v = ' Enter in pwl format without bracket i.e t1 v1 t2 v2.... '
+ t_v = ' Enter in pwl format without bracket\
+ i.e t1 v1 t2 v2.... '
sourcelist.append([index, compline, words[3], Title, t_v])
elif words[3] == "ac":
@@ -136,7 +139,8 @@ class PrcocessNetlist:
td2 = ' Enter fall time (seconds): '
tau2 = ' Enter fall time constant (seconds): '
sourcelist.append(
- [index, compline, words[3], Title, v1, v2, td1, tau1, td2, tau2])
+ [index, compline, words[3],
+ Title, v1, v2, td1, tau1, td2, tau2])
elif words[3] == "dc":
Title = "Add parameters for DC source " + compName
@@ -166,7 +170,7 @@ class PrcocessNetlist:
schematicInfo = schematicInfo + schematicInfo1
print("Source List : ", sourcelist)
- #print schematicInfo
+ # print schematicInfo
return schematicInfo, sourcelist
def convertICintoBasicBlocks(
@@ -187,8 +191,8 @@ class PrcocessNetlist:
for compline in schematicInfo:
words = compline.split()
compName = words[0]
- #print "Compline----------------->",compline
- #print "compName-------------->",compName
+ # print "Compline----------------->",compline
+ # print "compName-------------->",compName
# Find the IC from schematic
if compName[0] == 'u' or compName[0] == 'U':
# Find the component from the circuit
@@ -199,12 +203,14 @@ class PrcocessNetlist:
# e.g compLine : u1 1 2 gain
# compType : gain
# compName : u1
- #print "Compline",compline
- #print "CompType",compType
- #print "Words",words
- #print "compName",compName
+ # print "Compline",compline
+ # print "CompType",compType
+ # print "Words",words
+ # print "compName",compName
# Looking if model file is present
- if compType != "port" and compType != "ic" and compType not in plotList and compType != 'transfo':
+ if compType != "port" and compType != "ic" and \
+ compType not in plotList and \
+ compType != 'transfo':
xmlfile = compType + ".xml" # XML Model File
count = 0 # Check if model of same name is present
modelPath = []
@@ -223,10 +229,11 @@ class PrcocessNetlist:
elif count == 1:
try:
print(
- "Start Parsing Previous Values XML for ngspice model :", modelPath)
+ "Start Parsing Previous Values XML\
+ for ngspice model :", modelPath)
tree = ET.parse(modelPath[0])
- root = tree.getroot()
+ root = tree.getroot() # noqa
# Getting number of nodes for model and title
for child in tree.iter():
if child.tag == 'node_number':
@@ -243,33 +250,37 @@ class PrcocessNetlist:
for param in tree.findall('param'):
for item in param:
- #print "Tags ",item.tag
- #print "Value",item.text
+ # print "Tags ",item.tag
+ # print "Value",item.text
if 'vector'in item.attrib:
- #print "Tag having vector attribute",item.tag,item.attrib['vector']
+ # print "Tag having vector attribute",\
+ # item.tag,item.attrib['vector']
temp_count = 1
temp_list = []
for i in range(0, int(
item.attrib['vector'])):
temp_list.append(
- item.text + " " + str(temp_count))
+ item.text + " " + str(
+ temp_count))
temp_count += 1
if 'default' in item.attrib:
paramDict[item.tag + ":" +
- item.attrib['default']] = temp_list
+ item.attrib['default']] \
+ = temp_list
else:
paramDict[item.tag] = item.text
else:
if 'default' in item.attrib:
paramDict[item.tag + ":" +
- item.attrib['default']] = item.text
+ item.attrib['default']]\
+ = item.text
else:
paramDict[item.tag] = item.text
- #print "Number of Nodes : ",num_of_nodes
- #print "Title : ",title
- #print "Parameters",paramDict
+ # print "Number of Nodes : ",num_of_nodes
+ # print "Title : ",title
+ # print "Parameters",paramDict
# Creating line for adding model line in schematic
if splitDetail == 'None':
modelLine = "a" + str(k) + " "
@@ -281,28 +292,30 @@ class PrcocessNetlist:
print("Split Details :", splitDetail)
modelLine = "a" + str(k) + " "
vectorDetail = splitDetail.split(':')
- #print "Vector Details",vectorDetail
+ # print "Vector Details",vectorDetail
pos = 1 # Node position
for item in vectorDetail:
try:
if item.split("-")[1] == 'V':
- #print "Vector"
+ # print "Vector"
if compType == "aswitch":
modelLine += "("
for i in range(0, int(
item.split("-")[0])):
- modelLine += words[pos] + " "
+ modelLine += words[pos] +\
+ " "
pos += 1
modelLine += ") "
else:
modelLine += "["
for i in range(0, int(
item.split("-")[0])):
- modelLine += words[pos] + " "
+ modelLine += words[pos] + \
+ " "
pos += 1
modelLine += "] "
elif item.split("-")[1] == 'NV':
- #print "Non Vector"
+ # print "Non Vector"
for i in range(0, int(
item.split("-")[0])):
modelLine += words[pos] + " "
@@ -310,28 +323,33 @@ class PrcocessNetlist:
except BaseException:
print(
- "There is error while processing Vector Details")
+ "There is error while processing\
+ Vector Details")
sys.exit(2)
modelLine += compName
- #print "Final Model Line :",modelLine
+ # print "Final Model Line :",modelLine
try:
schematicInfo.append(modelLine)
k = k + 1
except Exception as e:
print(
- "Error while appending ModelLine ", modelLine)
+ "Error while appending \
+ ModelLine ", modelLine)
print("Exception Message : ", str(e))
# Insert comment at remove line
schematicInfo.insert(index, "* " + compline)
- comment = "* Schematic Name: " + compType + ", NgSpice Name: " + modelname
+ comment = "* Schematic Name:\
+ " + compType + ", NgSpice Name: " + modelname
# Here instead of adding compType(use for XML),
# added modelName(Unique Model Name)
modelList.append(
- [index, compline, modelname, compName, comment, title, type, paramDict])
+ [index, compline, modelname, compName,
+ comment, title, type, paramDict])
except Exception as e:
print(
- "Unable to parse the model, Please check your your XML file")
+ "Unable to parse the model, \
+ Please check your your XML file")
print("Exception Message : ", str(e))
sys.exit(2)
elif compType == "ic":
@@ -343,7 +361,8 @@ class PrcocessNetlist:
text = "Enter initial voltage at node for " + compline
paramDict[title] = text
modelList.append(
- [index, compline, modelname, compName, comment, title, type, paramDict])
+ [index, compline, modelname, compName,
+ comment, title, type, paramDict])
elif compType in plotList:
schematicInfo.insert(index, "* " + compline)
@@ -358,7 +377,8 @@ class PrcocessNetlist:
words = compline.split()
# Adding zero voltage source to netlist
schematicInfo.append(
- "v_" + words[0] + " " + words[1] + " " + words[2] + " " + "0")
+ "v_" + words[0] + " "
+ + words[1] + " " + words[2] + " " + "0")
plotText.append("plot i(v_" + words[0] + ")")
elif compType == 'plot_log':
words = compline.split()
@@ -374,20 +394,23 @@ class PrcocessNetlist:
schematicInfo.insert(index, "* " + compline)
# For Primary Couple
- modelLine = "a" + str(k) + " (" + words[1] + " " + words[2] + ") (interNode_" + str(
+ modelLine = "a" + str(k)
+ + " (" + words[1] + " " + words[2] + ") (interNode_" + str(
interMediateNodeCount) + " " + words[3] + ") "
modelLine += compName + "_primary"
schematicInfo.append(modelLine)
k = k + 1
# For iron core
- modelLine = "a" + str(k) + " (" + words[4] + " " + words[2] + ") (interNode_" + str(
+ modelLine = "a" + str(k) + " (" + words[4] + " " + words[2] + ") \
+ (interNode_" + str(
interMediateNodeCount + 1) + " " + words[3] + ") "
modelLine += compName + "_secondary"
schematicInfo.append(modelLine)
k = k + 1
# For Secondary Couple
modelLine = "a" + str(k) + " (interNode_" + str(
- interMediateNodeCount) + " interNode_" + str(interMediateNodeCount + 1) + ") "
+ interMediateNodeCount) + " interNode_" + \
+ str(interMediateNodeCount + 1) + ") "
modelLine += compName + "_iron_core"
schematicInfo.append(modelLine)
k = k + 1
@@ -396,16 +419,21 @@ class PrcocessNetlist:
modelname = "transfo"
comment = "* " + compline
title = "Transformer details for model " + compName
- type = "NA" # It is model but do not load from xml and lib file
+ type = "NA"
+ # It is model but do not load from xml and lib file
paramDict['h1_array'] = "Enter the H1 array "
- paramDict['primary_turns'] = "Enter the primary number of turns (default=310) "
+ paramDict['primary_turns'] = "Enter the primary number \
+ of turns (default=310) "
paramDict['area'] = "Enter iron core area (default=1)"
- paramDict['secondar_turns'] = "Enter the secondary number of turns (default=620)"
- paramDict['length'] = "Enter iron core length (default=0.01)"
+ paramDict['secondar_turns'] = "Enter the secondary number\
+ of turns (default=620)"
+ paramDict['length'] = "Enter iron core length \
+ (default=0.01)"
paramDict['b1_array'] = "Enter the B1 array "
modelList.append(
- [index, compline, modelname, compName, comment, title, type, paramDict])
+ [index, compline, modelname, compName,
+ comment, title, type, paramDict])
else:
schematicInfo.insert(index, "* " + compline)
@@ -418,4 +446,7 @@ class PrcocessNetlist:
multipleModelList)
print("Model List Details : ", modelList)
- return schematicInfo, outputOption, modelList, unknownModelList, multipleModelList, plotText
+ return (
+ schematicInfo, outputOption, modelList, unknownModelList,
+ multipleModelList, plotText
+ )