University of Central Florida

STARS
UCF Patents

Technology Transfer

7-10-2012

Symbolic Switch/Linear Circuit Simulator Systems and Methods
Issa Batarseh
University of Central Florida

Ghaith Haddad
University of Central Florida

Shadi Harb
University of Central Florida

Ehab Shoubaki
University of Central Florida

Find similar works at: https://stars.library.ucf.edu/patents
University of Central Florida Libraries http://library.ucf.edu
This Patent is brought to you for free and open access by the Technology Transfer at STARS. It has been accepted for
inclusion in UCF Patents by an authorized administrator of STARS. For more information, please contact
STARS@ucf.edu.

Recommended Citation
Batarseh, Issa; Haddad, Ghaith; Harb, Shadi; and Shoubaki, Ehab, "Symbolic Switch/Linear Circuit
Simulator Systems and Methods" (2012). UCF Patents. 550.
https://stars.library.ucf.edu/patents/550

Illlll llllllll Ill lllll lllll lllll lllll lllll 111111111111111111111111111111111
US008219374Bl

c12)

United States Patent

(10)

Batarseh et al.

(45)

(54)

SYMBOLIC SWITCH/LINEAR CIRCUIT
SIMULATOR SYSTEMS AND METHODS

(75)

Inventors: Issa Batarseh, Orlando, FL (US); Ehab
Shoubaki, Orlando, FL (US); Shadi
Harb, Gainesville, FL (US); Ghaith
Haddad, Orlando, FL (US)

(73)

Assignee: University of Central Florida Research
Foundation, Inc., Orlando, FL (US)

( *)

Notice:

(21)

Appl. No.: 12/035,137

(22)

Filed:

(60)

Provisional application No. 60/902,582, filed on Feb.
21, 2007.

(51)

Int. Cl.
G06F 17150
(2006.01)
G06G 7162
(2006.01)
U.S. Cl. ............................................ 703/13; 703/14
Field of Classification Search .................... 703/13,
703/14; 716/4
See application file for complete search history.

6,421,524
6,530,065
6,933,928
6,959,425
6,966,026
7,017,159
7,260,781
7,318,014
7,441,219
7,475,000

Feb.21,2008

Primary Examiner - Dwin M Craig
Assistant Examiner - Aniss Chad
(74) Attorney, Agent, or Firm - Brian S. Steinberger;
Phyllis K. Wood; Law Offices of Brian S. Steinberger, P.A.

900

Interactive and real time web-based electrical circuit symbolic solvers and simulators. The invention includes an interactive and innovative graphical user interface (GUI) for creating circuit schematics and generating netlists, circuits
symbolic solving and instant simulated solutions, their systems and methods. Users such as students can use GUI interfaces to remotely access a remote server controlled by educational institutions such as universities, or electronic book
publishers, in order to draw, symbolically solve, and instantly
simulate electrical circuits.

6/1998 Munyan
8/1999 Uranaka
912000 Kenney et al.
512001 Schwab
10/2001 Leeetal.
1112001 Chombo
112002 Heutschi

{

Start

9 Claims, 12 Drawing Sheets

)

1
Draw Circuit on
Graphic Editor

l
Convert
To Netlist

l
Populate
Y-admittance
Matrix
I

ABSTRACT

(57)

U.S. PATENT DOCUMENTS
A
A
A
Bl
S
Bl
Bl

Bl
712002 Padgett
Bl * 3/2003 McDonald et al. ............... 716/4
Bl
8/2005 Lilienthal
Bl
10/2005 Krauklis
Bl
1112005 Sommerer
Bl
3/2006 Baker
B2
8/2007 DeMello et al.
Bl* 112008 Molson et al. .................. 703/ 13
B2 * 10/2008 Perry et al ....................... 716/11
B2 * 112009 Cook et al ....................... 703/14

* cited by examiner

References Cited

5,761,485
5,937,158
6,121,965
6,229,502
D449,606
6,313,828
6,335,678

Jul. 10, 2012

Kinney et al., Web-Based Interactive Circuit Simulator for Introductory Physics, Jul. 2004, University of Delaware.*
Falstad, Circuit Simulator, 2005. *
Tosic et al., Advances in symbolic simulation of systems, The IPSI
BgD Transactions on Advanced Research, vol. 3, No. 1, ISSN 18204511, 2006, pp. 9-14.*
Lutovac et al., SchematicSolver Version 2.0 user manual, 20032004. *
Rodanski et al., Symbolic Analysis, 2006, Taylor & Francis Group,
LLC.*

Subject to any disclaimer, the term ofthis
patent is extended or adjusted under 35
U.S.C. 154(b) by 637 days.

(56)

US 8,219,374 Bl

OTHER PUBLICATIONS

Related U.S. Application Data

(52)
(58)

Patent No.:
Date of Patent:

r

i

•

-

Find Residues
(Partial Fraction
Expansion)

Get Desired
Output Nodes

l
Find appropriate
Cofactors

l
isplay Transte)
Functions

•
Find Poles
(using iaguerre's
method)
I

1
Apply Symbolic Inverse
Laplace Transform
(Symbolic time
response)

___ J

//'
,.,
',~,

-----

Plot
Transient
---------

,.

".\

.

.--/;

~

U.S. Patent

Jul. 10, 2012

Sheet 1of12

US 8,219,374 Bl

1

\

i

Iii _ I!
Fig.1

U.S. Patent

100

US 8,219,374 Bl

Sheet 2of12

Jul. 10, 2012

iacO

-~

~

0

µA

RO

CB:CJ
OIJliiill

co

R1

VacO

0011V

00

~,......

lllltet

IR1i

\flllue

loo

i.;...;.._ _

---110

_,JtNs: lia-n (Id)) I..,. I
OK

Fig. 2

U.S. Patent

Jul. 10, 2012

Sheet 3 of 12

Constructed
Sche1natic

,,
Circuit
Checker

Error-Free
Schematic

Fig. 3

US 8,219,374 Bl

U.S. Patent

Jul. 10, 2012

200

~

US 8,219,374 Bl

Sheet 4of12

Em>r·fl'H
Schematic

N.twork

\__ -~-- --,
I
I
I
I
I
I
I
I
I

Merging
Connection

Lin••

l
NetNamn
AHlgnmenta

I
I
I
I
I
I
I
I
I

~ ----1- --- ~
NO<Na
Asalgnmenta
for
Components

l
EITOf-Fnte

Generat.td
Netllat

300

~

Fig. 4

Fig. 5

U.S. Patent

Jul. 10, 2012

Sheet 5of12

400

Netlist
tnterp,.ter

NetH•t
Checker

1

Components
Generator

Connection
Linn
optimizer

Error-Free
Schematic

Fig. 6

US 8,219,374 Bl

U.S. Patent

Jul. 10, 2012

US 8,219,374 Bl

Sheet 6of12

500

11

l

Check F1rs1 Line

-·-·-~---------

---g-.

------r E.limina1e Units by

·
substituting their weights .
(e.g. µ=1 O"~)

I

--------

Oetennine Component
Type

l
No

~v• Parameter Name
and Value in Souroe
Objlll!Ct

)"">

Last Netlist
Line? /

Yes

c )
END

-------

Fig. 7

,

U.S. Patent

Jul. 10, 2012

Sheet 7of12

US 8,219,374 Bl

~-s::1

E

600

Variable
------

___}'.___

-

-

-

1

Add Other Symbolic
Variables or
Expressions, through
algebraic operations(+ .•
,/,*,A)

~_

1

J

_y_ _____

Get Symbolic
Expression, as
multivariate
polynomial rational
function

I

I

L

-----------

r---Aggregate several

Substitute Numericalj
values for any/all
variable in
expression

j

Symbolic
expressions into a
Symbolic Matrix
~-----------

~et

s:mbolic

terminants and

Cofactors of
y-=-~lic Matrix

l

JI

Pass Result to Time
Module

I
_J
(

__ _y__~

~--~~-----)
Fig. 8

Reduce Symbolic
rational expression to
simplest form

IL _______

Limit any variable to
zero or infinity

U.S. Patent

700

Jul. 10, 2012

---..

US 8,219,374 Bl

Sheet 8of12

Enter vnivariate
polynomial rational
function with numerical
coefficients (Laplace

domain transfer
function)

,---'!_____

roots~

Find
denominator
(Laguerre's
method)

--~~·.

I
j

I
•

_____J

Obtain"Parti:t

c~raction

Lansions
-~--

-App~ :verse

I

Laplace

Transform

1

I
I

______._y

--1

Get Time domain
Expression

_______ _J

U.S. Patent

Jul. 10, 2012

US 8,219,374 Bl

Sheet 9of12

800
Collect Switching
elements in
netlist

~~~1-s~~~lI

Store
and switch time
for each s~itchj

,_ _ _y______

~---"---Get state change
time for circuit in

Find which
switches ar on or
off for any time

chronologic.al
order

t>O

'f

( __
En_d__)

Fig. 10

U.S. Patent

900

Jul. 10, 2012

(

l

Start )

1

Get Desired
Output Nodes

Draw Circuit on
Graphic Editor

1

1

Populate
Y-admittance
Matrix
I

Find Residues
(Partial Fraction
Expansion)

1

Find appropriate
Cofactors

l

Convert
To Netlist

!

US 8,219,374 Bl

Sheet 10 of 12

isplay Transfer
Functions
Find Poles
(using laguerre's
method)

Apply Symbolic Inverse
Laplace Transform
(Symbolic time
response)

,(·
/;'
·,,_

Plot
Transient

··

'\, --.-.------- ·<:/

s

I

Fig. 11

Display,
Plot

Populare Symbolic
Admittance Malm<

Source

SopMatrix

rs op
(ra!i:lnal sop)

Complex

Fig. 12

0

mk3

..

mk4

..
I

I

I

mn]

..

m,J~(;J; ~
"

-1

m12

1

mu

0

m2n

min

XO--+ 0

..

..

Fig. 13

XO

mks+-

..

..
1

..

..

R ~Number of rows X 0 appears in

mnl

mk1

1
mk2 -x-

XO

m24

m23

m22+-

m21

1

m14

m13

m12

mu

0

0

m13

0

0

fn,4

0

..
1

0

min

.. ..

.. ..

~

=........
.........

""'"'

=

~

w
-....l

\C

""'"'

'N

rJl
00

d

N

0

.....

('D
('D

1J1

N

....

N
0

~o

2'
....
:--

~

=

~

~

~

~

00
•

U.S. Patent

Jul. 10, 2012

Cuurent Controlled
Current Source

Voltage Controlled
Current Source

a +o

-0

c

a

c

<;

:J

g,

aVab

vab
b

US 8,219,374 Bl

Sheet 12 of 12

a/ab= agtVab

b

d

d

/ - ........

a o
+

I

/

c

"

I XO

c
\

..
a Vab)'-----

II
\
0

~v

x

ab

0

I

\
b

Voltage Controlled
Voltage Source

\

I
I

\
"

"-

d

/

d

/

c

a

X ..+0
0

Current Controlled
Voltage Source

d

b

Fig. 14

US 8,219,374 Bl
1

2

SYMBOLIC SWITCH/LINEAR CIRCUIT
SIMULATOR SYSTEMS AND METHODS

bolic solver and simulators, systems and methods, that
develop enhanced problem solving skills using internet as a
portable platform for the education environment.
A secondary objective of the present invention is to provide
interactive and real time web-based electrical circuit symbolic solver and simulators, systems and methods that
develop design skills and sharpen critical thinking.
A third objective of the present invention is to provide
interactive and real time web-based electrical circuit symbolic solver and simulators, systems and methods that
develop global and comprehensive teaching circuit tools
which can be adopted nationally for educational purposes.
Another objective of the present invention is to provide an
interactive web-based circuit drawing tool for user interaction
and Netlist generation. Students can use the online circuit
drawer to carry out circuit simulation on the web and access
it virtually from any place. The online simulator provides a
user friendly graphical user interface (GUI), which has the
capability to allow students to draw electrical circuits and
engage the symbolic circuit solver on them.
Another objective of the present invention is to provide a
versatile symbolic based linear circuit with switches solver.
The solver works by accepting a Netlist from the drawing
tool, and the element one wants to find the voltage across or
current on, as input parameters. Then it either produces the
plot or the time domain expression of the output. Frequency
domain plots or Symbolic Transfer Functions are also produced. The solver gets its input from the circuit drawer.
The SymCirc Symbolic Solver provides all simulation
results as Time domain expressions composed of the basis
functions that exclusively include exponentials, sines,
cosines and/or t raised to any power. When the student continuously encounters such solution forms and correlates them
with the plots, it drives him or her more smoothly into a
deeper understanding of the subject matter on a level that
would otherwise require much effort and time.
The invention writes all components in the Java programming language due to its extensive support of web applications.
Further objects and advantages of this invention will be
apparent from the following detailed description of the presently preferred embodiments which are illustrated schematically in the accompanying exhibits.

This invention claims the benefit of priority to U.S. Provisional Patent Application 60/902,582 filed Feb. 21, 2007.
FIELD OF INVENTION
This invention relates to interactive and real time webbased electrical circuit symbolic solver and simulators, in
particular to an interactive and innovative graphical user
interface (GUI) for creating circuit schematics and generating
netlists, circuits symbolic solving and instant simulated solutions, their systems and methods.
BACKGROUND AND PRIOR ART
Typical simulation tools that students in the Electrical
Engineering (EE) field encounter after starting their first Circuits course are numerical in nature that is when presented
with an input circuit, they iteratively solve it across a set of
small time steps. The result is represented as a data set of
output versus time, which can be plotted for further inspection. Such results don't help the student understand the ultimate nature of circuits as Linear Time-Invariant systems with
a finite dimensional basis in the solution space. PSpice is one
example of a widely used software simulation tool that uses
the approach mentioned earlier.
Currently there are no circuit solvers that are available
online. If any, they would be of limited capabilities. For
example, several Electrical Circuits books provide webbased circuit solvers for their examples used in the book.
However, these solvers are very limited to the examples and
they cannot be used to solve an arbitrary circuit.
The prior techniques do not develop enhanced problem
solving skills using inteme as a portable platform for the
education environment. The prior techniques do not develop
design skills and sharpen critical thinking. The prior techniques do not develop global and comprehensive teaching
circuit tools which can be adopted nationally for educational
purposes.
Thus, the need exists for solutions to the problems with the
prior art.

10

15

20

25

30

35

40

BRIEF DESCRIPTION OF THE FIGURES
FIG. 1 shows an overview screen shot of the innovative
GUI (graphical user interface).
FIG. 2 shows an example of a three loop circuit.
FIG. 3 shows a circuit checking flowchart.
FIG. 4 shows a netlist generator flowchart.
FIG. 5 shows a netlist generation steps overview.
FIG. 6 shows a netlist to schematic generator flowchart.
FIG. 7 shows a flowchart for Net Parser module.
FIG. 8 shows a flowchart for Symbolic module.
FIG. 9 shows a flowchart for Time Domain Module
FIG. 10 shows a flowchart for Switching module.
FIG. 11 shows an overview flowchart for a specific execution.
FIG.12 shows Interrelationship diagramofModule classes
FIG. 13 shows a Pre-determinant evaluation limit finding
algorithm.
FIG. 14 shows Reduction of all dependent sources to
VCCS case

45

50

55

60

SUMMARY OF THE INVENTION
65

A primary objective of the present invention is to provide
interactive and real time web-based electrical circuit sym-

DESCRIPTION OF THE PREFERRED
EMBODIMENTS
Before explaining the disclosed embodiments of the
present invention in detail it is to be understood that the
invention is not limited in its applications to the details of the
particular arrangements shown since the invention is capable
of other embodiments. Also, the terminology used herein is
for the purpose of description and not of limitation.
A list of components will now be described.
1. Screen Shot of Graphical User Interface (GUI)
5.Menubar
10. Standard Tool Bar
15. Canvas Toolbar
20. Simulation Toolbar
25. Components Toolbar
30. Page Navigator
35. Status bar
40. Components Panel
45. Visiting elements Panel
50. Simulation Panel
60. Drawing Panel
70. View menu

US 8,219,374 Bl
4

3
75. Display Properties
80. DC voltage source inputs
100 Three Loop Circuit
110 Resistor Checker
200. Netlist Generator Flowchart
300. Netlist Generation Steps
400. Netlist to Schematic Generator Flowchart
500. Net Parser Module Flowchart
600. Symbolic Module Flowchart
700. Time Domain Module Flowchart
800. Switching Module Flowchart
900. Specific Execution Route Flowchart

GUI Interface
The GUI interface has integrated functionalities, which
provide the user with the capability to construct a circuit
schematic and generate a netlist. The invention can use a GUI
interface system such as, but not limited to, one described in
U.S. Pat. No. 6,121,965 to Kenney et al, which is incorporated
by reference. The invention can use a remote server that is
controlled by an educational institution such as a university, a
technical school, a science school and academy, and the like.
Additionally, the remote server can be an electronics book
publisher, a science book publisher and a technical book
publisher, and the like.
Students, scientists, engineers, and the like, or other users
can remotely access the server-side through their GUI interfaces as long as the interface can run Java applications. See for
example, Eckel, Bruce, Thinking in Java, 3rd edition, 2002,
which is nonessential subject matter incorporated by reference. The interfaces can include, but are not limited to, desktop computers, laptop computers, PDAs (Personal Digital
Assistants), and the like.
The user can add components to the GUI grid and manage
the schematic efficiently using the implemented GUI's panels, toolbars, menu bars, popup menus, and the like. The GUI
gives the user the option to change the component's attributes
and save the changes to the components database, as shown in
FIGS. 1 and 2.
FIG. 1 shows an overview screen shot of the innovative
GUI (graphical user interface) 1. FIG. 2 shows an example of
a three loop circuit 100 with Resistor checker 110. Referring
to FIGS.1-2, GUI screenl canincludeaMenubar5, Standard
Tool Bar 10, Canvas Toolbar 15, Simulation Toolbar 20,
Components Toolbar 25, Page Navigator 30, Status bar 35,
Components Panel 40, Visiting elements Panel 45, Simulation Panel 50, Drawing Panel 60, View menu 70, Display
Properties 75, DC voltage source inputs 80, that can be used
to create a circuit having electrical components such as resistors in circuits that can be tested.
The implemented circuit checker algorithm checks the
connections of the constructed schematic for common circuit
errors, such as an empty schematic, short circuit loops, floating nodes, ground does not exist, dependent controllers
doesn't exist, and the like, and notifies the user accordingly.
FIG. 3 shows the circuit checking algorithm flowchart.
Another main innovation is the implemented algorithm to
generate the netlist from the schematic after checking the
schematic for common circuit errors. The netlist generator
has two phases: the network optimization, and the nodes
assignment. In the network optimization phase, all the connection lines, which are electrically connected, must be
merged and reduced to an identified net name, In the nodes
assignment phase, all components are traversed to assign a net
name for each component's node. If there are two components, which have nodes that are electronically connected by
a connection line, they should be assigned the same net name.

10

15

20

25

30

35

40

45

The generated network of nodes and components is considered as a preliminary step for circuit simulation, which is
fed through the symbolic solver engine for simulation and
analysis. The Netlist generation flowchart and steps are
shown in FIGS. 4 and 5 respectively. FIG. 4 shows a netlist
generator flowchart 200. FIG. 5 shows a netlist generation
steps overview 300.
The GUI interface has an implemented algorithm to convert a given netlist to a schematic by directly typing the netlist
to the netlist editor, which is implemented in the GUI interface. The Netlist-to-Schematic generator 400 is comprised of
the following four main modules as shown in FIG. 6:
1) The netlist interpreter, which interprets the netlist text to
identified components names, nodes and attributes.
2) The netlist checker which checks the netlist from the
common circuit and netlist errors.
3) The components generator, which builds the database of
the identified components associated with nodes and
attributes.
4) The connection lines optimizer is an implemented algorithm to draw the connection lines in the constructed
schematic in very neat and organized presentation.
An interactive and real time web-based electrical circuit
simulator (SymCir) is presented, which provides the user
with an interactive and innovative graphical user interface
(GUI) to create a circuit schematic and generate a netlist. The
implemented algorithms to check the schematic for common
circuit errors and generate the netlist from the schematic are
the main innovated integrated features in the GUI interface.
Furthermore, The GUI has the capability to enter the netlist
and feed it directly to the simulator with the feature of constructing the schematic from the given netlist. The netlist is
then sent to the symbolic solver engine for simulation and the
results are returned back to the GUI for display.
SymCirc Symbolic Engine
The symbolic solver engine can be decomposed into five
main components (modules A through E), as follows,
A The Netlist Parser module: a module that converts a
Netlist into a corresponding symbolic indefinite admittance matrix, while storing the values for the elements
and inputs and other parameters like switch states for
further use. The flowchart for this module is shown in
FIG. 7. FIG. 7 shows a flowchart for Net Parser module
500.

50

55

60

65

As shown, the net list is entered, then the first line is
checked. The units are eliminated and their weights is substituted, the component type is determined and then a symbolic
Y-matrix is populated according to the component type. The
parameter name and value are saved in source object code. If
it is the last line of the netlist, the process is complete. If it is
not the last line, the steps are repeated for each next line until
the last line is complete.
B Symbolic module: a module that implements the capability of constructing symbolic variables, aggregating
them into expressions (multivariate polynomial or rational), and manipulating them in different ways (simplification, substitution, finding limits, etc.). Those symbolic
objects can also be combined into Symbolic Matrix
Objects on which symbolic determinant calculation,
cofactoring and population operations can be performed. This module is a critical part of SymCirc with
which the tenets of the Indefinite Admittance Matrix
approach for circuit analysis as described in Chen, WaiKai, Active Network and Feedback Amplifier Theory,
Chapter 2, Hemisphere Publishing Corporation, 1980,

US 8,219,374 Bl
5

6

which is none essential subject matter, which is incorfurthermore suggests a way of unifying how the four
dependent sources populate the Matrix.
porated by reference. The flowchart for this module 600
3. Rather than treating dependent current and voltage
is shown in FIG. 8.
sources as separate cases, where the dependent voltage
C Time Domain Module: a module that picks up a rational
source would be considered as a constraint that reduces
function of s with numerical coefficients that represents
the size of the admittance matrix, a special symbolic
the laplace transform of the output and through a process
impedance Xo is added to the voltage source in series.
of root extraction, residue evaluation and applying the
After applying Norton's theorem the voltage dependent
inverse laplace transform arrives at the time domain
source reduces to a current dependent source, which is
expressions of the signal at the output. The flowchart for
10
easier and more efficient to populate within the matrix as
this module 700 is shown in FIG. 9. As shown, the
shown in Chen, Wai-Kai, Active Network and Feedback
univariate polynomial rational funtion (Laplace transAmplifier Theory, Chapter 2, Hemisphere Publishing
form) is entered, using Laguerre's method the roots of
Corporation, 1980. Later, the limit finding algorithms
the denominator and residue are found, the partial fracare invoked to force all Xo terms to approach zero and
tion expansions are found and the inverse Laplace trans- 15
therefore disappear. FIG. 8 summarizes how all the
form is applied to get the time domain expression.
dependent sources relate to the Voltage Controlled CurD Switching Module: The part of SymCirc that collects
rent Source.
information about the switches within the circuit and
4. When dependent sources exist in the circuit, the limit
their states with respect to time. The flowchart for this
finding functions manipulate the cofactor matrices
module 800 is shown in FIG. 10. As shown, the module 20
before finding the determinant so as to reduce the comcollect the switching elements form the netlist and stores
plexity and length (therefore reducing processing time)
the initial state and switch time for each of the switches.
of the resulting transfer functions. This pre-determinant
The collected data is used to find which switches are on
evaluation limit finding is done as elaborated in the
and off at any time t greater than zero and determines the
example in FIG. 13 showing the cofactor that reduces to
state change time for the circuit in chronological order. 25
the transfer function numerator. The term (1/Xo that
E Plotter Module: A module that plots time and frequency
appears normally cancels out with an equivalent term in
the cofactor of the denominator, unless the transfer funcdomain plots of the simulation results, with ability to
tion must reduce to zero, in that case power R of the
control domain, zoom level, resolution and time shift. It
is built on top of jFreeChart which is an open source
denominator cofactor will be larger than the numerator
30
charting library for Java.
power R. FIG. 14 shows the algorithm for reducing all
dependent sources to Voltage Controlled Current
The SymCirc symbolic Engine receives the Netlist proSources (VCCS).
duced by a front end GUI circuit drawer and returns to the user
The symbolic circuit solver is the core of the Interactive
either the symbolic transfer function, the time domain
Linear Circuits Symbolic Simulation Tool. It is subdivided
response as an expression or a plot, or the frequency response
plot. The Engine is implemented in Java for web accessibility. 35 into several subroutines which when applied in succession to
a Netlist yield the Symbolic time response. The flowchart of
It is capable of dealing with arbitrary Linear Circuits with
Switching elements. FIG. 11 shows an overview flowchart
FIG. 11 starting from third execution block shows an outline
900 for a specific execution route. FIG. 12 shows an interreof what each subroutine does. After simulation is requested
lationship diagram of modules (a toe) classes.
by the user through the Simulation & Analysis menu the
The implementation is built upon a Symbolic Algebra 40 Netlist Parser passes the Netlist into a class that uses the list
module that is used to apply the techniques discussed in Chen,
data to populate the Indefinite Admittance Matrix for the
Wai-Kai, Active Network and Feedback Amplifier Theory,
circuit. The Indefinite Admittance Matrix is populated like
Chapter 2, Hemisphere Publishing Corporation, 1980, which
any regular admittance matrix by the following rule:
yi/={Sum of admittances connected to node i, ifi=j
is nonessential subject matter incorporated by reference, on
symbolic variable entries rather than numeric ones.
45
{Negative sum of admittances between i and j, if i"'j
The only difference between this and the regular admittance
Innovations in the application of those techniques include
a unified approach to presenting the dependent sources by the
matrix is that for this case the ground reference node is conintroduction of durnniy parameters that are limited to zero,
sidered to be outside the circuit. Note that all entries are in the
applying a novel method of finding said limits before evalufrequency domain in this example since a dynamic response
ating the determinant since determinant evaluation is the 50 is desired.
bottleneck. Finally, another innovation is the treatment of all
Then, depending on which outputs the user chooses to
sources as impedances then finding specific transfer functions
compute the symbolic results for, the program computes all
by applying the limiting procedure directly on the produced
required determinants and cofactors symbolically. The algotransfer function therefore eliminating the need to evaluate
rithms are adjusted to manipulate symbolic objects rather
determinants more than once.
55 than just numerical values. Determinants were implemented
The main innovative aspects in the implementation of the
using the method of LU factorization since it is fast and
SymCirc symbolic solving Engine stem from the fact that the,
efficient which is a big advantage for a simulation tool, and it
1. Indefinite Admittance Matrix, from which the response
was actually discovered that this part is not a bottleneck for
is computed, is populated with symbolic rather than
the simulation, unlike later parts where large symbolic results
60 may need to be manipulated. All transfer functions are modnumerical elements
eled as objects and are reduced to a standard rational s-func2. The developed procedure for finding limits at infinity
tion (Laplace domain) form before being displayed. The next
and zero for symbolic expressions allows a much simstep extracts the roots of the s-function denominator, it is well
pler attack of the problem of evaluating the cofactors and
determinant as described in Chen, Wai-Kai, Active Netknown that the values and number of the roots depend on the
work and Feedback Amplifier Theory, Chapter 2, Hemi- 65 coefficients and order of the circuit (number of storage elesphere Publishing Corporation, 1980, which is nonesments) respectively. Those same coefficients are of course
sential subject matter incorporated by reference and
functions of the circuit parameters (admittances, capacitance

t

US 8,219,374 Bl
7
and inductance values, etc.). At this point the numerical values of the circuit components are substituted into the transfer
functions since it is impossible to get roots in closed symbolic
form for polynomial equations larger than fifth order.
Laguerre's root finding algorithm was implemented here due
to its capability of converging quickly to complex roots. The
algorithm definition is:
1. Let sk be a random complex number

8

We claim:
1. A GUI (graphical user interface) system comprising:
a processor;
a memory;
a simulator for a user to draw a new electrical circuit
containing components on a display, each component
including one or more of a label, a value and a unit;
a circuit checker to check electrical connections in the new
electrical circuit for checking for errors in the new elec10
trical circuit and notifying the user when error are found;
1
a netlist generator for generating a netlist of nodes and
2. Calculate A= D (s,)
components from the error checked electrical circuit;
D(s,)
a netlist editor for receiving the netlist of nodes and com11
ponents; annetlist-to-schematic algorithm to convert the
3. Calculate B = A 2 - D (sk)
D(s,)
15
netlist of nodes and components to a test schematic, the
netlist-to-schematic algorithm consisting of:
a netlist interpreter for interpreting netlist text from a
4. Calculate
netlist to identified components names, nodes and
attributes;
a netlist checker for checking the netlist for common
20
n
C=
,
circuit and netlist errors;
A ± ,/ (n - 1 )(nB - G2)
a component generator for building a database of identified components associated with nodes and
Choose the sign that gives the larger denominator absolute
attributes of the checked netlist; and
value (where n is the number of roots).
25
a connection lines optimizer for drawing connection
lines from the database of the identified components
5. Set sk+i=sk-C
to generate an error free schematic; and
6. Repeat 2 to 5 until convergence occurs, store root as rk
a symbolic solver engine to simulate the circuit shown in
7. Divide Denominator by (s-rk), Repeat 2-7 for result.
the test schematic, wherein the GUI interface is used as
The Java class that implemented the above algorithm returns
an online circuit simulator, the symbolic solver engine
all roots with the multiplicity for each one. It then hands the 30
consisting of:
root data to another module that applies the Residue theorem
a netlist parser module to convert the netlist into a corto essentially obtain the partial fraction expansion of the
responding symbolic indefinite admittance matrix
transfer function:
and storing values for circuit components, inputs and
35
component parameters, the netlist parser module consisting of:
1 - lim { ,r--1 [(s- s,rT(s)] }
ResT(s) = - for
each component,
1
s=sk
(m - 1) ! s-'>sk &sma first set of parser instructions to eliminate the component units by substituting their units;
All partial fraction objects are then fed into the Symbolic 40
a second set of parser instructions to determine a
Inverse Laplace transform module which constructs the final
component type;
required time response. The GUI provides tools for graphia third set of parser instructions to populate a symcally plotting such responses with respect to time or just
bolic Y-matrix according to the component type;
potting the frequency response.
and
Another innovation is the treatment of all independent 45
a fourth set of parser instructions to save a parameter
sources (inputs and those representing capacitor and inductor
name and value in source object;
initial conditions) as resistors and populating them into the
a symbolic module to construct symbolic variables, aggreadmittance matrix as such. Due to the fact that the evaluation
gating the symbolic variables into expressions and
of the symbolic determinant step is a bottleneck in the code,
manipulating the symbolic variables;
this novel technique requires evaluating the determinant only 50
a time domain module to produce a time domain expresonce rather than the number of sources in the circuit as presion from the results of the symbolic module;
sented in Chen, Wai-Kai, Active Network and Feedback
a switching module to collect information about a switchAmplifier Theory, Chapter 2, Hemisphere Publishing Corpoing component in the circuit and the state of the switchration, 1980. The produced transfer function is then reduced
ing component with respect to time;
an output consisting of at least one of a symbolic transfer
to the correct form for a specific input by limiting the symbol 55
representing that input to infinity (whether the input is a
function, a time domain response as an expression, the
voltage or a current), and limiting all other symbols repretime domain as a plot or a frequency response plot; and
senting voltage and current sources to zero and infinity
a plotter module to plot the time and frequency domain of
the simulated results.
respectively.
While the invention has been described, disclosed, illus- 60
2. The GUI system of claim 1, wherein the circuit simulator
trated and shown in various terms of certain embodiments or
includes:
modifications which it has presumed in practice, the scope of
a Java program to run the simulator.
the invention is not intended to be, nor should it be deemed to
3. The GUI system of claim 1, wherein the checked errors
be, limited thereby and such other modifications or embodiare selected from a group consisting of:
an empty schematic, short circuit loops, floating nodes,
ments as may be suggested by the teachings herein are par- 65
ticularly reserved especially as they fall within the breadth
ground that does not exist, dependent controllers that do
and scope of the claims here appended.
not exist, and combinations thereof.

US 8,219,374 Bl
9

10

4. The GUI system of claim 1, wherein the netlist generator

consisting essentially of:
a network optimizer phase; and
a nodes assignment.
5. The GUI system of claim 4, wherein the network optimizer consists of:
a merger for merging all electrically connected connection
lines; and
a reducer for reducing the merged lines to an identified net
name.
6. The GUI system of claim 5, wherein the nodes assigner
phase consists of:
a traverser to traverse each components node; and
an assigner for assigning all traversed components for each
component node to a net name, traversed components
electrically connected by a connection line being
assigned the same net name.
7. The system of claim 1 wherein the symbolic module
consists of:
a first set of symbolic instructions to add symbolic variable
or expressions through algebraic expressions;
a second set of symbolic instructions to aggregate the symbolic variable or expressions as a multivariate polynomial rational function; and
a third set of symbolic instructions to consisting of one or
more of
a first subset of instructions to substitute numerical values of a variable in the symbolic expression;
a second subset of instructions to aggregate two or more
symbolic expressions into a symbolic matrix, get
determinants and cofactors of the symbolic matrix
and pass the results to a time domain module;

10

15

20

25

30

a third subset of instructions to reduce the symbolic
rational expression to a simplest form; and
a fourth subset of instructions to limit the variable to zero
or infinity.
8. The system of claim 7 wherein the time domain module
consists of:
an input to allow the user to enter an univariate polynomial
rational function with numerical coefficients;
a first set of time domain instructions to find the roots of a
denominator from the univariate polynomial rational
function;
a second set of time domain instructions to find the residues;
a third set of time domain instructions to obtain partial
fraction expansions;
a fourth set of time domain instructions to apply inverse
Laplace transform; and
a fifth set of time domain instructions to determine the time
domain transform.
9. The system of claim 8 wherein the switching module
consists of:
a first set of switching instructions to collect switching
elements from the netlist;
a second set of switching instructions to save an initial state
and switch time for each collected switching element;
and
a third set of switching instructions to determine which of
the switching elements are on and off at a point in time
and arrange switch state change time for the test circuit
in chronological order.

* * * * *

