/*************************************************************************** * Copyright (c) 2023 Ondsel, Inc. * * * * This file is part of OndselSolver. * * * * See LICENSE file for details about copyright. * ***************************************************************************/ #include "AtPointConstraintIqcJc.h" #include "DispCompIeqcJecO.h" #include "CREATE.h" #include "EndFrameqc.h" using namespace MbD; AtPointConstraintIqcJc::AtPointConstraintIqcJc(EndFrmsptr frmi, EndFrmsptr frmj, size_t axisi) : AtPointConstraintIJ(frmi, frmj, axisi) { } void AtPointConstraintIqcJc::initializeGlobally() { AtPointConstraintIJ::initializeGlobally(); ppGpEIpEI = (std::static_pointer_cast(riIeJeO))->ppriIeJeOpEIpEI; } void AtPointConstraintIqcJc::initriIeJeO() { riIeJeO = CREATE::With(frmI, frmJ, axis); } void AtPointConstraintIqcJc::calcPostDynCorrectorIteration() { AtPointConstraintIJ::calcPostDynCorrectorIteration(); pGpEI = std::static_pointer_cast(riIeJeO)->priIeJeOpEI; } void AtPointConstraintIqcJc::useEquationNumbers() { auto frmIeqc = std::static_pointer_cast(frmI); iqXIminusOnePlusAxis = frmIeqc->iqX() + axis; iqEI = frmIeqc->iqE(); } void AtPointConstraintIqcJc::fillPosICError(FColDsptr col) { Constraint::fillPosICError(col); col->atiminusNumber(iqXIminusOnePlusAxis, lam); col->atiplusFullVectortimes(iqEI, pGpEI, lam); } void AtPointConstraintIqcJc::fillPosICJacob(SpMatDsptr mat) { mat->atijplusNumber(iG, iqXIminusOnePlusAxis, -1.0); mat->atijplusNumber(iqXIminusOnePlusAxis, iG, -1.0); mat->atijplusFullRow(iG, iqEI, pGpEI); mat->atijplusFullColumn(iqEI, iG, pGpEI->transpose()); mat->atijplusFullMatrixtimes(iqEI, iqEI, ppGpEIpEI, lam); } void AtPointConstraintIqcJc::fillPosKineJacob(SpMatDsptr mat) { mat->atijplusNumber(iG, iqXIminusOnePlusAxis, -1.0); mat->atijplusFullRow(iG, iqEI, pGpEI); } void AtPointConstraintIqcJc::fillVelICJacob(SpMatDsptr mat) { mat->atijplusNumber(iG, iqXIminusOnePlusAxis, -1.0); mat->atijplusNumber(iqXIminusOnePlusAxis, iG, -1.0); mat->atijplusFullRow(iG, iqEI, pGpEI); mat->atijplusFullColumn(iqEI, iG, pGpEI->transpose()); } void AtPointConstraintIqcJc::fillAccICIterError(FColDsptr col) { col->atiminusNumber(iqXIminusOnePlusAxis, lam); col->atiplusFullVectortimes(iqEI, pGpEI, lam); auto efrmIqc = std::static_pointer_cast(frmI); auto qEdotI = efrmIqc->qEdot(); auto sum = -efrmIqc->qXddot()->at(axis); sum += pGpEI->timesFullColumn(efrmIqc->qEddot()); sum += qEdotI->transposeTimesFullColumn(ppGpEIpEI->timesFullColumn(qEdotI)); col->atiplusNumber(iG, sum); } void AtPointConstraintIqcJc::addToJointForceI(FColDsptr col) { col->atiminusNumber(axis, lam); } void AtPointConstraintIqcJc::addToJointTorqueI(FColDsptr jointTorque) { auto cForceT = std::make_shared>(3, 0.0); cForceT->atiput(axis, -lam); auto rIpIeIp = frmI->rpep(); auto pAOIppEI = frmI->pAOppE(); auto aBOIp = frmI->aBOp(); auto fpAOIppEIrIpIeIp = std::make_shared>(4, 0.0); for (size_t i = 0; i < 4; i++) { auto dum = cForceT->timesFullColumn(pAOIppEI->at(i)->timesFullColumn(rIpIeIp)); fpAOIppEIrIpIeIp->atiput(i, dum); } auto lampGpE = pGpEI->transpose()->times(lam); auto c2Torque = aBOIp->timesFullColumn(lampGpE->minusFullColumn(fpAOIppEIrIpIeIp)); jointTorque->equalSelfPlusFullColumntimes(c2Torque, 0.5); }