Skip to content

Commit

Permalink
[constraint] Improve speed in constructing lower triangle of A matrix…
Browse files Browse the repository at this point in the history
… in LCP
  • Loading branch information
jslee02 committed Mar 30, 2024
1 parent 0de4fb9 commit 4a91553
Showing 1 changed file with 7 additions and 20 deletions.
27 changes: 7 additions & 20 deletions dart/constraint/BoxedLcpConstraintSolver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -220,34 +220,21 @@ void BoxedLcpConstraintSolver::solveConstrainedGroup(ConstrainedGroup& group)
mA.data() + index, false);
}
}

// Filling symmetric part of A matrix
{
DART_PROFILE_SCOPED_N("Fill lower triangle of A");
for (std::size_t k = 0; k < i; ++k) {
const int indexI = mOffset[i] + j;
for (std::size_t l = 0;
l < group.getConstraint(k)->getDimension();
++l) {
const int indexJ = mOffset[k] + l;
mA(indexI, indexJ) = mA(indexJ, indexI);
}
}
}
}
}

assert(isSymmetric(
n,
mA.data(),
mOffset[i],
mOffset[i] + constraint->getDimension() - 1));

{
DART_PROFILE_SCOPED_N("Unexcite");
constraint->unexcite();
}
}

{
// Fill lower triangle blocks of A matrix
DART_PROFILE_SCOPED_N("Fill lower triangle of A");
mA.triangularView<Eigen::Lower>()
= mA.triangularView<Eigen::Upper>().transpose();
}
}

assert(isSymmetric(n, mA.data()));
Expand Down

0 comments on commit 4a91553

Please sign in to comment.