|
@@ -9,49 +9,37 @@
|
|
|
#include "colon.h"
|
|
|
#include <algorithm>
|
|
|
|
|
|
-template <typename DerivedI>
|
|
|
+template <typename DerivedI, typename URBG>
|
|
|
IGL_INLINE void igl::randperm(
|
|
|
const int n,
|
|
|
Eigen::PlainObjectBase<DerivedI> & I,
|
|
|
- const int64_t rng_min,
|
|
|
- const int64_t rng_max,
|
|
|
- const std::function<int64_t()> &rng)
|
|
|
+ URBG urbg)
|
|
|
{
|
|
|
Eigen::VectorXi II;
|
|
|
igl::colon(0,1,n-1,II);
|
|
|
I = II;
|
|
|
|
|
|
- // C++ named requirement : UniformRandomBitGenerator
|
|
|
- // This signature is required for the third parameter of
|
|
|
- // std::shuffle
|
|
|
- struct RandPermURBG {
|
|
|
- public:
|
|
|
- using result_type = int64_t;
|
|
|
- RandPermURBG(const result_type min,
|
|
|
- const result_type max,
|
|
|
- const std::function<result_type()> int_gen) :
|
|
|
- m_min(min),
|
|
|
- m_max(max),
|
|
|
- m_int_gen(std::move(int_gen)) {}
|
|
|
-
|
|
|
- result_type min() const noexcept { return m_min; }
|
|
|
- result_type max() const noexcept { return m_max; }
|
|
|
- result_type operator()() const { return m_int_gen(); };
|
|
|
- private:
|
|
|
- result_type m_min;
|
|
|
- result_type m_max;
|
|
|
- std::function<result_type()> m_int_gen;
|
|
|
- };
|
|
|
-
|
|
|
- const auto int_gen = (nullptr != rng) ?
|
|
|
- rng :
|
|
|
- []()->int64_t { return std::rand(); };
|
|
|
-
|
|
|
- std::shuffle(I.data(),I.data()+n, RandPermURBG(rng_min, rng_max, int_gen));
|
|
|
+ std::shuffle(I.data(),I.data()+n, urbg);
|
|
|
}
|
|
|
|
|
|
#ifdef IGL_STATIC_LIBRARY
|
|
|
// Explicit template instantiation
|
|
|
-template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1> >(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, const int64_t, const int64_t, const std::function<int64_t()>&);
|
|
|
-template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1> >(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, const int64_t, const int64_t, const std::function<int64_t()>&);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::minstd_rand0>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::minstd_rand0);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::minstd_rand0>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::minstd_rand0);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::minstd_rand>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::minstd_rand);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::minstd_rand>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::minstd_rand);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::mt19937>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::mt19937);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::mt19937>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::mt19937);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::mt19937_64>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::mt19937_64);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::mt19937_64>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::mt19937_64);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::ranlux24_base>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::ranlux24_base);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::ranlux24_base>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::ranlux24_base);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::ranlux48_base>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::ranlux48_base);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::ranlux48_base>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::ranlux48_base);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::ranlux24>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::ranlux24);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::ranlux24>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::ranlux24);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::ranlux48>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::ranlux48);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::ranlux48>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::ranlux48);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, 1, 0, -1, 1>, std::knuth_b>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&, std::knuth_b);
|
|
|
+template void igl::randperm<Eigen::Matrix<int, -1, -1, 0, -1, -1>, std::knuth_b>(int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&, std::knuth_b);
|
|
|
#endif
|