#
Hef.Math.Interpreter
1.1.1

An Interpreter that takes a math formula (string) as input, and outputs a numeric result.

Install-Package Hef.Math.Interpreter -Version 1.1.1

dotnet add package Hef.Math.Interpreter --version 1.1.1

<PackageReference Include="Hef.Math.Interpreter" Version="1.1.1" />

paket add Hef.Math.Interpreter --version 1.1.1

#### Prerequisites

This software is based on the **.Net 2.0 Framework** and has no other dependencies.

#### Examples

The interpreter accepts two notation styles. Operations can be written as functions with parenthesis and arguments, or like regular operations with a symbol. There is actually no difference between functions and symbols in the implementation.

For instance, the addition can be written `add(1, 2)`

or `1 + 2`

. Or even `add 1 2`

or `+(1, 2)`

if you like it.

The complete list of handled operations is availablable at Annex - Handled Operations.

Here is a simple example.

```
Interpreter interpreter = new Interpreter();
double result = interpreter.Calculate("sqrt(4) + 2"); // -> 4
```

The following example highlights the use of manually registered local and global variables.

```
Interpreter interpreter = new Interpreter();
Interpreter.SetGlobalVar("foo", 1d);
interpreter.SetVar("bar", 2d);
double result = interpreter.Calculate("($foo + $bar) * 2"); // -> 6
```

The following example highlights the use of `Hef.Math.IInterpreterContext`

, that allows the interpreter to access variables provided by other objects.

```
Interpreter interpreter = new Interpreter();
interpreter.SetContext("player", new Player()));
double result = interpreter.Calculate("$player.level - 1"); // -> 9
class Player : Hef.Math.IInterpreterContext
{
private int level = 10;
public bool TryGetVariable(string name, out double value)
{
value = 0d;
if (name == "level")
{
value = this.level;
return true;
}
return false;
}
}
```

#### Note About Caching

Each time a formula is calculated, the interpreter has to breaks the formula into nodes and build a tree of operations. This is a time-consumming process.

In order to make it faster, each time a new formula is processed, the intrepreder will keep the generated tree in memory (up to 64). So if the same formula is used again, the tree will be reused, and only the mathematical operations will be recomputed.

If for some reason the cache has to be manually cleared, the `Interpreter`

provides a function to do so.

```
Interpreter.ForceClearCache();
```

#### Prerequisites

This software is based on the **.Net 2.0 Framework** and has no other dependencies.

#### Examples

The interpreter accepts two notation styles. Operations can be written as functions with parenthesis and arguments, or like regular operations with a symbol. There is actually no difference between functions and symbols in the implementation.

For instance, the addition can be written `add(1, 2)`

or `1 + 2`

. Or even `add 1 2`

or `+(1, 2)`

if you like it.

The complete list of handled operations is availablable at Annex - Handled Operations.

Here is a simple example.

```
Interpreter interpreter = new Interpreter();
double result = interpreter.Calculate("sqrt(4) + 2"); // -> 4
```

The following example highlights the use of manually registered local and global variables.

```
Interpreter interpreter = new Interpreter();
Interpreter.SetGlobalVar("foo", 1d);
interpreter.SetVar("bar", 2d);
double result = interpreter.Calculate("($foo + $bar) * 2"); // -> 6
```

The following example highlights the use of `Hef.Math.IInterpreterContext`

, that allows the interpreter to access variables provided by other objects.

```
Interpreter interpreter = new Interpreter();
interpreter.SetContext("player", new Player()));
double result = interpreter.Calculate("$player.level - 1"); // -> 9
class Player : Hef.Math.IInterpreterContext
{
private int level = 10;
public bool TryGetVariable(string name, out double value)
{
value = 0d;
if (name == "level")
{
value = this.level;
return true;
}
return false;
}
}
```

#### Note About Caching

Each time a formula is calculated, the interpreter has to breaks the formula into nodes and build a tree of operations. This is a time-consumming process.

In order to make it faster, each time a new formula is processed, the intrepreder will keep the generated tree in memory (up to 64). So if the same formula is used again, the tree will be reused, and only the mathematical operations will be recomputed.

If for some reason the cache has to be manually cleared, the `Interpreter`

provides a function to do so.

```
Interpreter.ForceClearCache();
```

## Release Notes

FIXED

- An interpreter context can now be replaced by another one with the same name.

## Dependencies

This package has no dependencies.

## GitHub Usage

This package is not used by any popular GitHub repositories.

## Version History

Version | Downloads | Last updated | ||
---|---|---|---|---|

1.1.1 | 839 | 11/2/2017 | ||

1.1.0 | 326 | 9/11/2017 | ||

1.0.0 | 375 | 9/3/2017 | ||

0.2.0-alpha | 317 | 8/29/2017 | ||

0.1.1-alpha | 265 | 8/22/2017 | ||

0.1.0-alpha | 327 | 8/20/2017 |