Skip to content

Commit

Permalink
Merge pull request #27 from chemle/feature_calculator_refactor
Browse files Browse the repository at this point in the history
Refactor calculator to use EMLE Torch module
  • Loading branch information
lohedges authored Oct 17, 2024
2 parents f60605a + 925b9e7 commit 9fbb809
Show file tree
Hide file tree
Showing 7 changed files with 402 additions and 945 deletions.
12 changes: 12 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,18 @@ To stop the server:
emle-stop
```

## NNPOps

The ``EMLE`` model uses Atomic Environment Vectors (AEVs) for the calculation of
the electrostatic embedding energy. For performance, it is desirable to use
the optimised symmetry functions provided by the [NNPOps](https://github.com/openmm/NNPOps)
package. This requires a *static* compute graph, so needs to know the atomic
numbers for the atoms in the QM region in advance. These can be specified using
the ``EMLE_ATOMIC_NUMBERS`` environment variable, or the ``--atomic-numbers``
command-line argument when launching the server. This option should only be
used if the QM region is fixed, i.e. the atoms in the QM region do not change
each time the calculator is called.

## Backends

The embedding method relies on in vacuo energies and gradients, to which
Expand Down
41 changes: 41 additions & 0 deletions bin/emle-server
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ except:
species = None
method = os.getenv("EMLE_METHOD")
alpha_mode = os.getenv("EMLE_ALPHA_MODE")
atomic_numbers = os.getenv("EMLE_ATOMIC_NUMBERS")
mm_charges = os.getenv("EMLE_MM_CHARGES")
try:
num_clients = int(os.getenv("EMLE_NUM_CLIENTS"))
Expand Down Expand Up @@ -136,6 +137,7 @@ env = {
"species": species,
"method": method,
"alpha_mode": alpha_mode,
"atomic_numbers": atomic_numbers,
"mm_charges": mm_charges,
"num_clients": num_clients,
"backend": backend,
Expand Down Expand Up @@ -210,6 +212,13 @@ parser.add_argument(
choices=["species", "reference"],
required=False,
)
parser.add_argument(
"--atomic-numbers",
type=str,
nargs="*",
help="the atomic numbers of the atoms in the qm region",
required=False,
)
parser.add_argument(
"--mm-charges",
type=str,
Expand Down Expand Up @@ -480,6 +489,38 @@ if set_lambda_interpolate is not None:

# Handle special case formatting for environment variables.

# Validate the atomic numbers.
if args["atomic_numbers"] is not None:
# Whether we are parsing a list of atomic numbers, rather than a file.
is_list = False

if isinstance(args["atomic_numbers"], str):
# If this isn't a path to a file, try splitting on commas.
if not os.path.isfile(args["atomic_numbers"]) or not os.path.isfile(
os.path.abspath(args["atomic_numbers"])
):
try:
args["atomic_numbers"] = args["atomic_numbers"].split(",")
is_list = True
except:
raise ValueError(
"Unable to parse EMLE_ATOMIC_NUMBERS environment variable as a comma-separated list of ints"
)

# A single entry list is assumed to be the path to a file.
elif isinstance(args["atomic_numbers"], list):
if len(args["atomic_numbers"]) == 1:
args["atomic_numbers"] = args["atomic_numbers"][0]
else:
is_list = True

# Try to parse lists of atomic numbers into a list of ints.
if is_list:
try:
args["atomic_numbers"] = [int(x) for x in args["atomic_numbers"]]
except:
raise TypeError("Unable to parse atomic numbers as a list of ints")

# Validate the MM charges.
if args["mm_charges"] is None:
if method == "mm":
Expand Down
Loading

0 comments on commit 9fbb809

Please sign in to comment.