- 
                Notifications
    You must be signed in to change notification settings 
- Fork 127
Molecule for forcefield #1127
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
base: main
Are you sure you want to change the base?
Molecule for forcefield #1127
Conversation
bfbb00f    to
    6e8c8e0      
    Compare
  
    | Dear @JaGeo, can you help take a look at this PR at your convenience? | 
| Thank you! I am tagging @utf and @esoteric-ephemera as well as we have to decide how to handle molecular and structural outputs in general. | 
| Here is my understanding of how to handle molecular and structural outputs. I saw in atomate2, two approaches exist. In FHI-aims, and cp2k engines, their taskdoc inherents from both StructureMetadata, MoleculeMetadata and the output structure takes the same type of the input structure. While, in ase engine, the implementation is to output StructureTaskDoc or MoleculeTaskDoc based on the input structure. Since, the forcefield inherents mostly from ase, I picked the second approach. The FHI-aims/cp2k approach is cleaner in software engineering. However, StructureMetadata and MoleculeMetadata seems to have different symmetry types. I am not sure whether a conflict will happen is symmetry is used. My understanding is to make them fully compatible with each other would require a rework at the emmet-core level. | 
| Hey @yaoyi92, thanks for making this extension to the forcefields! The split that occurs for  I would avoid merging the  To @JaGeo's point: we have too many disparate schemas for each code, and it would likely be best to have them originate with the same base document models. Maybe we should start an issue for this? | 
| @esoteric-ephemera I agree with your points and I also believe we should think about the task docs more broadly. | 
| structure: Molecule | Structure, | ||
| prev_dir: str | Path | None = None, | ||
| ) -> ForceFieldTaskDocument: | ||
| ) -> ForceFieldStructureTaskDocument | ForceFieldMoleculeTaskDocument: | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure why this isn't done for all other ForceFieldMakers? There, I only see a replacement with ForceFieldStructureTaskDocument.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Which makers are you referring to? I only found two makers that have an explicit make function, ForceFieldRelaxMaker and ForceFieldMDMaker. It seems, the other makers inherent from these two.
| @classmethod | ||
| def from_ase_task_doc( | ||
| cls, ase_task_doc: AseTaskDoc, **task_document_kwargs | ||
| ) -> AseStructureTaskDoc: | ||
| """Create an AseStructureTaskDoc for a task that has ASE-compatible outputs. | ||
| Parameters | ||
| ---------- | ||
| ase_task_doc : AseTaskDoc | ||
| Task doc for the calculation | ||
| task_document_kwargs : dict | ||
| Additional keyword args passed to :obj:`.AseStructureTaskDoc()`. | ||
| """ | ||
| task_document_kwargs.update( | ||
| {k: getattr(ase_task_doc, k) for k in _task_doc_translation_keys}, | ||
| structure=ase_task_doc.mol_or_struct, | ||
| ) | ||
| return cls.from_structure( | ||
| meta_structure=ase_task_doc.mol_or_struct, **task_document_kwargs | ||
| ) | ||
|  | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is not needed anymore?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This function is only called from the forcefields schemas.
I moved this function to src/atomate2/forcefields/schemas.py.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see. However, it is a general static method. Why not keeping it here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have added the method back in this commit. 7b32166
6e8c8e0    to
    7b32166      
    Compare
  
            
          
                src/atomate2/forcefields/jobs.py
              
                Outdated
          
        
      | A list of tags for the task. | ||
| task_document_kwargs : dict (deprecated) | ||
| Additional keyword args passed to :obj:`.ForceFieldTaskDocument()`. | ||
| Additional keyword args passed to :obj:`.ForceFieldStructureTaskDocument()`. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| Additional keyword args passed to :obj:`.ForceFieldStructureTaskDocument()`. | |
| Additional keyword args passed to :obj:`.ForceFieldStructureTaskDocument()` or :obj:`.ForceFieldMoleculeTaskDocument()`. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, I updated these descriptions in 4e9f061.
7b32166    to
    4e9f061      
    Compare
  
    | I am happy to merge after these changes. I just fear we will have a CI failure now. mp-api and monty need to be updated | 
4e9f061    to
    d8592fd      
    Compare
  
    | Dear @JaGeo, just check, do we have the CI issue fixed? I think this pull request is read to merge. | 
| Thank you. If the tests workflow run through, it will get merged! | 
| @yaoyi92 still some failures, unfortunately. | 
| It seems my modification is incompatible with some new commits, let me see what I can do. | 
d1da370    to
    2f5a3a1      
    Compare
  
    | I fixed the incompatibility issue, how ever it seems there is still some error related to this merge of version bump of mdanalysis #1176. | 
…ent based on the input type of mol_or_struct. change name ForceFieldTaskDocument => ForceFieldStructureTaskDocument output ForceFieldStructureTaskDocument or ForceFieldMoleculeTaskDocument based on type of mol_or_struct update ForceFieldTaskDocument => ForceFieldStructureTaskDocument in the tests import Union from typing include Union in forcefield/md.py take the suggestions from the formatter take ruff's suggestions try again with ruff format ruff format again try again ruff ruff again fix the mypy error Take inputs of both Molecule and Structure update docstring add molecule test for forcefield
55fffef    to
    95fd127      
    Compare
  
    | @yaoyi92 hey, do you still want to get it merged? Sorry for not following up! | 
| 
 Yes, if the CI works fine now. I can try to merge it. | 
| Looks like all checks passed. Can you help merge it @JaGeo ? | 
Summary
Discussed in #1123. Following the same strategy as ase tasks, output ForceFieldStructureTaskDocument or ForceFieldMoleculeTaskDocument based on the input type of mol_or_struct.
Checklist
Work-in-progress pull requests are encouraged, but please put [WIP] in the pull request
title.
Before a pull request can be merged, the following items must be checked:
The easiest way to handle this is to run the following in the correct sequence on
your local machine. Start with running
ruffandruff formaton your new code. This willautomatically reformat your code to PEP8 conventions and fix many linting issues.
Run ruff on your code.
type check your code.
Note that the CI system will run all the above checks. But it will be much more
efficient if you already fix most errors prior to submitting the PR. It is highly
recommended that you use the pre-commit hook provided in the repository. Simply run
pre-commit installand a check will be run prior to allowing commits.