Minor optimization of PartContraction

Remove rarely used debug code from initialization loop.
This commit is contained in:
Geza Lore 2022-08-26 16:52:28 +01:00
parent 546aeab9f2
commit 881c3f6e40

View File

@ -1270,6 +1270,18 @@ public:
// METHODS // METHODS
void go() { void go() {
if (m_slowAsserts) {
// Check there are no redundant edges
for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp;
itp = itp->verticesNextp()) {
std::unordered_set<const V3GraphVertex*> neighbors;
for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) {
const bool first = neighbors.insert(edgep->top()).second;
UASSERT_OBJ(first, itp, "Redundant edge found in input to PartContraction()");
}
}
}
unsigned maxMTasks = v3Global.opt.threadsMaxMTasks(); unsigned maxMTasks = v3Global.opt.threadsMaxMTasks();
if (maxMTasks == 0) { // Unspecified so estimate if (maxMTasks == 0) { // Unspecified so estimate
if (v3Global.opt.threads() > 1) { if (v3Global.opt.threads() > 1) {
@ -1290,15 +1302,9 @@ public:
// - Incrementally recompute critical paths near the merged mtask. // - Incrementally recompute critical paths near the merged mtask.
for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp; itp = itp->verticesNextp()) { for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp; itp = itp->verticesNextp()) {
itp->userp(nullptr); // Reset user value. Used by PartPropagateCp. itp->userp(nullptr); // Reset user value while we are here. Used by PartPropagateCp.
std::unordered_set<const V3GraphVertex*> neighbors;
for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) { for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) {
m_sb.add(static_cast<MTaskEdge*>(edgep)); m_sb.add(static_cast<MTaskEdge*>(edgep));
if (m_slowAsserts) {
UASSERT_OBJ(neighbors.find(edgep->top()) == neighbors.end(), itp,
"Redundant edge found in input to PartContraction()");
}
neighbors.insert(edgep->top());
} }
siblingPairFromRelatives<GraphWay::REVERSE, true>(itp); siblingPairFromRelatives<GraphWay::REVERSE, true>(itp);
siblingPairFromRelatives<GraphWay::FORWARD, true>(itp); siblingPairFromRelatives<GraphWay::FORWARD, true>(itp);