NTRT Simulator  Version: Master
 All Classes Namespaces Files Functions Variables Typedefs Friends Pages
T6Model.h
1 /*
2  * Copyright © 2012, United States Government, as represented by the
3  * Administrator of the National Aeronautics and Space Administration.
4  * All rights reserved.
5  *
6  * The NASA Tensegrity Robotics Toolkit (NTRT) v1 platform is licensed
7  * under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * http://www.apache.org/licenses/LICENSE-2.0.
11  *
12  * Unless required by applicable law or agreed to in writing,
13  * software distributed under the License is distributed on an
14  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
15  * either express or implied. See the License for the specific language
16  * governing permissions and limitations under the License.
17 */
18 
19 #ifndef T6_MODEL_H
20 #define T6_MODEL_H
21 
28 // This library
29 #include "core/tgModel.h"
30 #include "core/tgSubject.h"
31 #include "core/tgRod.h"
32 // The C++ Standard Library
33 #include <vector>
34 
35 // Forward declarations
36 class tgBasicActuator;
37 class tgModelVisitor;
38 class tgStructure;
39 class tgWorld;
40 
44 class T6Model : public tgSubject<T6Model>, public tgModel
45 {
46 public:
47 
53  T6Model();
54 
59  virtual ~T6Model();
60 
69  virtual void setup(tgWorld& world);
70 
75  void teardown();
76 
81  virtual void step(double dt);
82 
90  virtual void onVisit(tgModelVisitor& r);
91 
95  std::vector<double> getBallCOM();
96 
101  const std::vector<tgBasicActuator*>& getAllMuscles() const;
102 
107  const std::vector<tgBasicActuator*>& getPassiveMuscles() const;
108 
113  const std::vector<tgBasicActuator*>& getActiveMuscles() const;
114 
120  virtual const double muscleRatio();
121 
122 private:
123 
130  void addNodes(tgStructure& s);
131 
137  static void addRods(tgStructure& s);
138 
143  void addMarkers(tgStructure& s);
144 
150  static void addMuscles(tgStructure& s);
151 
159  void moveModel(btVector3 targetPositionVector, btVector3 rotationVector,
160  btVector3 speedVector);
161 
162 private:
163 
168  std::vector<tgBasicActuator*> allMuscles;
169 
174  std::vector<tgBasicActuator*> passiveMuscles;
175 
180  std::vector<tgBasicActuator*> activeMuscles;
181 
185  std::vector<btVector3> nodePositions;
186 };
187 
188 #endif // T6_MODEL_H
Definition of tgSubject class.
std::vector< double > getBallCOM()
Definition: T6Model.cpp:284
virtual void onVisit(tgModelVisitor &r)
Definition: T6Model.cpp:242
const std::vector< tgBasicActuator * > & getAllMuscles() const
Definition: T6Model.cpp:247
const std::vector< tgBasicActuator * > & getPassiveMuscles() const
Definition: T6Model.cpp:252
virtual void setup(tgWorld &world)
Definition: T6Model.cpp:174
Contains the definition of class tgModel.
void teardown()
Definition: T6Model.cpp:268
virtual void step(double dt)
Definition: T6Model.cpp:227
virtual ~T6Model()
Definition: T6Model.cpp:104
const std::vector< tgBasicActuator * > & getActiveMuscles() const
Definition: T6Model.cpp:257
T6Model()
Definition: T6Model.cpp:100
virtual const double muscleRatio()
Definition: T6Model.cpp:262
Contains the definition of class tgRod.