-
Notifications
You must be signed in to change notification settings - Fork 668
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
Implementation of Water Selection token #4839
Comments
Which water resnames would you use to detect water? |
Also, note that ag = u.select_atoms("protein and water") will likely give you an empty atomgroup because I don't know of any molecules that are water and protein — did you mean |
From the ones that I saw mostly it would be at least those are the ones that come up quite often, although I didn't encounter 'HHO' or 'OHH' that often myself, some https://github.com/KurtzmanLab/SSTMap/blob/master/sstmap/water_analysis.py Other resname suggestions are also welcome, if I didn't cover any important ones :) |
Yes my bad, would be or, didn't notice that mistake, my bad :( |
So I will start by saying that I recognise this to be a useful thing for folks that aren't power users of MDAnalysis. Generally I don't like how these keywords obfuscate what actually happens. I.e. I know plenty of time I've sat down with a student and gone "are you sure your residues actually got selected with the protein keyword", just for them to realise that maybe they had a special residue that wasn't in the standard list. My personal take is that, like guessing by default, I would love to see keywords go away because they enable bad mistakes. That being said, I'll be honest and say that my opinion really isn't that strong. If it helps folks do what they need then I could live with it. |
True, I agree that it can lead to errors, since the user would rely more on the token, similar as you mention the cases with Basically it would be correct vs practical and both have good points, where the correct way would be not having them, so that such errors do not happen and practical is with the Although I could imagine moving completly away from keywords now would be tricky, since MDAnalysis users got used to the I will then let you @IAlibay and @orbeckst and the other coredevs decide what the best option is :) |
I am in favor of convenience selectors — I'd absolutely hate having to select proteins by index or chain; a selection keyword for water (and perhaps lipid #2082 (PR #4302) and carbohydrate #4563) seem reasonable. I feel that this is one of the few occasions where convenience is quite important.
That's fair, I'd just like to have my cake and eat it, too. 🍰 Perhaps we should be thinking along guesser contexts to set what these selections match. The downside is that MDA will behave differently depending on the context in which a universe was loaded but I think that will already be effectively happening with guessers. |
True, than I will start working on the PR. @orbeckst As for #4563 there I mentioned the possible problem in PR #4790 that due to it having a lot of different resnames Now that I see since I already started doing keywords with the |
Is your feature request related to a problem?
No, not directly. It has similarities to #4563 from the sense, that there was a discussion about selection of
GLYCAM and sugars, which makes sense. An additional feature, that could improve life would be a water
selection, thus a user could use a
water
token inselect_atoms()
to obtain water as anAtomGroup
.Describe the solution you'd like
Create a class
WaterSelection
incore/selection.py
, which would have the tokenwater
andadd all possible water
resnames
to allow a selection throughselect_atoms()
.which would create something like this:
Describe alternatives you've considered
Leave it as currently is and select the water via it's resname
Additional context
As for additional context, currently I am helping in implementing
waterbridge
interaction recognition inProLIF and there I noticed, that for the water selection the resname of the water is written out. Yes, in theory the user would
know the water
resname
and could write it out always, the main reason for this PR would be a quality of life improvement +in the cases where you have multiple Topologies with different water
resnames
it could be easier to select them through anuniversal
water
token.I would be able to do the implementation pretty quickly, but would need an opinion how reasonable it is and how much
everyone agrees that this would be a reasonable quality of life improvement for users.
The text was updated successfully, but these errors were encountered: