32. Expression Datum Filter¶
The Expression Datum Filter provides a way to generate new properties by evaluating expressions against existing properties.
This filter is provided by the Standard Datum Filters plugin.
32.1 Settings¶

In addition to the Common Settings, the following general settings are available:
| Setting | Description | 
|---|---|
| Expressions | A list of expression configurations that are evaluated to derive datum property values from other property values. | 
Use the + and - buttons to add/remove expression configurations.
32.2 Expression settings¶
Each expression configuration contains the following settings:
| Setting | Description | 
|---|---|
| Property | The datum property to store the expression result in. | 
| Property Type | The datum property type to use. | 
| Expression | The expression to evaluate. See below for more info. | 
| Expression Language | The expression language to write Expression in. | 
32.3 Expressions¶
See the SolarNode Expressions guide for general expressions reference. The root object
is a DatumExpressionRoot that lets you treat all datum properties, and
filter parameters, as expression variables directly, along with the following properties:
| Property | Type | Description | 
|---|---|---|
| datum | Datum | A Datumobject, populated with data from all property and virtual meter configurations. | 
| props | Map<String,Object> | Simple Map based access to the properties in datum, and transform parameters, to simplify expressions. | 
The following methods are available:
| Function | Arguments | Result | Description | 
|---|---|---|---|
| has(name) | String | boolean | Returns trueif a property namednameis defined. | 
| hasLatest(source) | String | boolean | Returns trueif a datum with source IDsourceis available via thelatest(source)function. | 
| latest(source) | String | DatumExpressionRootfor the latest available datum matching the given source ID, ornullif not available. | 
32.4 Expression examples¶
Assuming a datum sample with properties like the following:
| Property | Value | 
|---|---|
| current | 7.6 | 
| voltage | 240.1 | 
| status | Error | 
Then here are some example expressions and the results they would produce:
| Expression | Result | Comment | 
|---|---|---|
| voltage * current | 1824.76 | Simple multiplication of two properties. | 
| props['voltage'] * props['current'] | 1824.76 | Another way to write the previous expression. Can be useful if the property names contain non-alphanumeric characters, like spaces. | 
| has('frequency') ? 1 : null | null | Uses the ?:if/then/else operator to evaluate tonullbecause thefrequencyproperty is not available. When an expression evaluates tonullthen no property will be added to the output samples. | 
| current > 7 or voltage > 245 ? 1 : null | 1 | Uses comparison and logic operators to evaluate to 1becausecurrentis greater than7. | 
| voltage * currrent * (hasLatest('battery') ? 1.0 - latest('battery')['soc'] : 1) | 364.952 | Assuming a batterydatum with asocproperty value of0.8then the expression resolves to7.6 * 241.0 * (1.0 - 0.8). |