2000-11-03 23:02:47 +00:00
|
|
|
/*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
Source: FGForce.cpp
|
|
|
|
Author: Tony Peden
|
|
|
|
Date started: 6/10/00
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
------------- Copyright (C) 1999 Anthony K. Peden (apeden@earthlink.net) -------------
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; either version 2 of the License, or (at your option) any later
|
|
|
|
version.
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
details.
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|
|
|
Place - Suite 330, Boston, MA 02111-1307, USA.
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
Further information about the GNU General Public License can also be found on
|
|
|
|
the world wide web at http://www.gnu.org.
|
2001-03-30 01:04:50 +00:00
|
|
|
|
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
HISTORY
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
6/10/00 TP Created
|
2001-03-30 01:04:50 +00:00
|
|
|
|
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
FUNCTIONAL DESCRIPTION
|
|
|
|
--------------------------------------------------------------------------------
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
The purpose of this class is to provide storage for computed forces and
|
2001-03-30 01:04:50 +00:00
|
|
|
encapsulate all the functionality associated with transforming those
|
2000-10-02 23:07:30 +00:00
|
|
|
forces from their native coord system to the body system. This includes
|
|
|
|
computing the moments due to the difference between the point of application
|
|
|
|
and the cg.
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "FGFDMExec.h"
|
|
|
|
#include "FGAircraft.h"
|
|
|
|
#include "FGTranslation.h"
|
2001-10-05 20:19:59 +00:00
|
|
|
#include "FGMatrix33.h"
|
|
|
|
#include "FGColumnVector3.h"
|
|
|
|
#include "FGColumnVector4.h"
|
2000-10-02 23:07:30 +00:00
|
|
|
#include "FGForce.h"
|
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
static const char *IdSrc = "$Id$";
|
2001-06-05 20:58:48 +00:00
|
|
|
static const char *IdHdr = ID_FORCE;
|
2000-10-02 23:07:30 +00:00
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
FGForce::FGForce(FGFDMExec *FDMExec) :
|
2001-12-03 22:24:40 +00:00
|
|
|
ttype(tNone),
|
|
|
|
fdmex(FDMExec),
|
2000-10-02 23:07:30 +00:00
|
|
|
vFn(3),
|
|
|
|
vMn(3),
|
2001-12-03 22:24:40 +00:00
|
|
|
vH(3),
|
2000-10-02 23:07:30 +00:00
|
|
|
vFb(3),
|
|
|
|
vM(3),
|
|
|
|
vXYZn(3),
|
|
|
|
vDXYZ(3),
|
|
|
|
vSense(3),
|
2001-12-03 22:24:40 +00:00
|
|
|
mT(3,3)
|
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
{
|
2001-11-06 22:33:05 +00:00
|
|
|
mT(1,1) = 1; //identity matrix
|
|
|
|
mT(2,2) = 1;
|
|
|
|
mT(3,3) = 1;
|
2000-10-02 23:07:30 +00:00
|
|
|
vSense.InitMatrix(1);
|
2001-03-30 01:04:50 +00:00
|
|
|
if (debug_lvl & 2) cout << "Instantiated: FGForce" << endl;
|
2000-10-02 23:07:30 +00:00
|
|
|
}
|
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
FGForce::~FGForce()
|
|
|
|
{
|
|
|
|
if (debug_lvl & 2) cout << "Destroyed: FGForce" << endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2000-10-02 23:07:30 +00:00
|
|
|
|
2001-10-05 20:19:59 +00:00
|
|
|
FGColumnVector3& FGForce::GetBodyForces(void) {
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2001-11-06 22:33:05 +00:00
|
|
|
vFb = Transform()*(vFn.multElementWise(vSense));
|
2000-10-02 23:07:30 +00:00
|
|
|
|
|
|
|
//find the distance from this vector's location to the cg
|
|
|
|
//needs to be done like this to convert from structural to body coords
|
2001-11-12 16:06:29 +00:00
|
|
|
vDXYZ(1) = -(vXYZn(1) - fdmex->GetMassBalance()->GetXYZcg(1))*inchtoft;
|
|
|
|
vDXYZ(2) = (vXYZn(2) - fdmex->GetMassBalance()->GetXYZcg(2))*inchtoft; //cg and rp values are in inches
|
|
|
|
vDXYZ(3) = -(vXYZn(3) - fdmex->GetMassBalance()->GetXYZcg(3))*inchtoft;
|
2000-10-02 23:07:30 +00:00
|
|
|
|
2001-11-09 04:38:53 +00:00
|
|
|
vM = vMn + vDXYZ*vFb;
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
return vFb;
|
|
|
|
}
|
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
2000-10-02 23:07:30 +00:00
|
|
|
|
2001-10-05 20:19:59 +00:00
|
|
|
FGMatrix33 FGForce::Transform(void) {
|
2000-10-02 23:07:30 +00:00
|
|
|
switch(ttype) {
|
|
|
|
case tWindBody:
|
2001-11-20 22:34:24 +00:00
|
|
|
return fdmex->GetState()->GetTs2b();
|
2000-10-02 23:07:30 +00:00
|
|
|
case tLocalBody:
|
|
|
|
return fdmex->GetState()->GetTl2b();
|
|
|
|
case tCustom:
|
2001-03-30 01:04:50 +00:00
|
|
|
|
2000-10-02 23:07:30 +00:00
|
|
|
case tNone:
|
2001-03-30 01:04:50 +00:00
|
|
|
return mT;
|
2000-10-02 23:07:30 +00:00
|
|
|
default:
|
|
|
|
cout << "Unrecognized tranform requested from FGForce::Transform()" << endl;
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2001-11-20 22:34:24 +00:00
|
|
|
void FGForce::SetAnglesToBody(double broll, double bpitch, double byaw) {
|
2000-10-02 23:07:30 +00:00
|
|
|
|
|
|
|
if(ttype == tCustom) {
|
2001-11-20 22:34:24 +00:00
|
|
|
double cp,sp,cr,sr,cy,sy;
|
2000-10-02 23:07:30 +00:00
|
|
|
|
|
|
|
cp=cos(bpitch); sp=sin(bpitch);
|
|
|
|
cr=cos(broll); sr=sin(broll);
|
|
|
|
cy=cos(byaw); sy=sin(byaw);
|
|
|
|
|
|
|
|
mT(1,1)=cp*cy;
|
|
|
|
mT(1,2)=cp*sy;
|
|
|
|
mT(1,3)=-1*sp;
|
|
|
|
|
|
|
|
mT(2,1)=sr*sp*cy-cr*sy;
|
|
|
|
mT(2,2)=sr*sp*sy+cr*cy;
|
|
|
|
mT(2,3)=sr*cp;
|
|
|
|
|
|
|
|
mT(3,1)=cr*sp*cy+sr*sy;
|
|
|
|
mT(3,2)=cr*sp*sy-sr*cy;
|
|
|
|
mT(3,3)=cr*cp;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2001-03-30 01:04:50 +00:00
|
|
|
//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
void FGForce::Debug(void)
|
|
|
|
{
|
|
|
|
//TODO: Add your source code here
|
|
|
|
}
|
2000-10-02 23:07:30 +00:00
|
|
|
|