1
0
Fork 0

YASim: export more forces to prop tree for in flight debugging

This commit is contained in:
Henning Stahlke 2017-12-11 19:02:00 +01:00
parent a199ca817c
commit 13e00b275b
2 changed files with 27 additions and 10 deletions

View file

@ -61,6 +61,12 @@ Model::Model()
_fAeroXN = _modelN->getNode("f-x-drag", true); _fAeroXN = _modelN->getNode("f-x-drag", true);
_fAeroYN = _modelN->getNode("f-y-side", true); _fAeroYN = _modelN->getNode("f-y-side", true);
_fAeroZN = _modelN->getNode("f-z-lift", true); _fAeroZN = _modelN->getNode("f-z-lift", true);
_fGravXN = _modelN->getNode("gravity-x", true);
_fGravYN = _modelN->getNode("gravity-y", true);
_fGravZN = _modelN->getNode("gravity-z", true);
_fSumXN = _modelN->getNode("f-sum-x", true);
_fSumYN = _modelN->getNode("f-sum-y", true);
_fSumZN = _modelN->getNode("f-sum-z", true);
_gefxN = fgGetNode("/fdm/yasim/debug/ground-effect/ge-f-x", true); _gefxN = fgGetNode("/fdm/yasim/debug/ground-effect/ge-f-x", true);
_gefyN = fgGetNode("/fdm/yasim/debug/ground-effect/ge-f-y", true); _gefyN = fgGetNode("/fdm/yasim/debug/ground-effect/ge-f-y", true);
@ -293,8 +299,7 @@ void Model::calcForces(State* s)
// Do each surface, remembering that the local velocity at each // Do each surface, remembering that the local velocity at each
// point is different due to rotation. // point is different due to rotation.
float faero[3]; float faero[3] {0,0,0};
faero[0] = faero[1] = faero[2] = 0;
for(i=0; i<_surfaces.size(); i++) { for(i=0; i<_surfaces.size(); i++) {
Surface* sf = (Surface*)_surfaces.get(i); Surface* sf = (Surface*)_surfaces.get(i);
@ -374,6 +379,12 @@ void Model::calcForces(State* s)
_fAeroXN->setFloatValue(faero[0]); _fAeroXN->setFloatValue(faero[0]);
_fAeroYN->setFloatValue(faero[1]); _fAeroYN->setFloatValue(faero[1]);
_fAeroZN->setFloatValue(faero[2]); _fAeroZN->setFloatValue(faero[2]);
_fGravXN->setFloatValue(grav[0]);
_fGravYN->setFloatValue(grav[1]);
_fGravZN->setFloatValue(grav[2]);
_fSumXN->setFloatValue(faero[0]+grav[0]);
_fSumYN->setFloatValue(faero[1]+grav[1]);
_fSumZN->setFloatValue(faero[2]+grav[2]);
} }
// Convert the velocity and rotation vectors to local coordinates // Convert the velocity and rotation vectors to local coordinates
float lrot[3], lv[3]; float lrot[3], lv[3];
@ -382,18 +393,18 @@ void Model::calcForces(State* s)
// The landing gear // The landing gear
for(i=0; i<_gears.size(); i++) { for(i=0; i<_gears.size(); i++) {
float force[3], contact[3]; float force[3], contact[3];
Gear* g = (Gear*)_gears.get(i); Gear* g = (Gear*)_gears.get(i);
g->calcForce(&_body, s, lv, lrot); g->calcForce(&_body, s, lv, lrot);
g->getForce(force, contact); g->getForce(force, contact);
_body.addForce(contact, force); _body.addForce(contact, force);
} }
// The arrester hook // The arrester hook
if(_hook) { if(_hook) {
_hook->calcForce(_ground_cb, &_body, s, lv, lrot); _hook->calcForce(_ground_cb, &_body, s, lv, lrot);
float force[3], contact[3]; float force[3], contact[3];
_hook->getForce(force, contact); _hook->getForce(force, contact);
_body.addForce(contact, force); _body.addForce(contact, force);
} }
@ -401,13 +412,13 @@ void Model::calcForces(State* s)
// The launchbar/holdback // The launchbar/holdback
if(_launchbar) { if(_launchbar) {
_launchbar->calcForce(_ground_cb, &_body, s, lv, lrot); _launchbar->calcForce(_ground_cb, &_body, s, lv, lrot);
float forcelb[3], contactlb[3], forcehb[3], contacthb[3]; float forcelb[3], contactlb[3], forcehb[3], contacthb[3];
_launchbar->getForce(forcelb, contactlb, forcehb, contacthb); _launchbar->getForce(forcelb, contactlb, forcehb, contacthb);
_body.addForce(contactlb, forcelb); _body.addForce(contactlb, forcelb);
_body.addForce(contacthb, forcehb); _body.addForce(contacthb, forcehb);
} }
// The hitches // The hitches
for(i=0; i<_hitches.size(); i++) { for(i=0; i<_hitches.size(); i++) {
float force[3], contact[3]; float force[3], contact[3];
Hitch* h = (Hitch*)_hitches.get(i); Hitch* h = (Hitch*)_hitches.get(i);

View file

@ -118,6 +118,12 @@ private:
SGPropertyNode_ptr _fAeroXN; SGPropertyNode_ptr _fAeroXN;
SGPropertyNode_ptr _fAeroYN; SGPropertyNode_ptr _fAeroYN;
SGPropertyNode_ptr _fAeroZN; SGPropertyNode_ptr _fAeroZN;
SGPropertyNode_ptr _fSumXN;
SGPropertyNode_ptr _fSumYN;
SGPropertyNode_ptr _fSumZN;
SGPropertyNode_ptr _fGravXN;
SGPropertyNode_ptr _fGravYN;
SGPropertyNode_ptr _fGravZN;
SGPropertyNode_ptr _gefxN; SGPropertyNode_ptr _gefxN;
SGPropertyNode_ptr _gefyN; SGPropertyNode_ptr _gefyN;
SGPropertyNode_ptr _gefzN; SGPropertyNode_ptr _gefzN;