Data Structure for Spatial Agent Based Modeling [c

2020-06-04 05:09发布

What are some good data structures for keeping track of agents in a two-dimensional, spatial simulation?

I've seen some references to quadtrees (which I understand) and kd-trees (which I don't understand very well).

I'm looking for something through which an agent can efficiently say, "I know my location, and I would like to know which agents are near me (within a certain radius of myself)."

Examples (pseudo-code is fine) would be greatly appreciated.

I'm working in Java.

2条回答
迷人小祖宗
2楼-- · 2020-06-04 05:30

I have found something called a Bucket PR Quadtree.

查看更多
我想做一个坏孩纸
3楼-- · 2020-06-04 05:37

Well, I'm not sure exactly how it is implemented, but the MASON toolkit uses a discretization algorithm that places agents that are close to one another in the same "bucket" of a hash table. It makes for very fast lookups, as only a few of these buckets have to be checked for each query.

The best thing for you is probably to take a look at the source code here: http://code.google.com/p/mason/source/browse/trunk/mason/sim/field/continuous/Continuous2D.java?r=529

查看更多
登录 后发表回答