-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
7 changed files
with
146 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
bin/ | ||
old/ | ||
images/ | ||
images/ | ||
Circuit-Simulator.zip |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
<<<<<<< HEAD | ||
# Circuit-Simulator | ||
A simple yet powerful circuit cimulator for the 21th century. | ||
|
||
It currently provides CLI frontend, and we're working to release the GUI as soon as possible. | ||
More on how to use this program later. | ||
======= | ||
##Overview | ||
Circuit Simulator is a circuit simulation program. It's written in Java, hence it's available on Windows Mac & Linux. It provides both CLI and GUI frontends. It supports multiple components, including non-linear and frequency-varrying components. | ||
## Installation | ||
You can find zip binary package in github releases. | ||
## Build From Source | ||
First clone the github repository, | ||
`git clone https://github.com/hamza-Algohary/Circuit-Simulator` | ||
Then use makefile, | ||
``` | ||
cd Circuit-Simulator | ||
make | ||
``` | ||
## Dependencies | ||
Circuit Simulator uses the following libraries: | ||
- [ejml](https://github.com/lessthanoptimal/ejml) (For solving linear system of equations) | ||
- [jchart2d](https://jchart2d.sourceforge.net/) (For providing the oscilliscope) | ||
- GUI is done using Swing™ | ||
There is no need to install them before building from source, because they're already included in the repository. | ||
|
||
## Usage | ||
Circuit Simulator currently provides only CLI frontend. The GUI is mostly ready and is going to be available on next release. | ||
Circuit Simulator takes a circuit from the user as a file, and prints out the solution to a file. | ||
Example Input File (test.txt) : | ||
``` | ||
dcv 0,0 1,0 30 | ||
r 0,0 0,1 5 | ||
r 0,1 1,1 5 | ||
r 1,0 1,1 5 | ||
``` | ||
Which corresponds to the following circuit: | ||
data:image/s3,"s3://crabby-images/87469/8746940d3fd601221ba0a5ba4470c485130c6e74" alt="Simple Circuit Imgae" | ||
To run the program with that file, navigate to bin directory then fire up a terminal and type: | ||
`./run.sh test.txt` | ||
if you're running it for the first time you need to type this command first: | ||
`chmod +x run.sh` | ||
|
||
After running the program you will find a newly created file called `results.txt` containing key-value pairs of all variables in the circuit. | ||
|
||
The output file of the above program will be: | ||
``` | ||
I1.0,0.0:1.0,1.0 = 2.0 | ||
I0.0,0.0:1.0,0.0 = 2.0 | ||
V1.0,1.0 = -0.0 | ||
V0.0,0.0 = -20.0 | ||
I0.0,1.0:1.0,1.0 = -2.0 | ||
V0.0,1.0 = -10.0 | ||
V1.0,0.0 = 10.0 | ||
I0.0,0.0:0.0,1.0 = -2.0 | ||
``` | ||
|
||
## Input File Structure | ||
The general for input file is the following | ||
```<Component Name> <Start Coordinate> <End Coordinate> <Arguments> <Monitored variable (Optional)>``` | ||
Available names: | ||
- r (Resistance) | ||
- dcv (DC Voltage Source) | ||
- dci (DC Current Source) | ||
- w (Wire) | ||
- acv (AC Voltage Source) | ||
- aci (AC Current Source) | ||
- c (Capacitor) | ||
- d (Diode) | ||
|
||
Inorder to decide coordinates, draw the desired circuit as shown above then give each node a coordinate. To make the process easiear align all components to be either horizontal or vertical, otherwise the program may produce unexpected results. | ||
|
||
All components don't care which terminal is their start and which is their end, except three components (dcv , dci & d). For dcv and dci, the negative terminal as at start and positive terminal is at end. For the PN-junction diode P is at start, and N is at end. | ||
|
||
Here is a list of expected arguments for each component: | ||
- r (resistance) | ||
- dcv (Voltage, where negative voltage reverses polarity) | ||
- dci (Current, where negative current reverses polarity) | ||
- w | ||
- acv (Frequency) (Amplitude) | ||
- aci (Frequency) (Amplitude) | ||
- c (Capacitance) | ||
- d (V diode, where negative Vd reverses diode's polarity) | ||
|
||
## Output File Structure | ||
Each line contains one variable as following: | ||
Variable Name = Value | ||
Where variable name is either __node voltage__ or __branch current__. | ||
Node voltage is "V" followed by node coordinate | ||
Branch current is "I" followed by start then end coordinates of the branch. | ||
|
||
####How to determine current direction? | ||
Let current name be `Ix1,y1:x2,y2`, if the value is positive then it's flowing from x1,y1 to x2,y2, otherwise it's flowing the other way. | ||
|
||
## The Oscilliscope | ||
For dc circuits, the result.txt might be enough, but inorder for AC simulaiton to be useful, there must be a mean for monitoring currents or potential differences of components in real time. Using the oscilliscope is as easy as adding two letters to the input file. In the meantime you can only monitor current or potential difference across a single component, support for monitoring potential difference between any two points will be provided in future release. | ||
|
||
To monitor Voltage of a component simply add `mv` at the end of this component. Similarly add `mi` to monitor current. | ||
|
||
__Example (Half Wave Rectifier)__ | ||
Input File: | ||
``` | ||
acv 0,0 1,0 60 30 | ||
r 0,0 0,1 5 | ||
r 0,1 1,1 5 | ||
d 1,0 1,1 -0.7 mv | ||
``` | ||
|
||
Oscilliscope: | ||
data:image/s3,"s3://crabby-images/31838/31838258f0d755ef0701b80dfe53bcb429bf2800" alt="Oscilliscope-for-half-wave-rectifier" | ||
|
||
## Prototype of GUI Frontend | ||
|
||
This is just a prototype of the planned GUI, the end result will be (hopefully) prettier and might get rewritten with another toolkit. | ||
|
||
data:image/s3,"s3://crabby-images/996ea/996eab147f4ca7c66ff18cc35baaf84b73b14d8f" alt="Screenshot" | ||
|
||
>>>>>>> e18b782 (Added a meaningful README) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters