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

issue #2469 #2614

Merged
merged 37 commits into from
Mar 28, 2020
Merged

issue #2469 #2614

merged 37 commits into from
Mar 28, 2020

Conversation

siddharthjain1611
Copy link
Member

@siddharthjain1611 siddharthjain1611 commented Mar 11, 2020

Fixes #2469

Changes made in this Pull Request:

PR Checklist

  • Tests?
  • Docs?
  • CHANGELOG updated?
  • Issue raised/referenced?

@siddharthjain1611 siddharthjain1611 mentioned this pull request Mar 11, 2020
4 tasks
Copy link
Member

@orbeckst orbeckst left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How do your changes address the points raised in #2469 ?

There's @lilyminium 's #2469 (comment) and talk about doc changes. Can you explain a bit more your approach?

@siddharthjain1611
Copy link
Member Author

How do your changes address the points raised in #2469 ?

There's @lilyminium 's #2469 (comment) and talk about doc changes. Can you explain a bit more your approach?

I tried to avoid the missing attribute error using a warning. I really couldn't understand why there's a need straight away put match_atoms=True. Please help me understand this.

@orbeckst
Copy link
Member

@lilyminium could you provide a quick comment if you have time?

@PicoCentauri do you have time to look after this PR as the main reviewer?

Copy link
Member

@lilyminium lilyminium left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for looking at this @siddharthjain1611! match_atoms is currently set to True by default because that matches the historical behaviour of the class before match_atoms was added as a keyword. It checks that the alignment selection atoms have similar element-wise masses, to make sure that you're not accidentally doing something weird, like aligning your molecule backwards.

package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
@PicoCentauri
Copy link
Contributor

@orbeckst Yes I have time to do the main review.

Copy link
Contributor

@PicoCentauri PicoCentauri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree with @lilyminium. It is probably better to add if not hasattr(ag1, 'masses') and hasattr(ag2, 'masses') directly after if math_atoms to check wether both groups contain masses. If not you can warn the user saying that "Atoms could not be matched since they don't contain masses."

Copy link
Contributor

@PicoCentauri PicoCentauri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good!
Now please also add a test to the TestAlign class. You can use a with statement together with pytest to test your warning with pytest.warns():.

@siddharthjain1611
Copy link
Member Author

Looks good!
Now please also add a test to the TestAlign class. You can use a with statement together with pytest to test your warning with pytest.warns():.

Okay sir, I'll do that and get back to you as soon as possible.

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 15, 2020

Looks good!
Now please also add a test to the TestAlign class. You can use a with statement together with pytest to test your warning with pytest.warns():.

Sir, why are these tests being added to Test Align class and not Test Matching Atoms class.

Edit: Which new function should be created or referenced. What should be the contents for the same?

@PicoCentauri
Copy link
Contributor

You are right it should be in TestGetMatchingAtoms 🙂.

Create a function like test_no_atom_masses similar to the test_match method where you create a universe without masses. Something like

reference = make_Universe()
align.get_matching_atoms(reference.atoms, reference.atoms)

should do the job.

package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
testsuite/MDAnalysisTests/analysis/test_align.py Outdated Show resolved Hide resolved
@siddharthjain1611
Copy link
Member Author

@PicoCentauri Sir, Please find some time to review my PR again.

@PicoCentauri
Copy link
Contributor

Hey @siddharthjain1611 sorry for the delay! I will review your PR later today. For now try to check why all tests are failing.

@siddharthjain1611
Copy link
Member Author

Hey @siddharthjain1611 sorry for the delay! I will review your PR later today. For now try to check why all tests are failing.

Sure, Sir

Copy link
Contributor

@PicoCentauri PicoCentauri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks quite good now. Just a few things:

  • Why do you need the testsuite/MDAnalysisTests/data/rmsfit_adk_dims.dcd? It is not used in any of your tests.

  • Due to your fix the test_fit_translation_no_masses is failing since fit_translation now raises an ValueError in line 104 rather an AttributeError in line 102. For now I would just change AttributeError by ValueError in the test.

  • In addition add yourself the the AUTHORS and add your changes to the CHANGELOG.

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 19, 2020

Looks quite good now. Just a few things:

  • Why do you need the testsuite/MDAnalysisTests/data/rmsfit_adk_dims.dcd? It is not used in any of your tests.
  • Due to your fix the test_fit_translation_no_masses is failing since fit_translation now raises an ValueError in line 104 rather an AttributeError in line 102. For now I would just change AttributeError by ValueError in the test.
  • In addition add yourself the the AUTHORS and add your changes to the CHANGELOG.

I'll delete the file testsuite/MDAnalysisTests/data/rmsfit_adk_dims.dcd. And I'll add myself to authors and will also edit the changelog. Also, wondering sir why does creating a universe without masses raises an error? Shouldn't it be allowed?

@orbeckst orbeckst dismissed their stale review March 20, 2020 00:30

My review was a blocking comment until the PR was more substantial. Other revieers have taken over.

@siddharthjain1611
Copy link
Member Author

@orbeckst Sir, is the pr not appropriate? Does it need more work?

@PicoCentauri
Copy link
Contributor

Also, wondering sir why does creating a universe without masses raises an error? Shouldn't it be allowed?

Your are right. The creation is valid but the method fit_translation() with the option weights="mass" requires an universe witth masses and therefore should raise an error if they don't exist.

@siddharthjain1611
Copy link
Member Author

Is this pr ready for merging?

@PicoCentauri
Copy link
Contributor

First you have to fix the test_fit_translation_no_masses test. If the tests are not passing we can not merge.

@siddharthjain1611
Copy link
Member Author

First you have to fix the test_fit_translation_no_masses test. If the tests are not passing we can not merge.

I'll fix that as soon as possible.

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 20, 2020

@PicoCentauri Sir, For that problem, I feel setting the mass to 1 solve the problem.
Is below code correct:
with pytest.raises(ValueError):
fit_translation(test_u, ref_u, weights=1)(ts)

@PicoCentauri
Copy link
Contributor

You really want that the test raises an error here. The purpose of tests is not only to check wether code works but also to check that it raises errors under certain conditions.

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 20, 2020

You really want that the test raises an error here. The purpose of tests is not only to check wether code works but also to check that it raises errors under certain conditions.

Okay sir, would just a warning be sufficient?

Copy link
Contributor

@PicoCentauri PicoCentauri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I checked our changes locally and if you do these changes it should work out

errmsg = ("Failed to automatically find matching atoms: created empty selections. " +
"Try to improve your selections for mobile and reference.")
errmsg = ("Failed to automatically find matching atoms: created empty selections. "
"Try to improve your selections for mobile and reference.")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is still to be fixed

package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
package/MDAnalysis/transformations/fit.py Outdated Show resolved Hide resolved
@siddharthjain1611
Copy link
Member Author

@PicoCentauri @lilyminium Please review this.

Copy link
Contributor

@PicoCentauri PicoCentauri left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very good. Just remove the spaces and I am happy

package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
package/MDAnalysis/analysis/align.py Outdated Show resolved Hide resolved
@siddharthjain1611
Copy link
Member Author

@PicoCentauri Sir, I think the spaces look fine now, Please find some time to have a look :)

logger.error(errmsg)
raise SelectionError(errmsg)
if (not hasattr(ag1, 'masses') or not hasattr(ag2, 'masses')):
# # WARNING:
Copy link
Contributor

@PicoCentauri PicoCentauri Mar 27, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Finally, remove this superfluous comment if you want.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I saw a comment of this kind somewhere else, therefore I wrote it.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Having the comment there is not bad but I would say not needed because the code itself clearly says "warning".

However, I see a PEP8 issue below...

Copy link
Member

@lilyminium lilyminium left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good, @siddharthjain1611, nearly there. Please remove rmsfit_adk_dims.dcd also. Thank you!

package/MDAnalysis/analysis/rms.py Outdated Show resolved Hide resolved
testsuite/MDAnalysisTests/analysis/test_align.py Outdated Show resolved Hide resolved
testsuite/MDAnalysisTests/analysis/test_rms.py Outdated Show resolved Hide resolved
@orbeckst
Copy link
Member

@PicoCentauri – you have the power to dismiss @lilyminium 's request if you think that her points have been addressed and if she doesn't have the time to look at the PR. If you do this, you just write a short justification message and go ahead.

@orbeckst
Copy link
Member

Oops – apparently @lilyminium commented 30 seconds ago.... ignore my previous comment ;-).

@lilyminium
Copy link
Member

Thanks @siddharthjain1611, I'm happy with this but let's wait for Travis to go green. Don't forget to remove rmsfit_adk_dims.dcd :-)

@siddharthjain1611
Copy link
Member Author

Thanks @siddharthjain1611, I'm happy with this but let's wait for Travis to go green. Don't forget to remove rmsfit_adk_dims.dcd :-)

Sorry, ma'am wasn't able to find that file in pr. I think I already discarded that in my system, but even if by mistake I pushed it. Please do point it out. I'll happily do it.

@lilyminium
Copy link
Member

@siddharthjain1611
Copy link
Member Author

Copy link
Member

@lilyminium lilyminium left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Awesome, looks good to me and thanks for the contribution! I'll let @PicoCentauri do the honours.

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 28, 2020

Awesome, looks good to me and thanks for the contribution! I'll let @PicoCentauri do the honours.

Thank you, ma'am. Got to learn a lot from both of you.
@PicoCentauri

@siddharthjain1611
Copy link
Member Author

siddharthjain1611 commented Mar 28, 2020

@PicoCentauri @lilyminium is the PR ready for merging?

@lilyminium lilyminium merged commit 60eb9d8 into MDAnalysis:develop Mar 28, 2020
@lilyminium
Copy link
Member

@PicoCentauri seems to be busy so I've just merged it now. Congratulations on your first contribution!

IAlibay added a commit that referenced this pull request Dec 18, 2023
orbeckst added a commit that referenced this pull request Dec 21, 2023
Update of AUTHORS and CHANGELOG with inferred author contributions.

*  Removed duplicate mattwthompson in 0.20.0 changelog entry.: mattwthompson was placed twice by accident, this removes this duplication.

* Addition of missing authors.

   An retrospective analysis of the authors found via `git shortlog -s -n --email --branches="develop"` found several commits by authors which were not present in the `AUTHORS.md` file.

    - Zhenbo Li: commited via PR: Started tests for gnm. #803 and Make Travis run tests on OSX. #771,
    - Jenna M. Swarthout via PR Update CoC according to suggestions from current CoC committee #4289 and Point to new reporting form link (owned by [email protected]) #4298,
    - Bradley Dice via PR   Fix GSD Windows compatibility #2384 ,
    - David Minh via PR #2668

   There seemed to be no indications in the above mentioned PRs that the author did not want to be in the authors file, it looks like it was just forgotten.

* Addition of missing entries from the changelog

   Continued cross referencing of the git shortlog output but also accounting for the changelog identified several individuals that had not been included in the changelog entries for the release they contributed under. They were added to the relevant entry of the changelog based on the merge commit date.

   Please note that for Tone Bengsten, we a) had no github handle (so they were assigned @tbengtsen), and b) no specific commit. Given we know that this individual was including alongside the encore merge, they were assigned to the 0.16.0 release.

* Update CHANGELOG
* PR #1218
* PR #1284 and #1408
* PR #4109
* based on git history
* PRs #803 and #771 (author addition, changelog addition)
* PR #2255 and #2221
* PR #1225
* PR #4289 and #4298
* PR #4031
* PR #4085
* PR #3635
* PR #2356
* PR #2559
* No GH handle - Encore author addition @tbengtsen
* PR #4184
* PR #2614
* PR #2219
* PR #2384
* PR #2668
* Add missing entry for Jenna

Thanks to @fiona-naughton for helping out with digging into this data :)

Co-authored-by: Fiona Naughton <[email protected]>
Co-authored-by: Oliver Beckstein <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Proper error message and suggestion for AlignTraj on trajectory without mass
5 participants