A New Kind of Graphing Tool
If you've been using any of the betas at www.hunterdavis.com/quickgrapher/ you may have found yourself wondering how it works, what libraries we use, and if the tech is available for public consumption. QuickGrapher is based on two of our pure Javascript libraries, our solver library and our graphing library. Due to the increased interest in these libraries, we've bundled them both together into a single javascript library you can include on your site, which allows you unprecedented graphing power in a fully client-side javascript environment. You can display unlimited graphs with scores of points and complex equations faster than you ever thought possible, and without requiring your users to download a bandwidth-intensive image or flash applet. Our graph+solve library allows you to embed a graph of arbitrary algorithmic and point complexity using a single "graph" tag, just like any other html tag. Our library is compatiblie with Chrome, Safari, Opera, IE, and even embedded browsers for your iPhone, Blackberry, and Android devices.
Seriously Easy
Ok, so you're writing a post in your blog and you want to display your data on a graph. Maybe you're a huge corporation with thousands of employees, maybe you're an election enthusiast who wants to show some key demographic, or maybe you're just writing in your personal Wordpress blog. You don't pay for application hosting, and even if you did you don't know or don't have the time to install a server process to generate graphs. Why should it be so complicated? Why can't you just do it with a single html tag?
Now you can. Graph+Solve allows you to instantly and easily insert graphs anywhere into your site. Fully stylable via CSS and HTML5 compliant, Graph+Solve allows any level of user from novice to web designer the power to visually display your data.
Example 1
Say you're writing a blog post about trigonometry. Maybe you're an engineer, maybe you're a student, maybe you just like math. You're explaining sin and cos waves, and you'd like to show their periodicity. You could use traditional methods (screenshots of math utilities, excel sheets, etc), or you could have it done in 5 second with Graph+Solve library. Graph+Solve allows you to graph sine, cosine, and many more functions in a single tag. The following tag is all that is required to generate a graph of cosine and sine.
<graph equation1="sin(x)" equation2="cos(y)" />
Versatile Options
Graph+Solve supports a wide range of options and CSS styles. Simply by setting the correct attributes one may use Graph+Solve to instantly create cross-platform maps and terrain graphs. Dimensions, colors, backgrounds, grids, legends and so much more can be easily set using standard html and css tag attributes. Perhaps you're not interested in a background grid, XY coordinates, multiple equations, legends, etc. Graph+Solve allows you to set exactly the options you care about, and can auto-generate any necessary attributes not specified by the user.
Example 2
Say you're writing a blog post about military tactics. Maybe you're a soldier, maybe you're a history buff, maybe you just like tactics. You'd like to show the positions of soldiers on a battlefield grid, and you don't want to have to continually edit maps by hand. With Graph+Solve, you can instantly share your strategies with no image editing. The following tag is all that is needed to generate the following graph.
<graph values="10,10;30,11;40,12;20,8;50,7;60,15;70,5;21,10;33,12;44,24;" label="confederate soldiers" type="point" values2="3,20;10,20;15,23;20,25;33,28;30,22;40,18;55,22;70,18" type2="point" label2="union soliders" background="http://www.hunterdavis.com/discursivelabs/images/3lakes.png" title="Battle of The Three Lakes" style="height:400px; width:400px;"/>
Serious Bandwidth Reduction
Our pure clientside Javascript graph+solve library in its entirety weighs in at 40 kilobytes. That's roughly equivalent to a very small, highly compressed jpeg from a camera phone circa 2005. With this one 40 kilobyte library (less than what adsense loads), you can replace every single graph or equation plot on your website. If you're running a graph heavy website this can be a reduction of many thousands of times. What's more, our graph+solve library is used by many websites, and may be cached by the users browser. If a user is coming in from another graph+solve enabled site, they download nothing. This is a serious reduction in page load times for all browsers, but especially for those on 3g networks or hampered by a slow connection.
Example 3
Let's say you're writing an article on statistics, and you'd like to show a random distribution. A really large random distribution would be best, as the more data the better visual. You could generate a million points using a programming language, then feed it into an existing tool such as excel or matlab. Then, using the same tool you could plot another guide line along the median to show where the mean distribution should be. That is, if you can figure out how to add a line to a plot graph. Or, you could do it in ten seconds in a single line of html using the Graph+Solve library. The following line of html generates a hundred random points and plots a line across the median of the graph. Note how you are able to style the graph using standard CSS tags, and simultaneously display line graphs, point graphs, and equation graphs using the same tag.
<graph equation1="rand(x)" minstepmax1="0,10,1000" title="Mean Random Distrubtion" values1="1,.5;100,.5" label2="Median Line" type2="line"/>
Serious Efficiency
Just because graph+solve is executed by a client's browser, don't expect it to be slow. Graph+solve requires no external plugin of any kind, Flash or otherwise. It speedily graphs thousands of points in a few moments on a Pentium 3 class computer, quite ancient now in 2011. Graphs of complex equations with thousands of data points and complex algebraic functions load faster than a single equivalent image on mobile 3g devices.
Example 4
So you're looking to plot a large number of data points in a graph, and you want it to be easy? Good luck! Unless you're using our Graph+Solve library, you are in for a headache. Find the data source, paste it into your graph generator, save it as an image, upload that image to your web host and align for your page. Need to update a single data point? You've got to do it over. Want to change to a plot graph from a line graph? You've got to do it over. What to update the graph styling, size, etc? You've got to do it over. Want it to look good on all devices? Well you'd better make a new image size for each device! Starting to get frustrated? Do it with a single line of QuickGrapher, update it whenver you like in moments, and never think of it again. The following two lines of html generate line graphs using points taken from an graphing calculator games worksheet. As you can see, switching between a point and a line graph is as simple as selecting "point" or "line"
<graph title="Our Mystery Point Graph" values="20,11;19,6;19,2;17,2;17,6;16,5;15,2;13,2;14,5;14,6;12,6;12,2;10,2;10,4;9,2;7,2;9,6;7,6;4,4;2,3;0,2;1,3;3,5;5,9;9,11;17,11;21,17;23,18;25,17;24,16;20,11;" label="Mystery Points" type="point" style="width:250px;float:left;" />
<graph title="Not A Mystery Anymore" values="20,11;19,6;19,2;17,2;17,6;16,5;15,2;13,2;14,5;14,6;12,6;12,2;10,2;10,4;9,2;7,2;9,6;7,6;4,4;2,3;0,2;1,3;3,5;5,9;9,11;17,11;21,17;23,18;25,17;24,16;20,11;" label="Point Connecting Lines" type="line" style="width:250px;float:left;align:right;" />
|