NTRT Simulator
 All Classes Files Functions Variables Typedefs Friends Pages
FlemonsSpineModel.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 FLEMONS_SPINE_MODEL_H
20 #define FLEMONS_SPINE_MODEL_H
21 
22 #include "core/tgModel.h"
23 
24 #include "core/tgSubject.h"
25 
26 #include <set>
27 #include <map>
28 
29 class tgLinearString;
30 class tgWorld;
31 class CPGEquations;
32 
33 class FlemonsSpineModel: public tgSubject<FlemonsSpineModel>, public tgModel
34 {
35 public:
36 
37  FlemonsSpineModel(int segments);
38 
39  virtual ~FlemonsSpineModel()
40  {}
41 
42  virtual void setup(tgWorld& world);
43 
44  virtual void step(double dt);
45 
46  const std::vector<double> getSegmentCOM(const int n) const;
47 
48  void changeMuscle (double length, double dt);
49 
50  const std::vector<tgLinearString*> getMuscles (std::string key)
51  {
52  return muscleMap[key];
53  }
54 
55  const int getSegments() const
56  {
57  return m_segments;
58  }
59 
60 private:
61  std::vector<tgLinearString*> allMuscles;
62  std::vector<tgModel*> allSegments;
63  std::map<std::string, std::vector<tgLinearString*> > muscleMap;
64 
65  const int m_segments;
66 };
67 
68 #endif // FLEMONS_SPINE_MODEL_H
virtual void setup(tgWorld &world)
Definition of tgSubject class.
Contains the definition of class tgModel. $Id$.
virtual void step(double dt)