Libbarrett  1.2.4
include/barrett/systems/inverse_dynamics.h
00001 /*
00002         Copyright 2009, 2010 Barrett Technology <support@barrett.com>
00003 
00004         This file is part of libbarrett.
00005 
00006         This version of libbarrett is free software: you can redistribute it
00007         and/or modify it under the terms of the GNU General Public License as
00008         published by the Free Software Foundation, either version 3 of the
00009         License, or (at your option) any later version.
00010 
00011         This version of libbarrett is distributed in the hope that it will be
00012         useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
00013         MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014         GNU General Public License for more details.
00015 
00016         You should have received a copy of the GNU General Public License along
00017         with this version of libbarrett.  If not, see
00018         <http://www.gnu.org/licenses/>.
00019 
00020         Further, non-binding information about licensing is available at:
00021         <http://wiki.barrett.com/libbarrett/wiki/LicenseNotes>
00022 */
00023 
00024 /*
00025  * inverse_dynamics.h
00026  *
00027  *  Created on: Nov 9, 2011
00028  *      Author: dc
00029  */
00030 
00031 #ifndef BARRETT_SYSTEMS_INVERSE_DYNAMICS_H_
00032 #define BARRETT_SYSTEMS_INVERSE_DYNAMICS_H_
00033 
00034 
00035 #include <libconfig.h++>
00036 
00037 #include <barrett/detail/ca_macro.h>
00038 #include <barrett/units.h>
00039 
00040 #include <barrett/math/dynamics.h>
00041 #include <barrett/systems/abstract/single_io.h>
00042 #include <barrett/systems/kinematics_base.h>
00043 
00044 
00045 namespace barrett {
00046 namespace systems {
00047 
00048 
00049 template<size_t DOF>
00050 class InverseDynamics :
00051         public SingleIO<typename units::JointAccelerations<DOF>::type, typename units::JointTorques<DOF>::type>,
00052         public KinematicsInput<DOF>,
00053         public math::Dynamics<DOF>
00054 {
00055         BARRETT_UNITS_TEMPLATE_TYPEDEFS(DOF);
00056 
00057 // IO
00058 public:         System::Input<jv_type> jvInput;
00059 
00060 public:
00061         explicit InverseDynamics(const libconfig::Setting& setting, const std::string& sysName = "InverseDynamics")
00062                 : SingleIO<ja_type, jt_type>(sysName), KinematicsInput<DOF>(this), math::Dynamics<DOF>(setting), jvInput(this) {}
00063         virtual ~InverseDynamics() { this->mandatoryCleanUp(); }
00064 
00065 protected:
00066         virtual void operate() {
00067                 evalInverse(this->kinInput.getValue(), jvInput.getValue(), this->input.getValue());
00068                 this->outputValue->setData(&this->jt);
00069         }
00070 
00071 private:
00072         DISALLOW_COPY_AND_ASSIGN(InverseDynamics);
00073 };
00074 
00075 
00076 }
00077 }
00078 
00079 
00080 #endif /* BARRETT_SYSTEMS_INVERSE_DYNAMICS_H_ */
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Defines