index.html 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8"/>
  5. <title>libigl</title>
  6. <meta name="author" content="Alec Jacobson and Daniele Panozzo and others"/>
  7. <link type="text/css" rel="stylesheet" href="tutorial/style.css"/>
  8. <script type='text/javascript' src='http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML'></script>
  9. <link rel='stylesheet' href='http://yandex.st/highlightjs/7.3/styles/default.min.css'>
  10. <script src='http://yandex.st/highlightjs/7.3/highlight.min.js'></script>
  11. <script>hljs.initHighlightingOnLoad();</script>
  12. </head>
  13. <body>
  14. <h1 id="libigl-asimplecgeometryprocessinglibrary">libigl - A simple C++ geometry processing library</h1>
  15. <figure>
  16. <img src="tutorial/images/libigl-logo.jpg" alt="" />
  17. <figcaption></figcaption></figure>
  18. <p><a href="https://github.com/libigl/libigl/">https://github.com/libigl/libigl/</a></p>
  19. <p>libigl is a simple C++ geometry processing library. We have a wide functionality including construction of sparse discrete differential geometry operators and finite-elements matrices such as the contangent Laplacian and diagonalized mass matrix, simple facet and edge-based topology data structures, mesh-viewing utilities for OpenGL and GLSL, and many core functions for matrix manipulation which make <a href="http://eigen.tuxfamily.org">Eigen</a> feel a lot more like MATLAB.</p>
  20. <p>It is first and foremost a header library. Each header file contains a single function. Most are tailored to operate on a generic triangle mesh stored in an n-by&#8211;3 matrix of vertex positions V and an m-by&#8211;3 matrix of triangle indices F. The library may also be <a href="build/README.html">compiled</a> into a statically linked library, for faster compile times with your projects.</p>
  21. <p>We use the <a href="http://eigen.tuxfamily.org">Eigen</a> library heavily in our code. Our group prototypes a lot in MATLAB, and we have a useful <a href="http://libigl.github.io/libigl/tutorial/matlab-to-eigen.html">conversion table</a> from MATLAB to libigl/Eigen.</p>
  22. <h1 id="tutorial">Tutorial</h1>
  23. <p>As of version 1.0, libigl includes an introductory
  24. <a href="http://libigl.github.io/libigl/tutorial/tutorial.html">tutorial</a> that covers
  25. its basic functionalities.</p>
  26. <h2 id="installation">Installation</h2>
  27. <p>Libigl is a <em>header</em> library. You do <strong>not</strong> need to build anything to install.
  28. Simply add <code>igl/</code> to your include path and include relevant headers. Here is a
  29. small &#8220;Hello, World&#8221; program:</p>
  30. <pre><code class="cpp">#include &lt;igl/cotmatrix.h&gt;
  31. #include &lt;Eigen/Dense&gt;
  32. #include &lt;Eigen/Sparse&gt;
  33. #include &lt;iostream&gt;
  34. int main()
  35. {
  36. Eigen::MatrixXd V(4,2);
  37. V&lt;&lt;0,0,
  38. 1,0,
  39. 1,1,
  40. 0,1;
  41. Eigen::MatrixXi F(2,3);
  42. F&lt;&lt;0,1,2,
  43. 0,2,3;
  44. Eigen::SparseMatrix&lt;double&gt; L;
  45. igl::cotmatrix(V,F,L);
  46. std::cout&lt;&lt;&quot;Hello, mesh: &quot;&lt;&lt;std::endl&lt;&lt;L*V&lt;&lt;std::endl;
  47. return 0;
  48. }
  49. </code></pre>
  50. <p>If you save this in <code>hello.cpp</code>, then you could compile this with (assuming Eigen
  51. is installed in /opt/local/include/eigen3):</p>
  52. <pre><code class="bash">gcc -I/opt/local/include/eigen3 -I./igl/ hello.cpp -o hello
  53. </code></pre>
  54. <p>Running <code>./hello</code> would then produce</p>
  55. <pre><code>Hello, mesh:
  56. 0.5 0.5
  57. -0.5 0.5
  58. -0.5 -0.5
  59. 0.5 -0.5
  60. </code></pre>
  61. <h2 id="dependencies">Dependencies</h2>
  62. <p>Dependencies are on a per-include basis and the majority of the functions in libigl
  63. depends only on the <a href="http://eigen.tuxfamily.org">Eigen</a> library.</p>
  64. <p>For more information see our <a href="tutorial/tutorial.html">tutorial</a>.</p>
  65. <h1 id="download">Download</h1>
  66. <p>You can keep up to date by cloning a read-only copy of our GitHub <a href="https://github.com/libigl">repository</a>.</p>
  67. <h2 id="howtocontribute">How to contribute</h2>
  68. <p>If you are interested in joining development, please fork the repository and submit a <a href="https://help.github.com/articles/using-pull-requests/">pull request</a> with your changes.</p>
  69. <h2 id="license">License</h2>
  70. <p>libigl is primarily <a href="http://www.mozilla.org/MPL/2.0/">MPL2</a> licensed (<a href="http://www.mozilla.org/MPL/2.0/FAQ.html">FAQ</a>). Some files contain third-party code under other licenses. We&#8217;re currently in the processes of identifying these and marking appropriately.</p>
  71. <h2 id="attribution">Attribution</h2>
  72. <p>If you use libigl in your academic projects, please cite the papers we implement
  73. as appropriate. To cite the library in general, you could use this BibTeX entry:</p>
  74. <pre><code class="bibtex">@misc{libigl,
  75. title = {{libigl}: A simple {C++} geometry processing library},
  76. author = {Alec Jacobson and Daniele Panozzo and others},
  77. note = {http://igl.ethz.ch/projects/libigl/},
  78. year = {2014},
  79. }
  80. </code></pre>
  81. <h1 id="contact">Contact</h1>
  82. <p>Libigl is a group endeavor led by <a href="http://www.cs.columbia.edu/~jacobson/">Alec Jacobson</a> and <a href="http://www.inf.ethz.ch/personal/dpanozzo/">Daniele Panozzo</a>. Please
  83. <a href="&#109;&#97;&#105;&#108;&#x74;&#111;&#x3a;&#x61;&#x6c;&#101;&#x63;&#x6a;&#x61;&#x63;&#111;&#98;&#115;&#111;&#110;&#64;&#103;&#109;&#x61;&#105;&#108;&#x2e;&#x63;&#x6f;&#x6d;&#44;&#x64;&#x61;&#110;&#105;&#101;&#x6c;&#101;&#x2e;&#x70;&#x61;&#110;&#x6f;&#122;&#x7a;&#x6f;&#64;&#x67;&#x6d;&#x61;&#x69;&#x6c;&#x2e;&#99;&#x6f;&#x6d;">&#99;&#x6f;&#x6e;&#116;&#x61;&#99;&#x74; &#117;&#115;</a> if you have questions or comments. We are happy to get feedback!</p>
  84. <p>If you&#8217;re using libigl in your projects, quickly <a href="&#x6d;&#x61;&#105;&#108;&#x74;&#x6f;&#58;&#97;&#x6c;&#101;&#99;&#106;&#x61;&#x63;&#111;&#x62;&#x73;&#x6f;&#110;&#64;&#103;&#x6d;&#x61;&#x69;&#x6c;&#46;&#99;&#x6f;&#x6d;&#x2c;&#100;&#x61;&#110;&#105;&#x65;&#108;&#x65;&#x2e;&#112;&#97;&#x6e;&#111;&#x7a;&#x7a;&#x6f;&#x40;&#103;&#109;&#x61;&#105;&#x6c;&#x2e;&#x63;&#111;&#109;">&#x64;&#x72;&#111;&#112; &#x75;&#x73; &#97;
  85. &#110;&#111;&#116;&#101;</a>. Tell us who you are and what you&#8217;re using it for. This helps us apply for funding and justify spending time maintaining
  86. this.</p>
  87. <p>If you find bugs or have problems please use our <a href="https://github.com/libigl/libigl/issues">github issue tracking
  88. page</a>.</p>
  89. <h3 id="copyright">Copyright</h3>
  90. <p>2014 Alec Jacobson, Daniele Panozzo, Olga Diamanti, Kenshi
  91. Takayama, Leo Sacht, Wenzel Jacob, Nico Pietroni, Amir Vaxman</p>
  92. </body>
  93. </html>