Builtin Functions
General-purpose functions
The following functions can be meaningfully used on data of arbitrary types:
DATATYPE
returns the datatype of the value. For IRIs (and constant), the type is reported ashttp://www.w3.org/2001/XMLSchema#anyURI
. For language-tagged strings, the type ishttp://www.w3.org/1999/02/22-rdf-syntax-ns#langString
. As of Nemo v0.5.0, named nulls (blank nodes) have no defined type andDATATYPE
does not return a valid result for such value. Moreover, the datatype is currently returned as a string, but will be an IRI in future versions (#463).STR
returns the value as a string. For IRIs, this is the IRI string itself. For all other datatypes, this is the canonical form of the lexical value (without any datatype).fullStr
returns the value as a string that is formatted as in RDF. Such stings would also be correct ways of writing the value in a Nemo rules file (though there might be shorter ways due to Nemo’s abbreviations).
Further, it is possible to compare any values using =
or !=
.
Functions for strings
Nemo supports the following functions on strings.
STRLEN
: computes the (integer) length of a stringUCASE
andLCASE
: convert a string to upper case and lower case, respectivelyCONCAT
: creates a new string by concatenating the input stringsSUBSTR
: this function requires the following parameters: a string and an integer index. The function returns the substring that starts at the given index and extends to the end of the string. Optionally, the length of the substring can be supplied via a third parameter.STRAFTER
: takes two string parameters A and B, and returns the substring of A that follows the first occurrence of B in A. For example,STRAFTER("3.14",".")
is"14"
.STRBEFORE
: takes two string parameters A and B, and returns the substring of A that ends before the first occurrence of B in A. For example,STRBEFORE("3.14",".")
is"3"
.STRREV
: returns the input string with its characters in reverse order.COMPARE
: compares two strings alphabetically. The result is-1
if the first string is alphabetically before the second,1
if it is after, and0
if they are equal.STRSTARTS
: checks if the string given as the first parameter starts with the string given as second parameterSTRENDS
: checks if the string given as the first parameter ends with the string given as the second parameterCONTAINS
: checks if the string given as the first parameter contains the string given as the second parameterREGEX
: checks if the string given as the first parameter matches the regular expression given as second the parameterURIENCODE
: transforms the given string according to the rules of RFC 3986, Section 2.1, making it suitable for use as part of the query string of a URI by percent-encoding all characters except-
,_
,.
, and~
.URIDECODE
: decodes a string transformed byURIENCODE
back to the original, unencoded version.
Format Strings
Format strings are denoted with a leading f
before the double quoted string. They allow for arbitrary expressions to be embedded into the string using curly braces {}
. Format strings are equivalent to using the CONCAT
builtin function in combination with STR
for converting the result of the expressions into strings.
Functions for language tagged strings
A language-tagged string is a value like "Hello world"@en
. The function LANG
can be used to extract the language tag (en
in the example), whereas STR
can be used to obtain the lexical value ("Hello world"
).
Functions for numbers
All standard arithmetic operations, including addition (+
), subtraction (-
), multiplication (*
), and division (/
), are fully supported. Numeric values can also be compared via the operators <
, <=
, =>
, and >
.
In addition, Nemo provides many useful arithmetic functions. Currently, these include the following functions on single input parameters:
ABS
(absolute), SQRT
(square root), SIN
(sine), COS
(cosine), TAN
(tangent), ROUND
(rounding up or down), CEIL
(rounding up), FLOOR
(rounding down). Moreover, the following functions require two parameters:
LOG(x,y)
: computes the logarithm of x to base yPOW(x,y)
: computes the power of x to the y.REM(x,y)
: computes the remainder of dividing x by y.
And finally, the following functions can be called with arbitrary many input parameters:
SUM(x_1, ..., x_n)
: computes the sum of the given argumentsPRODUCT(x_1, ..., x_n)
: computes the product of the given argumentsMIN(x_1, ..., x_n)
: returns the minimum of the given argumentsMAX(x_1, ..., x_n)
: returns the maximum of the given argumentsLUKA(x_1, ..., x_n)
: computes the Łukasiewicz t-norm for the given argumentsBITAND(x_1, ..., x_n)
: computes the bitwise “and” of the given argumentsBITOR(x_1, ..., x_n)
: computes the bitwise “or” of the given argumentsBITXOR(x_1, ..., x_n)
: computes the bitwise “xor” of the given arguments
Nemo supports the following conversion functions:
INT
: Convert the given value to an integer. This works for various datatypes (not just numbers), but only for data that already corresponds to an integer. The following all evaluate to42
:INT(42)
,INT(42.0)
,INT("42")
,INT("42"^^<http://www.w3.org/2001/XMLSchema#gYear>)
,INT(ROUND(42.1))
. However,INT(42.1)
does not return a result.DOUBLE
: Convert a given value to a double. This function works for various datatypes (not just numbers). For example, the following evaluate to42.0
:DOUBLE(42)
,DOUBLE("42.0")
,DOUBLE("42").
FLOAT
: Convert a given value to a float. This is analogous toDOUBLE
but for 32bit floating point numbers.
It is also possible to mix numeric types, which implicitly converts them to 64-bit floating point numbers. For example, SUM(3 * 4.0, 5, 1.0)
returns the 64-bit floating point number 18.0
.
Boolean Functions
Nemo supports the usual Boolean functions (AND
, OR
, and NOT
), but requires them to be written in prefix-notation like other functions, e.g., OR(?X,?Y)
rather than ?X OR ?Y
.
Checking the datatype
Nemo provides built-in functions to check whether a value is of a certain type:
isInteger
: tests if the argument is an integer numberisFloat
: tests if the argument is a 32bit floating point number (float)isDouble
: tests if the argument is a 64bit floating point number (double)isIri
: tests if the argument is an IRI, including a “plain constant”, which Nemo considers to be relative IRIsisNumeric
: tests if the argument is of any numeric typeisNull
: tests if the argument is a named null (blank node)isString
: tests if the argument is a plain string (without a language tag)
For example, the following program computes result("true"^^<http://www.w3.org/2001/XMLSchema#boolean>)
:
Nesting functions
Built-in functions can be nested arbitrarily. For example, the following is a valid expression:
Known restriction in version 0.6.0: Currently, infix operators are not allowed within nested terms. As a workaround, it is possible to use the prefix-notation for such functions.
Infix | Name |
---|---|
= | EQUALITY |
!= | UNEQUALITY |
> | NUMGREATER |
>= | NUMGREATEREQ |
< | NUMLESS |
<= | NUMLESSEQ |
+ | SUM |
- | SUBTRACTION |
* | PRODUCT |
/ | DIVISION |
As an example, consider the following rule: