123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- #include <igl/jet.h>
- #include <igl/readOFF.h>
- #include <igl/cotmatrix.h>
- #include <igl/matlab/matlabinterface.h>
- #include <igl/opengl/glfw/Viewer.h>
- #include <iostream>
- #include "tutorial_shared_path.h"
- Eigen::MatrixXd V;
- Eigen::MatrixXi F;
- Engine* engine;
- Eigen::MatrixXd EV;
- void plotEV(igl::opengl::glfw::Viewer& viewer, int id)
- {
- Eigen::VectorXd v = EV.col(id);
- v = v.array() - v.minCoeff();
- v = v.array() / v.maxCoeff();
-
- Eigen::MatrixXd C(V.rows(),3);
- for (unsigned i=0; i<V.rows(); ++i)
- {
- double r,g,b;
- igl::jet(v(i),r,g,b);
- C.row(i) << r,g,b;
- }
- viewer.data().set_colors(C);
- }
- bool key_down(igl::opengl::glfw::Viewer& viewer, unsigned char key, int modifier)
- {
- if (key >= '1' && key <= '9')
- plotEV(viewer,(key - '1') + 1);
- return false;
- }
- int main(int argc, char *argv[])
- {
-
- igl::readOFF(TUTORIAL_SHARED_PATH "/3holes.off", V, F);
-
- igl::matlab::mlinit(&engine);
-
- Eigen::SparseMatrix<double> L;
- igl::cotmatrix(V,F,L);
-
- igl::matlab::mlsetmatrix(&engine,"L",L);
-
- igl::matlab::mleval(&engine,"spy(L)");
-
- igl::matlab::mleval(&engine,"[EV,~] = eigs(-L,10,'sm')");
-
- std::cerr << igl::matlab::mleval(&engine,"size(EV)") << std::endl;
-
- igl::matlab::mlgetmatrix(&engine,"EV",EV);
-
- igl::opengl::glfw::Viewer viewer;
- viewer.callback_key_down = &key_down;
- viewer.data().set_mesh(V, F);
-
- plotEV(viewer,1);
-
- viewer.launch();
- }
|