File: DillCreator.hpp

package info (click to toggle)
bullet 3.06%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 15,012 kB
  • sloc: cpp: 243,705; lisp: 12,017; ansic: 11,175; python: 626; makefile: 133; sh: 75
file content (47 lines) | stat: -rw-r--r-- 1,723 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#ifndef DILLCREATOR_HPP_
#define DILLCREATOR_HPP_

#include "MultiBodyTreeCreator.hpp"

namespace btInverseDynamics
{
/// Creator class for building a "Dill" system as intruduced as benchmark example in
/// Featherstone (1999), "A Divide-and-Conquer Articulated-Body Algorithm for Parallel O(log(n))
/// Calculation of Rigid-Body Dynamics. Part 2: Trees, Loops, and Accuracy.",  The International
/// Journal of Robotics Research 18 (9): 876–892. doi : 10.1177 / 02783649922066628.
///
/// This is a self-similar branched tree, somewhat resembling a dill plant
class DillCreator : public MultiBodyTreeCreator
{
public:
	/// ctor
	/// @param levels the number of dill levels
	DillCreator(int levels);
	/// dtor
	~DillCreator();
	///\copydoc MultiBodyTreeCreator::getNumBodies
	int getNumBodies(int* num_bodies) const;
	///\copydoc MultiBodyTreeCreator::getBody
	int getBody(const int body_index, int* parent_index, JointType* joint_type,
				vec3* parent_r_parent_body_ref, mat33* body_T_parent_ref, vec3* body_axis_of_motion,
				idScalar* mass, vec3* body_r_body_com, mat33* body_I_body, int* user_int,
				void** user_ptr) const;

private:
	/// recursively generate dill bodies.
	/// TODO better documentation
	int recurseDill(const int levels, const int parent, const idScalar d_DH_in,
					const idScalar a_DH_in, const idScalar alpha_DH_in);
	int m_level;
	int m_num_bodies;
	idArray<int>::type m_parent;
	idArray<vec3>::type m_parent_r_parent_body_ref;
	idArray<mat33>::type m_body_T_parent_ref;
	idArray<vec3>::type m_body_axis_of_motion;
	idArray<idScalar>::type m_mass;
	idArray<vec3>::type m_body_r_body_com;
	idArray<mat33>::type m_body_I_body;
	int m_current_body;
};
}  // namespace btInverseDynamics
#endif