10 #ifndef CROCODDYL_CORE_SQUASHING_SMOOTH_SAT_HPP_
11 #define CROCODDYL_CORE_SQUASHING_SMOOTH_SAT_HPP_
13 #include "crocoddyl/core/actuation/squashing-base.hpp"
14 #include "crocoddyl/core/fwd.hpp"
18 template <
typename _Scalar>
21 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
24 typedef _Scalar Scalar;
28 typedef typename MathBase::VectorXs VectorXs;
31 const Eigen::Ref<const VectorXs>& u_ub,
40 smooth_ = Scalar(0.1);
42 d_ = (u_ub_ - u_lb_) * smooth_;
43 a_ = d_.array() * d_.array();
48 virtual void calc(
const std::shared_ptr<SquashingDataAbstract>& data,
49 const Eigen::Ref<const VectorXs>& s)
override {
53 data->u = Scalar(0.5) *
54 (Eigen::sqrt(Eigen::pow((s - u_lb_).array(), 2) + a_.array()) -
55 Eigen::sqrt(Eigen::pow((s - u_ub_).array(), 2) + a_.array()) +
56 u_lb_.array() + u_ub_.array());
59 virtual void calcDiff(
const std::shared_ptr<SquashingDataAbstract>& data,
60 const Eigen::Ref<const VectorXs>& s)
override {
61 data->du_ds.diagonal() =
63 (Eigen::pow(a_.array() + Eigen::pow((s - u_lb_).array(), 2),
67 Eigen::pow(a_.array() + Eigen::pow((s - u_ub_).array(), 2),
73 template <
typename NewScalar>
76 ReturnType ret(u_lb_.template cast<NewScalar>(),
77 u_ub_.template cast<NewScalar>(), ns_);
81 const Scalar get_smooth()
const {
return smooth_; };
82 void set_smooth(
const Scalar smooth) {
84 throw_pretty(
"Invalid argument: " <<
"Smooth value has to be positive");
88 d_ = (u_ub_ - u_lb_) * smooth_;
89 a_ = d_.array() * d_.array();
95 const VectorXs& get_d()
const {
return d_; };