Halide 19.0.0
Halide compiler and libraries
Loading...
Searching...
No Matches
Halide::Internal::IRGraphVisitor Class Reference

A base class for algorithms that walk recursively over the IR without visiting the same node twice. More...

#include <IRVisitor.h>

Inheritance diagram for Halide::Internal::IRGraphVisitor:
Halide::Internal::IRVisitor Halide::Internal::ExprUsesVars< T >

Protected Member Functions

virtual void include (const Expr &)
 By default these methods add the node to the visited set, and return whether or not it was already there.
 
virtual void include (const Stmt &)
 
void visit (const IntImm *) override
 These methods should call 'include' on the children to only visit them if they haven't been visited already.
 
void visit (const UIntImm *) override
 
void visit (const FloatImm *) override
 
void visit (const StringImm *) override
 
void visit (const Cast *) override
 
void visit (const Reinterpret *) override
 
void visit (const Variable *) override
 
void visit (const Add *) override
 
void visit (const Sub *) override
 
void visit (const Mul *) override
 
void visit (const Div *) override
 
void visit (const Mod *) override
 
void visit (const Min *) override
 
void visit (const Max *) override
 
void visit (const EQ *) override
 
void visit (const NE *) override
 
void visit (const LT *) override
 
void visit (const LE *) override
 
void visit (const GT *) override
 
void visit (const GE *) override
 
void visit (const And *) override
 
void visit (const Or *) override
 
void visit (const Not *) override
 
void visit (const Select *) override
 
void visit (const Load *) override
 
void visit (const Ramp *) override
 
void visit (const Broadcast *) override
 
void visit (const Call *) override
 
void visit (const Let *) override
 
void visit (const LetStmt *) override
 
void visit (const AssertStmt *) override
 
void visit (const ProducerConsumer *) override
 
void visit (const For *) override
 
void visit (const Store *) override
 
void visit (const Provide *) override
 
void visit (const Allocate *) override
 
void visit (const Free *) override
 
void visit (const Realize *) override
 
void visit (const Block *) override
 
void visit (const IfThenElse *) override
 
void visit (const Evaluate *) override
 
void visit (const Shuffle *) override
 
void visit (const VectorReduce *) override
 
void visit (const Prefetch *) override
 
void visit (const Acquire *) override
 
void visit (const Fork *) override
 
void visit (const Atomic *) override
 
void visit (const HoistedStorage *) override
 
- Protected Member Functions inherited from Halide::Internal::IRVisitor

Additional Inherited Members

- Public Member Functions inherited from Halide::Internal::IRVisitor
 IRVisitor ()=default
 
virtual ~IRVisitor ()=default
 

Detailed Description

A base class for algorithms that walk recursively over the IR without visiting the same node twice.

This is for passes that are capable of interpreting the IR as a DAG instead of a tree.

Definition at line 85 of file IRVisitor.h.

Member Function Documentation

◆ include() [1/2]

virtual void Halide::Internal::IRGraphVisitor::include ( const Expr & )
protectedvirtual

By default these methods add the node to the visited set, and return whether or not it was already there.

If it wasn't there, it delegates to the appropriate visit method. You can override them if you like.

◆ include() [2/2]

virtual void Halide::Internal::IRGraphVisitor::include ( const Stmt & )
protectedvirtual

◆ visit() [1/48]

void Halide::Internal::IRGraphVisitor::visit ( const IntImm * )
overrideprotectedvirtual

These methods should call 'include' on the children to only visit them if they haven't been visited already.

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [2/48]

void Halide::Internal::IRGraphVisitor::visit ( const UIntImm * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [3/48]

void Halide::Internal::IRGraphVisitor::visit ( const FloatImm * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [4/48]

void Halide::Internal::IRGraphVisitor::visit ( const StringImm * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [5/48]

void Halide::Internal::IRGraphVisitor::visit ( const Cast * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [6/48]

void Halide::Internal::IRGraphVisitor::visit ( const Reinterpret * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [7/48]

void Halide::Internal::IRGraphVisitor::visit ( const Variable * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [8/48]

void Halide::Internal::IRGraphVisitor::visit ( const Add * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [9/48]

void Halide::Internal::IRGraphVisitor::visit ( const Sub * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [10/48]

void Halide::Internal::IRGraphVisitor::visit ( const Mul * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [11/48]

void Halide::Internal::IRGraphVisitor::visit ( const Div * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [12/48]

void Halide::Internal::IRGraphVisitor::visit ( const Mod * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [13/48]

void Halide::Internal::IRGraphVisitor::visit ( const Min * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [14/48]

void Halide::Internal::IRGraphVisitor::visit ( const Max * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [15/48]

void Halide::Internal::IRGraphVisitor::visit ( const EQ * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [16/48]

void Halide::Internal::IRGraphVisitor::visit ( const NE * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [17/48]

void Halide::Internal::IRGraphVisitor::visit ( const LT * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [18/48]

void Halide::Internal::IRGraphVisitor::visit ( const LE * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [19/48]

void Halide::Internal::IRGraphVisitor::visit ( const GT * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [20/48]

void Halide::Internal::IRGraphVisitor::visit ( const GE * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [21/48]

void Halide::Internal::IRGraphVisitor::visit ( const And * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [22/48]

void Halide::Internal::IRGraphVisitor::visit ( const Or * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [23/48]

void Halide::Internal::IRGraphVisitor::visit ( const Not * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [24/48]

void Halide::Internal::IRGraphVisitor::visit ( const Select * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [25/48]

void Halide::Internal::IRGraphVisitor::visit ( const Load * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [26/48]

void Halide::Internal::IRGraphVisitor::visit ( const Ramp * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [27/48]

void Halide::Internal::IRGraphVisitor::visit ( const Broadcast * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [28/48]

void Halide::Internal::IRGraphVisitor::visit ( const Call * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [29/48]

void Halide::Internal::IRGraphVisitor::visit ( const Let * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [30/48]

void Halide::Internal::IRGraphVisitor::visit ( const LetStmt * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [31/48]

void Halide::Internal::IRGraphVisitor::visit ( const AssertStmt * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [32/48]

void Halide::Internal::IRGraphVisitor::visit ( const ProducerConsumer * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [33/48]

void Halide::Internal::IRGraphVisitor::visit ( const For * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [34/48]

void Halide::Internal::IRGraphVisitor::visit ( const Store * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [35/48]

void Halide::Internal::IRGraphVisitor::visit ( const Provide * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [36/48]

void Halide::Internal::IRGraphVisitor::visit ( const Allocate * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [37/48]

void Halide::Internal::IRGraphVisitor::visit ( const Free * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [38/48]

void Halide::Internal::IRGraphVisitor::visit ( const Realize * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [39/48]

void Halide::Internal::IRGraphVisitor::visit ( const Block * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [40/48]

void Halide::Internal::IRGraphVisitor::visit ( const IfThenElse * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [41/48]

void Halide::Internal::IRGraphVisitor::visit ( const Evaluate * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [42/48]

void Halide::Internal::IRGraphVisitor::visit ( const Shuffle * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [43/48]

void Halide::Internal::IRGraphVisitor::visit ( const VectorReduce * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [44/48]

void Halide::Internal::IRGraphVisitor::visit ( const Prefetch * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [45/48]

void Halide::Internal::IRGraphVisitor::visit ( const Acquire * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [46/48]

void Halide::Internal::IRGraphVisitor::visit ( const Fork * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [47/48]

void Halide::Internal::IRGraphVisitor::visit ( const Atomic * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.

◆ visit() [48/48]

void Halide::Internal::IRGraphVisitor::visit ( const HoistedStorage * )
overrideprotectedvirtual

Reimplemented from Halide::Internal::IRVisitor.


The documentation for this class was generated from the following file: