Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Example for Poisson process state switching #64

Open
mountaindust opened this issue Oct 7, 2024 · 0 comments
Open

Example for Poisson process state switching #64

mountaindust opened this issue Oct 7, 2024 · 0 comments

Comments

@mountaindust
Copy link
Owner

There are many cases where an agent-based model includes attribute of state switches that occur as a Poisson process. An example is a locust model where locusts can be stationary, walking, or hopping. Another example is an intermittent search strategy where agents switch between ballistic motion and Brownian motion as they search for something. The typical thing to do in order to simulate such processes is to take dt small enough that one can assume a maximum of one state transition occurs during each time step (more than one transition is O(dt^2)). The time between transitions is then exponential and independent on each time step, and so it's easy to check if a transition occurs or not. If a transition does occur, the time of the transition can be used to split up the time step into two actions for that agent.

From the point of view of the Planktos framework, there is no reason that this cannot be done within the current capabilities of the code. Individual agent states can be stored in swarm.props, and a time history of that DataFrame (props_history) has been implemented in a branch. Growing lists of precise transition times could be stored on a per-agent basis in swarm.props, though it is worth noting that when a deep copy of the DataFrame is made to store in props_history, the process is not recursive. So the lists will be updated in the entire history each time it is updated in swarm.props. However, since the lists themselves are the history, this is more a feature than a bug because it saves memory. However, it should be pointed out in an example and/or documentation.

So, an example needs to be made demonstrating how one can implement some sort of basic, state-switching behavior using a Poisson process. I'm particularly thinking of an intermittent search strategy that could be used to simulate small organisms searching in flow.

mountaindust added a commit that referenced this issue Nov 15, 2024
This example is rather complicated, but it shows how agents can have
updating states where the updates can occur at any time.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant