In my essay on the rep-tile puzzle, I introduced the concept of the rep-tile, covered how Solomon W. Golomb defined a rep-k polygon and demonstrated what it means to construct a rep-3 triangle. If you haven’t read that essay, I would recommend you to do so. This is because I will be building on top of those concepts in this essay.
You see, the rep-3 triangle is a special case for which I couldn’t find any structured approach. However, I’m happy to report that Golomb figured out structured approaches to tiling higher-order rep-k triangles. I will be demonstrating how we could tile the various possible higher-order rep-k triangles in this essay. Let us begin.
In his 1964 paper titled “Replicating Figures in the Plane” (linked in the references at the end of this essay), Golomb stated three specific conditions for tiling rep-tile triangles. In other words, if these conditions are not met, it would not be possible to tile the corresponding triangle.
Given the intention to tile an arbitrary triangle into n-tiles, Golomb’s conditions are as follows:
1. A triangle can be tiled if ’n’ is of the form ‘k²’.
2. A triangle can be tiled if ’n’ is of the form ‘3k²’.
3. A triangle can be tiled if ’n’ is of the form ‘k² + l²’.
In the above set of conditions, ’n’, ‘k’, and ‘l’ refer to positive integers. Accordingly, any other form of ’n’ would not be tile-able as far as triangles are concerned. This came to be known as Golomb’s theorem in this field.
After Golomb, Snover et al. proved Golomb’s theorem in their 1989 paper titled “Rep-tiling for triangles” (also linked in the references section at the end of the essay). Now that we have covered the relevant background, let us see how we can tile triangles that conform to each of the above-stated conditions.
How to Rep-tile a Triangle into n tiles, where n = k²?
The procedure to tile an arbitrary triangle into ’n’ tiles where ’n’ is of the form ‘k²’ is pretty straightforward. Firstly, we divide each of the sides into ‘k’ equal lengths. Then, we interconnect all of these points. Since this might be challenging to imagine, let us work with an example.
Say that we are interested in tiling a triangle into 9 tiles. Now, 9 = 3². So, n = 9 and k = 3. Knowing this, we can divide each side of the triangle into three equal parts. Then, we interconnect the resulting points using straight lines as shown below.
Illustration of a rep-9 triangle — created by the author (figures not to scale)
How to Rep-tile a Triangle into n tiles, where n = 3k²?
Rep-tiling a triangle into ‘n = 3k²’ tiles appears challenging on the surface, but with a little bit of knowledge application, it is simple enough. In my essay on the rep-tile puzzle, I demonstrated how you could tile a rep-3 triangle.
Similar to that approach, you will need start with a 90–60–30 triangle with side length proportions of x, 2x and √3x respectively. Once you construct a rep-3 triangle based on the given specification, you can apply the ‘k²’ algorithm that we just saw to each one of these triangles.
Illustration of a Rrep-3 triangle — created by the author (figures not to scale)
By doing this, you would end up with ‘n = 3k²’ tiles.
How to Rep-tile a Triangle into n tiles, where n = (k² + l²)?
This is the most complex one out of all three conditions. When tiling a triangle into ‘n = (k² + l²)’, you will first need to sort ‘k’ and ‘l’ in terms of magnitude. For our purposes, let us say that k > l.
Next, you will need to construct a right-triangle such that two sides of length ‘k’ and ‘l’ are perpendicular to each other. Consequently, the hypotenuse would have a length of ‘√ (k² + l²)’ or √n. Now, let us visualize this triangle such that the hypotenuse appears horizontal on the bottom.
Next, drop a perpendicular line to the hypotenuse from the opposite vertex. Then, divide the side that is ‘k’ units long into ‘k’ equal proportions and the side that is ‘l’ units long into ‘l’ equal proportions. As a final step, just inter-connect the resulting points.
Let us say that we would like to tile a triangle using 5 tiles. We know that 5 = 2² + 1². So, n = 5, k = 2, and l = 1. If we execute the above discussed algorithm, the resulting triangle would look like this:
Illustration of a rep-5 triangle — created by the author (figures not to scale)
As you may have noted, this algorithm results in tiles that don’t match vertices at the boundary between the k-triangles and the l-triangle(s). Still, the triangle is considered tiled.
Final Remarks
You might be wondering what the purpose of a rep-tile is. Well, in two words: infinite scalability.
In the work done by Martin Gardner on this topic, I came across a beautiful little poem by British mathematician Augustus De Morgan on the scalability of rep-tiles (De Morgan had been researching this topic much before Golomb).
To conclude this essay with a poetic touch, I leave you with a quote from De Morgan’s own words. Enjoy!
We use cookies on our website to give you the most relevant experience by remembering your preferences and repeat visits. By clicking “Accept”, you consent to the use of ALL the cookies.
This website uses cookies to improve your experience while you navigate through the website. Out of these, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may affect your browsing experience.
Necessary cookies are absolutely essential for the website to function properly. These cookies ensure basic functionalities and security features of the website, anonymously.
Cookie
Duration
Description
cookielawinfo-checkbox-advertisement
1 year
Set by the GDPR Cookie Consent plugin, this cookie is used to record the user consent for the cookies in the "Advertisement" category .
cookielawinfo-checkbox-analytics
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Analytics".
cookielawinfo-checkbox-functional
11 months
The cookie is set by GDPR cookie consent to record the user consent for the cookies in the category "Functional".
cookielawinfo-checkbox-necessary
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookies is used to store the user consent for the cookies in the category "Necessary".
cookielawinfo-checkbox-others
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Other.
cookielawinfo-checkbox-performance
11 months
This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Performance".
CookieLawInfoConsent
1 year
Records the default button state of the corresponding category & the status of CCPA. It works only in coordination with the primary cookie.
viewed_cookie_policy
11 months
The cookie is set by the GDPR Cookie Consent plugin and is used to store whether or not user has consented to the use of cookies. It does not store any personal data.
Functional cookies help to perform certain functionalities like sharing the content of the website on social media platforms, collect feedbacks, and other third-party features.
Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.
Cookie
Duration
Description
_gat
1 minute
This cookie is installed by Google Universal Analytics to restrain request rate and thus limit the collection of data on high traffic sites.
Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics the number of visitors, bounce rate, traffic source, etc.
Cookie
Duration
Description
__gads
1 year 24 days
The __gads cookie, set by Google, is stored under DoubleClick domain and tracks the number of times users see an advert, measures the success of the campaign and calculates its revenue. This cookie can only be read from the domain they are set on and will not track any data while browsing through other sites.
_ga
2 years
The _ga cookie, installed by Google Analytics, calculates visitor, session and campaign data and also keeps track of site usage for the site's analytics report. The cookie stores information anonymously and assigns a randomly generated number to recognize unique visitors.
_ga_R5WSNS3HKS
2 years
This cookie is installed by Google Analytics.
_gat_gtag_UA_131795354_1
1 minute
Set by Google to distinguish users.
_gid
1 day
Installed by Google Analytics, _gid cookie stores information on how visitors use a website, while also creating an analytics report of the website's performance. Some of the data that are collected include the number of visitors, their source, and the pages they visit anonymously.
CONSENT
2 years
YouTube sets this cookie via embedded youtube-videos and registers anonymous statistical data.
Advertisement cookies are used to provide visitors with relevant ads and marketing campaigns. These cookies track visitors across websites and collect information to provide customized ads.
Cookie
Duration
Description
IDE
1 year 24 days
Google DoubleClick IDE cookies are used to store information about how the user uses the website to present them with relevant ads and according to the user profile.
test_cookie
15 minutes
The test_cookie is set by doubleclick.net and is used to determine if the user's browser supports cookies.
VISITOR_INFO1_LIVE
5 months 27 days
A cookie set by YouTube to measure bandwidth that determines whether the user gets the new or old player interface.
YSC
session
YSC cookie is set by Youtube and is used to track the views of embedded videos on Youtube pages.
yt-remote-connected-devices
never
YouTube sets this cookie to store the video preferences of the user using embedded YouTube video.
yt-remote-device-id
never
YouTube sets this cookie to store the video preferences of the user using embedded YouTube video.
Comments