【发布时间】:2013-09-21 16:50:36
【问题描述】:
如何使用 netlogo 计算补丁之间的边到边距离?使用“距离”函数,从块的中心计算块之间的距离。
非常感谢您的帮助。 祝你有美好的一天 海洋
【问题讨论】:
标签: netlogo
如何使用 netlogo 计算补丁之间的边到边距离?使用“距离”函数,从块的中心计算块之间的距离。
非常感谢您的帮助。 祝你有美好的一天 海洋
【问题讨论】:
标签: netlogo
如果您想测量补丁边缘之间的距离,可以在补丁边缘创建临时海龟并测量这些海龟之间的距离。我假设您想要位于两个补丁边缘的任意两个点之间的最短距离。在这种情况下,您可以在每个面片(四个角和四个中间边缘点)上创建 8 个海龟,并取任意一对海龟之间的最小距离。
to-report create-edge-turtles [ p ]
let edge-turtles nobody
ask p [
foreach sort neighbors [
sprout 1 [
face ?
fd distance ? / 2
set edge-turtles (turtle-set edge-turtles self)
]
]
]
report edge-turtles
end
to-report edge-distance [ patch-a patch-b ]
let edges-a create-edge-turtles patch-a
let edges-b create-edge-turtles patch-b
let result min [ min [ distance myself ] of edges-b ] of edges-a
ask edges-a [ die ]
ask edges-b [ die ]
report result
end
【讨论】:
sort neighbors?
ask neighbors 然后myself 而不是? 来引用每个邻居确实会更清晰、更快。
edges-a 乌龟,它计算该乌龟与所有edges-b 乌龟之间的距离。它采用这些距离中的最小距离并将其放入列表中。然后它需要所有这些最小距离中的最小距离。最后,这会为您提供最接近的一对 A-B 海龟之间的距离。