You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Conception/drake-master/multibody/fem/calc_lame_parameters.cc

32 lines
980 B

#include "drake/multibody/fem/calc_lame_parameters.h"
#include "drake/common/default_scalars.h"
namespace drake {
namespace multibody {
namespace fem {
namespace internal {
template <typename T>
LameParameters<T> CalcLameParameters(const T& youngs_modulus,
const T& poissons_ratio) {
if (!(youngs_modulus >= 0.0)) {
throw std::logic_error("Young's modulus must be nonnegative.");
}
if (!(poissons_ratio < 0.5 && poissons_ratio > -1)) {
throw std::logic_error("Poisson's ratio must be in (-1, 0.5).");
}
const T mu = youngs_modulus / (2.0 * (1.0 + poissons_ratio));
const T lambda = youngs_modulus * poissons_ratio /
((1.0 + poissons_ratio) * (1.0 - 2.0 * poissons_ratio));
return {lambda, mu};
}
DRAKE_DEFINE_FUNCTION_TEMPLATE_INSTANTIATIONS_ON_DEFAULT_NONSYMBOLIC_SCALARS(
(&CalcLameParameters<T>))
} // namespace internal
} // namespace fem
} // namespace multibody
} // namespace drake