Sierpinski Carpet

Start with a square, dividing it into a 3-by-3 grid, and remove the center square; then repeat the process for each remaining square. The limiting shape (that is, the shape remaining “after” iterating the process an infinite number of times) is the Sierpinski carpet.

four iterations toward Sierpinski carpet

(Compare the generation process with the 2-D Cantor dust process and the 3-D Menger sponge process. You might also enjoy the Jerusalem square part of this Jerusalem cube page.)

Some ancient code, for what it’s worth: define a function makehole that takes the lower-left and upper-right corners of a square, and returns a list of eight squares arranged about the center of the original square (that is, it returns the original square with the middle ninth erased); iterate makehole four times, remembering each step, giving four lists of corners; the line starting with Show makes the lists of corners into renderable rectangles, which it then shows. It made sense at the time.

makehole[{{x0_, y0_}, {x1_, y1_}}] :=

  With[{xr = Abs[x1 - x0], yr = Abs[y1 - y0]},
    
      { {{x0, y0},               {x0 + xr/3, y0 + yr/3}},
        {{x0, y0 + yr/3},        {x0 + xr/3, y1 - yr/3}},
        {{x0, y1 - yr/3},        {x0 + xr/3, y1}},
        {{x0 + xr/3, y0},        {x1 - xr/3, y0 + yr/3}},
        {{x0 + xr/3, y1 - yr/3}, {x1 - xr/3, y1}},
        {{x1 - xr/3, y0},        {x1, y0 + yr/3}},
        {{x1 - xr/3, y0 + yr/3}, {x1, y1 - yr/3}},
        {{x1 - xr/3, y1 - yr/3}, {x1, y1}}
       }];

Show[
  GraphicsArray[
    Partition[
      Map[ Graphics[#, AspectRatio -> 1]&,
        Apply[
          Rectangle,
            Rest@
              NestList[ Flatten[ Map[ makehole, # ], 1 ]&,
                {{{0, 0}, {1, 1}}},
               4],
         {2}]],
     2]]];

Designed and rendered long ago using Mathematica versions 2.2 and 3.0 for the Apple Macintosh.

© 1995–2025 by Robert Dickau.

[ home ] || [ 97???? ]

www.robertdickau.com/carpet.html