Simulate electronic circuit using Python and the Ngspice / Xyce simulators
Project description
Overview
What is PySpicePro ?
PySpicePro is a Python module based on the PySpice module created by Fabrice Salvaire with additions that are not yet integrated into PySpice.
PySpicePro only works with ngspice version 30 (install from ngspice-30_dll_64.zip).
Additions:
The .meas(ure) keyword has been added through the simulator.measure(..) member function. This allows the use of simulator.options(‘AUTOSTOP’).
Parallelisation is now more convenient with the use of NgSpiceShared.new_instance() where the management of new instances is now completely automated (temporary dll, instances deletions).
Installation:
pip install PySpicePro
PySpicePro needs to work with a specific version of ngspice. Currently only supporting v30.
What is PySpice ?
PySpice is a Python module which interface Python to the Ngspice and Xyce circuit simulators.
Where is the Documentation ?
The documentation is available on the PySpice Home Page.
What are the main features ?
support Ngspice and Xyce circuit simulators
support Linux, Windows and Mac OS X platforms
licensed under GPLv3 therms
implement an Ngspice shared library binding using CFFI which support external sources
implement (partial) SPICE netlist parser
implement an Oriented Object API to define circuit
export simulation output to Numpy arrays
plot using Matplotlib
handle units
work with Kicad schematic editor
implement a documentation generator
provides many examples
Credits
Author of the original PySpice: Fabrice Salvaire
V1.4.0 (development release)
V1.3.2 (production release) 2019-03-11
support Ngspice 30 and Xyce 6.10
fixed NgSpice and Xyce support on Windows 10
bug fixes
V1.2.0 2018-06-07
Initial support of the Xyce simulator. Xyce is an open source, SPICE-compatible, high-performance analog circuit simulator, capable of solving extremely large circuit problems developed at Sandia National Laboratories. Xyce will make PySpice suitable for industry and research use.
Fixed OSX support
Splitted G device
Implemented partially ‘A’ XSPICE device
Implemented missing transmission line devices
Implemented high level current sources Notice: Some classes were renamed !
Implemented node kwarg e.g.
circuit.Q(1, base=1, collector=2, emitter=3, model='npn')
Implemented raw spice pass through (see ‘User FAQ </faq.html>’_)
Implemented access to internal parameters (cf.
save @device[parameter]
)Implemented check for missing ground node
Implemented a way to disable an element and clone netlist
Improved SPICE parser
Improved unit support:
Implemented unit prefix cast ‘U_μV(U_mV(1))’ to easily convert values
Added ‘U_mV’, … shortcuts
Added Numpy array support to unit, see ‘UnitValues’ Notice: this new feature could be buggy !!!
Rebased ‘WaveForm’ to ‘UnitValues’
Fixed node order so as to not confuse users Now PySpice matches SPICE order for two ports elements !
Fixed device shortcuts in ‘Netlist’ class
Fixed model kwarg for BJT Notice: it must be passed exclusively as kwarg !
Fixed subcircuit nesting
Outsourced documentation generator to Pyterate
Updated ‘setup.py’ for wheel
V1.1.0 2017-09-06
Enhanced shared mode
Shared mode is now set as default on Linux
V1.0.0 2017-09-06
Bump version to v1.0.0 since it just works!
Support Windows platform using Ngspice shared mode
Fixed shared mode
Fixed and completed Spice parser : tested on example’s libraries
V0.4.2
Fixed Spice parser for lower case device prefix.
V0.4.0 2017-07-31
Git repository cleanup: filtered generated doc and useless files so as to shrink the repository size.
Improved documentation generator: Implemented
format
for RST content and Tikz figure.Improved unit support: It implements now the International System of Units. And we can now use unit helper like
u_mV
or compute the value of1.2@u_kΩ / 2@u_mA
. The relevant documentation is on this page.Added the Simulation instance to the Analysis class.
Refactored simulation parameters as classes.
V0.3.2 2017-02-22
fixed CCCS and CCVS
V0.3.1 2017-02-22
fixed ngspice shared
V0.3.0 2015-12-08
Added an example to show how to use the NgSpice Shared Simulation Mode.
Completed the Spice netlist parser and added examples, we could now use a schematic editor to define the circuit. The program cir2py translates a circuit file to Python.
V0 2014-03-21
Started project
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file PySpicePro-40.2.tar.gz
.
File metadata
- Download URL: PySpicePro-40.2.tar.gz
- Upload date:
- Size: 444.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.1.0 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e0b07bf3cda028c4ae9da05b8abd974589bc10d664dc81dab824380d0a1f11e6 |
|
MD5 | 9b6d7c7ea080f4cae33684b28690e760 |
|
BLAKE2b-256 | bc2a3c6edf64fc647f164d8f082eabb5cae9844224c1984432f2575145fa5ed0 |
File details
Details for the file PySpicePro-40.2-py2.py3-none-any.whl
.
File metadata
- Download URL: PySpicePro-40.2-py2.py3-none-any.whl
- Upload date:
- Size: 126.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.1.0 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88b25f6011c3670f32688870424158c802cec7fcd0f18a6a05b230db35f7359b |
|
MD5 | aece50f1380141d856d9fbe0a73b6232 |
|
BLAKE2b-256 | 3764815867927e25acadad8fd002d819ecb369ebfbcfaa49a98778f9905e6ce4 |