-
Notifications
You must be signed in to change notification settings - Fork 93
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
Optionally preserve ambertools temporary directory #1931
Comments
This is up to @j-wags but I'm a little down on this idea, or maybe I don't understand the motivation. Adding more and more keyword arguments to toolkit wrappers rapidly increases the complexity and makes the toolkit harder and harder to test and maintain, so IMHO there should be a high barrier to increasing API surface in these modules. This one in particular would probably only ever interact with If it's a matter of debugging installation issues, there are plenty of ways that can be handled externally to this. We have a script we sometimes use that reports information about the user's machine and setup, for example. If the installation issues stem from packaging ecosystems other than the one we support, then that's quickly of scope with what we handle. If there are modifications you want to make to how AmberTools is ultimately called, that can be done externally and the charges/conformers/etc. brought to the toolkit with the existing API. ( |
I see your point - I also don't think this belongs in the API. But each toolkit wrapper has a lot of unique (possibly private) functions outside the uniform API, so I think adding a toggle (e.g. property, possibly private) to Your suggestion to call AmberTools (or rather However, I still think that if a single python function call (in this case # Check to ensure charges were actually produced
if not os.path.exists(f"{tmpdir}/charges.txt"):
# TODO: copy files into local directory to aid debugging?
raise ChargeCalculationError(
"Antechamber/sqm partial charge calculation failed on "
"molecule {} (SMILES {})".format(
molecule.name, molecule.to_smiles()
)
) To me this looks like the issue was already on your table so I would just like to add my vote in favor 🙂 |
Agree. I think that adding a new attribute like I'd be happy to take a PR that does this! The test could run AM1BCC on something really small (like water) and ensure that some expected files are present in the specified directory. |
Thanks, I'll see what I can do about that PR. Since I haven't contributed before and am not familiar with the layout of the project and the requirements for PRs and tests, would you kindly point me towards the relevant guidelines? I've seen this: https://docs.openforcefield.org/projects/toolkit/en/stable/users/developing.html - is there anything more detailed? |
Sure! Unfortunately we don't have better resources on how to contribute, but a general outline for this one would be:
|
Is your feature request related to a problem? Please describe.
We've integrated part of the openff-toolkit into a closed-source project and so we need to distribute the AmberTools binaries separately to conform with the GPL. We had some issues when preparing the distribution (paths not set, missing libraries, etc.) and these were difficult to diagnose because the AmberTools wrapper deletes the temporary directory where antechamber is run regardless of whether the system calls were successful or not.
Describe the solution you'd like
There should be an option to always keep the temporary directory and ideally the default behavior should be to keep it when antechamber returns a non-zero exit code. Not sure what implementation best fits the philosophy but I suppose it can either be an optional argument in the public methods of the
AmberToolsToolkitWrapper
(but so far these have the same call signature for all children ofToolkitWrapper
), an extra method which configures the behavior, or some global variable.There are some existing TODOs in the
assign_partial_charges
code hinting that this is a known issue:# TODO: Add error handling if antechamber chokes
and
Describe alternatives you've considered
As a workaround, we copied the entire
ambertools_wrapper.py
into our project and changed theassign_partial_charges
method to always keep the temporary directory (diff below). We then manually re-register this patched version into theGLOBAL_TOOLKIT_REGISTRY
. This is not ideal since we would need to port upstream changes there (or fork the whole openff-toolkit project to change these few lines).The text was updated successfully, but these errors were encountered: