82 lines
3.3 KiB
Groff
82 lines
3.3 KiB
Groff
|
.TH "RoutingEventLoop" 3 "Mon Apr 27 2020" "Version 1.0" "Kite - Detailed Router" \" -*- nroff -*-
|
||
|
.ad l
|
||
|
.nh
|
||
|
.SH NAME
|
||
|
RoutingEventLoop \- Simple loop dectector for \fBRoutingEvent\fP\&.
|
||
|
|
||
|
.SH SYNOPSIS
|
||
|
.br
|
||
|
.PP
|
||
|
.SS "Public Member Functions"
|
||
|
|
||
|
.in +1c
|
||
|
.ti -1c
|
||
|
.RI "\fBRoutingEventLoop\fP (size_t depth=10, int limit=20)"
|
||
|
.br
|
||
|
.ti -1c
|
||
|
.RI "bool \fBisLooping\fP () const"
|
||
|
.br
|
||
|
.ti -1c
|
||
|
.RI "int \fBgetMaxCount\fP () const"
|
||
|
.br
|
||
|
.ti -1c
|
||
|
.RI "const std::vector< Element > & \fBgetElements\fP () const"
|
||
|
.br
|
||
|
.ti -1c
|
||
|
.RI "void \fBupdate\fP (size_t id)"
|
||
|
.br
|
||
|
.ti -1c
|
||
|
.RI "void \fBerase\fP (size_t id)"
|
||
|
.br
|
||
|
.in -1c
|
||
|
.SH "Detailed Description"
|
||
|
.PP
|
||
|
Simple loop dectector for \fBRoutingEvent\fP\&.
|
||
|
|
||
|
The \fBRoutingEventLoop\fP can be roughly understood as a truncated histogram of the \fCdepth\fP last (in the time meaning) greatest riped up elements\&.
|
||
|
.PP
|
||
|
The loop detector keep track of the \fCdepth\fP \fBTrackElement\fP with the greatest processing count\&. \fBTrackElement\fP are just identified through the \fCid\fP of their associated AutoSegment\&. Each entry in the loop table contains:
|
||
|
.IP "\(bu" 2
|
||
|
The \fCid\fP of the associated \fBTrackSegment\fP (\fBKatabatic::AutoSegment\fP)\&.
|
||
|
.IP "\(bu" 2
|
||
|
The \fCcount\fP of times it has been processed
|
||
|
.IP "\(bu" 2
|
||
|
The \fCtimestamp\fP of the latest time it has been updated\&.
|
||
|
.PP
|
||
|
.PP
|
||
|
The table (implemented as \fCvector<>\fP) it kept sorted on the timestamp (decreasing)\&. Whenever there is more than \fCdepth\fP elements in the table, the oldest one are discarted (regardless of their count)\&. Obviously, there are pathological cases into which a loop cannot be detected, but so far it has not happened so a more robust approach seems not necessary at this time\&.
|
||
|
.PP
|
||
|
Whenever the count of an element reaches \fCcountLimit\fP, the looping flag is set\&. It will remains set unless the faulty element is manually removed\&.
|
||
|
.SH "Constructor & Destructor Documentation"
|
||
|
.PP
|
||
|
.SS "\fBRoutingEventLoop\fP (size_t depth = \fC10\fP, int countLimit = \fC20\fP)"
|
||
|
Construct a loop detector that handle \fCdepth\fP differents segments and has a looping threshold of \fCcountLimit\fP\&.
|
||
|
.SH "Member Function Documentation"
|
||
|
.PP
|
||
|
.SS "bool isLooping () const\fC [inline]\fP"
|
||
|
\fBReturns:\fP \fBtrue\fP if the loop threshold has been reached for at least one element\&.
|
||
|
.PP
|
||
|
Referenced by RoutingEvent::process()\&.
|
||
|
.SS "int getMaxCount () const\fC [inline]\fP"
|
||
|
The maximal count an element as reached so far\&.
|
||
|
.PP
|
||
|
Referenced by RoutingEvent::process()\&.
|
||
|
.SS "const std::vector< Element > & getElements () const\fC [inline]\fP"
|
||
|
The complete table elements\&.
|
||
|
.PP
|
||
|
Referenced by RoutingEvent::process()\&.
|
||
|
.SS "void update (size_t id)"
|
||
|
Update the loop, telling that element \fCid\fP has appreared one more time\&.
|
||
|
.PP
|
||
|
Referenced by RoutingEvent::process()\&.
|
||
|
.SS "void erase (size_t id)"
|
||
|
Remove the entry related to element \fCid\fP in the table\&. The state of the table is fully recomputed after the removal (looping flag & maximum count)\&.
|
||
|
.PP
|
||
|
This method is used when a loop has been encountered, presumably on element \fCid\fP, and we want to continue\&. To avoid the loop detector yelling at each check, the associated \fBTrackElement\fP should be invalidated and it's reference removed from the table\&.
|
||
|
.PP
|
||
|
Referenced by RoutingEvent::process()\&.
|
||
|
|
||
|
.SH "Author"
|
||
|
.PP
|
||
|
Generated automatically by Doxygen for Kite - Detailed Router from the source code\&.
|