ONE - On-device Neural Engine
Loading...
Searching...
No Matches
luci::RemoveUnnecessaryDivPass Struct Referencefinal

Class to temove unnecessary(input and output are same) Mul/Div node. More...

#include <RemoveUnnecessaryMulDivPass.h>

Collaboration diagram for luci::RemoveUnnecessaryDivPass:

Public Member Functions

const charname (void) const final
 
bool run (loco::Graph *g) final
 
- Public Member Functions inherited from logo::Pass
virtual ~Pass ()=default
 

Detailed Description

Class to temove unnecessary(input and output are same) Mul/Div node.

Definition at line 28 of file RemoveUnnecessaryMulDivPass.h.

Member Function Documentation

◆ name()

const char * luci::RemoveUnnecessaryDivPass::name ( void  ) const
inlinefinalvirtual

Reimplemented from logo::Pass.

Definition at line 30 of file RemoveUnnecessaryMulDivPass.h.

30{ return "luci::RemoveUnnecessaryDivPass"; }

◆ run()

bool luci::RemoveUnnecessaryDivPass::run ( loco::Graph g)
finalvirtual

BEFORE [CircleNode] | | [CircleConst(=1.0)] | / | / [CircleDiv/CircleMul] (no activation) | [CircleNode]

AFTER [CircleNode] | | [CircleNode]

Implements logo::Pass.

Definition at line 96 of file RemoveUnnecessaryMulDivPass.cpp.

97{
98 bool changed = false;
99 for (auto node : loco::active_nodes(loco::output_nodes(g)))
100 {
101 auto div_node = dynamic_cast<luci::CircleDiv *>(node);
103 {
104 changed = true;
105 }
106 }
107 return changed;
108}
DIV in Circle.
Definition CircleDiv.h:37
std::set< loco::Node * > active_nodes(const std::vector< loco::Node * > &roots)
Enumerate all the nodes required to compute "roots".
std::vector< Node * > output_nodes(Graph *)
Definition Graph.cpp:101
T must_cast(loco::Node *node)

References loco::active_nodes(), luci::must_cast(), and loco::output_nodes().


The documentation for this struct was generated from the following files: