Files
solver/OndselSolver/DistancexyConstraintIJ.cpp
aiksiongkoh de8759384c Mb dyn half sine and cosine (#42)
* (int) added

* size_t count

* add files

* MBDyn new joints, sine, cosine

* CompoundJoints debugged
2023-12-13 15:52:16 +01:00

104 lines
2.5 KiB
C++

/***************************************************************************
* Copyright (c) 2023 Ondsel, Inc. *
* *
* This file is part of OndselSolver. *
* *
* See LICENSE file for details about copyright. *
***************************************************************************/
#include "DistancexyConstraintIJ.h"
#include "DistancexyConstraintIqcJqc.h"
#include "EndFrameqc.h"
using namespace MbD;
MbD::DistancexyConstraintIJ::DistancexyConstraintIJ(EndFrmsptr frmi, EndFrmsptr frmj) : ConstraintIJ(frmi, frmj)
{
}
std::shared_ptr<DistancexyConstraintIJ> MbD::DistancexyConstraintIJ::With(EndFrmsptr frmi, EndFrmsptr frmj)
{
assert(frmi->isEndFrameqc());
assert(frmj->isEndFrameqc());
auto distxyCon = std::make_shared<DistancexyConstraintIqcJqc>(frmi, frmj);
distxyCon->init_xyIeJeIe();
return distxyCon;
}
void MbD::DistancexyConstraintIJ::calcPostDynCorrectorIteration()
{
auto x = xIeJeIe->value();
auto y = yIeJeIe->value();
aG = x * x + (y * y) - (aConstant * aConstant);
}
void MbD::DistancexyConstraintIJ::init_xyIeJeIe()
{
assert(false);
}
void MbD::DistancexyConstraintIJ::initialize()
{
ConstraintIJ::initialize();
this->init_xyIeJeIe();
}
void MbD::DistancexyConstraintIJ::initializeGlobally()
{
xIeJeIe->initializeGlobally();
yIeJeIe->initializeGlobally();
}
void MbD::DistancexyConstraintIJ::initializeLocally()
{
xIeJeIe->initializeLocally();
yIeJeIe->initializeLocally();
}
void MbD::DistancexyConstraintIJ::postInput()
{
xIeJeIe->postInput();
yIeJeIe->postInput();
ConstraintIJ::postInput();
}
void MbD::DistancexyConstraintIJ::postPosICIteration()
{
xIeJeIe->postPosICIteration();
yIeJeIe->postPosICIteration();
ConstraintIJ::postPosICIteration();
}
void MbD::DistancexyConstraintIJ::preAccIC()
{
xIeJeIe->preAccIC();
yIeJeIe->preAccIC();
ConstraintIJ::preAccIC();
}
void MbD::DistancexyConstraintIJ::prePosIC()
{
xIeJeIe->prePosIC();
yIeJeIe->prePosIC();
ConstraintIJ::prePosIC();
}
void MbD::DistancexyConstraintIJ::preVelIC()
{
xIeJeIe->preVelIC();
yIeJeIe->preVelIC();
ConstraintIJ::preVelIC();
}
void MbD::DistancexyConstraintIJ::simUpdateAll()
{
xIeJeIe->simUpdateAll();
yIeJeIe->simUpdateAll();
ConstraintIJ::simUpdateAll();
}
ConstraintType MbD::DistancexyConstraintIJ::type()
{
return displacement;
}