Enum egglog::ast::GenericCommand

source ·
pub enum GenericCommand<Head, Leaf>
where Head: Clone + Display, Leaf: Clone + PartialEq + Eq + Display + Hash,
{
Show 26 variants SetOption { name: Symbol, value: GenericExpr<Head, Leaf>, }, Sort(Span, Symbol, Option<(Symbol, Vec<Expr>)>), Datatype { span: Span, name: Symbol, variants: Vec<Variant>, }, Datatypes { span: Span, datatypes: Vec<(Span, Symbol, Subdatatypes)>, }, Constructor { span: Span, name: Symbol, schema: Schema, cost: Option<usize>, unextractable: bool, }, Relation { span: Span, name: Symbol, inputs: Vec<Symbol>, }, Function { span: Span, name: Symbol, schema: Schema, merge: Option<GenericExpr<Head, Leaf>>, }, AddRuleset(Symbol), UnstableCombinedRuleset(Symbol, Vec<Symbol>), Rule { name: Symbol, ruleset: Symbol, rule: GenericRule<Head, Leaf>, }, Rewrite(Symbol, GenericRewrite<Head, Leaf>, Subsume), BiRewrite(Symbol, GenericRewrite<Head, Leaf>), Action(GenericAction<Head, Leaf>), RunSchedule(GenericSchedule<Head, Leaf>), PrintOverallStatistics, Simplify { span: Span, expr: GenericExpr<Head, Leaf>, schedule: GenericSchedule<Head, Leaf>, }, QueryExtract { span: Span, variants: usize, expr: GenericExpr<Head, Leaf>, }, Check(Span, Vec<GenericFact<Head, Leaf>>), PrintFunction(Span, Symbol, usize), PrintSize(Span, Option<Symbol>), Input { span: Span, name: Symbol, file: String, }, Output { span: Span, file: String, exprs: Vec<GenericExpr<Head, Leaf>>, }, Push(usize), Pop(Span, usize), Fail(Span, Box<GenericCommand<Head, Leaf>>), Include(Span, String),
}
Expand description

A Command is the top-level construct in egglog. It includes defining rules, declaring functions, adding to tables, and running rules (via a Schedule).

Variants§

§

SetOption

Egglog supports several experimental options that can be set using the set-option command.

Options supported include:

  • “interactive_mode” (default: false): when enabled, egglog prints “(done)” after each command, allowing an external tool to know when each command has finished running.

Fields

§name: Symbol
§value: GenericExpr<Head, Leaf>
§

Sort(Span, Symbol, Option<(Symbol, Vec<Expr>)>)

Create a new user-defined sort, which can then be used in new Command::Function declarations. The Command::Datatype command desugars directly to this command, with one Command::Function per constructor. The main use of this command (as opposed to using Command::Datatype) is for forward-declaring a sort for mutually-recursive datatypes.

It can also be used to create a container sort. For example, here’s how to make a sort for vectors of some user-defined sort Math:

(sort MathVec (Vec Math))

Now MathVec can be used as an input or output sort.

§

Datatype

Egglog supports three types of functions

A constructor models an egg-style user-defined datatype It can only be defined through the datatype/datatype* command or the constructor command

A relation models a datalog-style mathematical relation It can only be defined through the relation command

A custom function is a dictionary It can only be defined through the function command The datatype command declares a user-defined datatype. Datatypes can be unioned with Action::Union either at the top level or in the actions of a rule. This makes them equal in the implicit, global equality relation. Example:

(datatype Math
  (Num i64)
  (Var String)
  (Add Math Math)
  (Mul Math Math))

defines a simple Math datatype with variants for numbers, named variables, addition and multiplication.

Datatypes desugar directly to a Command::Sort and a Command::Constructor for each constructor. The code above becomes:

(sort Math)
(constructor Num (i64) Math)
(constructor Var (String) Math)
(constructor Add (Math Math) Math)
(constructor Mul (Math Math) Math)
Datatypes are also known as algebraic data types, tagged unions and sum types.

Fields

§span: Span
§name: Symbol
§variants: Vec<Variant>
§

Datatypes

Fields

§span: Span
§datatypes: Vec<(Span, Symbol, Subdatatypes)>
§

Constructor

The constructor command defines a new constructor for a user-defined datatype Example:

(constructor Add (i64 i64) Math)

Fields

§span: Span
§name: Symbol
§schema: Schema
§unextractable: bool
§

Relation

The relation command declares a named relation Example:

(relation path (i64 i64))
(relation edge (i64 i64))

Fields

§span: Span
§name: Symbol
§inputs: Vec<Symbol>
§

Function

The function command declare an egglog custom function, which is a database table with a a functional dependency (also called a primary key) on its inputs to one output.

(function <name:Ident> <schema:Schema> <cost:Cost>
       (:on_merge <List<Action>>)?
       (:merge <Expr>)?)

A function can have a cost for extraction.

Finally, it can have a merge and on_merge, which are triggered when the function dependency is violated. In this case, the merge expression determines which of the two outputs for the same input is used. The on_merge actions are run after the merge expression is evaluated.

Note that the :merge expression must be monotonic for the behavior of the egglog program to be consistent and defined. In other words, the merge function must define a lattice on the output of the function. If values are merged in different orders, they should still result in the same output. If the merge expression is not monotonic, the behavior can vary as actions may be applied more than once with different results.

(function LowerBound (Math) i64 :merge (max old new))

Specifically, a custom function can also have an EqSort output type:

(function Add (i64 i64) Math)

All functions can be set with Action::Set.

Output of a function, if being the EqSort type, can be unioned with Action::Union with another datatype of the same sort.

Fields

§span: Span
§name: Symbol
§schema: Schema
§merge: Option<GenericExpr<Head, Leaf>>
§

AddRuleset(Symbol)

Using the ruleset command, defines a new ruleset that can be added to in Command::Rules. Rulesets are used to group rules together so that they can be run together in a Schedule.

Example: Ruleset allows users to define a ruleset- a set of rules

(ruleset myrules)
(rule ((edge x y))
      ((path x y))
      :ruleset myrules)
(run myrules 2)
§

UnstableCombinedRuleset(Symbol, Vec<Symbol>)

Using the combined-ruleset command, construct another ruleset which runs all the rules in the given rulesets. This is useful for running multiple rulesets together. The combined ruleset also inherits any rules added to the individual rulesets after the combined ruleset is declared.

Example:

(ruleset myrules1)
(rule ((edge x y))
      ((path x y))
     :ruleset myrules1)
(ruleset myrules2)
(rule ((path x y) (edge y z))
      ((path x z))
      :ruleset myrules2)
(combined-ruleset myrules-combined myrules1 myrules2)
§

Rule

(rule <body:List<Fact>> <head:List<Action>>)

defines an egglog rule. The rule matches a list of facts with respect to the global database, and runs the list of actions for each match. The matches are done modulo equality, meaning equal datatypes in the database are considered equal. Example:

(rule ((edge x y))
      ((path x y)))
(rule ((path x y) (edge y z))
      ((path x z)))

Fields

§name: Symbol
§ruleset: Symbol
§rule: GenericRule<Head, Leaf>
§

Rewrite(Symbol, GenericRewrite<Head, Leaf>, Subsume)

rewrite is syntactic sugar for a specific form of rule which simply unions the left and right hand sides.

Example:

(rewrite (Add a b)
         (Add b a))

Desugars to:

(rule ((= lhs (Add a b)))
      ((union lhs (Add b a))))

Additionally, additional facts can be specified using a :when clause. For example, the same rule can be run only when a is zero:

(rewrite (Add a b)
         (Add b a)
         :when ((= a (Num 0)))

Add the :subsume flag to cause the left hand side to be subsumed after matching, which means it can no longer be matched in a rule, but can still be checked against (See Change for more details.)

(rewrite (Mul a 2) (bitshift-left a 1) :subsume)

Desugars to:

(rule ((= lhs (Mul a 2)))
      ((union lhs (bitshift-left a 1))
       (subsume (Mul a 2))))
§

BiRewrite(Symbol, GenericRewrite<Head, Leaf>)

Similar to Command::Rewrite, but generates two rules, one for each direction.

Example:

(bi-rewrite (Mul (Var x) (Num 0))
            (Var x))

Becomes:

(rule ((= lhs (Mul (Var x) (Num 0))))
      ((union lhs (Var x))))
(rule ((= lhs (Var x)))
      ((union lhs (Mul (Var x) (Num 0)))))
§

Action(GenericAction<Head, Leaf>)

Perform an Action on the global database (see documentation for Action for more details). Example:

(let xplusone (Add (Var "x") (Num 1)))
§

RunSchedule(GenericSchedule<Head, Leaf>)

Runs a Schedule, which specifies rulesets and the number of times to run them.

Example:

(run-schedule
    (saturate my-ruleset-1)
    (run my-ruleset-2 4))

Runs my-ruleset-1 until saturation, then runs my-ruleset-2 four times.

See Schedule for more details.

§

PrintOverallStatistics

Print runtime statistics about rules and rulesets so far.

§

Simplify

Fields

§span: Span
§expr: GenericExpr<Head, Leaf>
§schedule: GenericSchedule<Head, Leaf>
§

QueryExtract

The query-extract command runs a query, extracting the result for each match that it finds. For a simpler extraction command, use Action::Extract instead.

Example:

(query-extract (Add a b))

Extracts every Add term in the database, once for each class of equivalent a and b.

The resulting datatype is chosen from the egraph as the smallest term by size (taking into account the :cost annotations for each constructor). This cost does not take into account common sub-expressions. For example, the following term has cost 5:

(Add
    (Num 1)
    (Num 1))

Under the hood, this command is implemented with the EGraph::extract function.

Fields

§span: Span
§variants: usize
§expr: GenericExpr<Head, Leaf>
§

Check(Span, Vec<GenericFact<Head, Leaf>>)

The check command checks that the given facts match at least once in the current database. The list of facts is matched in the same way a Command::Rule is matched.

Example:

(check (= (+ 1 2) 3))
(check (<= 0 3) (>= 3 0))
(fail (check (= 1 2)))

prints

[INFO ] Checked.
[INFO ] Checked.
[ERROR] Check failed
[INFO ] Command failed as expected.
§

PrintFunction(Span, Symbol, usize)

Print out rows a given function, extracting each of the elements of the function. Example:

(print-function Add 20)

prints the first 20 rows of the Add function.

§

PrintSize(Span, Option<Symbol>)

Print out the number of rows in a function or all functions.

§

Input

Input a CSV file directly into a function.

Fields

§span: Span
§name: Symbol
§file: String
§

Output

Extract and output a set of expressions to a file.

Fields

§span: Span
§file: String
§exprs: Vec<GenericExpr<Head, Leaf>>
§

Push(usize)

push the current egraph n times so that it is saved. Later, the current database and rules can be restored using pop.

§

Pop(Span, usize)

pop the current egraph, restoring the previous one. The argument specifies how many egraphs to pop.

§

Fail(Span, Box<GenericCommand<Head, Leaf>>)

Assert that a command fails with an error.

§

Include(Span, String)

Include another egglog file directly as text and run it.

Trait Implementations§

source§

impl<Head, Leaf> Clone for GenericCommand<Head, Leaf>
where Head: Clone + Display + Clone, Leaf: Clone + PartialEq + Eq + Display + Hash + Clone,

source§

fn clone(&self) -> GenericCommand<Head, Leaf>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Head, Leaf> Debug for GenericCommand<Head, Leaf>
where Head: Clone + Display + Debug, Leaf: Clone + PartialEq + Eq + Display + Hash + Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Head, Leaf> Display for GenericCommand<Head, Leaf>
where Head: Clone + Display, Leaf: Clone + PartialEq + Eq + Display + Hash,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Head, Leaf> Freeze for GenericCommand<Head, Leaf>
where Leaf: Freeze, Head: Freeze,

§

impl<Head, Leaf> RefUnwindSafe for GenericCommand<Head, Leaf>
where Leaf: RefUnwindSafe, Head: RefUnwindSafe,

§

impl<Head, Leaf> Send for GenericCommand<Head, Leaf>
where Leaf: Send, Head: Send,

§

impl<Head, Leaf> Sync for GenericCommand<Head, Leaf>
where Leaf: Sync, Head: Sync,

§

impl<Head, Leaf> Unpin for GenericCommand<Head, Leaf>
where Leaf: Unpin, Head: Unpin,

§

impl<Head, Leaf> UnwindSafe for GenericCommand<Head, Leaf>
where Leaf: UnwindSafe, Head: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V