Recommend this page to a friend!  Stumble It!  Bookmark in del.icio.us 
Download .zip  
Info  Example  Demos  View files (10)  Download .zip  Reputation  Support forum  Blog  Links  
Last Updated  Ratings  Unique User Downloads  Download Rankings  
20150728 (2 days ago)  61%  Total: 1,857 This week: 15  All time: 2,005 This week: 55  
Version  License  PHP version  Categories  
eos 3.2.1  GNU Lesser Genera...  5.3  Graphics, Math  
Description  Author  
This class solves equations with multiple variables.


Details provided by the author  
Add the dependency:
"require": {
"jlawrence/eos": "3.*"
}
$ composer update
and you're done.
This class makes it incredibly easy to use and parse/solve equations in
your own applications. __NOTE__ ALL of the functions within
these classes are static. It is also important to note that these
classes throw exceptions if running in to errors, please read the beginning
of the Math.php
file for the defines of the exceptions thrown. Exceptions
includes a descriptive message of the error encountered and within Parser
will
also typically include the full equation used.
This class has one important function, Parser::solve()
which does all the legwork,
so we'll start there and end with examples.
use jlawrence\eos\Parser;
To use this function:
$value = Parser::solve($eq, $vars);
Is simply a standard equation with variable support.
Example Equations:
2(4x)
5+((1+2)*4)+3
5+4(1+2)+3
10*sin(x)
10*cos(x)
The parser has good implied multiplication, for everything but allowed functions. Allowed functions require an explicit operator on either/both sides to work properly, I hope to change that in the next revision; but for now, note that it will not work as you would expect. For example:
5sin(1.5707963267) = 51
5*sin(1.5707963267) = 5
sin(1.5707963267)5 = 15
The reason is because there is no implied multiplication being applied, the result
of sin(1.5707963267) = 1
is being concatenated with the number 5, giving
incredibly odd results if you are not expecting it.
The variables are fairly simple to understand. If it contains a scalar (ie
a nonarray value) _every_ variable within the equation will be replaced with
that number. If it contains an array, there will be a byvariable replacement 
note that the array MUST be in the format of 'variable' => value
Such as:
array(
'x' => 2,
'y' => 3
);
Given the equation:
5x^y
If this is called by:
Parser::solveIF('5x^y', 2);
It will equal '20', as every variable is replaced by 2. However, if called like:
Parser::solveIF('5x^y', array(
'x' => 2,
'y' => 3));
You will get the result of '40' as it would equate to 5*2^3
, as expected.
To use:
use jlawrence\eos\Graph;
This is the fun class that can create graphs. The image will default to 640x480, to initialize a different size use:
Graph::init($width, $height);
The $width
and $height
are the values used for the image size.
This method will generate the graph for the equation ($eq
) with a min and max
x
range that it will parse through. All Variables explained:
$eq
The Standard Equation to use. _Must_ have a variable in it. (ie x
)$xLow
The starting point for the calculations  the left side of the graph.$xHigh
The last point calculated for the variable  the right side of the graph.$xStep
Stepping point for the variable. Set to null/false to use the smart xStep feature within the graph class.$xyGrid = false
Show x/y
gridlines on the graph. Defaults to false. Each grid line is set at an integer, with a max of 30 lines, so it will calculate the stepping for it. When the grid is show, the lines are labeled along the top and left side of the image. $yGuess = true
Guess the Lower and Upper ybounds
(The bottom and top of the image
respectively.) This will set the the bounds to the lowest y
value
encountered for the $yLow
, and the largest y
value for $yHigh
.$yLow = null
Lower bound for y
. Will be reset if a lower value for y
is found if $yGuess
is true.$yHigh = null
Upper bound for y
. Will be reset if a larger y
value is found if $yGuess
is true.If you don't want the axis' labeled with their numbers, you can turn off the default behavior with:
Graph::$labelAxis = false;
TODO:
To set up a graph with a 21x21
window (ie 10 to 10
) for the equation
sin(x)
and output as PNG, would use as:
Graph::graph('sin(x)', 10, 10, 0.01, true, false, 10, 10);
Graph::outPNG();
Files  
File  Role  Description  

src (7 files)  
README.md  Doc.  Description of class functionality and use cases  
composer.json  Data  Auxiliary data  
index.php  Example  Example usage of graphing function 
Files  /  src  
File  Role  Description 

AdvancedFunctions.php  Class  Class source 
Graph.php  Class  Class source 
Math.php  Class  Class source 
Matrix.php  Class  Class source 
Parser.php  Class  Class source 
Stack.php  Class  Class source 
Trig.php  Class  Class source 
Version Control  Unique User Downloads  Download Rankings  
90%  Total:  1,857  All time:  2,005  
This week:  15  This week:  55  
User Ratings  
 
Applications that use this package  
Equation Grapher Online graphing calculator 
If you know an application of this package, send a message to the author to add a link here.
Related pages  
GitHub Github with readme 
Pages that reference this package  
complex mathematical operations (Turkish) For these complex equations there is a class... 