Charles Pence
5696d7c94d

2 years ago  

build  9 years ago  
doc/html  3 years ago  
include  11 years ago  
lib  10 years ago  
src  3 years ago  
tests  9 years ago  
.gitignore  3 years ago  
AUTHORS  12 years ago  
COPYING  12 years ago  
ChangeLog  11 years ago  
INSTALL  9 years ago  
Makefile.am  11 years ago  
NEWS  10 years ago  
README  2 years ago  
README.md  2 years ago  
THANKS  11 years ago  
aformula1.1.pc.in  11 years ago  
config.h.in  9 years ago  
configure.ac  9 years ago  
doxygen.cfg  11 years ago 
README.md
AFormula
AFormula is a library for dynamically calculating the value of mathematical formulas, passed in as strings. It is designed to mirror roughly the API of the muParser library http://muparser.sourceforge.net/ as well as offer me a place to experiment with more advanced formula evaluation techniques such as JITcompiling formulas.
Support is included for all the standard arithmetic and comparative operators, including <=, >=, !=, ==, <, >, +, , *, /, and ^ (power). Arbitrary variables may be defined (as pointers to doublevalues), and the assignment operator (=) may be used to assign values to them. A full suite of builtin functions is supported, including:
 Trigonometry (sin, cos, tan, asin, acos, atan, atan2)
 Hyperbolic trigonometry (sinh, cosh, tanh, asinh, acosh, atanh)
 Exponentials (log2, log10 [= log], ln, exp, sqrt)
 Miscellaneous (sign, rint, abs)
 Logical control (if(x,iftrue,iffalse))
Finally, the constants 'pi' and 'e' are supported.
The priority of operations is:
= (assignment, lowest)
<=, >=, !=, ==, <, > (comparisons)
+,  (addition/subtraction)
*, / (multiplication/division)
^ (exponentiation)
AFormula is designed to be quite robust to invalid formulas, and is careful to return appropriate errors when necessary.
There are two JIT backends which AFormula can use in order to compile functions on the fly: LLVM and libjit. In general, both should provide roughly the same performance, though there is a performance test included which will benchmark the library and permit selection at runtime.
Documentation
Doxygen documentation for this library is available at https://aformula.charlespence.net.
Requirements
The Boost C++ Libraries http://www.boost.org are required to build AFormula.
If you want either of the dynamiccompilation backends to be built, you will need to install either LLVM (version 3) http://www.llvm.org, or libjit http://freshmeat.net/projects/libjit/.
Note that at the time of this writing I was not able to get libjit to compile without a fair bit of hacking around on its source code. I've pushed my changes to an unofficial clone of libjit, available at http://github.com/cpence/libjit.
Neither of these libraries are necessary (the included muParser backend will be built regardless), but they will provide a large speed boost.
Thanks
Thanks are most obviously due to the author of muParser, Ingo Berg. Without muParser having been written, I never would have been able to start on the project that produced the need for AFormula. muParser, which is licensed under the MIT license, is Copyright (C) 20042006 Ingo Berg.
Also, thanks is due to the pair of massively crossplatform JIT compilation libraries, LLVM and libjit, without which a JITcompilation backend (for something like an order of magnitude of performance) would be impossible.