
O que quero fazer é criar uma sequência de iterações do tapete Sierpinski. O tapete de Sierpinski é criado dividindo o quadrado em nove subquadrados congruentes e removendo o do meio, depois dividindo os subquadrados restantes em nove subquadrados menores e removendo o do meio, repetindo o processo.
Criei o diagrama abaixo usando tikz desenhando e, quando necessário, preenchendo cada retângulo individual. No entanto, este é um processo tedioso e ineficiente, especialmente porque a próxima iteração exigiria 512 retângulos brancos adicionais.
\begin{tikzpicture}
\fill (0, 0) rectangle (1, 1);
\begin{scope}[xshift = 1.5 cm]
\fill (0, 0) rectangle (1, 1);
\fill[color=white] (1/3, 1/3) rectangle (2/3, 2/3);
\end{scope}
\begin{scope}[xshift = 3 cm]
\fill (0, 0) rectangle (1, 1);
\fill[color=white] (1/3, 1/3) rectangle (2/3, 2/3);
\fill[color=white] (1/9, 1/9) rectangle (2/9, 2/9);
\fill[color=white] (4/9, 1/9) rectangle (5/9, 2/9);
\fill[color=white] (7/9, 1/9) rectangle (8/9, 2/9);
\fill[color=white] (1/9, 4/9) rectangle (2/9, 5/9);
\fill[color=white] (7/9, 4/9) rectangle (8/9, 5/9);
\fill[color=white] (1/9, 7/9) rectangle (2/9, 8/9);
\fill[color=white] (4/9, 7/9) rectangle (5/9, 8/9);
\fill[color=white] (7/9, 7/9) rectangle (8/9, 8/9);
\end{scope}
\begin{scope}[xshift = 4.5 cm]
\fill (0, 0) rectangle (1, 1);
\fill[color=white] (1/3, 1/3) rectangle (2/3, 2/3);
\fill[color=white] (1/9, 1/9) rectangle (2/9, 2/9);
\fill[color=white] (4/9, 1/9) rectangle (5/9, 2/9);
\fill[color=white] (7/9, 1/9) rectangle (8/9, 2/9);
\fill[color=white] (1/9, 4/9) rectangle (2/9, 5/9);
\fill[color=white] (7/9, 4/9) rectangle (8/9, 5/9);
\fill[color=white] (1/9, 7/9) rectangle (2/9, 8/9);
\fill[color=white] (4/9, 7/9) rectangle (5/9, 8/9);
\fill[color=white] (7/9, 7/9) rectangle (8/9, 8/9);
\fill[color=white] (4/81, 4/81) rectangle (5/81, 5/81);
\fill[color=white] (13/81, 4/81) rectangle (14/81, 5/81);
\fill[color=white] (22/81, 4/81) rectangle (23/81, 5/81);
\fill[color=white] (31/81, 4/81) rectangle (32/81, 5/81);
\fill[color=white] (40/81, 4/81) rectangle (41/81, 5/81);
\fill[color=white] (49/81, 4/81) rectangle (50/81, 5/81);
\fill[color=white] (58/81, 4/81) rectangle (59/81, 5/81);
\fill[color=white] (67/81, 4/81) rectangle (68/81, 5/81);
\fill[color=white] (76/81, 4/81) rectangle (77/81, 5/81);
\fill[color=white] (4/81, 13/81) rectangle (5/81, 14/81);
\fill[color=white] (22/81, 13/81) rectangle (23/81, 14/81);
\fill[color=white] (31/81, 13/81) rectangle (32/81, 14/81);
\fill[color=white] (49/81, 13/81) rectangle (50/81, 14/81);
\fill[color=white] (58/81, 13/81) rectangle (59/81, 14/81);
\fill[color=white] (76/81, 13/81) rectangle (77/81, 14/81);
\fill[color=white] (4/81, 22/81) rectangle (5/81, 23/81);
\fill[color=white] (13/81, 22/81) rectangle (14/81, 23/81);
\fill[color=white] (22/81, 22/81) rectangle (23/81, 23/81);
\fill[color=white] (31/81, 22/81) rectangle (32/81, 23/81);
\fill[color=white] (40/81, 22/81) rectangle (41/81, 23/81);
\fill[color=white] (49/81, 22/81) rectangle (50/81, 23/81);
\fill[color=white] (58/81, 22/81) rectangle (59/81, 23/81);
\fill[color=white] (67/81, 22/81) rectangle (68/81, 23/81);
\fill[color=white] (76/81, 22/81) rectangle (77/81, 23/81);
\fill[color=white] (4/81, 31/81) rectangle (5/81, 32/81);
\fill[color=white] (13/81, 31/81) rectangle (14/81, 32/81);
\fill[color=white] (22/81, 31/81) rectangle (23/81, 32/81);
\fill[color=white] (58/81, 31/81) rectangle (59/81, 32/81);
\fill[color=white] (67/81, 31/81) rectangle (68/81, 32/81);
\fill[color=white] (76/81, 31/81) rectangle (77/81, 32/81);
\fill[color=white] (4/81, 40/81) rectangle (5/81, 41/81);
\fill[color=white] (22/81, 40/81) rectangle (23/81, 41/81);
\fill[color=white] (58/81, 40/81) rectangle (59/81, 41/81);
\fill[color=white] (76/81, 40/81) rectangle (77/81, 41/81);
\fill[color=white] (4/81, 49/81) rectangle (5/81, 50/81);
\fill[color=white] (13/81, 49/81) rectangle (14/81, 50/81);
\fill[color=white] (22/81, 49/81) rectangle (23/81, 50/81);
\fill[color=white] (58/81, 49/81) rectangle (59/81, 50/81);
\fill[color=white] (67/81, 49/81) rectangle (68/81, 50/81);
\fill[color=white] (76/81, 49/81) rectangle (77/81, 50/81);
\fill[color=white] (4/81, 58/81) rectangle (5/81, 59/81);
\fill[color=white] (13/81, 58/81) rectangle (14/81, 59/81);
\fill[color=white] (22/81, 58/81) rectangle (23/81, 59/81);
\fill[color=white] (31/81, 58/81) rectangle (32/81, 59/81);
\fill[color=white] (40/81, 58/81) rectangle (41/81, 59/81);
\fill[color=white] (49/81, 58/81) rectangle (50/81, 59/81);
\fill[color=white] (58/81, 58/81) rectangle (59/81, 59/81);
\fill[color=white] (67/81, 58/81) rectangle (68/81, 59/81);
\fill[color=white] (76/81, 58/81) rectangle (77/81, 59/81);
\fill[color=white] (4/81, 67/81) rectangle (5/81, 68/81);
\fill[color=white] (22/81, 67/81) rectangle (23/81, 68/81);
\fill[color=white] (31/81, 67/81) rectangle (32/81, 68/81);
\fill[color=white] (49/81, 67/81) rectangle (50/81, 68/81);
\fill[color=white] (58/81, 67/81) rectangle (59/81, 68/81);
\fill[color=white] (76/81, 67/81) rectangle (77/81, 68/81);
\fill[color=white] (4/81, 76/81) rectangle (5/81, 77/81);
\fill[color=white] (13/81, 76/81) rectangle (14/81, 77/81);
\fill[color=white] (22/81, 76/81) rectangle (23/81, 77/81);
\fill[color=white] (31/81, 76/81) rectangle (32/81, 77/81);
\fill[color=white] (40/81, 76/81) rectangle (41/81, 77/81);
\fill[color=white] (49/81, 76/81) rectangle (50/81, 77/81);
\fill[color=white] (58/81, 76/81) rectangle (59/81, 77/81);
\fill[color=white] (67/81, 76/81) rectangle (68/81, 77/81);
\fill[color=white] (76/81, 76/81) rectangle (77/81, 77/81);
\end{scope}
\end{tikzpicture}
O que eu esperava fazer era adaptar a solução de Jake usando sistemas Lindenmayer paraComo criar um triângulo de Sierpinski em LaTeX?para um retângulo, como o marsupilam fez para um hexágono emFractal Tikz - Hexágono Sierpinski.
Estou ciente de que perguntas sobre a geração de um tapete Sierpinski já foram feitas anteriormente. A resposta de Mark Wibrow paraGerando um tapete Sierpinski com tikznão usa um sistema Lindenmayer e faz com que meu sistema trave. A resposta de Henri Menke aDesenhando um Fractal Simples em Tikzé lindo, mas fica bem pequeno quando reduzo a ordem do fractal e fico em um vértice em vez de em um lado. Desejo manter cada iteração do mesmo tamanho, conforme mostrado acima.
Suponho que se eu definir order=\level, gostaria de definir \squarewidth=9^\level já que cada quadrado é dividido em nove quadrados e que devo definir o ângulo=90 já que cada ângulo é um ângulo reto. No entanto, estou confuso sobre como adaptar as regras dos símbolos X e Y que Jake e Marsupilam usaram em suas respostas para gerar os padrões mostrados acima.
Responder1
Aqui está uma macro que coloca nós brancos nos locais apropriados.
\sierpinski[options]{levels}
A opção que tenho em mente é scale=
, mas rotate=
também funcionará. Ou xscale=
se você quiser retângulos que não sejam quadrados. Certifique-se de usar transform shape
.
\documentclass{article}
\usepackage{tikz}
\newcommand{\sierpinski}[2][]{\tikz[#1]{
\draw[fill=black] rectangle(1,1);
\foreach \n[evaluate=\n as \m using \n-1, evaluate=\n as \s using 1/3^\n, evaluate=\m as \p using 3^\m] in {1,...,#2}{
\foreach \k[evaluate=\k as \x using (2*\k-1)/2/3^\m] in {1,...,\p}{
\foreach \j[evaluate=\j as \y using (2*\j-1)/2/3^\m] in {1,...,\p}{
\node[fill=white, minimum size=\s cm, inner sep=0] at (\x,\y){};
}}}}}
\begin{document}
\tikz{\draw[fill=black] rectangle(1,1);}\quad\sierpinski{1}\quad\sierpinski{2}\quad\sierpinski{3}\quad\sierpinski{4}
\end{document}
Aqui está \sierpinski[scale=3, transform shape]{5}
, que é tudo o que minha máquina pode suportar. É O(9ⁿ), então prepare-se para esperar.
Responder2
com uma atualizaçãohttps://ctan.org/pkg/pst-fractale correndo lualatex
:
\documentclass[pstricks]{standalone}
\usepackage{pst-fractal}
\begin{document}
\begin{pspicture}(18,3)
\multido{\iA=1+1,\iB=0+12}{6}{%
\psSierCarpet[scale=0.25,n=\iA](\iB,0.2)}
\end{pspicture}
\end{document}
e com opção basecolor=red,linecolor=blue
:
Responder3
Você obteve a resposta tikz que procurava, então sinto-me à vontade para adicionar uma resposta feita com MetaPost/MetaFun. Provavelmente o código pode ser otimizado e provavelmente alguém pode fazer algo semelhante com o tikz (mas não posso). A primeira versão desenha um quadrado e dá voltas e desfaz as partes que deveriam ser brancas. O segundo usa recursão.
Em relação ao horário:
First version: 2.9s
Second version: 1.8s
Eu o envolvi em páginas MetaPost no ConTeXt lmtx. O arquivo pode ser compilado com context
.
\starttext
\startMPpage[offset=1dk]
vardef sierpinski(expr w, n) =
image(
fill unitsquare scaled w ;
for i = 1 upto n :
for j = 1 upto (3^(i-1)) :
for k = 1 upto (3^(i-1)) :
unfill unitsquare scaled (w/(3^i)) shifted ( (3*j-2)*w/(3^i), (3*k-2)*w/(3^i) ) ;
endfor
endfor
endfor)
enddef ;
for i = 1 upto 3 :
draw sierpinski(3cm,i) shifted (4*(i-1)*cm, 0 ) ;
draw sierpinski(3cm,i+3) shifted (4*(i-1)*cm, -4cm) ;
endfor ;
\stopMPpage
\startMPpage[offset=1dk]
vardef Sierpinski(expr w,n) =
save tmppic ;
picture tmppic ;
if n = 1 :
image(
fill unitsquare scaled w ;
unfill unitsquare scaled (w/3) shifted (w/3,w/3) ;
)
else :
tmppic := Sierpinski(w, n - 1) scaled 1/3 ;
image(
for i = 1 upto 3 :
for j = 1 upto 3 :
if ((i*j) <> 4) :
draw tmppic shifted (((i-1)/3)*w,((j-1)/3)*w) ;
fi
endfor
endfor
)
fi
enddef ;
for i = 1 upto 3 :
draw Sierpinski(3cm,i) shifted (4*(i-1)*cm, 0 ) ;
draw Sierpinski(3cm,i+3) shifted (4*(i-1)*cm, -4cm) ;
endfor ;
\stopMPpage
\stoptext
A saída parece a mesma em ambas as variantes (até onde posso ver), então mostro apenas uma delas.
Responder4
Aqui está uma versão pura em LaTeX e recursão.
Obviamente, isso só funciona porque você está usando retângulos (que são facilmente colocados com a tabular
).
Código
\documentclass{article}
\newcommand*\startCarpet[2][1em]{{%
\renewcommand*\arraystretch{0}%
\setlength\fboxsep{0pt}\setlength\fboxrule{#1}%
\edef\BOX{\noexpand\fbox{%
\noexpand\rule[-\the\dimexpr#1/2\relax]{0pt}{#1}\noexpand\rule{#1}{0pt}}}%
\def\TAB##1{\tabular{@{}c@{}c@{}c@{}}##1&##1&##1\\##1&&##1\\##1&##1&##1\endtabular}%
\def\level{#2}%
\def\doCarpet{%
\ifnum\level=0
\def\next{\TAB{\BOX}}%
\else
\def\next{%
\edef\level{\inteval{\level-1}}%
\TAB{\doCarpet}}%
\fi
\next}
\doCarpet}}
\begin{document}
\centering
\startCarpet{0}
\startCarpet[.3333em]{1}
\startCarpet[.1111em]{2}
\startCarpet[.117em]{3}
\end{document}