Please Consider the following :
lesDisques={{14.2065, 10.609, 0.974938}, {19.5653, 6.92721, 0.974938},
{30.4607,17.4802, 0.974938}, {27.4621, 10.0393, 0.974938},
{15.915, 20.4278,0.974938}, {28.6921, 5.2132, 1.53205},
{27.0317, 24.8346,1.53205}, {20.8853, 18.8588, 1.53205}}
where lesDisques[[#]] is {X,Y,R}
frmCorner = {{6.5946, 1.5946`}, {6.5946, 28.4054`},
{60.2162`,28.4054`}, {33.4054`, 28.4054`}}
cog = {23.91871026577044`, 15.010499627383863`}
scrCenter = {20, 15}
frmXY={{6.5946, 1.5946}, {33.4054, 28.4054}}
Graphics[{
White, EdgeForm[Thick],
Rectangle @@ frmXY,
Red, PointSize[.04],
Point@cog,
Black, Disk @@@ (lesDisques /. {a_, b_, c_} :> {{a, b}, c})},
ImageSize -> 600]
For each of the 8 disks,
I would like to compute the minimum distance between its edge and :
-The edge of every other disks (7 values) -Each frame corner {4 values},
I would then obtain 8 lists of 11 values.
The following enables me to "pointize" the disks perimeter :
pointize[{{x_,y_},r_},size_:12]:=Table[{x+r Cos[i ((2\[Pi])/size)],
y+r Sin[i ((2\[Pi])/size)]},{i,0,size}]
With this I could find the 2 closest points for 2 disks and compute de distance, but I feel this might not be the right way to do it.
Try this,
It works by computing the distance between the centers of the discs,
Norm[#1[[;;2]] - #2[[;;2]]]
, and then subtracting off their radii for all pairs of discs. For a large list, though, this may not be the speediest as it computes all the values twice, but it is straightforward.For a speed up, first we need to determine what the pairs we want to calculate are. A straightforward way is to determine all unique pairs with
which returns
Also, it doesn't pair up the discs with themselves, unlike
Outer
. I'd use it like thisEdit: I have a pathological dislike for using variables like
lesDisques
in more than one place as it makes it more difficult to change later. So, here's a rewrite:Edit: The
Subsets
version has a flaw that theOuter
version does not, as written you can't tell which pair of disks are being compared. Here's a rewritten version,which returns
It occurs to me that I never answered the second part of your question, find the minimum distances between the discs and the corners of the frame. This task is best done using
Outer
as there aren't any redundant calculations. So, this is what I'd dowhich is only a slight modification of the original code. Note, in the matrix generated by
Outer
, the rows correspond to the first input (frmCorner
in this case) and the columns to the second input, as follows