CGRA-ME
|
Go to the source code of this file.
Classes | |
struct | BinaryOperandTags |
Mark nodes with no fanin as inputs, no fanout as outputs, and also verify it
Definition at line 5 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_2NodeLoop4Node | ( | ) |
a -> l -> m -> d ^-—'
Definition at line 115 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Converging121 | ( | ) |
a -> b -> c '--> b2 –^
Definition at line 151 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Converging21 | ( | ConfigStore | options = {} | ) |
a -> b a2 –^
Operands default to BINARY_ANY. Can set the "operands" key to "commutative" (default), "non-commutative" (BINARY_RHS and _LHS), or "untagged" (both UNTAGGED)
Definition at line 163 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_CrossbarWithBranchComp | ( | ) |
i1 —> a1 —> o1 ‘**\,--^ ,__/’–v i2 —> a2 —> b1 (br)
Definition at line 251 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_DeviceFiller | ( | const ConfigStore & | options | ) |
Make a connected 3-dimensional grid of nodes. Takes options 'width', 'height' and 'num_contexts'. Grid will have connection between neighbours, in time and space, but no more than 2 inputs. No torus connections. Self loops if 'self_loop_via_regfile' is truthy Const units to buff up inputs to 2 if 'num_consts_in_pe' > 0 No context N-1 to contex 0 connections – would be impossible to balance latency otherwise
Definition at line 1086 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Huge | ( | const std::vector< int > & | allowed_ids = {} , |
ConfigStore | options = {} |
||
) |
Derived from mibench/aes allowed_ids
is a whitelist of node numbers to include, however, an empty list is interpreted as 'allow-all'
Definition at line 408 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Large | ( | bool | require_non_NN_FUs | ) |
Derived from "microbench/accumulate"
Definition at line 288 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Larger | ( | ) |
Derived from microbench/mults1
Definition at line 335 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Linear2Node | ( | ConfigStore | options = {} | ) |
a--> b
"ops" key – comma-separated list of ops, one for each node. Defaults to "add,add"
Definition at line 34 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Linear3Node | ( | ) |
a -> b -> c
Definition at line 50 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Loop2Node | ( | ) |
a -> b ^-—'
Definition at line 92 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Loop3Node | ( | ) |
a -> b -> c ^------—'
Definition at line 103 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_MultiEdge11 | ( | ConfigStore | options = {} | ) |
a -> b '-—^
Definition at line 203 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_MultiInputReconverging2121 | ( | ) |
a --> b -> c -> d a2 –^'--> c2 –^
Definition at line 188 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_MultiInputReconverging3x2Grid | ( | ) |
i2 \/
i1 --> a1 --> b1 \/ \/ \/ a2 --> b2 --> c
Definition at line 234 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Parallel11_11 | ( | ) |
a1 -> b1 a2 -> b2
Definition at line 176 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_SelfLoop1Node | ( | ) |
l ^ \ '-'
Definition at line 60 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_SelfLoop1NodeWith1ExtraFanout | ( | ) |
l -> b ^ \ '-'
Definition at line 70 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_SelfLoop3Node | ( | ) |
a -> l —> c ^ \ '-'
Definition at line 80 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Small | ( | ConfigStore | options = {} | ) |
Derived from "microbench/nomem1"
c5 -> a4 -> m0 -> a2 -> o3 -^ c1-^
-^
Definition at line 268 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Tree | ( | const ConfigStore & | options | ) |
Make a DFG consisting of (possibly overlapping) converging trees Must specify option 'num_levels'. See source for more options.
Ex. { num_levels = 2, num_trees = 2, tree_overlap = 1 } i i i \/ \/
Ex. { num_levels = 3, num_trees = 2, tree_overlap = 2 } i i i i \/ \/ \/
Definition at line 1021 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Tree112 | ( | ) |
a -> b -> c '--> c2
Definition at line 139 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_Tree12 | ( | ) |
a -> b '--> b2
Definition at line 128 of file OpGraphsForTesting.cpp.
OpGraph makeDFG_TriangeWithAntiparellelDoubledBottomEdge | ( | ) |
i ---—> a '--> b <–^ Interesting because there there is one trail balancing constraint system ( nameley (in->a)+(a->b) == (in->b);(in->b)+(b->a) == (in->a) ) that implies a zero latency loop
Definition at line 222 of file OpGraphsForTesting.cpp.
BinaryOperandTags parseBinaryOperandOption | ( | const std::string & | option | ) |
Definition at line 16 of file OpGraphsForTesting.cpp.