fn_hist.hpp 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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 fn_hist
  16. //! @{
  17. template<typename T1>
  18. arma_warn_unused
  19. arma_inline
  20. typename
  21. enable_if2
  22. <
  23. is_arma_type<T1>::value && is_cx<typename T1::elem_type>::no,
  24. const mtOp<uword,T1,op_hist>
  25. >::result
  26. hist(const T1& A, const uword n_bins = 10)
  27. {
  28. arma_extra_debug_sigprint();
  29. return mtOp<uword,T1,op_hist>(A, n_bins, 0);
  30. }
  31. template<typename T1, typename T2>
  32. arma_warn_unused
  33. arma_inline
  34. typename
  35. enable_if2
  36. <
  37. is_arma_type<T1>::value && is_arma_type<T2>::value && is_cx<typename T1::elem_type>::no && is_same_type<typename T1::elem_type, typename T2::elem_type>::value,
  38. const mtGlue<uword,T1,T2,glue_hist_default>
  39. >::result
  40. hist(const T1& X, const T2& Y)
  41. {
  42. arma_extra_debug_sigprint();
  43. return mtGlue<uword,T1,T2,glue_hist_default>(X, Y);
  44. }
  45. template<typename T1, typename T2>
  46. arma_warn_unused
  47. arma_inline
  48. typename
  49. enable_if2
  50. <
  51. is_arma_type<T1>::value && is_arma_type<T2>::value && is_cx<typename T1::elem_type>::no && is_same_type<typename T1::elem_type, typename T2::elem_type>::value,
  52. const mtGlue<uword,T1,T2,glue_hist>
  53. >::result
  54. hist(const T1& X, const T2& Y, const uword dim)
  55. {
  56. arma_extra_debug_sigprint();
  57. return mtGlue<uword,T1,T2,glue_hist>(X, Y, dim);
  58. }
  59. //! @}