initial commit

This commit is contained in:
Lukas Cremer
2026-02-03 21:09:26 +01:00
commit 9fe02d248f
333 changed files with 25642 additions and 0 deletions

30
koche.py Executable file
View File

@@ -0,0 +1,30 @@
import math
C = math.sqrt( 3 )
def koch( x, y, smin=1, nmax=None ):
r=min(x,y)
pts, tmp = [ ( x, y + r ),
( x - C * r / 2, y - r / 2 ),
( x + C * r / 2, y - r / 2 ) ], []
s, n = 3 * r / C, 0
while s > smin and ( nmax is None or n < nmax ):
for i in range( len( pts ) ):
( x1, y1 ), ( x5, y5 ) = pts[ i - 1 ], pts[ i ]
dx, dy = ( x5 - x1 ) / 3, ( y5 - y1 ) / 3
tmp += [ ( x1 + dx, y1 + dy ),
( ( x1 + x5 + C * dy ) / 2, ( y1 + y5 - C * dx ) / 2 ),
( x5 - dx, y5 - dy ),
( x5, y5 ) ]
pts, tmp = tmp, []
s /= 4
n += 1
print 'Laenge'+ str(s) + 'Iterationen' + str(n)
return pts
def koche(plt):
list=koch(plt.center[0],plt.center[1],smin=1,nmax=5)
print list[-1]
return Program([Command('IN'),Command('SP1'),Command('PU',*list[-1])]\
+[Command('PD',*p) for p in list]\
+[Command('PU')])