Compiler

class Compiler
Members defined in Compiler (4 members)

max_steps

RW

Maximum number of steps an expression evaluation may take. When this is reached, evaluation stops with an error. Actual steps are an implementation detail.

__init__

evaluate

Evaluate expression. Note that custom functions and expressions, and most except a few standard library functions are not evaluatable. Constructor expressions evaluate as themselves because the constructor expressions conform to the constructed object implicitly. This primarily evaluates operator, metadata access, and feature reference expressions. If provided, stdlib is used to accelerate some common evaluations, e.g. checking for self expressions.

evaluate_feature

Evaluate feature in scope, taking into account redefinitions. If feature is an Expression, this effectively performs evaluate.

Attributes

property max_steps: int

Maximum number of steps an expression evaluation may take. When this is reached, evaluation stops with an error. Actual steps are an implementation detail.

Methods

__init__(max_steps: int = 100000) None
evaluate(expr: syside.Expression, stdlib: syside.Stdlib | None = None, scope: syside.Type | None | None = None, experimental_quantities: bool = False) tuple[syside.Value | None, syside.CompilationReport]

Evaluate expression. Note that custom functions and expressions, and most except a few standard library functions are not evaluatable. Constructor expressions evaluate as themselves because the constructor expressions conform to the constructed object implicitly. This primarily evaluates operator, metadata access, and feature reference expressions. If provided, stdlib is used to accelerate some common evaluations, e.g. checking for self expressions.

If experimental_quantities is enabled, compiler will additionally attempt to evaluate scalar quantity expressions in SI units, other systems of quantities are not supported. The results will be returned in scalar float and no type-checking will be performed. In the future, when typed quantities are implemented, this may be changed.

Note that quantity evaluation requires Stdlib to have found elements from MeasurementReferences library. Additionally, evaluation is tested to work with standard library quantities and prefixes. Custom package-level prefixes and quantities are also expected to work, however any nested feature chaining may or may not work.

evaluate_feature(feature: syside.Feature, scope: syside.Type, stdlib: syside.Stdlib | None = None, experimental_quantities: bool = False) tuple[syside.Value | None, syside.CompilationReport]

Evaluate feature in scope, taking into account redefinitions. If feature is an Expression, this effectively performs evaluate.