Plug in development
Posted: Wed Jul 17, 2019 6:39 pm
Hi all,
I am attempting to develop a simple plug in to compute body segment momentum about the centre of mass. I have managed to achieve my first successful build, but the resulting .sto file only has -1.#IND0000000000000000 for every value, suggesting I have made a mistake (I am a complete novice at C++).
Due to my inexperience, I am hoping someone can tell me what I have done wrong? The main portion of the code is below. Please note that I developed this as a modification to the example (for body kinematics) provided in the original OpenSim 3.3 distribution, hence there may be a couple of things in there that are no longer needed.
I am attempting to develop a simple plug in to compute body segment momentum about the centre of mass. I have managed to achieve my first successful build, but the resulting .sto file only has -1.#IND0000000000000000 for every value, suggesting I have made a mistake (I am a complete novice at C++).
Due to my inexperience, I am hoping someone can tell me what I have done wrong? The main portion of the code is below. Please note that I developed this as a modification to the example (for body kinematics) provided in the original OpenSim 3.3 distribution, hence there may be a couple of things in there that are no longer needed.
Code: Select all
int AnalysisPlugin_Template::
record(const SimTK::State& s)
{
/*
These variables are no longer needed, so I have commented out
// VARIABLES
SimTK::Vec3 vec;
SimTK::SpatialVec vec6;
double Mass = 0.0;
*/
// GROUND BODY
const Body& ground = _model->getGroundBody();
// POSITION
const BodySet& bodySet = _model->getBodySet();
for(int i=0;i<_bodyIndices.getSize();i++) {
const Body& body = bodySet.get(_bodyIndices[i]);
// GET MOMENTUM
SimTK::SpatialVec vec6 = _model->getMatterSubsystem().getMobilizedBody(MobilizedBodyIndex(i)).calcBodyMomentumAboutBodyMassCenterInGround(s);
// the argument for "getMobilizedBody" is probably the issue, but I am not sure what I have done wrong and how to fix it
// FILL ARRAY, currently called "_bodypos", but that does not matter
int I=6*i;
memcpy(&_bodypos[I],&vec6[0],6*sizeof(double));
}
_storePos.append(s.getTime(),_bodypos.getSize(),&_bodypos[0]);
return(0);
}