このコードは、Fractal 記述言語ファイルを読み取って解釈し、FractalWorld を使用します。これは TurtleWorld の特別なバージョンであり、カメを削除するだけで遅延はありません。
import math, random, sys
from FractalWorld import *
world = FractalWorld(width=1000,height=1000,delay=0)
Rasmus = Fractal(draw=False)
class command(object):
def __init__(self, cmd, l):
self.cmd = cmd
self.l = l
def execute(self, turtle, length):
if self.cmd=='lt':
lt(turtle, int(self.l[0]))
if self.cmd=='rt':
rt(turtle, int(self.l[0]))
if self.cmd=='fd':
fd(turtle, length)
if self.cmd=='bk':
bk(turtle, length)
if self.cmd=='scale':
lenght = length*float(self.l[0])
class rule(object):
def __init__(self):
self.rule={} #we make an empty dictionary
def newrule(self,leftside,rightside):
self.rule[leftside]=rightside #we fill the dictionary
def expand (self,oldlist,depth):
if depth <= 0:
return oldlist
newlist=[] # we make an empty new list
for i in oldlist:
if i not in self.rule:
newlist.append(i)
else:
newlist.append(self.expand(self.rule[i],depth-1))
return newlist
class Fractal(object):
def __init__(self, start, rules, commands, length, depth):
self.start = start
self.rules = rules
self.commands = commands
self.length = length
self.depth = depth
def draw(self, oldlist):
for i in oldlist:
if type(i) == list:
self.draw(i)
else:
cmd = self.commands[i]
cmd.execute(Rasmus, self.length)
def read():
files = open('tree.fdl')
commands = {}
r = rule()
for line in files:
line = line.strip()
oldlist = line.split(' ')
if oldlist[0] == 'start':
start = oldlist[1:]
elif oldlist[0] == 'rule':
r.newrule(oldlist[1], oldlist[3:])
elif oldlist[0] == 'cmd':
cmd = command(oldlist[2], oldlist[3:])
commands[oldlist[1]] = cmd
elif oldlist[0] == 'length':
length = int(oldlist[1])
elif oldlist[0] == 'depth':
depth = int(oldlist[1])
return Fractal(start, r, commands, length, depth)
re = read()
print re.commands.keys()
l = re.rules.expand(re.start , re.depth)
re.draw(l)
wait_for_user()
fdl ファイルはバイナリ ツリーを作成し、次のようになります。
start X
rule X -> F L D X R X U L B
length 100
depth 10
cmd X nop
cmd F fd
cmd B bk
cmd R rt 70
cmd L lt 35
cmd D scale 0.7
cmd U scale 1.4285714285714286
私の問題は、インタープリターにバグがあることです。インタプリタが縮尺を正しく読み取らず、木の枝の次の深さに合わせて線を縮尺縮小しているようです。デバッグしようとしましたが、できませんでした。