Compare the Shape of Different Countries
Use CanonicalWarpingDistance to find similarity between shapes of different countries.
In[1]:=
data:image/s3,"s3://crabby-images/f1225/f1225dfd28207128c7ef8dafb6f7602a635d2b6a" alt="Click for copyable input"
names = {"USA", "Poland", "Portugal", "Vietnam", "Brazil",
"Finland"};
borders = <|# ->
ArrayResample[CountryData[#, "Polygon"][[1, 1, 1]], 200] & /@
names|>;
In[2]:=
data:image/s3,"s3://crabby-images/ed14e/ed14e80bbcc0670266f95ed5f867e75cb659df72" alt="Click for copyable input"
shapes = Graphics[CountryData[#, "Shape"][[1]],
ImageSize -> {50, 50}] & /@ Keys[borders]
Out[2]=
data:image/s3,"s3://crabby-images/0eeda/0eedae9db7c0b603b2d76a42dd5179e89e0712d7" alt=""
Calculate shape distances using canonical time warping.
In[3]:=
data:image/s3,"s3://crabby-images/f489d/f489d0b572f6608c45ef143fe73d9945eebdd3b6" alt="Click for copyable input"
dm = DistanceMatrix[Values[borders],
DistanceFunction -> (Chop[
CanonicalWarpingDistance[##, MaxIterations -> 6]] &)];
Show the distance matrix.
In[4]:=
data:image/s3,"s3://crabby-images/49335/493356b9f5576555bf42988aadc8f888e1861dad" alt="Click for copyable input"
MatrixPlot[dm,
FrameTicks -> {{MapIndexed[{#2[[1]], #1} &, shapes],
None}, {MapIndexed[{#2[[1]], Rotate[#1, \[Pi]/4]} &, names],
None}}, Mesh -> True, ColorFunction -> "BlueGreenYellow",
PlotLegends -> Automatic,
PlotLabel -> "Distance based on country shape", ImageSize -> Medium]
Out[4]=
data:image/s3,"s3://crabby-images/4c3a6/4c3a6c1ab305328ea69bcb167de591dade219db8" alt=""