Search code examples
triangulationsurfacecurves

Smoothing algorithm, 2.5D


The picture below shows a triangular surface mesh. Its vertices are exactly on the surface of the original 3D object but the straight edges and faces have of course some geometric error where the original surface bends and I need some algorithm to estimate the smooth original surface.

Details: I have a height field of (a projectable part of) this surface (a 2.5D triangulation where each x,y pair has a unique height z) and I need to compute the height z of arbitrary x,y pairs. For example the z-value of the point in the image where the cursor points to.

If it was a 2D problem, I would use cubic splines but for surfaces I'm not sure what is the best solution.

Surface


Solution

  • As commented by @Darren what you need are patches.

    It can be bi-linear patches or bi-quadratic or Coon's patches or other.

    I have found no much reference doing a quick search but this links:

    The concept is that you calculate splines along the edges (height function with respect to the straight edge segment itself) and then make a blending inside the surface delimited by the edges. The patch os responsible for the blending meaning that inside any face you have an height which is a function of the point position coordinates inside the face and the values of the spline ssegments which are defined on the edges of the same face.

    As per my knowledge it is quite easy to use this approach on a quadrilateral mesh (because it becomes easy to define on which edges sequence to do the splines) while I am not sure how to apply if you are forced to go for an actual triangulation.