Skip to content

Commit

Permalink
Merge pull request #1158 from cmastalli/topic/fix-state-residual
Browse files Browse the repository at this point in the history
  • Loading branch information
cmastalli authored Aug 12, 2023
2 parents 0eae0de + 74f8fbe commit 1e89951
Show file tree
Hide file tree
Showing 4 changed files with 95 additions and 12 deletions.
10 changes: 5 additions & 5 deletions include/crocoddyl/core/residuals/joint-acceleration.hpp
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
///////////////////////////////////////////////////////////////////////////////
// BSD 3-Clause License
//
// Copyright (C) 2022, Heriot-Watt University
// Copyright (C) 2022-2023, Heriot-Watt University
// Copyright note valid unless otherwise stated in individual files.
// All rights reserved.
///////////////////////////////////////////////////////////////////////////////
Expand Down Expand Up @@ -54,22 +54,22 @@ class ResidualModelJointAccelerationTpl
* @brief Initialize the joint-acceleration residual model
*
* @param[in] state State description
* @param[in] uref Reference joint acceleration
* @param[in] aref Reference joint acceleration
* @param[in] nu Dimension of the control vector
*/
ResidualModelJointAccelerationTpl(boost::shared_ptr<StateAbstract> state,
const VectorXs& uref, const std::size_t nu);
const VectorXs& aref, const std::size_t nu);

/**
* @brief Initialize the joint-acceleration residual model
*
* The default `nu` value is obtained from `StateAbstractTpl::get_nv()`.
*
* @param[in] state State description
* @param[in] uref Reference joint acceleration
* @param[in] aref Reference joint acceleration
*/
ResidualModelJointAccelerationTpl(boost::shared_ptr<StateAbstract> state,
const VectorXs& uref);
const VectorXs& aref);

/**
* @brief Initialize the joint-acceleration residual model
Expand Down
16 changes: 14 additions & 2 deletions include/crocoddyl/core/residuals/joint-acceleration.hxx
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,25 @@ template <typename Scalar>
ResidualModelJointAccelerationTpl<Scalar>::ResidualModelJointAccelerationTpl(
boost::shared_ptr<StateAbstract> state, const VectorXs& aref,
const std::size_t nu)
: Base(state, state->get_nv(), nu, true, true, true), aref_(aref) {}
: Base(state, state->get_nv(), nu, true, true, true), aref_(aref) {
if (static_cast<std::size_t>(aref_.size()) != state->get_nv()) {
throw_pretty("Invalid argument: "
<< "aref has wrong dimension (it should be " +
std::to_string(state->get_nv()) + ")");
}
}

template <typename Scalar>
ResidualModelJointAccelerationTpl<Scalar>::ResidualModelJointAccelerationTpl(
boost::shared_ptr<StateAbstract> state, const VectorXs& aref)
: Base(state, state->get_nv(), state->get_nv(), true, true, true),
aref_(aref) {}
aref_(aref) {
if (static_cast<std::size_t>(aref_.size()) != state->get_nv()) {
throw_pretty("Invalid argument: "
<< "aref has wrong dimension (it should be " +
std::to_string(state->get_nv()) + ")");
}
}

template <typename Scalar>
ResidualModelJointAccelerationTpl<Scalar>::ResidualModelJointAccelerationTpl(
Expand Down
10 changes: 5 additions & 5 deletions include/crocoddyl/multibody/residuals/state.hxx
Original file line number Diff line number Diff line change
Expand Up @@ -147,11 +147,11 @@ ResidualModelStateTpl<Scalar>::get_reference() const {

template <typename Scalar>
void ResidualModelStateTpl<Scalar>::set_reference(const VectorXs& reference) {
if (static_cast<std::size_t>(reference.size()) != nr_) {
throw_pretty("Invalid argument: "
<< "the state reference has wrong dimension ("
<< reference.size()
<< " provided - it should be " + std::to_string(nr_) + ")")
if (static_cast<std::size_t>(reference.size()) != state_->get_nx()) {
throw_pretty(
"Invalid argument: "
<< "the state reference has wrong dimension (" << reference.size()
<< " provided - it should be " + std::to_string(state_->get_nx()) + ")")
}
xref_ = reference;
}
Expand Down
71 changes: 71 additions & 0 deletions unittest/test_residuals.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,13 @@
#define BOOST_TEST_NO_MAIN
#define BOOST_TEST_ALTERNATIVE_INIT_API

#include "crocoddyl/core/residuals/control.hpp"
#include "crocoddyl/core/residuals/joint-acceleration.hpp"
#include "crocoddyl/core/residuals/joint-effort.hpp"
#include "crocoddyl/multibody/data/multibody.hpp"
#include "crocoddyl/multibody/residuals/centroidal-momentum.hpp"
#include "crocoddyl/multibody/residuals/com-position.hpp"
#include "crocoddyl/multibody/residuals/state.hpp"
#include "factory/actuation.hpp"
#include "factory/residual.hpp"
#include "unittest_common.hpp"
Expand Down Expand Up @@ -198,6 +204,61 @@ void test_partial_derivatives_against_numdiff(
BOOST_CHECK((data->Rx - data_num_diff->Rx).isZero(tol));
}

void test_reference() {
ResidualModelFactory factory;
StateModelTypes::Type state_type = StateModelTypes::StateMultibody_Talos;
ActuationModelTypes::Type actuation_type =
ActuationModelTypes::ActuationModelFloatingBase;
StateModelFactory state_factory;
ActuationModelFactory actuation_factory;
boost::shared_ptr<crocoddyl::StateMultibody> state =
boost::static_pointer_cast<crocoddyl::StateMultibody>(
state_factory.create(state_type));
boost::shared_ptr<crocoddyl::ActuationModelAbstract> actuation =
actuation_factory.create(actuation_type, state_type);

const std::size_t nu = actuation->get_nu();
const std::size_t nv = state->get_nv();

// Test reference in state residual
crocoddyl::ResidualModelState state_residual(state, state->rand(), nu);
Eigen::VectorXd x_ref = state_residual.get_state()->rand();
state_residual.set_reference(x_ref);
BOOST_CHECK((x_ref - state_residual.get_reference()).isZero());

// Test reference in control residual
crocoddyl::ResidualModelControl control_residual(state, nu);
Eigen::VectorXd u_ref = Eigen::VectorXd::Random(nu);
control_residual.set_reference(u_ref);
BOOST_CHECK((u_ref - control_residual.get_reference()).isZero());

// Test reference in joint-acceleration residual
crocoddyl::ResidualModelJointAcceleration jacc_residual(state, nu);
Eigen::VectorXd a_ref = Eigen::VectorXd::Random(nv);
jacc_residual.set_reference(a_ref);
BOOST_CHECK((a_ref - jacc_residual.get_reference()).isZero());

// Test reference in joint-effort residual
crocoddyl::ResidualModelJointEffort jeff_residual(state, actuation, nu);
Eigen::VectorXd tau_ref = Eigen::VectorXd::Random(nu);
jeff_residual.set_reference(tau_ref);
BOOST_CHECK((tau_ref - jeff_residual.get_reference()).isZero());

// Test reference in centroidal-momentum residual
crocoddyl::ResidualModelCentroidalMomentum cmon_residual(
state, Eigen::Matrix<double, 6, 1>::Zero());
Eigen::Matrix<double, 6, 1> h_ref = Eigen::Matrix<double, 6, 1>::Random();
cmon_residual.set_reference(h_ref);
BOOST_CHECK((h_ref - cmon_residual.get_reference()).isZero());

// Test reference in com-position residual
crocoddyl::ResidualModelCoMPosition c_residual(state,
Eigen::Vector3d::Zero());
Eigen::Vector3d c_ref = Eigen::Vector3d::Random();
c_residual.set_reference(c_ref);
BOOST_CHECK((c_ref - c_residual.get_reference()).isZero());
}

//----------------------------------------------------------------------------//

void register_residual_model_unit_tests(
Expand All @@ -219,6 +280,15 @@ void register_residual_model_unit_tests(
framework::master_test_suite().add(ts);
}

void regiter_residual_reference_unit_tests() {
boost::test_tools::output_test_stream test_name;
test_name << "test_reference";
std::cout << "Running " << test_name.str() << std::endl;
test_suite* ts = BOOST_TEST_SUITE(test_name.str());
ts->add(BOOST_TEST_CASE(boost::bind(&test_reference)));
framework::master_test_suite().add(ts);
}

bool init_function() {
// Test all residuals available with all the activation types with all
// available states types.
Expand Down Expand Up @@ -247,6 +317,7 @@ bool init_function() {
}
}
}
regiter_residual_reference_unit_tests();
return true;
}

Expand Down

0 comments on commit 1e89951

Please sign in to comment.