Imageruler is a free Python program to compute the minimum length scale of binary images which are typically designs produced by topology optimization. The algorithm is based on morphological transformations [1,2] as implemented using the OpenCV library [3]. Imageruler also supports 1d binary images.
For examples of using Imageruler on a variety of structures, see this notebook. Documentation is currently provided by the docstrings. A user manual is under development.
The procedure used by Imageruler for determining the minimum length scale of the solid regions in a binary image involves four steps:
- Binarize the 2d array
$\rho$ representing the image such that each of its elements is a Boolean value for solid (true) and void (false). - For a circular-ball kernel with diameter
$d$ , compute the morphological opening$\mathcal{O}_d(\rho)$ and obtain its difference with the original array via$\mathcal{O}_d(\rho) \oplus \rho$ , where$\oplus$ denotes the exclusive-or operator. - Check whether
$\mathcal{O}_d(\rho) \oplus \rho$ contains a solid pixel within the interior solid regions of$\rho$ . If no,$d$ is less than the minimum length scale of solid regions. If yes,$d$ is equal or greater than the minimum length scale of the solid regions. The interior of the solid regions of$\rho$ is obtained by morphological erosion using a "cross" kernel of size$3\times3$ pixels. - Use a binary search and repeat Steps 2 and 3 to find the smallest
$d$ for which the check in Step 3 evaluates to true. This value of$d$ is considered to be the minimum length scale of the solid regions.
To estimate the minimum length scale of the void regions, the binary image is inverted after the binarization of Step 1:
The minimum length scale of
For a 1d binary image, the algorithm simply finds the minimum length among all solid or void segments.
The accuracy of the minimum length scale computed by Imageruler is limited by the finite resolution of the input image. A fundamental feature is that length scales smaller than a single pixel cannot be measured. Also, in certain situations, length scales of a few pixels may be indistinguishable from discretization artifacts such as the "staircasing" of curved surfaces. As an example, a sharp 90° corner corresponds to a length scale (radius of curvature) of zero at infinite resolution. However, at a finite resolution, a sharp corner is indistinguishable from one that is rounded with a radius of curvature of a few pixels. Imageruler will therefore return a length scale proportional to the pixel size rather than zero. In general, the measured length scale should be viewed as having an "error bar" on the few-pixel level.
[1] L. Hägg and E. Wadbro, On minimum length scale control in density based topology optimization, Structural and Multidisciplinary Optimization, Vol. 58, pp. 1015–1032 (2018).
[2] R. C. Gonzalez and R. E. Woods, Digital Image Processing (Fourth Edition), Chapter 9: Morphological Image Processing, (Pearson, 2017).
[3] OpenCV: Open Source Computer Vision Library, https://github.com/opencv/opencv.