Clustering tangent spheres

in #math7 years ago (edited)

tangent circles
An initial sphere triplet located on the vertices of a triangle with side lengths constructed from sphere radii:

So you want to do some sphere packing to make your inflatable space habitats for deployment on the Moon and Mars snug and cozy. Perfectly straightforward you think to yourself; since one can start with a triplet of spheres tangent pairwise by placing one at some origin on a 2D plane, extending the second out in the direction and completing the triangle by identifying the third sphere's position based on the radii of all three.

There's not even time to take a mirco-break to refresh your favourite time sink website before you've busted out the coordinates of

On a roll, you extend the coordinates of , and into three dimensions setting their component to 0 and construct a tetrahedron from this base triangle and three new distances , , ; finding the tetrahedron's fourth vertex

Pausing for just a moment, you realise you've been on autopilot for a second—since such trivial calculations are self evident. Reflecting on a time that feels so long ago now, when you learnt that a minimal set of four tangent spheres in three dimensions can be described by a tetrahedron. The locus of each sphere's center point is one of the tetrahedron's vertices, and the lengths of each edge of the tetrahedron are defined via the radii of the pair of spheres for which the edge connects their centers. Using the already-known properties of the base triangle; introducing a fourth sphere with known radius and finding its coordinates, is now just some basic geometry—extending the system of equations used to solve the locus of

to the intersection represented by

Back from your daydream—that time sink website is calling. Since you've pretty much wrapped this problem up, why not take a peek? After a few sensible chuckles, it dawns on you that there's still work to do. Your sphere packing algorithm is going to feed you positions and radii of arbitrary sets of pairwise tangent triplets for you to calculate the fourth position. This means that if you are solving the tetrahedron in this simple basis, translation and rotation of 's position must occur.

Moreover, this is going to have to happen in a number of steps.

  1. Remove 's translation component, aligning to the origin.
  2. Recalculate , , in the simple basis for this triplet to solve for the fourth locus.
  3. Denote the solution as in tetrahedron , which now must be translated to tetrahedron 's basis to find .
  4. Rotate onto .
  5. Rotate to by rotating the face normals of the triangle identified in 4 and .
  6. Translate this triangle to the basis by returning the translation component removed in 1.

None of this is too difficult in of its own, but without proper forethought—you're gonna have a bad time.
Basically you're going to end up catching edge cases just to the left of center like a tennis ball to the nuts of a daydreaming ball boy at the US Open.

What happens when you're sent a triplet that has coordinates (in the translated basis) , , or in other words: when and ? You must check for this mirror symmetry to make sure that the first rotation doesn't place your position closer to Alpha Centauri than it does to it's wanted position at .

The list goes on, but it suffices to say that you start juggling possibilities like some guy trying to wash a car in an infomercial.

Fret not! There is a better way!


Consider that we have a pairwise tangent triplet with known radii and arbitrary positions in .
Additionally, we know the radius of a fourth sphere we wish to add to the cluster.

To not confuse the skimming reader—I will change notations here, and define a tetrahedron with vertices , and residing at distances , , from a fourth vertex , whose coordinates must be found.

The distance values here are straightforward, since they are defined as the sum of the radii along a given edge: . Since is at the intersection of three spheres centered at , and with radii , , , we know its coordinates satisfy the equations

Subtract (1) from (2) & (3) to obtain the equations for two planes, and couple this set with (1) to yield the quadratic system:

The closed form solution to this system is not the nicest of expressions, so we can consider the equivalent set below in vector format

where is our unknown vector. Following from this, we obtain values of most of the components directly,

Notice that and are unit vectors, so we can form a basis with a third vector:

A solution to can then be obtained in the form once , and are identified. Plugging this expression for into the vector equations for and above immediately yields

while the third equation becomes where .

This last equation can finally be solved for :

With these values you can now solve the irregular tetrahedron in 3D directly! This means no edge cases, no recalculation of previously known values or complex if elseif else blocks based on various input conditions.

sphere cluster
The fruits of your labour made manifest.

Sort:  

Congratulations @libbum! You received a personal award!

Happy Birthday! - You are on the Steem blockchain for 2 years!

You can view your badges on your Steem Board and compare to others on the Steem Ranking

Do not miss the last post from @steemitboard:

SteemitBoard Ranking update - A better rich list comparator
Vote for @Steemitboard as a witness to get one more award and increased upvotes!

Hi! I am a robot. I just upvoted you! I found similar content that readers might be interested in:
https://axiomatic.neophilus.net/

This is a link to my personal blog, so it's certainly relevant! Thank you helpful robot.

Congratulations @libbum! You received a personal award!

Happy Birthday! - You are on the Steem blockchain for 1 year!

Click here to view your Board

Support SteemitBoard's project! Vote for its witness and get one more award!