-
Notifications
You must be signed in to change notification settings - Fork 86
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
Implement 2D stepping stone model #2100
Comments
Hi @connor-french ! 👋 I think it should be fairly straightforward to implement in the stepping_stone_model Here's a first pass: import msprime
import numpy as np
def stepping_stone2d(initial_size, rate):
assert len(initial_size.shape) == 2
n, m = initial_size.shape
N = n * m
model = msprime.Demography.isolated_model(initial_size.reshape(N))
M = model.migration_matrix
for j in range(n):
for k in range(m):
index = j * m + k
model.populations[index].name = f"pop_{j}_{k}"
M[index, index - 1] = rate
M[index, (index + 1) % N] = rate
M[index, index - m] = rate
M[index, (index + m) % N] = rate
M[index - 1, index] = rate
M[(index + 1) % N, index] = rate
M[index - m, index] = rate
M[(index + m) % N, index] = rate
return model
model = stepping_stone2d(np.zeros((3, 3)) + 5, 1)
print(model) This gives us:
Does that look roughly right to you? There would be some tedious details around detail with the boundaries or not, but hey. |
@jeromekelleher Wow, this is great! It definitely gets the ball rolling, thank you. I didn't think it could be this straightforward. I agree, the fun part now is dealing with the edges. I appreciate the help! -Connor |
Great! If you get it working, then it would be great to add to the API. PR welcome! |
Hello all,
I am interested in simulating large "landscapes" of connected demes parameterized by species distribution models for neutral demographic inference in non-model species. A tough line I'm trying to balance in this type of analysis is realism (e.g. forward-time simulations in
SLiM
orSPLATCHE
) vs speed. I'm simulating long timescales (~20,000 generations) with large landscapes (~5x10^4 to 5x10^5 demes) and many individuals (10s of millions if taking a forward-time perspective), which makes forward simulations intractable when the final goal is to use simulation output for inference, where 10's of thousands of simulations are generally necessary. This is a problem faced by quite a few of my colleagues, who straddle the line between phylogeography and landscape genetics.I believe applying a 2D stepping stone model would facilitate this type of analysis, especially when combined with
msprime
's flexibility and speed. I'm aware of a recent step towards this through the gridCoal software, but it limits its output to coalescent times which, although useful, constrains its flexibility. I'm not suggesting something with the specific application domain ofgridCoal
, which contains functionality for pre-processing data for the type of data analysis I outlined above, but I think a Demography helper to setup 2D stepping stone models of arbitrary size would be a great addition to the "spatial genetics" toolkit.I appreciate the fantastic work you've done on this software!
Best,
Connor
The text was updated successfully, but these errors were encountered: