Find Connected Graph Components
Model the frog's jumping network from the lily leaf density. Version 11 introduces ConnectedGraphComponents and WeaklyConnectedGraphComponents functions for network connectivity analysis.
A frog in a lily pond is able to jump 1.5 feet to get from one of the 25 lily pads to another.
In[1]:=
data:image/s3,"s3://crabby-images/635ca/635ca37b8bc362da65fe0f623676a6c66bd326d1" alt="Click for copyable input"
lilyDensity =
MixtureDistribution[{1, 1,
1}, {BinormalDistribution[{0, 0}, {1, 1}, 0],
BinormalDistribution[{-1, 4}, {1, 1}, -1/2],
BinormalDistribution[{4, 4}, {1, 1}, 1/3]}];
lilyPond = SpatialGraphDistribution[25, 1.5, lilyDensity];
Sample a random pond.
In[2]:=
data:image/s3,"s3://crabby-images/55c09/55c09505f726fb515bf33104e8a53cc4184670f5" alt="Click for copyable input"
g = RandomGraph[lilyPond, VertexShape -> \!\(\*
GraphicsBox[
{EdgeForm[{Hue[0.3277777777777778, 0.16216216216216217`, 1.], Opacity[
1.], AbsoluteThickness[1], CapForm["Round"]}], FaceForm[Hue[
0.2388888888888889, 1., 0.9224857536122444]],
PolygonBox[CompressedData["
1:eJxTTMoPSmViYGCQAmIQDQYVhQ5gWiALQkeUQmiDPAj9ohxCcxRB6IwKCF1R
DKF3QOVnlKDqvwGlT0DNzyiD0AE5ENoCyr+QBOVD9StEoupz8IHqy4XQDeZQ
fiqEZtCG0AvioXxdVHMabKD8YKh5flDaG0I/iIbynaDuSYbqs4bQH2D2WkLo
Dqg7HXwh9A+o/xdEQOgZVVD3Qc2xqIbQE9Kh/oLKf4CFNzQ8N0DDBRZ+BTkO
ABBsOr4=
"]]},
ImageSize->{45., Automatic}]\), VertexSize -> {"Scaled", 0.1},
EdgeStyle -> Opacity[0], Background -> Hue[0.6, 0.8, 0.4],
ImageSize -> 150]
Out[2]=
data:image/s3,"s3://crabby-images/18a02/18a02ece518573cfee8bd47ae1e9e4b8db93cd4a" alt=""
Find the largest collection of lily pads the frog can jump between.
In[3]:=
data:image/s3,"s3://crabby-images/cf232/cf232f5788a1a9fa4d9e0115600d5dd7556ca2cd" alt="Click for copyable input"
VertexCount[First[ConnectedGraphComponents[g]]]
Out[3]=
data:image/s3,"s3://crabby-images/4183c/4183c14b2f06d6e9aea4cd2b3217aa75ed42f910" alt=""
Find the number of times the frog would have to swim to visit all the lily pads.
In[4]:=
data:image/s3,"s3://crabby-images/c2f9c/c2f9c6a5dcc33e69fc2a53cd456207b879d161af" alt="Click for copyable input"
Length[ConnectedGraphComponents[g]] - 1
Out[4]=
data:image/s3,"s3://crabby-images/909db/909db593de73484ed746e21b3490445ef0c287f0" alt=""