Pitón | Alfombra Serpino

| | | | |

¿Cómo funciona?
La alfombra de Sierpinski comienza con un cuadrado. Este cuadrado se divide en nueve partes iguales. El cuadrado más pequeño más pequeño se elimina del cuadrado más grande original. Luego, los cuadrados restantes se dividen nuevamente en nueve partes iguales, y se elimina el cuadrado más central de cada cuadrado. Cuando se repite este proceso, se observa un hermoso patrón de alfombra de Sierpinski.

Supongamos que comenzamos con un cuadrado negro.

Dividirlo en 9 partes iguales y eliminar el cuadrado central.

Repetir el proceso conduce más a algo como esto.

Podemos visualizar este fenómeno en detalle en este video .

Veamos cómo se ve su código:


# importar módulos requeridos

import numpy as np

de PIL importar Imagen


# número total de repeticiones del proceso

total = 7


# tamaño de imagen

tamaño = 3 * * total


# crear imagen

cuadrado = np.empty ([tamaño, tamaño, 3 ], dtype = np.uint8)

color = np.array ([ 255 , 255 , 255 ], dtype = np. uint8)


# rellenando esto con negro

cuadrado.llenar ( 0 )

< br>

para i en rango ( 0 , total < /código> + 1 ):

paso a paso = 3 * * (total - i)

for x < /código> en rango ( 0 , 3 * * i):

# revisando el cuadrado central

if x % 3 = = 1 :

para y en rango ( 0 , 3 * * i):

si y % 3 = = 1 :

# cambia tu color

cuadrado [y * stepdown: (y + 1 ) * reducción, x * reducción: (x + < /código> 1 ) * stepdown] = color


# guarda la imagen resultante

save_file = "sierpinski.jpg"

Image.fromarray (square) .save (guardar _file)


# mostrarlo en la consola

i = Imagen. abrir ( " sierpinski.jpg " )

i.show()

Salida:

Esta es una alfombra de Sierpinski después de 7 repeticiones. Puede obtener su código para otros idiomas en rosettacode .

Shop

Learn programming in R: courses

$

Best Python online courses for 2022

$

Best laptop for Fortnite

$

Best laptop for Excel

$

Best laptop for Solidworks

$

Best laptop for Roblox

$

Best computer for crypto mining

$

Best laptop for Sims 4

$

Latest questions

NUMPYNUMPY

psycopg2: insert multiple rows with one query

12 answers

NUMPYNUMPY

How to convert Nonetype to int or string?

12 answers

NUMPYNUMPY

How to specify multiple return types using type-hints

12 answers

NUMPYNUMPY

Javascript Error: IPython is not defined in JupyterLab

12 answers

News


Wiki

Python OpenCV | cv2.putText () method

numpy.arctan2 () in Python

Python | os.path.realpath () method

Python OpenCV | cv2.circle () method

Python OpenCV cv2.cvtColor () method

Python - Move item to the end of the list

time.perf_counter () function in Python

Check if one list is a subset of another in Python

Python os.path.join () method