add labelmap tests for bonds/angles/dihedrals/impropers

This commit is contained in:
Axel Kohlmeyer
2022-09-04 17:51:06 -04:00
parent c7ab8e160a
commit f956530f0d

View File

@ -16,6 +16,7 @@
#include "atom.h"
#include "compute.h"
#include "domain.h"
#include "info.h"
#include "label_map.h"
#include "math_const.h"
#include "modify.h"
@ -35,13 +36,13 @@ using ::testing::ExitedWithCode;
using ::testing::StrEq;
namespace LAMMPS_NS {
class SetTest : public LAMMPSTest {
class LabelMapTest : public LAMMPSTest {
protected:
Atom *atom;
Domain *domain;
void SetUp() override
{
testbinary = "SetTest";
testbinary = "LabelMapTest";
args = {"-log", "none", "-echo", "screen", "-nocite", "-v", "num", "1"};
LAMMPSTest::SetUp();
atom = lmp->atom;
@ -51,10 +52,10 @@ protected:
void TearDown() override { LAMMPSTest::TearDown(); }
};
TEST_F(SetTest, NoBoxAtoms)
TEST_F(LabelMapTest, Atoms)
{
ASSERT_EQ(atom->natoms, 0);
ASSERT_EQ(domain->box_exist, 0);
EXPECT_EQ(atom->natoms, 0);
EXPECT_EQ(domain->box_exist, 0);
ASSERT_EQ(atom->lmap, nullptr);
TEST_FAILURE(".*ERROR: Labelmap command before simulation box is.*",
command("labelmap atom 3 C1"););
@ -70,22 +71,23 @@ TEST_F(SetTest, NoBoxAtoms)
command("mass H1 4.0");
END_HIDE_OUTPUT();
ASSERT_NE(atom->lmap, nullptr);
ASSERT_FALSE(atom->lmap->is_complete(Atom::ATOM));
ASSERT_DOUBLE_EQ(atom->mass[1], 1.0);
ASSERT_DOUBLE_EQ(atom->mass[2], 2.0);
ASSERT_DOUBLE_EQ(atom->mass[3], 3.0);
ASSERT_DOUBLE_EQ(atom->mass[4], 4.0);
EXPECT_FALSE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_DOUBLE_EQ(atom->mass[1], 1.0);
EXPECT_DOUBLE_EQ(atom->mass[2], 2.0);
EXPECT_DOUBLE_EQ(atom->mass[3], 3.0);
EXPECT_DOUBLE_EQ(atom->mass[4], 4.0);
BEGIN_HIDE_OUTPUT();
command("labelmap atom 1 C1 2 N2 3 ' O#' 1 C1 4 H# 2 N3"); // second '#' starts comment
command("mass \"O#\" 10.0");
END_HIDE_OUTPUT();
ASSERT_TRUE(atom->lmap->is_complete(Atom::ATOM));
ASSERT_EQ(atom->lmap->find("C1", Atom::ATOM), 1);
ASSERT_EQ(atom->lmap->find("N2", Atom::ATOM), 2);
ASSERT_EQ(atom->lmap->find("O#", Atom::ATOM), 3);
ASSERT_EQ(atom->lmap->find("H", Atom::ATOM), 4);
ASSERT_DOUBLE_EQ(atom->mass[3], 10.0);
EXPECT_TRUE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_EQ(atom->lmap->find("C1", Atom::ATOM), 1);
EXPECT_EQ(atom->lmap->find("N2", Atom::ATOM), 2);
EXPECT_EQ(atom->lmap->find("O#", Atom::ATOM), 3);
EXPECT_EQ(atom->lmap->find("H", Atom::ATOM), 4);
EXPECT_EQ(atom->lmap->find("X", Atom::ATOM), -1);
EXPECT_DOUBLE_EQ(atom->mass[3], 10.0);
TEST_FAILURE(".*ERROR: Labelmap atom type 0 must be within 1-4.*",
command("labelmap atom 0 C1"););
@ -132,21 +134,110 @@ TEST_F(SetTest, NoBoxAtoms)
command("labelmap clear");
command("labelmap atom 3 C1 2 N2");
END_HIDE_OUTPUT();
ASSERT_FALSE(atom->lmap->is_complete(Atom::ATOM));
ASSERT_EQ(atom->lmap->find("C1", Atom::ATOM), 3);
ASSERT_EQ(atom->lmap->find("N2", Atom::ATOM), 2);
EXPECT_FALSE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_EQ(atom->lmap->find("C1", Atom::ATOM), 3);
EXPECT_EQ(atom->lmap->find("N2", Atom::ATOM), 2);
BEGIN_HIDE_OUTPUT();
command("labelmap clear");
command("labelmap atom 1 \"C1'\" 2 'C2\"' 3 \"\"\"C1'-C2\" \"\"\" 4 \"\"\" C2\"-C1'\"\"\"");
END_HIDE_OUTPUT();
ASSERT_TRUE(atom->lmap->is_complete(Atom::ATOM));
ASSERT_EQ(atom->lmap->find("C1'", Atom::ATOM), 1);
ASSERT_EQ(atom->lmap->find("C2\"", Atom::ATOM), 2);
ASSERT_EQ(atom->lmap->find("C1'-C2\"", Atom::ATOM), 3);
ASSERT_EQ(atom->lmap->find("C2\"-C1'", Atom::ATOM), 4);
EXPECT_TRUE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_EQ(atom->lmap->find("C1'", Atom::ATOM), 1);
EXPECT_EQ(atom->lmap->find("C2\"", Atom::ATOM), 2);
EXPECT_EQ(atom->lmap->find("C1'-C2\"", Atom::ATOM), 3);
EXPECT_EQ(atom->lmap->find("C2\"-C1'", Atom::ATOM), 4);
}
TEST_F(LabelMapTest, Topology)
{
if (!info->has_style("atom", "full")) GTEST_SKIP();
EXPECT_EQ(atom->natoms, 0);
EXPECT_EQ(atom->nbonds, 0);
EXPECT_EQ(atom->nangles, 0);
EXPECT_EQ(atom->ndihedrals, 0);
EXPECT_EQ(atom->nimpropers, 0);
EXPECT_EQ(domain->box_exist, 0);
ASSERT_EQ(atom->lmap, nullptr);
TEST_FAILURE(".*ERROR: Labelmap command before simulation box is.*",
command("labelmap atom 3 C1"););
BEGIN_HIDE_OUTPUT();
command("atom_style full");
command("region box block 0 2 0 2 0 2");
command("create_box 2 box bond/types 3 angle/types 2 dihedral/types 1 improper/types 1");
command("labelmap atom 1 C1");
END_HIDE_OUTPUT();
ASSERT_NE(atom->lmap, nullptr);
EXPECT_FALSE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_FALSE(atom->lmap->is_complete(Atom::BOND));
EXPECT_FALSE(atom->lmap->is_complete(Atom::ANGLE));
EXPECT_FALSE(atom->lmap->is_complete(Atom::DIHEDRAL));
EXPECT_FALSE(atom->lmap->is_complete(Atom::IMPROPER));
BEGIN_HIDE_OUTPUT();
command("labelmap atom 2 \"N2'\"");
command("labelmap bond 1 C1-N2 2 [C1][C1] 3 N2=N2");
command("labelmap angle 1 C1-N2-C1 2 \"\"\" N2'-C1\"-N2' \"\"\"");
command("labelmap dihedral 1 'C1-N2-C1-N2'");
command("labelmap improper 1 \"C1-N2-C1-N2\"");
command("mass C1 12.0");
command("mass \"N2'\" 14.0");
command("labelmap write labelmap_topology.inc");
END_HIDE_OUTPUT();
EXPECT_TRUE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_TRUE(atom->lmap->is_complete(Atom::BOND));
EXPECT_TRUE(atom->lmap->is_complete(Atom::ANGLE));
EXPECT_TRUE(atom->lmap->is_complete(Atom::DIHEDRAL));
EXPECT_TRUE(atom->lmap->is_complete(Atom::IMPROPER));
EXPECT_EQ(atom->lmap->find("C1", Atom::ATOM), 1);
EXPECT_EQ(atom->lmap->find("N2'", Atom::ATOM), 2);
EXPECT_EQ(atom->lmap->find("C1-N2", Atom::BOND), 1);
EXPECT_EQ(atom->lmap->find("[C1][C1]", Atom::BOND), 2);
EXPECT_EQ(atom->lmap->find("N2=N2", Atom::BOND), 3);
EXPECT_EQ(atom->lmap->find("C1-N2-C1", Atom::ANGLE), 1);
EXPECT_EQ(atom->lmap->find("N2'-C1\"-N2'", Atom::ANGLE), 2);
EXPECT_EQ(atom->lmap->find("C1-N2-C1-N2", Atom::DIHEDRAL), 1);
EXPECT_EQ(atom->lmap->find("C1-N2-C1-N2", Atom::IMPROPER), 1);
EXPECT_EQ(atom->lmap->find("X", Atom::ATOM), -1);
EXPECT_EQ(atom->lmap->find("N2'-C1\"-N2'", Atom::BOND), -1);
EXPECT_DOUBLE_EQ(atom->mass[1], 12.0);
EXPECT_DOUBLE_EQ(atom->mass[2], 14.0);
BEGIN_HIDE_OUTPUT();
command("labelmap clear");
command("labelmap atom 1 C1");
END_HIDE_OUTPUT();
EXPECT_NE(atom->lmap, nullptr);
EXPECT_FALSE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_FALSE(atom->lmap->is_complete(Atom::BOND));
EXPECT_FALSE(atom->lmap->is_complete(Atom::ANGLE));
EXPECT_FALSE(atom->lmap->is_complete(Atom::DIHEDRAL));
EXPECT_FALSE(atom->lmap->is_complete(Atom::IMPROPER));
BEGIN_HIDE_OUTPUT();
command("include labelmap_topology.inc");
END_HIDE_OUTPUT();
EXPECT_TRUE(atom->lmap->is_complete(Atom::ATOM));
EXPECT_TRUE(atom->lmap->is_complete(Atom::BOND));
EXPECT_TRUE(atom->lmap->is_complete(Atom::ANGLE));
EXPECT_TRUE(atom->lmap->is_complete(Atom::DIHEDRAL));
EXPECT_TRUE(atom->lmap->is_complete(Atom::IMPROPER));
EXPECT_EQ(atom->lmap->find("C1", Atom::ATOM), 1);
EXPECT_EQ(atom->lmap->find("N2'", Atom::ATOM), 2);
EXPECT_EQ(atom->lmap->find("C1-N2", Atom::BOND), 1);
EXPECT_EQ(atom->lmap->find("[C1][C1]", Atom::BOND), 2);
EXPECT_EQ(atom->lmap->find("N2=N2", Atom::BOND), 3);
EXPECT_EQ(atom->lmap->find("C1-N2-C1", Atom::ANGLE), 1);
EXPECT_EQ(atom->lmap->find("N2'-C1\"-N2'", Atom::ANGLE), 2);
EXPECT_EQ(atom->lmap->find("C1-N2-C1-N2", Atom::DIHEDRAL), 1);
EXPECT_EQ(atom->lmap->find("C1-N2-C1-N2", Atom::IMPROPER), 1);
EXPECT_EQ(atom->lmap->find("X", Atom::ATOM), -1);
EXPECT_EQ(atom->lmap->find("N2'-C1\"-N2'", Atom::BOND), -1);
}
} // namespace LAMMPS_NS
int main(int argc, char **argv)