我想得到所有垂死乌龟的平均年龄。我尝试通过以下代码剪切来实现这一点:
globals [mean-death-age]
turtles-own [age prob-die?]
to-report mean-age
if (prob-die? = true) [
set mean-death-age mean [age] of turtles
]
report mean-death-age
end
每只乌龟都有死亡的可能性(概率死亡?),应该在每个时间步骤(勾号)计算出新的乌龟。如果问题?设置为真正的平均死亡年龄应该更新。目前我遇到的问题是
我不知道如何启动变量平均死亡年龄。也许,使用if循环可以帮助
if (ticks >= 1) [
if (prob-die? = true) [
set mean-death-age mean [age] of turtles
]
]
我没有得到已计算的平均死亡年龄的更新,但该变量被覆盖,并返回此蜱的平均死亡年龄
我在访问该值时遇到问题。当我尝试用例如。
来调用它时print mean-age
我收到的错误信息是,即使我尝试将保存作为全局变量,也只能使用平均值 -
整个代码可用here。
答案 0 :(得分:3)
我认为你让它变得比它需要的更复杂。最简单的方法是保留海龟死亡的年龄列表,然后取出该列表的平均值:
globals [death-ages]
turtles-own [age]
to setup
clear-all
create-turtles 100 [
setxy random-xcor random-ycor
set age random 100
]
set death-ages [] ; start with an empty list
reset-ticks
end
to go
if not any? turtles [ stop ]
ask turtles [
if random 100 < age [
set death-ages lput age death-ages ; add age to our list of ages of death
die
]
]
print mean death-ages
tick
end
唯一的缺点是,当您的模型运行时,您的death-ages
列表将继续增长。如果事实证明这是一个问题(虽然可能不会),你需要跟踪当前的平均值和当前的观察数量,并用set avg ((n * avg) + age) / (n + 1) set n n + 1
更新你的平均值。
至于为什么你当前的代码不起作用,会有很多解包来解释它(对不起,我现在不能)。作为一般性评论,我建议您在遇到这样的困难时尝试退一步,并考虑解决问题所需的最少量信息。在这种情况下,您需要表示死亡年龄。最简单的方法是什么?保留死亡年龄列表,并在需要时记录该列表的平均值。