icp.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*************************************/
  2. /* Auteur : Rémi Synave */
  3. /* Date de création : 01/03/07 */
  4. /* Date de modification : 15/03/15 */
  5. /* Version : 0.4 */
  6. /*************************************/
  7. /*************************************/
  8. /* Auteur : Romain Leguay */
  9. /* Nguyen Haiduong */
  10. /* Marianne Fichoux */
  11. /* Date de modification : 06/06/09 */
  12. /* Version : 0.2 */
  13. /*************************************/
  14. /***************************************************************************/
  15. /* This file is part of a2ri. */
  16. /* */
  17. /* a2ri is free software: you can redistribute it and/or modify it */
  18. /* under the terms of the GNU Lesser General Public License as published */
  19. /* by the Free Software Foundation, either version 3 of the License, or */
  20. /* (at your option) any later version. */
  21. /* */
  22. /* a2ri is distributed in the hope that it will be useful, */
  23. /* but WITHOUT ANY WARRANTY; without even the implied warranty of */
  24. /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
  25. /* GNU Lesser General Public License for more details. */
  26. /* */
  27. /* You should have received a copy of the GNU Lesser General Public */
  28. /* License along with a2ri. */
  29. /* If not, see <http://www.gnu.org/licenses/>. */
  30. /***************************************************************************/
  31. #ifndef ICP__H
  32. #define ICP__H
  33. #include <string.h>
  34. #include <gsl/gsl_math.h>
  35. #include <gsl/gsl_eigen.h>
  36. #include <math.h>
  37. #include <pthread.h>
  38. #include "model.h"
  39. #include "matrix.h"
  40. #include "point.h"
  41. #include "util.h"
  42. #include "overlap.h"
  43. #include "geometry.h"
  44. #include "space_partition.h"
  45. /**
  46. Recalage de deux modeles
  47. @param P modele à recaler
  48. @param X premier modele servant de base
  49. @param dkarret critère d'arret.
  50. @return aucun
  51. **/
  52. void a2ri_vf_icp (
  53. vf_model * P,
  54. const vf_model * const X,
  55. double dkarret);
  56. /**
  57. Recalage de deux modeles
  58. @param P modele à recaler
  59. @param X premier modele servant de base
  60. @param recouvrement estimation du taux de recouvrement
  61. @param dkarret critère d'arret.
  62. @return aucun
  63. **/
  64. void a2ri_vf_trimmed_icp (
  65. vf_model * P,
  66. const vf_model * const X,
  67. double recouvrement,
  68. double dkarret);
  69. /**
  70. Recalage automatique de deux modeles
  71. @param P modele à recaler
  72. @param X premier modele servant de base
  73. @param dkarret critère d'arret.
  74. @param sensibility sensiblité du taux de recouvrement
  75. @return aucun
  76. **/
  77. //REMARQUE : le maillage devrait etre qualifié const mais impossible a cause de l'utilisation de la focntion a2ri_vf_bounding_ball_minimale_compute_overlap qui utilise des threads et ne permet donc pas la qualifidation de const du maillage.
  78. void a2ri_vf_automated_trimmed_icp (
  79. vf_model * P,
  80. vf_model * X,
  81. double dkarret,
  82. double sensibility);
  83. /**
  84. Recalage automatique de deux modeles
  85. @param P modele à recaler
  86. @param X premier modele servant de base
  87. @param dkarret critère d'arret.
  88. @return aucun
  89. **/
  90. //REMARQUE : le maillage devrait etre qualifié const mais impossible a cause de l'utilisation de thread.
  91. void a2ri_vf_automated_trimmed_icp_pulli (
  92. vf_model * P,
  93. vf_model * X,
  94. double dkarret);
  95. /**
  96. Recalage automatique de deux modeles
  97. @param P tableau de modeles à recaler
  98. @param X tableau de modeles servant de référence
  99. @param sizeP nombre de modele dans P
  100. @param sizeX nombre de modele dans X
  101. @param dkarret critère d'arret.
  102. @param sensibility sensibilité du taux de recouvrement
  103. @return aucun
  104. **/
  105. //REMARQUE : le maillage devrait etre qualifié const mais impossible a cause de l'utilisation de la focntion a2ri_vf_bounding_ball_minimale_compute_overlap qui utilise des threads et ne permet donc pas la qualifidation de const du maillage.
  106. void a2ri_vf_automated_trimmed_icp_multiple (
  107. vf_model ** P,
  108. vf_model ** X,
  109. int sizeP,
  110. int sizeX,
  111. double dkarret,
  112. double sensibility);
  113. #endif