Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aradzie/jecs
Electronic circuit simulator written in JavaScript.
https://github.com/aradzie/jecs
circuit circuit-simulator electronics simulator spice
Last synced: 6 days ago
JSON representation
Electronic circuit simulator written in JavaScript.
- Host: GitHub
- URL: https://github.com/aradzie/jecs
- Owner: aradzie
- Created: 2021-08-30T09:54:25.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2022-08-29T09:24:24.000Z (over 2 years ago)
- Last Synced: 2024-11-20T23:04:08.629Z (2 months ago)
- Topics: circuit, circuit-simulator, electronics, simulator, spice
- Language: TypeScript
- Homepage:
- Size: 32.5 MB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Electronic Circuit Simulator
**jecs** is an electronic circuit simulator written in TypeScript.
It supports AC, DC and transient analyses.
## Example
Create a netlist file `netlist.txt`:
```text
Vac:Vin pow gnd V=1 f=1k
R:R1 pow vout R=1k
C:C1 vout gnd C=$C1
R:R2 vout gnd R=1k
.tr
stopTime=3m timeStep=1u
.sweep $C1 type="lin" start=1u stop=3u points=3
```and run the simulator in the terminal:
```shell
jecs --verbose netlist.txt
```The simulator will produce a dataset file `netlist.data`.
## Example
The following code:
```typescript
// Create an empty circuit.
const circuit = new Circuit();// Allocate circuit nodes.
const GND = circuit.groundNode;
const N1 = circuit.makeNode("N1");
const N2 = circuit.makeNode("N2");// Create devices.
const V1 = new Vdc("V1");
const R1 = new Resistor("R1");
const D1 = new Diode("D1");// Connect devices in the circuit.
circuit.connect(V1, [N1, GND]);
circuit.connect(R1, [N1, N2]);
circuit.connect(D1, [N2, GND]);// Set device properties.
V1.properties.set("V", 10);
R1.properties.set("R", 1000);
D1.properties.set("temp", 26.85);// Perform DC analysis, compute node voltages and branch currents.
const analysis = new DcAnalysis();
analysis.properties.set("maxIter", 10);
analysis.properties.set("abstol", 1e-12);
analysis.properties.set("vntol", 1e-6);
analysis.properties.set("reltol", 1e-3);
analysis.run(circuit);// Print the operating points.
console.log(dumpCircuit(circuit));
```prints the following result:
```typescript
[
"V(N1)=10V", // voltage at node N1
"V(N2)=712.407mV", // voltage at node N2
"V1{V=10V,I=-9.288mA,P=-92.876mW}", // voltage source output params
"R1{V=9.288V,I=9.288mA,P=86.259mW}", // resistor output params
"D1{V=712.407mV,I=9.288mA,P=6.617mW}", // diode output params
];
```## Interactive Shell
An [interactive shell](https://aradzie.github.io/jecs/) is available to play with netlists.
## Virtual Curve Tracer
The following non-linear device I/V curves were obtained from the simulator.
### Diode I/V Curve
![Diode I/V curve](examples/iv-diode.svg)
### BJT I/V Curve
![BJT I/V curve](examples/iv-bjt.svg)
### MOSFET I/V Curve
![MOSFET I/V curve](examples/iv-mosfet.svg)
### JFET I/V Curve
![JFET I/V curve](examples/iv-jfet.svg)
### BJT Amplifier I/V Curve
![BJT Amplifier I/V curve](examples/amp-bjt.svg)
### MOSFET Amplifier I/V Curve
![MOSFET Amplifier I/V curve](examples/amp-mosfet.svg)
# License
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free Software
Foundation; either version 2 of the License, or (at your option) any later
version.This program is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE. See the GNU General Public License for more details.You should have received a copy of the GNU General Public License along with
this program; if not, write to the Free Software Foundation, Inc., 51 Franklin
Street, Fifth Floor, Boston, MA 02110-1301, USA.