op_princomp_bones.hpp 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. // Copyright 2008-2016 Conrad Sanderson (http://conradsanderson.id.au)
  2. // Copyright 2008-2016 National ICT Australia (NICTA)
  3. //
  4. // Licensed under the Apache License, Version 2.0 (the "License");
  5. // you may not use this file except in compliance with the License.
  6. // You may obtain a copy of the License at
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. // ------------------------------------------------------------------------
  15. //! \addtogroup op_princomp
  16. //! @{
  17. class op_princomp
  18. : public traits_op_default
  19. {
  20. public:
  21. template<typename T1>
  22. inline static bool
  23. direct_princomp
  24. (
  25. Mat<typename T1::elem_type>& coeff_out,
  26. Mat<typename T1::elem_type>& score_out,
  27. Col<typename T1::pod_type>& latent_out,
  28. Col<typename T1::elem_type>& tsquared_out,
  29. const Base<typename T1::elem_type, T1>& X
  30. );
  31. template<typename T1>
  32. inline static bool
  33. direct_princomp
  34. (
  35. Mat<typename T1::elem_type>& coeff_out,
  36. Mat<typename T1::elem_type>& score_out,
  37. Col<typename T1::pod_type>& latent_out,
  38. const Base<typename T1::elem_type, T1>& X
  39. );
  40. template<typename T1>
  41. inline static bool
  42. direct_princomp
  43. (
  44. Mat<typename T1::elem_type>& coeff_out,
  45. Mat<typename T1::elem_type>& score_out,
  46. const Base<typename T1::elem_type, T1>& X
  47. );
  48. template<typename T1>
  49. inline static bool
  50. direct_princomp
  51. (
  52. Mat<typename T1::elem_type>& coeff_out,
  53. const Base<typename T1::elem_type, T1>& X
  54. );
  55. template<typename T1>
  56. inline static void
  57. apply(Mat<typename T1::elem_type>& out, const Op<T1,op_princomp>& in);
  58. };
  59. //! @}