Draw the shown pentaflake fractal shape. The following figures show pentaflakes in different recursion depths.
data:image/s3,"s3://crabby-images/68d0a/68d0ade8348e6c604f8e27622a4b8452d21a7192" alt=""
data:image/s3,"s3://crabby-images/9dd78/9dd78c9fe4ce94ced452c453817191e77368ec74" alt=""
data:image/s3,"s3://crabby-images/2008c/2008c537d0631425584b9233cbb82eb402c12630" alt=""
data:image/s3,"s3://crabby-images/56081/5608197ccb727135714c86dd377bb6243db63407" alt=""
data:image/s3,"s3://crabby-images/ebdb8/ebdb8d2e4578c93165af2e76f31d67eb53449332" alt=""
data:image/s3,"s3://crabby-images/f08e3/f08e3de321526ae88e68b7f87a9f0ddee30a09ef" alt=""
Source Code:
import turtle
import math
screen = turtle.Screen()
screen.title('Pentaflake Fractal - PythonTurtle.Academy')
screen.setup(1000,1000)
screen.setworldcoordinates(-1000,-1000,1000,1000)
turtle.speed(0)
turtle.hideturtle()
screen.tracer(0,0)
turtle.fillcolor('dark cyan')
def pentagon(x,y,r,direction,pencolor): #x,y is the center
turtle.up()
turtle.goto(x,y)
turtle.seth(direction)
turtle.fd(r)
turtle.left(126)
turtle.down()
turtle.pencolor(pencolor)
turtle.begin_fill()
for _ in range(5):
turtle.fd(2*r*math.sin(math.radians(36)))
turtle.left(72)
turtle.end_fill()
def pentaflake(x,y,r,direction,n,pencolor='dark cyan'):
if n==0:
pentagon(x,y,r,direction,pencolor)
return
r2 = r/(1+2*math.cos(math.radians(36)))
d = 2*r2*math.cos(math.radians(36))
for _ in range(5):
x2,y2 = x+d*math.cos(math.radians(direction)),y+d*math.sin(math.radians(direction))
pentaflake(x2,y2,r2,direction,n-1)
direction += 72
pentaflake(x,y,r2,direction+180,n-1,'dark green')
pentaflake(0,0,1000,90,0,'dark green')
screen.update()