Welcome to mirror list, hosted at ThFree Co, Russian Federation.

ControlledObject.cpp « itasc « intern - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 3c3e87ee09e5badbd723d187f7f632c024ff293d (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/** \file itasc/ControlledObject.cpp
 * \ingroup itasc
 */
/*
 * ControlledObject.cpp
 *
 *  Created on: Jan 5, 2009
 *      Author: rubensmits
 */

#include "ControlledObject.hpp"


namespace iTaSC {
ControlledObject::ControlledObject():
    Object(Controlled),m_nq(0),m_nc(0),m_nee(0)
{
	// max joint variable = 0.52 radian or 0.52 meter in one timestep
	m_maxDeltaQ = e_scalar(0.52);
}

void ControlledObject::initialize(unsigned int _nq,unsigned int _nc, unsigned int _nee)
{
	assert(_nee >= 1);
	m_nq = _nq;
	m_nc = _nc;
	m_nee = _nee;
	if (m_nq > 0) {
		m_Wq =  e_identity_matrix(m_nq,m_nq);
		m_qdot = e_zero_vector(m_nq);
	}
	if (m_nc > 0) {
		m_Wy = e_scalar_vector(m_nc,1.0);
		m_ydot = e_zero_vector(m_nc);
	}
	if (m_nc > 0 && m_nq > 0)
		m_Cq = e_zero_matrix(m_nc,m_nq);
	// clear all Jacobian if any
	m_JqArray.clear();
	// reserve one more to have a zero matrix handy
	if (m_nq > 0)
		m_JqArray.resize(m_nee+1, e_zero_matrix(6,m_nq));
}

ControlledObject::~ControlledObject() {}



const e_matrix& ControlledObject::getJq(unsigned int ee) const
{
	assert(m_nq > 0);
	return m_JqArray[(ee>m_nee)?m_nee:ee];
}

double ControlledObject::getMaxTimestep(double& timestep)
{
	e_scalar maxQdot = m_qdot.array().abs().maxCoeff();
	if (timestep*maxQdot > m_maxDeltaQ) {
		timestep = m_maxDeltaQ/maxQdot;
	}
	return timestep;
}

}