summaryrefslogtreecommitdiff
path: root/src/kicadtoNgspice/Convert.py
diff options
context:
space:
mode:
authorRahul P2022-09-17 23:31:49 +0530
committerGitHub2022-09-17 23:31:49 +0530
commit6e38b8cd9b8662a09a01765eb4c3b1ffaddd6ea3 (patch)
tree298942db122882e247da05e7e7fa10cb3dd03d85 /src/kicadtoNgspice/Convert.py
parent2843e73ed81ac0bb5e685a5f1e045babb67083f0 (diff)
parent39632efe85fcfc781139442103269e90e0a29d3a (diff)
downloadeSim-6e38b8cd9b8662a09a01765eb4c3b1ffaddd6ea3.tar.gz
eSim-6e38b8cd9b8662a09a01765eb4c3b1ffaddd6ea3.tar.bz2
eSim-6e38b8cd9b8662a09a01765eb4c3b1ffaddd6ea3.zip
Merge pull request #221 from rahulp13/sky130-dev
Added IPs and subcircuits, fixed path issues
Diffstat (limited to 'src/kicadtoNgspice/Convert.py')
-rwxr-xr-xsrc/kicadtoNgspice/Convert.py44
1 files changed, 17 insertions, 27 deletions
diff --git a/src/kicadtoNgspice/Convert.py b/src/kicadtoNgspice/Convert.py
index c1209cd3..566182e0 100755
--- a/src/kicadtoNgspice/Convert.py
+++ b/src/kicadtoNgspice/Convert.py
@@ -525,47 +525,40 @@ class Convert:
# print("Library Path :", libpath)
# Copying library from devicemodelLibrary to Project Path
# Special case for MOSFET
- print(eachline[0:5])
+ tempStr = libname.split(':')
+ libname = tempStr[0]
+ libAbsPath = os.path.join(libpath, libname)
+
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]
- words[-1] = self.getRefrenceName(libname, libpath)
+ words[-1] = self.getReferenceName(libname, libpath)
# Appending Dimension of MOSFET
words.append(dimension)
deviceLine[index] = words
includeLine.append(".include " + libname)
- # src = completeLibPath.split(':')[0] # <----- Not
- # working in Windows
-
- (src_path, src_lib) = os.path.split(completeLibPath)
- src_lib = src_lib.split(':')[0]
- src = os.path.join(src_path, src_lib)
- dst = projpath
- shutil.copy2(src, dst)
+ shutil.copy2(libAbsPath, projpath)
elif eachline[0:6] == 'scmode':
(filepath, filemname) = os.path.split(self.clarg1)
self.Fileopen = os.path.join(filepath, ".spiceinit")
- print("======================================================")
- print("Writing to the .spiceinit file to make ngspice SKY130 compatible")
+ print("==============================================")
+ print("Writing to the .spiceinit file to " +
+ "make ngspice SKY130 compatible")
self.writefile = open(self.Fileopen, "w")
self.writefile.write('''
set ngbehavior=hsa ; set compatibility for reading PDK libs
-set ng_nomodcheck ; don't check the model parameters
+set ng_nomodcheck ; don't check the model parameters
set num_threads=8 ; CPU hardware threads available
option noinit ; don't print operating point data
optran 0 0 0 100p 2n 0 ; don't use dc operating point, but transient op)
''')
- print("======================================================")
+ print("==============================================")
- tempStr = completeLibPath.split(':')
- print(tempStr)
libs = '''
sky130_fd_pr__model__diode_pd2nw_11v0.model.spice
sky130_fd_pr__model__diode_pw2nd_11v0.model.spice
@@ -575,31 +568,28 @@ sky130_fd_pr__model__pnp.model.spice
sky130_fd_pr__model__r+c.model.spice
'''
includeLine.append(
- ".lib \"" + tempStr[0] + "\" " + tempStr[1])
+ ".lib \"" + libAbsPath + "\" " + tempStr[1])
for i in libs.split():
includeLine.append(
- ".include \"" + tempStr[0].replace(
+ ".include \"" + libAbsPath.replace(
"sky130.lib.spice", i) + "\"")
deviceLine[index] = "*scmode"
# words.append(completeLibPath)
# deviceLine[index] = words
elif eachline[0:2] == 'sc' and eachline[0:6] != 'scmode':
- temp_str = words[0].replace('sc', 'xsc')
- words[0] = temp_str
+ words[0] = words[0].replace('sc', 'xsc')
words.append(completeLibPath)
deviceLine[index] = words
else:
# Replace last word with library name
# words[-1] = libname.split('.')[0]
- words[-1] = self.getRefrenceName(libname, libpath)
+ words[-1] = self.getReferenceName(libname, libpath)
deviceLine[index] = words
includeLine.append(".include " + libname)
- src = completeLibPath
- dst = projpath
- shutil.copy2(src, dst)
+ shutil.copy2(completeLibPath, projpath)
# Adding device line to schematicInfo
for index, value in deviceLine.items():
@@ -673,7 +663,7 @@ sky130_fd_pr__model__r+c.model.spice
return schematicInfo
- def getRefrenceName(self, libname, libpath):
+ def getReferenceName(self, libname, libpath):
libname = libname.replace('.lib', '.xml')
library = os.path.join(libpath, libname)