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

Can compute parameter derivatives #143

Merged
merged 6 commits into from
May 22, 2024
Merged

Conversation

peastman
Copy link
Member

Implements #141.

@RaulPPelaez
Copy link
Contributor

We really need to fix the CI...

void TorchForce::addEnergyParameterDerivative(const string& name) {
for (int i = 0; i < globalParameters.size(); i++)
if (name == globalParameters[i].name) {
energyParameterDerivatives.push_back(i);
Copy link
Contributor

Choose a reason for hiding this comment

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

I have seen this in other parts of OpenMM, what happens if I call this function twice with the same name? Is that handled somewhere before or after this?

torch::Tensor& forceTensor) {
torch::Tensor& forceTensor, map<string, torch::Tensor>& derivInputs) {
vector<torch::Tensor> gradInputs;
if (!outputsForces)
Copy link
Contributor

Choose a reason for hiding this comment

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

This should be !outputsForces && includeForces right?

@RaulPPelaez
Copy link
Contributor

There should also be a Python side test. Take this one if you'd like:
https://github.com/openmm/openmm-torch/blob/4c9b5e509d15ce52db7600f7538fbe66538c1c2a/python/tests/TestParameterDerivatives.py

BTW, this is still a problem. I do not think OpenMM-Torch can do anything about it, but perhaps there is a way to detect it and provide a useful message?

@peastman
Copy link
Member Author

Thanks for the comments. It turned out that what I had written didn't work with CUDA graphs. I restructured it to handle the input tensors in a different way and made the test case run both with and without graphs. Can you see if it looks better now?

@peastman
Copy link
Member Author

Is this ok to merge? Getting CI working is its own major project. I'm working on that in another PR.

@RaulPPelaez RaulPPelaez merged commit e17b5d0 into openmm:master May 22, 2024
1 of 4 checks passed
@peastman peastman deleted the derivatives branch May 22, 2024 15:36
@RaulPPelaez RaulPPelaez mentioned this pull request Aug 28, 2024
@peastman peastman mentioned this pull request Nov 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants