Skip to content

Commit

Permalink
breaking: change DeepTensor output dim from nsel_atoms to natoms
Browse files Browse the repository at this point in the history
Signed-off-by: Jinzhe Zeng <[email protected]>
  • Loading branch information
njzjz committed Mar 2, 2024
1 parent c61ba88 commit 8e0d396
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 20 deletions.
10 changes: 2 additions & 8 deletions deepmd/infer/deep_tensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,11 +104,8 @@ def eval(
aparam=aparam,
**kwargs,
)
sel_natoms = self._get_sel_natoms(atom_types[0])
if sel_natoms == 0:
sel_natoms = atom_types.shape[-1] # set to natoms
if atomic:
return results[self.output_tensor_name].reshape(nframes, sel_natoms, -1)
return results[self.output_tensor_name].reshape(nframes, natoms, -1)

Check warning on line 108 in deepmd/infer/deep_tensor.py

View check run for this annotation

Codecov / codecov/patch

deepmd/infer/deep_tensor.py#L108

Added line #L108 was not covered by tests
else:
return results[f"{self.output_tensor_name}_redu"].reshape(nframes, -1)

Expand Down Expand Up @@ -187,9 +184,6 @@ def eval_full(
**kwargs,
)

sel_natoms = self._get_sel_natoms(atom_types[0])
if sel_natoms == 0:
sel_natoms = atom_types.shape[-1] # set to natoms
energy = results[f"{self.output_tensor_name}_redu"].reshape(nframes, -1)
force = results[f"{self.output_tensor_name}_derv_r"].reshape(
nframes, -1, natoms, 3
Expand All @@ -199,7 +193,7 @@ def eval_full(
)
if atomic:
atomic_energy = results[self.output_tensor_name].reshape(
nframes, sel_natoms, -1
nframes, natoms, -1
)
atomic_virial = results[f"{self.output_tensor_name}_derv_c"].reshape(
nframes, -1, natoms, 9
Expand Down
12 changes: 12 additions & 0 deletions deepmd/tf/infer/deep_eval.py
Original file line number Diff line number Diff line change
Expand Up @@ -967,6 +967,18 @@ def _eval_inner(
v_out[ii] = self.reverse_map(
np.reshape(v_out[ii], odef_shape), sel_imap[:natoms_real]
)
if nloc_sel < nloc:

Check warning on line 970 in deepmd/tf/infer/deep_eval.py

View check run for this annotation

Codecov / codecov/patch

deepmd/tf/infer/deep_eval.py#L970

Added line #L970 was not covered by tests
# convert shape from nsel to nloc
# sel_atoms was applied before sort; see sort_input
# do not consider mixed_types here (as it is never supported)
sel_mask = np.isin(atom_types[0], self.sel_type)
out_nsel = v_out[ii]
out_nloc = np.zeros(

Check warning on line 976 in deepmd/tf/infer/deep_eval.py

View check run for this annotation

Codecov / codecov/patch

deepmd/tf/infer/deep_eval.py#L974-L976

Added lines #L974 - L976 were not covered by tests
(nframes, nloc, *out_nsel.shape[2:]), dtype=out_nsel.dtype
)
out_nloc[:, sel_mask] = out_nsel
v_out[ii] = out_nloc
odef_shape = self._get_output_shape(odef, nframes, nloc)

Check warning on line 981 in deepmd/tf/infer/deep_eval.py

View check run for this annotation

Codecov / codecov/patch

deepmd/tf/infer/deep_eval.py#L979-L981

Added lines #L979 - L981 were not covered by tests
v_out[ii] = np.reshape(v_out[ii], odef_shape)
elif odef.category in (
OutputVariableCategory.REDU,
Expand Down
21 changes: 15 additions & 6 deletions source/tests/tf/test_deepdipole.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ def setUp(self):
1.667785136187720063e00,
]
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
Expand All @@ -85,7 +86,7 @@ def test_attrs(self):
self.assertEqual(self.dp.get_sel_type(), [0])

def test_1frame_atm(self):
dd = self.dp.eval(self.coords, self.box, self.atype)
dd = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -97,7 +98,7 @@ def test_1frame_atm(self):
def test_2frame_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
dd = self.dp.eval(coords2, box2, self.atype)
dd = self.dp.eval(coords2, box2, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand Down Expand Up @@ -151,14 +152,15 @@ def setUp(self):
1.667798310054391e00,
]
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
os.remove("deepdipole.pb")
cls.dp = None

def test_1frame_atm(self):
dd = self.dp.eval(self.coords, None, self.atype)
dd = self.dp.eval(self.coords, None, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -168,7 +170,7 @@ def test_1frame_atm(self):
np.testing.assert_almost_equal(dd.ravel(), self.expected_d, default_places)

def test_1frame_atm_large_box(self):
dd = self.dp.eval(self.coords, self.box, self.atype)
dd = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -455,6 +457,7 @@ def setUp(self):
self.expected_gv = (
self.expected_v.reshape(1, self.nout, 6, 9).sum(-2).reshape(-1)
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
Expand All @@ -476,7 +479,7 @@ def test_1frame_old(self):
np.testing.assert_almost_equal(gt.ravel(), self.expected_gt, default_places)

def test_1frame_old_atm(self):
at = self.dp.eval(self.coords, self.box, self.atype)
at = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -488,7 +491,7 @@ def test_1frame_old_atm(self):
def test_2frame_old_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
at = self.dp.eval(coords2, box2, self.atype)
at = self.dp.eval(coords2, box2, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand All @@ -515,6 +518,7 @@ def test_1frame_full_atm(self):
gt, ff, vv, at, av = self.dp.eval_full(
self.coords, self.box, self.atype, atomic=True
)
at = at[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -550,6 +554,7 @@ def test_1frame_full_atm_shuffle(self):
self.atype[i_sf],
atomic=True,
)
at = at[:, self.sel_mask[i_sf]]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -617,6 +622,7 @@ def test_2frame_full_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
gt, ff, vv, at, av = self.dp.eval_full(coords2, box2, self.atype, atomic=True)
at = at[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand Down Expand Up @@ -949,6 +955,7 @@ def setUp(self):
)
fake_target = fake_target - 13 * np.rint(fake_target / 13)
self.target_t = fake_target.reshape(-1)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
Expand All @@ -966,6 +973,7 @@ def test_1frame_full_atm(self):
gt, ff, vv, at, av = self.dp.eval_full(
self.coords, self.box, self.atype, atomic=True
)
at = at[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -1001,6 +1009,7 @@ def test_1frame_full_atm_shuffle(self):
self.atype[i_sf],
atomic=True,
)
at = at[:, self.sel_mask[i_sf]]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down
18 changes: 12 additions & 6 deletions source/tests/tf/test_deeppolar.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ def setUp(self):
4.448255365635306879e-01,
]
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
Expand All @@ -95,7 +96,7 @@ def test_attrs(self):
self.assertEqual(self.dp.get_sel_type(), [0])

def test_1frame_atm(self):
dd = self.dp.eval(self.coords, self.box, self.atype)
dd = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -107,7 +108,7 @@ def test_1frame_atm(self):
def test_2frame_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
dd = self.dp.eval(coords2, box2, self.atype)
dd = self.dp.eval(coords2, box2, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand Down Expand Up @@ -173,14 +174,15 @@ def setUp(self):
4.382376148484938e-01,
]
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
os.remove("deeppolar.pb")
cls.dp = None

def test_1frame_atm(self):
dd = self.dp.eval(self.coords, None, self.atype)
dd = self.dp.eval(self.coords, None, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -190,7 +192,7 @@ def test_1frame_atm(self):
np.testing.assert_almost_equal(dd.ravel(), self.expected_d, default_places)

def test_1frame_atm_large_box(self):
dd = self.dp.eval(self.coords, self.box, self.atype)
dd = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -921,6 +923,7 @@ def setUp(self):
self.expected_gv = (
self.expected_v.reshape(1, self.nout, 6, 9).sum(-2).reshape(-1)
)
self.sel_mask = np.isin(self.atype, self.dp.get_sel_type())

@classmethod
def tearDownClass(cls):
Expand All @@ -942,7 +945,7 @@ def test_1frame_old(self):
np.testing.assert_almost_equal(gt.ravel(), self.expected_gt, default_places)

def test_1frame_old_atm(self):
at = self.dp.eval(self.coords, self.box, self.atype)
at = self.dp.eval(self.coords, self.box, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand All @@ -954,7 +957,7 @@ def test_1frame_old_atm(self):
def test_2frame_old_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
at = self.dp.eval(coords2, box2, self.atype)
at = self.dp.eval(coords2, box2, self.atype)[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand All @@ -981,6 +984,7 @@ def test_1frame_full_atm(self):
gt, ff, vv, at, av = self.dp.eval_full(
self.coords, self.box, self.atype, atomic=True
)
at = at[:, self.sel_mask]

# check shape of the returns
nframes = 1
Expand Down Expand Up @@ -1017,6 +1021,7 @@ def test_1frame_full_atm_shuffle(self):
self.atype[i_sf],
atomic=True,
)
at = at[:, self.sel_mask[i_sf]]
# check shape of the returns
nframes = 1
natoms = len(self.atype)
Expand Down Expand Up @@ -1054,6 +1059,7 @@ def test_2frame_full_atm(self):
coords2 = np.concatenate((self.coords, self.coords))
box2 = np.concatenate((self.box, self.box))
gt, ff, vv, at, av = self.dp.eval_full(coords2, box2, self.atype, atomic=True)
at = at[:, self.sel_mask]
# check shape of the returns
nframes = 2
natoms = len(self.atype)
Expand Down

0 comments on commit 8e0d396

Please sign in to comment.