701_Statistics.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import sys, os
  2. # Add the igl library to the modules search path
  3. import math
  4. sys.path.insert(0, os.getcwd() + "/../")
  5. import pyigl as igl
  6. from shared import TUTORIAL_SHARED_PATH, check_dependencies
  7. dependencies = []
  8. check_dependencies(dependencies)
  9. if __name__ == "__main__":
  10. V = igl.eigen.MatrixXd()
  11. F = igl.eigen.MatrixXi()
  12. # Load meshes in OFF format
  13. igl.readOBJ(TUTORIAL_SHARED_PATH + "horse_quad.obj", V, F)
  14. # Count the number of irregular vertices, the border is ignored
  15. irregular = igl.is_irregular_vertex(V, F)
  16. vertex_count = V.rows()
  17. irregular_vertex_count = sum(irregular)
  18. irregular_ratio = irregular_vertex_count / vertex_count
  19. print("Irregular vertices: \n%d/%d (%.2f%%)\n" % (
  20. irregular_vertex_count, vertex_count, irregular_ratio * 100))
  21. # Compute areas, min, max and standard deviation
  22. area = igl.eigen.MatrixXd()
  23. igl.doublearea(V, F, area)
  24. area /= 2.0
  25. area_avg = area.mean()
  26. area_min = area.minCoeff() / area_avg
  27. area_max = area.maxCoeff() / area_avg
  28. area_ns = (area - area_avg) / area_avg
  29. print(area_ns[0])
  30. # area_ns *= area_ns
  31. print(area_ns[0])
  32. area_sigma = math.sqrt(area_ns.mean())
  33. print("Areas (Min/Max)/Avg_Area Sigma: \n%.2f/%.2f (%.2f)\n" % (
  34. area_min, area_max, area_sigma))
  35. # Compute per face angles, min, max and standard deviation
  36. angles = igl.eigen.MatrixXd()
  37. igl.internal_angles(V, F, angles)
  38. angles = 360.0 * (angles / (2 * math.pi))
  39. angle_avg = angles.mean()
  40. angle_min = angles.minCoeff()
  41. angle_max = angles.maxCoeff()
  42. angle_ns = (angles - angle_avg) * (angles - angle_avg)
  43. angle_sigma = math.sqrt(angle_ns.mean())
  44. print("Angles in degrees (Min/Max) Sigma: \n%.2f/%.2f (%.2f)\n" % (
  45. angle_min, angle_max, angle_sigma))