example.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. // g++ -o main main.cpp -I. -I/usr/local/include/eigen3
  2. #include <Eigen/Core>
  3. #include <iostream>
  4. using namespace std;
  5. #include <igl/sort.h>
  6. using namespace igl;
  7. template <typename T>
  8. void matlab_print(const string name, const T & X)
  9. {
  10. cout<<name<<"=["<<endl<<X<<endl<<"];"<<endl;
  11. }
  12. int main(int argc, char * argv[])
  13. {
  14. Eigen::MatrixXd X(2,3);
  15. X << 3,5,2,1,3,8;
  16. matlab_print("X",X);
  17. // sort each row independently
  18. int dim = 2;
  19. // sort ascending order
  20. int ascending = true;
  21. // Sorted output matrix
  22. Eigen::MatrixXd Y;
  23. // sorted indices for sort dimension
  24. Eigen::MatrixXi IX;
  25. sort(X,dim,ascending,Y,IX);
  26. matlab_print<Eigen::MatrixXd>("Y",Y);
  27. matlab_print<Eigen::MatrixXi>("IX",IX);
  28. // Verify that IX really does sort X into Y
  29. int num_outer = (dim == 1 ? X.cols() : X.rows() );
  30. // get number of rows (or columns)
  31. int num_inner = (dim == 1 ? X.rows() : X.cols() );
  32. bool verified = true;
  33. for(int i = 0;i<num_outer;i++)
  34. {
  35. for(int j = 0;j<num_inner;j++)
  36. {
  37. if(dim == 1)
  38. {
  39. if( Y(j,i) != X(IX(j,i),i))
  40. {
  41. printf("Y(%d,%d) = %g != %g = X(%d,%d) = X(IX(%d,%d),%d)\n",
  42. j,i,Y(j,i),X(IX(j,i),i),IX(j,i),i,j,i,i);
  43. verified = false;
  44. }
  45. }else
  46. {
  47. if( Y(i,j) != X(i,IX(i,j)))
  48. {
  49. printf("Y(%d,%d) = %g != %g = X(%d,%d) = X(IX(%d,%d),%d)\n",
  50. i,j,Y(i,j),X(i,IX(i,j)),IX(i,j),i,i,j,i);
  51. verified = false;
  52. }
  53. }
  54. }
  55. }
  56. if(verified)
  57. {
  58. printf("Sorting succeeded\n");
  59. }else
  60. {
  61. printf("Sorting failed\n");
  62. }
  63. return (verified?0:1);
  64. }