easy_expression_eval v1.1.0
Easy Expression Eval (eeeval)
eeeval is a lightweight and efficient expression evaluator for Crystal. It supports mathematical calculations, user-defined variables, pre-compiled ASTs for performance, and conditional expressions.
Installation
-
Add the dependency to your
shard.yml:dependencies: eeeval: github: eltony81/easy_expression_eval -
Run
shards install
Features
Mathematical Evaluation
You can evaluate complex mathematical expressions containing numbers, functions, and operators:
require "eeeval"
# Simple evaluation
result = EEEval::CalcFuncParser.evaluate("sin(pi/2) + e")
puts result # => 3.718281828459045
Variables Support (Native & Efficient)
Pass a hash of variables to the evaluator. No string replacement is performed; variables are resolved during AST evaluation:
require "eeeval"
vars = {"x" => 3.0, "y" => 1.5}
result = EEEval::CalcFuncParser.evaluate("x^2 + sin(y)", vars)
puts result
Pre-compilation (AST)
For performance-critical code (such as evaluations inside loops), compile the expression once into an AST, then evaluate it repeatedly with different variables:
require "eeeval"
# Compile the expression once
ast = EEEval::CalcFuncParser.compile("sin(x) * phi")
# Evaluate multiple times without re-parsing
(0..100).each do |i|
res = EEEval::CalcFuncParser.evaluate(ast, {"x" => i.to_f64})
puts "f(#{i}) = #{res}"
end
Conditional Expressions
The library includes a CondParser for boolean logic:
require "eeeval"
# Numeric comparisons
EEEval::CondParser.evaluate("10 == 10") # => true
EEEval::CondParser.evaluate("5 != 3") # => true
# String comparisons
EEEval::CondParser.evaluate("'hello' == 'hello'") # => true
# Logical operators
EEEval::CondParser.evaluate("(1 == 1) && (2 != 3)") # => true
EEEval::CondParser.evaluate("1 == 0 || 1 == 1") # => true
Built-in Support
- Constants:
pi,e,tau,sqrt2,phi,rad2deg,deg2rad,g,inf,nan. - Functions:
sin,cos,tan,asin,acos,atan,log,log2,log10,exp,exp2,sqrt,abs,floor,ceil,round,sgn,sinh,cosh,tanh,gamma. - Operators:
+,-,*,/,%(modulo),^(power).
Performance
eeeval is designed for high-performance mathematical evaluation, especially in scenarios requiring repetitive calculations. Beyond using a pre-compiled AST, it employs several key strategies:
- Vectorization (Tensor Integration): Built on top of
num.cr, the evaluator can process entire Tensors in a single pass. When evaluating ranges, operations are performed on data blocks using SIMD-like patterns, drastically reducing overhead compared to standard loops. - Constant Folding: During AST compilation, sub-expressions containing only constants (e.g.,
sin(pi/2) * 10) are pre-calculated and replaced with a single numeric node, eliminating redundant math at runtime. - Native Symbol Resolution: Variables and constants are resolved directly via an environment hash. No string replacement or regex manipulation is performed during evaluation.
- Single-Pass Parsing: Uses an optimized Shunting-Yard algorithm to build the AST in a single tokenization pass, ensuring minimal memory allocation and fast startup.
Examples
The repository includes standalone scripts in the examples/ directory to demonstrate advanced usage:
- Gaussian Distribution: Calculation of PDF and ASCII visualization.
- Mandelbrot Set: ASCII rendering of the famous fractal.
- Monte Carlo Pi: Estimation of π using random sampling.
Run them with:
crystal examples/gaussian.cr
CLI Usage
The library includes a powerful CLI tool (eeval) for quick evaluations, range calculations, and interactive sessions.
Installation
Build the executable using shards:
shards build eeval
The binary will be available at ./bin/eeval.
Parameters:
-v, --var VAR: Specify the variable name to use in the range evaluation (e.g.,x,t).-s, --start VAL: Set the starting value for the range evaluation.-e, --end VAL: Set the ending value for the range evaluation.-d, --step VAL: Set the increment step size (defaults to1.0).-D, --define VAR=VAL: Define a fixed variable (e.g.,-D offset=10).-c, --cond: Use the conditional evaluator for boolean logic.-i, --interactive: Start an interactive REPL session.
Examples:
Single expression evaluation:
./bin/eeval "sin(pi/2) + e"
Range evaluation (vector calculation): Evaluate x^2 + sin(x) for x from 0 to 10 with a step of 0.5.
./bin/eeval -v x -s 0 -e 10 -d 0.5 "x^2 + sin(x)"
Using custom variables:
./bin/eeval -D a=5 -D b=2 "a^b + 10"
Interactive REPL:
./bin/eeval -i
Contributing
- Fork it (https://github.com/eltony81/easy_expression_eval/fork)
- Create your feature branch (
git checkout -b my-new-feature) - Commit your changes (
git commit -am 'Add some feature') - Push to the branch (
git push origin my-new-feature) - Create a new Pull Request
Contributors
- eltony81 - creator and maintainer
easy_expression_eval
- 3
- 0
- 0
- 0
- 1
- 18 days ago
- November 28, 2022
MIT License
Sun, 14 Jun 2026 10:53:59 GMT