Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Find an isometry in the plane that maps a polygon to a congruent one
| ResourceFunction["FindPolygonIsometry"][poly1,poly2] finds an isometric transformation in the x,y-plane between congruent polygons poly1 and poly2. | |
| ResourceFunction["FindPolygonIsometry"][poly1,poly2,n] finds up to n isometries. | 
Find an isometry between two congruent triangles:
| In[1]:= | ![ResourceFunction["FindPolygonIsometry"][
 Triangle[{{0, 0}, {1, 0}, {0, 1}}], Triangle[{{2, 0}, {3, 0}, {2, -1}}]]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/2c36140006706714.png) | 
| Out[1]= |  | 
Consider two congruent polygons:
| In[2]:= | ![poly1 = RandomPolygon[5];
poly2 = TransformedRegion[poly1, RotationTransform[.4, {2, 5}]@*ReflectionTransform[{7, 2}]@*
    TranslationTransform[{2, 3}]];
Graphics[{Red, poly1, Blue, poly2}, Axes -> True]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/778e725abca519b6.png) | 
| Out[3]= |  | 
Find an isometry between them:
| In[4]:= | ![iso = First@ResourceFunction["FindPolygonIsometry"][poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/6ebc5a7aeffff59a.png) | 
| Out[4]= |  | 
Apply it to the first polygon to get the second:
| In[5]:= | ![Graphics[#, Axes -> True] & /@ {iso[poly1], poly2}](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/0e98408f67140274.png) | 
| Out[5]= |  | 
Find all eight isometries of the unit square:
| In[6]:= | ![ResourceFunction["FindPolygonIsometry"][Rectangle[], Rectangle[], All]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/781e40d587900868.png) | 
| Out[6]= |  | 
Define a kite:
| In[7]:= | ![kite = Polygon[{{0, 0}, {1, 3}, {0, 4}, {-1, 3}}];
Graphics[kite]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/5e9bc1bc3157bb03.png) | 
| Out[8]= |  | 
Find both of its isometries:
| In[9]:= | ![ResourceFunction["FindPolygonIsometry"][kite, kite, All]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/4a64329f5cb11601.png) | 
| Out[9]= |  | 
Consider two congruent polygons with holes in them:
| In[10]:= | ![poly1 = Polygon[{{0, 0}, {5, 0}, {2.5, 4}, {2, 1}, {2, 2}, {3, 2}, {3,
      1}, {3.3, 1}, {3, 1.3}}, {1, 2, 3} -> {{4, 5, 6}, {7, 8, 9}}];
poly2 = TransformedRegion[poly1, RotationTransform[.4, {12, 5}]@*ReflectionTransform[{7, 2}]@*
    TranslationTransform[{2, 3}]];
Graphics[{Red, poly1, Blue, poly2}, Axes -> True]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/20417c4f6ec8123a.png) | 
| Out[11]= |  | 
Find an isometry between them:
| In[12]:= | ![iso = First@ResourceFunction["FindPolygonIsometry"][poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/65030f189d018638.png) | 
| Out[12]= |  | 
Apply it to the first polygon to get the second:
| In[13]:= | ![Graphics[#, Axes -> True] & /@ {iso[poly1], poly2}](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/323f4a79c4e90bce.png) | 
| Out[13]= |  | 
Use FindRegionTransform on the polygons:
| In[14]:= | ![frt = FindRegionTransform[poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/3c6e54e4005b4836.png) | 
| Out[14]= |  | 
Applying this transform does not map the first polygon to the second:
| In[15]:= | ![Graphics[#, Axes -> True] & /@ {frt[poly1], poly2}](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/173fb6a20f9c3a01.png) | 
| Out[15]= |  | 
Define a function for determining polygon congruence:
| In[16]:= | ![polygonCongruentQ[poly1_, poly2_] := MatchQ[ResourceFunction["FindPolygonIsometry"][poly1, poly2], {_}]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/6aed84715bc5f50b.png) | 
Consider two congruent multi-polygons:
| In[17]:= | ![poly1 = Polygon[{{0, 0}, {5, 0}, {2.5, 4}, {2, 1}, {2, 2}, {3, 2}, {3,
      1}, {3.3, 1}, {3, 1.3}}, {{4, 5, 6}, {7, 8, 9}}];
poly2 = TransformedRegion[poly1, RotationTransform[.4, {12, 5}]@*ReflectionTransform[{7, 2}]@*
    TranslationTransform[{-3, 5}]];
Graphics[{Red, poly1, Blue, poly2}, Axes -> True]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/52148e022dcbe87f.png) | 
| Out[12]= |  | 
Confirm they are congruent:
| In[18]:= | ![polygonCongruentQ[poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/6ca616114053e439.png) | 
| Out[18]= |  | 
RegionCongruent does not evaluate in all cases:
| In[19]:= | ![RegionCongruent[poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/1a9a0086ead310e5.png) | 
| Out[19]= |  | 
Consider two random polygons:
| In[20]:= | ![poly1 = RandomPolygon[5];
poly2 = RandomPolygon[5];
Graphics[{Opacity[.5], Red, poly1, Blue, poly2}, Axes -> True]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/38131614318f6742.png) | 
| Out[21]= |  | 
Because they are not congruent, there is no isometry between them:
| In[22]:= | ![ResourceFunction["FindPolygonIsometry"][poly1, poly2]](https://www.wolframcloud.com/obj/resourcesystem/images/f09/f0992d8b-efc6-4ea6-98f1-e81fc5858c9d/713228ea849c6a5c.png) | 
| Out[22]= |  | 
Wolfram Language 14.0 (January 2024) or above
This work is licensed under a Creative Commons Attribution 4.0 International License