-
Notifications
You must be signed in to change notification settings - Fork 0
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
Unexpected behaviour at high density #22
Comments
There is a good chance that the voxelization procedure for structures is not working as expected in single-bead cases. From reading this, and having encountered the problem at some time ago (though I thought it had resolved itself), it may be the case that In other words, for single-bead structures, the voxelization may just be ... nothing. Or perhaps a single-voxel space without any filled voxels. At low densities, this will not be a problem, simply due to the very low probability of two single-bead structures being placed in close-enough proximity to hit each other. But when the density becomes large, there will be instances (perhaps only a few, that would be enough to wreak havoc) where beads are placed in exactly the same location (due to the voxelized discretization of positions). So, when I come around to this (or somebody else, feel free), I will start out testing this hypothesis by investigating |
In any case, that is something good to check. However, I don't think that is the entire problem. When I try to pack a larger molecule like FAD in a high density, overlaps still occur in the system. The curious thing is that for macromolecules like proteins, these overlaps don't appear to happen (even at high concentrations). |
Right, that really is very strange to me, how larger structures do not seem to cause this problem. For now, I have added further assertions and checks to
An assert that was already in place checked against the When I run this against my test cases, and against a new single-bead test case (ALA.gro), none of these assertions are hit. This shows that my initial hypothesis was incorrect. Next stepsSince it also occurs for larger molecules, it becomes more likely that the actual voxelization strategy is insufficient. (Beads can be right on the edge of a voxel yet only one voxel is filled in even though filling in 2 or up to 8 would be most appropriate.) To investigate this hypothesis, we could try a very conservative voxelization scheme, that draws 8 voxels around each point. This is not necessary in production, but it can be a useful check. If the problem goes away, that suggests our currect voxelization strategy is in fact at fault. @jan-stevens, if you have a minute, could you give me the necessary files to replicate this issue:
You can just drop the files into this issue or send me the path to the file server. Thanks! |
The following input results in no placed molecules, which is unexpected behaviour. However, if I reduce the "number" of molecules I ask bentopy to place by a factor of
10
, then all the10000 ALA
are placed correctly.I think this problem arises when you ask to place more molecules (in this case single beads) than fit in the 3D voxel space.
The text was updated successfully, but these errors were encountered: