Wiki source code of Intermediate Processors
Last modified by Alexander Schulz-Rosengarten on 2023/07/11 10:33
Hide last authors
author | version | line-number | content |
---|---|---|---|
![]() |
41.1 | 1 | This section lists the intermediate processors that are available. For a description of what intermediate processors actually are, see [[doc:KIELER.Discontinued Projects.Layout Algorithms (KLay).KLay Layered.WebHome]]. |
![]() |
1.1 | 2 | |
![]() |
36.1 | 3 | To add a new intermediate processor, create a corresponding class in the {{code language="none"}}...klay.layered.intermediate{{/code}} package and add proper documentation (refer to existing intermediate processors). Choose which intermediate processing slot(s) the processor can be run in. Then think about possible dependencies to other processors in that slot. Add the processor to the {{code language="none"}}IntermediateProcessingStrategy{{/code}} enumeration such, that all processors it depends on precede the definition of the new processor. |
![]() |
1.1 | 4 | |
![]() |
37.1 | 5 | The following table provides an overview of all available layout processors and the slots they can be placed in. Note that a processor may appear in more than one slot. Within each slot, processors are ordered by theirs dependencies on each other. For more documentation on how the processors actually work, refer to their Javadoc documentation. |
![]() |
1.1 | 6 | |
7 | |=((( | ||
8 | Slot | ||
9 | )))|=((( | ||
10 | Processor | ||
![]() |
20.1 | 11 | )))|=(% colspan="1" %)(% colspan="1" %) |
12 | ((( | ||
13 | Tested | ||
![]() |
1.1 | 14 | ))) |
15 | |((( | ||
16 | Before phase 1 | ||
17 | )))|((( | ||
![]() |
7.1 | 18 | Graph Transformer |
19 | Comment Preprocessor | ||
![]() |
1.1 | 20 | Edge And Layer Constraint Edge Reverser |
![]() |
20.1 | 21 | )))|(% colspan="1" %)(% colspan="1" %) |
22 | ((( | ||
![]() |
31.1 | 23 | \\ |
![]() |
1.1 | 24 | ))) |
25 | |((( | ||
26 | Before phase 2 | ||
27 | )))|((( | ||
![]() |
10.1 | 28 | Label Dummy Inserter |
![]() |
20.1 | 29 | )))|(% colspan="1" %)(% colspan="1" %) |
30 | ((( | ||
![]() |
38.1 | 31 | |
![]() |
1.1 | 32 | ))) |
33 | |((( | ||
34 | Before phase 3 | ||
35 | )))|((( | ||
![]() |
7.1 | 36 | Layer Constraint Processor |
![]() |
1.1 | 37 | Hierarchical Port Constraint Processor |
38 | Long Edge Splitter | ||
39 | Port Side Processor | ||
![]() |
10.1 | 40 | Label Dummy Switcher |
![]() |
7.1 | 41 | Inverted Port Processor |
![]() |
1.1 | 42 | Self Loop Processor |
![]() |
7.1 | 43 | Port List Sorter |
44 | North South Port Preprocessor | ||
![]() |
20.1 | 45 | )))|(% colspan="1" %)(% colspan="1" %) |
46 | ((( | ||
47 | |||
![]() |
41.1 | 48 | \\\\\\\\ |
![]() |
1.1 | 49 | ))) |
50 | |((( | ||
51 | Before phase 4 | ||
52 | )))|((( | ||
![]() |
7.1 | 53 | In Layer Constraint Processor |
![]() |
34.1 | 54 | Hierarchical Port Dummy Size Processor |
![]() |
14.1 | 55 | Hyperedge Dummy Merger |
![]() |
13.1 | 56 | Label Side Selector |
![]() |
15.1 | 57 | Label And Node Size Processor |
![]() |
1.1 | 58 | Node Margin Calculator |
![]() |
20.1 | 59 | )))|(% colspan="1" %)(% colspan="1" %) |
60 | ((( | ||
61 | |||
![]() |
41.1 | 62 | \\ |
![]() |
1.1 | 63 | ))) |
64 | |((( | ||
65 | Before phase 5 | ||
66 | )))|((( | ||
![]() |
19.1 | 67 | Layer Size and Graph Height Calculator |
![]() |
1.1 | 68 | Hierarchical Port Position Processor |
![]() |
20.1 | 69 | )))|(% colspan="1" %)(% colspan="1" %) |
70 | ((( | ||
71 | \\ | ||
![]() |
1.1 | 72 | ))) |
73 | |((( | ||
74 | After phase 5 | ||
75 | )))|((( | ||
![]() |
7.1 | 76 | Comment Postprocessor |
77 | Hypernode Processor | ||
![]() |
1.1 | 78 | Hierarchical Port Orthogonal Edge Router |
79 | Long Edge Joiner | ||
80 | North South Port Postprocessor | ||
![]() |
10.1 | 81 | Label Dummy Remover |
![]() |
1.1 | 82 | Reversed Edge Restorer |
![]() |
7.1 | 83 | Graph Transformer |
![]() |
10.1 | 84 | End Label Processor |
![]() |
20.1 | 85 | )))|(% colspan="1" %)(% colspan="1" %) |
86 | ((( | ||
87 | |||
![]() |
41.1 | 88 | \\\\\\\\ |
![]() |
1.1 | 89 | ))) |