12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- #define IGL_HEADER_ONLY
- #include <igl/readOFF.h>
- #include <igl/matlab/matlabinterface.h>
- #include <igl/viewer/Viewer.h>
- #include <igl/jet.h>
- #include <igl/cotmatrix.h>
- Eigen::MatrixXd V;
- Eigen::MatrixXi F;
- Engine* engine;
- Eigen::MatrixXd EV;
- void plotEV(igl::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.set_colors(C);
- }
- bool key_down(igl::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("../shared/3holes.off", V, F);
-
- igl::mlinit(&engine);
-
- Eigen::SparseMatrix<double> L;
- igl::cotmatrix(V,F,L);
-
- igl::mlsetmatrix(&engine,"L",L);
-
- igl::mleval(&engine,"spy(L)");
-
- igl::mleval(&engine,"[EV,~] = eigs(-L,10,'sm')");
-
- std::cerr << igl::mleval(&engine,"size(EV)") << std::endl;
-
- igl::mlgetmatrix(&engine,"EV",EV);
-
- igl::Viewer viewer;
- viewer.callback_key_down = &key_down;
- viewer.set_mesh(V, F);
-
- plotEV(viewer,1);
-
- viewer.launch();
- }
|