package
0.0.0-20210308221757-5fede1ba46da
Repository: https://github.com/howeyc/sc.git
Documentation: pkg.go.dev

# README

evaler

Package evaler implements a simple fp arithmetic expression evaluator.

Evaler uses Dijkstra's Shunting Yard algorithm [1] to convert an infix expression to postfix/RPN format [2], then evaluates the RPN expression. The implementation is adapted from a Java implementation at [3]. The results are returned as a math/big *big.Rat.

This is release 2.0. The previous version that returned results as float64 is in the branch float64.

Usage

result, err := evaler.Eval("1+2")

Operators

The operators supported are:

+ - * / ** () < >

< (less than) and > (greater than) will get lowest precedence, all other precedence is as expected (BODMAS [4]).

< and > tests will evaluate to 0.0 for false and 1.0 for true, allowing expressions like:

3 * (1 < 2) # returns 3.0
3 * (1 > 2) # returns 0.0

Issues

The math/big library doesn't have an exponent function (**), and implenting one for big.Rat numbers is non-trivial. As a work around, arguments are converted to float64's, the calculation is done using the math.Pow() function, the result is converted to a big.Rat and placed back on the stack.

Documentation

http://godoc.org/github.com/soniah/evaler

There are also a number of utility functions (eg BigratToFloat(), BigratToInt()) that may be useful when working with evaler.

Author

Sonia Hamilton

http://www.snowfrog.net

[email protected]

License

Modified BSD License (BSD-3)

Links

[1] http://en.wikipedia.org/wiki/Shunting-yard_algorithm

[2] http://en.wikipedia.org/wiki/Reverse_Polish_notation

[3] http://willcode4beer.com/design.jsp?set=evalInfix

[4] http://www.mathsisfun.com/operation-order-bodmas.html

# Packages

No description provided by the author

# Functions

BigratToInt converts a *big.Rat to a *big.Int (with truncation).
BigratToFloat converts a *big.Rat to a float64 (with loss of precision).
BigratToInt converts a *big.Rat to an int64 (with truncation); it returns an error for integer overflows.
Eval takes an infix string arithmetic expression, and evaluates it Usage: result, err := evaler.Eval("1+2") Returns: the result of the evaluation, and any errors .
evaluatePostfix takes a postfix expression and evaluates it.
FloatToBigrat converts a float64 to a *big.Rat.
No description provided by the author
isCellAddr returns true if token is a cell address.