triangle_grid


triangle_grid, a Fortran90 code which generates a grid of points over the interior of a triangle in 2D.

Starting with any 3 points A, B, and C that define a triangle, we can divide each side of the triangle into N subintervals, and create a triangular grid. This defines ((N+1)*(N+2))/2 points that lie on the intersections of grid lines. The arrangement is suggested by this diagram:

              X
             9 X
            8 9 X
           7 8 9 X
          6 7 8 9 X
         5 6 7 8 9 X
        4 5 6 7 8 9 X
       3 4 5 6 7 8 9 X
      2 3 4 5 6 7 8 9 X
     1 2 3 4 5 6 7 8 9 X
    0 1 2 3 4 5 6 7 8 9 X
      

The library includes a routine which allows the user to pick an arbitrary triangle and an arbitrary number of subdivisions. It then returns the triangular gridpoints defined by that choice.

Licensing:

The information on this web page is distributed under the MIT license.

Languages:

triangle_grid is available in a C version and a C++ version and a Fortran90 version and a MATLAB version and an Octave version and a Python version.

Related Data and Programs:

triangle_grid_test

ball_grid, a Fortran90 code which computes a grid of points over the interior of a ball in 3D.

circle_arc_grid, a Fortran90 code which computes points equally spaced along a circular arc;

cube_grid, a Fortran90 code which computes a grid of points over the interior of a cube in 3D.

disk_grid, a Fortran90 code which computes a grid of points over the interior of a disk in 2D.

ellipse_grid, a Fortran90 code which computes a grid of points over the interior of an ellipse in 2D.

ellipsoid_grid, a Fortran90 code which computes a grid of points over the interior of an ellipsoid in 3D.

hypercube_grid, a Fortran90 code which computes a grid of points over the interior of a hypercube in M dimensions.

line_grid, a Fortran90 code which computes a grid of points over the interior of a line segment in 1D.

polygon_grid, a Fortran90 code which generates a grid of points over the interior of a polygon in 2D.

pyramid_grid, a Fortran90 code which computes a grid of points over the interior of the unit pyramid in 3D;

simplex_grid, a Fortran90 code which generates a grid of points over the interior of a simplex in M dimensions.

sphere_cubed_grid, a Fortran90 code which uses the projection of a cube to create grids of points, lines, and quadrilaterals on the surface of the unit sphere in 3D.

sphere_fibonacci_grid, a Fortran90 code which uses a Fibonacci spiral to create a grid of points on the surface of the unit sphere in 3D.

sphere_grid, a Fortran90 code which provides a number of ways of generating grids of points, or of points and lines, or of points and lines and faces, on the surface of the unit sphere in 3D.

sphere_llq_grid, a Fortran90 code which uses longitudes and latitudes to create grids of points, lines, and quadrilaterals on the surface of the unit sphere in 3D.

sphere_llt_grid, a Fortran90 code which uses longitudes and latitudes to create grids of points, lines, and triangles on the surface of the unit sphere in 3D.

tetrahedron_grid, a Fortran90 code which computes a grid of points over the interior of a tetrahedron in 3D.

wedge_grid, a Fortran90 code which computes a grid of points over the interior of the unit wedge in 3D.

Source Code:


Last revised on 09 September 2020.