Program Listing for File generator.h

Return to documentation for file (manif/impl/generator.h)

#ifndef _MANIF_MANIF_GENERATOR_H_
#define _MANIF_MANIF_GENERATOR_H_

namespace manif {
namespace internal {

template <typename Derived>
struct GeneratorEvaluator
{
  static typename Derived::LieAlg
  run(const unsigned int)
  {
    static_assert(constexpr_false<Derived>(),
                  "GeneratorEvaluator not overloaded for Derived type!");
  }
};

template <typename Derived>
struct InnerWeightsEvaluator
{
  static typename Derived::InnerWeightsMatrix
  run()
  {
    using InnerWeightsMatrix = typename Derived::InnerWeightsMatrix;

    auto computeW = []()
    {
      InnerWeightsMatrix W = InnerWeightsMatrix::Zero();

      for (int r = 0; r <Derived::DoF; ++r)
        for (int c = 0; c < Derived::DoF; ++c)
          W(r,c) = (Derived::Generator(r) * Derived::Generator(c).transpose()).trace();

      return W;
    };

    const static InnerWeightsMatrix W = computeW();

    return W;
  }
};

} /* namespace internal */
} /* namespace manif */

#endif /* _MANIF_MANIF_GENERATOR_H_ */