Robotics Library  0.7.0
Element.h
Go to the documentation of this file.
1 //
2 // Copyright (c) 2009, Markus Rickert
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are met:
7 //
8 // * Redistributions of source code must retain the above copyright notice,
9 // this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright notice,
11 // this list of conditions and the following disclaimer in the documentation
12 // and/or other materials provided with the distribution.
13 //
14 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
15 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
18 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
19 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
20 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
22 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
23 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24 // POSSIBILITY OF SUCH DAMAGE.
25 //
26 
27 #ifndef RL_MDL_ELEMENT_H
28 #define RL_MDL_ELEMENT_H
29 
30 #include <string>
31 #include <rl/math/Real.h>
32 
33 namespace rl
34 {
35  namespace mdl
36  {
37  class Compound;
38 
39  class Element
40  {
41  public:
42  Element();
43 
44  virtual ~Element();
45 
46  virtual void forwardAcceleration() = 0;
47 
48  virtual void forwardDynamics1() = 0;
49 
50  virtual void forwardDynamics2() = 0;
51 
52  virtual void forwardDynamics3() = 0;
53 
54  virtual void forwardPosition() = 0;
55 
56  virtual void forwardVelocity() = 0;
57 
58  const ::std::string& getName() const;
59 
60  virtual void inverseDynamics1() = 0;
61 
62  virtual void inverseDynamics2() = 0;
63 
64  virtual void inverseForce() = 0;
65 
66  void setName(const ::std::string& name);
67 
69 
70  protected:
71 
72  private:
73  ::std::string name;
74  };
75  }
76 }
77 
78 #endif // RL_MDL_ELEMENT_H
rl::mdl::Element::inverseDynamics2
virtual void inverseDynamics2()=0
rl::mdl::Element::forwardDynamics1
virtual void forwardDynamics1()=0
rl::mdl::Element::forwardAcceleration
virtual void forwardAcceleration()=0
rl::mdl::Element::name
::std::string name
Definition: Element.h:73
rl::mdl::Element::setName
void setName(const ::std::string &name)
Definition: Element.cpp:50
rl::mdl::Element::Element
Element()
Definition: Element.cpp:33
rl::mdl::Element::compound
Compound * compound
Definition: Element.h:68
rl::mdl::Element::forwardDynamics3
virtual void forwardDynamics3()=0
rl::mdl::Element::inverseDynamics1
virtual void inverseDynamics1()=0
rl::mdl::Element::getName
const ::std::string & getName() const
Definition: Element.cpp:44
rl::mdl::Compound
Definition: Compound.h:42
rl::mdl::Element::forwardVelocity
virtual void forwardVelocity()=0
rl::mdl::Element
Definition: Element.h:40
rl::mdl::Element::inverseForce
virtual void inverseForce()=0
Real.h
rl::mdl::Element::forwardPosition
virtual void forwardPosition()=0
rl::mdl::Element::~Element
virtual ~Element()
Definition: Element.cpp:39
rl::mdl::Element::forwardDynamics2
virtual void forwardDynamics2()=0
rl
Robotics Library.
Definition: AnalogInput.cpp:30