Is there a simple algorithm for calculating the maximum inscribed circle into a convex polygon?
Asked Answered
T

4

15

I found some solutions, but they're too messy.

Transposal answered 17/10, 2010 at 14:31 Comment(0)
M
10

Yes. The Chebyshev center, x*, of a set C is the center of the largest ball that lies inside C. [Boyd, p. 416] When C is a convex set, then this problem is a convex optimization problem.

Better yet, when C is a polyhedron, then this problem becomes a linear program.

Suppose the m-sided polyhedron C is defined by a set of linear inequalities: ai^T x <= bi, for i in {1, 2, ..., m}. Then the problem becomes

maximize  R
such that ai^T x + R||a|| <= bi,  i in {1, 2, ..., m}
          R >= 0

where the variables of minimization are R and x, and ||a|| is the Euclidean norm of a.

Melli answered 31/10, 2010 at 3:32 Comment(4)
There is an iterative solution on that: link.springer.com/article/10.1007%2FBF01204183Dillondillow
A simple O(n log n) algorithm is given in #27873464. But the answer would better fit to this question here.Nievesniflheim
I assume you used this (en.wikipedia.org/wiki/Distance_from_a_point_to_a_line) formula to calculate the distance from point to a line. I am wondering, how did you get rid of the absolute value? I am stuck with |ai^T x - bi| / ||a|| >= r and have no idea how to continue.Titicaca
An example with CVXR: <web.cvxr.com/cvx/examples/cvxbook/Ch04_cvx_opt_probs/html/…>Meridional
L
7

Perhaps these "too messy" solutions are what you actually looking for, and there are no simplier ones?

I can suggest a simple, but potentially imprecise solution, which uses numerical analysis. Assume you have a resilient ball, and you inflate it, starting from radius zero. If its center is not in the center you're looking for, then it will move, because the walls would "push" it in the proper direction, until it reaches the point, from where he can't move anywhere else. I guess, for a convex polygon, the ball will eventually move to the point where it has maximum radius.

You can write a program that emulates the process of circle inflation. Start with an arbitrary point, and "inflate" the circle until it reaches a wall. If you keep inflating it, it will move in one of the directions that don't make it any closer to the walls it already encounters. You can determine the possible ways where it could move by drawing the lines that are parallel to the walls through the center you're currently at.

In this example, the ball would move in one of the directions marked with green:


(source: coldattic.info)

Then, move your ball slightly in one of these directions (a good choice might be moving along the bisection of the angle), and repeat the step. If the new radius would be less than the one you have, retreat and decrease the pace you move it. When you'll have to make your pace less than a value of, say, 1 inch, then you've found the centre with precision of 1 in. (If you're going to draw it on a screen, precision of 0.5 pixel would be good enough, I guess).

If an imprecise solution is enough for you, this is simple enough, I guess.

Lessee answered 17/10, 2010 at 14:53 Comment(1)
This worked well for me. It is easy to implement. I even used a variation of this to find the maximal inscribed circle in a (not necessarily convex) blob with holes.Tarpon
P
6

Summary: It is not trivial. So it is very unlikely that it will not get messy. But there are some lecture slides which you may find useful.

Source: http://www.eggheadcafe.com/software/aspnet/30304481/finding-the-maximum-inscribed-circle-in-c.aspx

Your problem is not trivial, and there is no C# code that does this straight out of the box. You will have to write your own. I found the problem intriguing, and did some research, so here are a few clues that may help.

First, here's an answer in "plain English" from mathforum.org:

Link

The answer references Voronoi Diagrams as a methodology for making the process more efficient. In researching Voronoi diagrams, in conjunction with the "maximum empty circle" problem (same problem, different name), I came across this informative paper:

http://www.cosy.sbg.ac.at/~held/teaching/compgeo/slides/vd_slides.pdf

It was written by Martin Held, a Computational Geometry professor at the University of Salzberg in Austria. Further investigation of Dr. Held's writings yielded a couple of good articles:

http://www.cosy.sbg.ac.at/~held/projects/vroni/vroni.html http://www.cosy.sbg.ac.at/~held/projects/triang/triang.html

Further research into Vornoi Diagrams yielded the following site:

http://www.voronoi.com/

This site has lots of information, code in various languages, and links to other resources.

Finally, here is the URL to the Mathematics and Computational Sciences Division of the National Institute of Standards and Technology (U.S.), a wealth of information and links regarding mathematics of all sorts:

http://math.nist.gov/mcsd/

-- HTH,

Kevin Spencer Microsoft MVP

Pauwles answered 17/10, 2010 at 14:40 Comment(5)
This bulk of this reply text from Kevin Spencer refers to the problem involving concave or convex polygons. The problem might be much easier in the convex case.Bobbery
@Josephine: Might be. I haven't gone through in detail, but might be. Perhaps you have something on your mind?Pauwles
After commenting here, I also posted an answer. My ideas are there.Bobbery
The problem is definitely easier when the polygon is convex. The problem becomes a linear program. I posted an answer, too.Melli
Links are broken.Copyholder
B
2

The largest inscribed circle (I'm assuming it's unique) will intersect some of the faces tangentially, and may fail to intersect others. Let's call a face "relevant" if the largest inscribed circle intersects it, and "irrelevant" otherwise.

If your convex polygon is in fact a triangle, then the problem can be solved by calculating the triangle's incenter, by intersecting angle bisectors. This may seem a trivial case, but even when your convex polygon is complicated, the inscribed circle will always be tangent to at least three faces (proof? seems geometrically obvious), and so its center can be calculated as the incenter of three relevant faces (extended outwards to make a triangle which circumscribes the original polygon). Here we assume that no two such faces are parallel. If two are parallel, we have to interpret the "angle bisector" of two parallel lines to mean that third parallel line between them.

This immediately suggests a rather terrible algorithm: Consider all n-choose-3 subsets of faces, find the incenters of all triangles as above, and test each circle for containment in the original polygon. Maximize among those that are legal. But this is cubic in n and we can do much better.

But it's possible instead to identify faces that are irrelevant upfront: If a face is tangent to some inscribed circle, then there is a region of points bounded by that face and by the two angle bisectors at its endpoints, wherein the circle's center must lie. If even the circle whose center lies at the farthest tip of that triangular region is "legal" (entirely contained in the polygon), then the face itself is irrelevant, and can be removed. The two faces touching it should be extended beyond it so that they meet.

By iteratively removing faces which are irrelevant in this sense, you should be able to reduce the polygon to a triangle, or perhaps a trapezoid, at which point the problem will be easily solved, and its solution will still lie within the original polygon.

Bobbery answered 18/10, 2010 at 15:53 Comment(5)
What about a rectangle? What about a modified rectangle which has it's smaller sides slightly convexed out as two sides of a triangle, each? ...but even when your convex polygon is complicated, the inscribed circle will always be tangent to at least three faces (proof? seems geometrically obvious) doesn't seem to hold.Pauwles
In both cases you describe, "the" largest inscribed circle is not unique, but among all largest inscribed circles, at least one intersects three sides.Bobbery
even if it was only for such cases, you need to somehow know if the largest inscribed circle is not unique.Pauwles
the polygon is convex, so the largest inscribed circle is unique.Transposal
@m88: That's not true. For example, any rectangle having different width and height is (a) convex and (b) has an infinite number of maximum-size inscribed circles.Stealer

© 2022 - 2025 — McMap. All rights reserved.