- by writing so called domain-specific language - math expressions compiler. This is achieved by using some tools such as fsyacc and fslex. Defining custom tokens and etc.
- by using .NET System.CodeDom.Compiler libraries. This is achieved by generating class definition "on the fly" and with the help of CodeDom - compiling this class in memory.
- another different approach - is try to write F# script which recursively analyzes math expression and evaluates it piece by piece until it finds the answer. This solution does not use tools mentioned above.
So the last approach will be discussed here. Main algorithm of evaluating math expressions is displayed below:
data:image/s3,"s3://crabby-images/15f3d/15f3d48f1b0c16c04253e187c07644877bef29f5" alt=""
F# code which implements this idea is placed here.
There are also some eval() function tests implemented in this code. So that after executing this script you will get output something like:
data:image/s3,"s3://crabby-images/2de56/2de563ab8fba4fca602f1470baff876fb85f780a" alt=""
Conclusions:
It is possible to generalize eval() function algorithm in about 90~ lines of F# code without using CodeDom model or fsyacc/fslex tools. This makes solution pretty much "homogeneous" which can be useful in some situations. Also this eval() implementation takes as input arbitrary math expression. As for the bad side - solution is very slow (can be hundreds of times slower than plain F# function call), because of joining/spliting lists constantly. So if you need fast implementation of eval - you should optimize/rewrite this code if possible or take a look in other above mentioned solutions. But in systems where speed issues are not critical - this solution may be OK.
Have fun with F# and eval !!
No comments:
Post a Comment
Comment will be posted after comment moderation.
Thank you for your appreciation.