私はPython 3でSugarscapeエージェントシミュレーションモデルの小さな部分を複製しています。私のコードのパフォーマンスはNetLogoの性能よりも3倍遅いことがわかりました。それはおそらく私のコードに問題があるのでしょうか、それともPythonの本質的な制限ですか?エージェントベースのシミュレーション:パフォーマンスの問題:PythonとNetLogo&Repast
明らかに、これはコードの単なる断片ですが、Pythonが実行時の3分の2を費やしているところです。私はそれがこのフラグメントに表示される場合があります本当に非効率的な何かを書いた場合、私は願っています:
; -- The SugarScape growth and motion procedures. --
to M ; Motion rule (page 25)
locals [ps p v d]
set ps (patches at-points neighborhood) with [count turtles-here = 0]
if (count ps > 0) [
set v psugar-of max-one-of ps [psugar] ; v is max sugar w/in vision
set ps ps with [psugar = v] ; ps is legal sites w/ v sugar
set d distance min-one-of ps [distance myself] ; d is min dist from me to ps agents
set p random-one-of ps with [distance myself = d] ; p is one of the min dist patches
if (psugar >= v and includeMyPatch?) [set p patch-here]
setxy pxcor-of p pycor-of p ; jump to p
set sugar sugar + psugar-of p ; consume its sugar
ask p [setpsugar 0] ; .. setting its sugar to 0
]
set sugar sugar - metabolism ; eat sugar (metabolism)
set age age + 1
end
私のコンピュータの場合:
UP = (0, -1)
RIGHT = (1, 0)
DOWN = (0, 1)
LEFT = (-1, 0)
all_directions = [UP, DOWN, RIGHT, LEFT]
# point is just a tuple (x, y)
def look_around(self):
max_sugar_point = self.point
max_sugar = self.world.sugar_map[self.point].level
min_range = 0
random.shuffle(self.all_directions)
for r in range(1, self.vision+1):
for d in self.all_directions:
p = ((self.point[0] + r * d[0]) % self.world.surface.length,
(self.point[1] + r * d[1]) % self.world.surface.height)
if self.world.occupied(p): # checks if p is in a lookup table (dict)
continue
if self.world.sugar_map[p].level > max_sugar:
max_sugar = self.world.sugar_map[p].level
max_sugar_point = p
if max_sugar_point is not self.point:
self.move(max_sugar_point)
ほぼ同等のcode in NetLogoを(このフラグメントは、上記のPythonの関数よりも少しありません) 、Pythonコードは15.5秒で1000ステップ実行されます。同じラップトップ上で、ブラウザ内でJavaで実行されているNetLogoシミュレーションは、6秒未満で1000ステップを終了します。
EDIT:Java実装を使用してRepastをチェックしました。 5.4秒でNetLogoとほぼ同じです。 JavaとPythonの間のRecent comparisonsはJavaに利点がないことを示唆しているので、それは自分の責任であると思いますか?
編集:MASONはRepastよりも高速であると思われますが、それでもまだJavaを実行します。
ニース。実行時間は15.5秒から11.4秒(〜26%)に減少しました。なぜ私は少なくともインタプリタに-Oオプションを指定すると、Pythonがそのようなものを最適化しないのでしょうか? – max
「占有」機能を取り除くとさらに10.4秒になりました。 – max
@max:あなたが経験したスピードアップで書き返してくれてありがとう。 – Curious2learn