Skip to content

Commit

Permalink
Rewrite LJcos interaction interface
Browse files Browse the repository at this point in the history
  • Loading branch information
jhossbach authored and jngrad committed Aug 26, 2022
1 parent f56f5f3 commit dbb08ef
Show file tree
Hide file tree
Showing 9 changed files with 85 additions and 82 deletions.
39 changes: 16 additions & 23 deletions src/core/nonbonded_interactions/ljcos.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,34 +25,27 @@
#include "ljcos.hpp"

#ifdef LJCOS
#include "interactions.hpp"
#include "nonbonded_interaction_data.hpp"

#include <utils/constants.hpp>
#include <utils/math/sqr.hpp>

int ljcos_set_params(int part_type_a, int part_type_b, double eps, double sig,
double cut, double offset) {
IA_parameters *data = get_ia_param_safe(part_type_a, part_type_b);

if (!data)
return ES_ERROR;

data->ljcos.eps = eps;
data->ljcos.sig = sig;
data->ljcos.cut = cut;
data->ljcos.offset = offset;

/* Calculate dependent parameters */
#include <stdexcept>

LJcos_Parameters::LJcos_Parameters(double eps, double sig, double cut,
double offset)
: eps{eps}, sig{sig}, cut{cut}, offset{offset} {
if (eps < 0.) {
throw std::domain_error("LJcos parameter 'epsilon' has to be >= 0");
}
if (sig < 0.) {
throw std::domain_error("LJcos parameter 'sigma' has to be >= 0");
}
auto const facsq = Utils::cbrt_2() * Utils::sqr(sig);
data->ljcos.rmin = sqrt(Utils::cbrt_2()) * sig;
data->ljcos.alfa = Utils::pi() / (Utils::sqr(data->ljcos.cut) - facsq);
data->ljcos.beta =
Utils::pi() * (1. - (1. / (Utils::sqr(data->ljcos.cut) / facsq - 1.)));

/* broadcast interaction parameters */
mpi_bcast_ia_params(part_type_a, part_type_b);

return ES_OK;
rmin = sqrt(Utils::cbrt_2()) * sig;
alfa = Utils::pi() / (Utils::sqr(cut) - facsq);
beta = Utils::pi() * (1. - (1. / (Utils::sqr(cut) / facsq - 1.)));
}
#endif

#endif // LJCOS
4 changes: 0 additions & 4 deletions src/core/nonbonded_interactions/ljcos.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,11 @@

#include "nonbonded_interaction_data.hpp"

#include <utils/Vector.hpp>
#include <utils/math/int_pow.hpp>
#include <utils/math/sqr.hpp>

#include <cmath>

int ljcos_set_params(int part_type_a, int part_type_b, double eps, double sig,
double cut, double offset);

/** Calculate Lennard-Jones cosine force factor */
inline double ljcos_pair_force_factor(IA_parameters const &ia_params,
double dist) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -188,8 +188,7 @@ static double recalc_maximal_cutoff(const IA_parameters &data) {
#endif

#ifdef LJCOS
max_cut_current =
std::max(max_cut_current, (data.ljcos.cut + data.ljcos.offset));
max_cut_current = std::max(max_cut_current, data.ljcos.max_cutoff());
#endif

#ifdef LJCOS2
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,9 @@ struct LJcos_Parameters {
double alfa = 0.0;
double beta = 0.0;
double rmin = 0.0;
LJcos_Parameters() = default;
LJcos_Parameters(double eps, double sig, double cut, double offset);
double max_cutoff() const { return cut + offset; }
};

/** Lennard-Jones with a different Cos potential */
Expand Down
14 changes: 0 additions & 14 deletions src/python/espressomd/interactions.pxd
Original file line number Diff line number Diff line change
Expand Up @@ -106,12 +106,6 @@ cdef extern from "nonbonded_interactions/nonbonded_interaction_data.hpp":
double Fmax
double r

cdef struct LJcos_Parameters:
double eps
double sig
double cut
double offset

cdef struct LJcos2_Parameters:
double eps
double sig
Expand Down Expand Up @@ -140,8 +134,6 @@ cdef extern from "nonbonded_interactions/nonbonded_interaction_data.hpp":

cdef struct IA_parameters:

LJcos_Parameters ljcos

LJcos2_Parameters ljcos2

LJGen_Parameters ljgen
Expand Down Expand Up @@ -176,12 +168,6 @@ cdef extern from "nonbonded_interactions/nonbonded_interaction_data.hpp":
cdef void ia_params_set_state(string)
cdef void reset_ia_params()

IF LJCOS:
cdef extern from "nonbonded_interactions/ljcos.hpp":
cdef int ljcos_set_params(int part_type_a, int part_type_b,
double eps, double sig,
double cut, double offset)

IF LJCOS2:
cdef extern from "nonbonded_interactions/ljcos2.hpp":
cdef int ljcos2_set_params(int part_type_a, int part_type_b,
Expand Down
58 changes: 19 additions & 39 deletions src/python/espressomd/interactions.pyx
Original file line number Diff line number Diff line change
Expand Up @@ -563,37 +563,22 @@ IF LENNARD_JONES_GENERIC == 1:
return {"epsilon", "sigma", "cutoff",
"shift", "offset", "e1", "e2", "b1", "b2"}

IF LJCOS:
IF LJCOS == 1:

cdef class LennardJonesCosInteraction(NonBondedInteraction):

def validate_params(self):
if self._params["epsilon"] < 0:
raise ValueError("Lennard-Jones epsilon has to be >=0")
if self._params["sigma"] < 0:
raise ValueError("Lennard-Jones sigma has to be >=0")

def _get_params_from_es_core(self):
cdef IA_parameters * ia_params
ia_params = get_ia_param_safe(
self._part_types[0],
self._part_types[1])
return {
"epsilon": ia_params.ljcos.eps,
"sigma": ia_params.ljcos.sig,
"cutoff": ia_params.ljcos.cut,
"offset": ia_params.ljcos.offset,
}

def is_active(self):
return(self._params["epsilon"] > 0)
@script_interface_register
class LennardJonesCosInteraction(NewNonBondedInteraction):
"""Lennard-Jones cosine interaction.
def set_params(self, **kwargs):
"""Set parameters for the Lennard-Jones cosine interaction.
Methods
-------
set_params()
Set or update parameters for the interaction.
Parameters marked as required become optional once the
interaction has been activated for the first time;
subsequent calls to this method update the existing values.
Parameters
----------
epsilon : :obj:`float`
Magnitude of the interaction.
sigma : :obj:`float`
Expand All @@ -602,18 +587,15 @@ IF LJCOS:
Cutoff distance of the interaction.
offset : :obj:`float`, optional
Offset distance of the interaction.
"""
super().set_params(**kwargs)
"""

def _set_params_in_es_core(self):
if ljcos_set_params(self._part_types[0],
self._part_types[1],
self._params["epsilon"],
self._params["sigma"],
self._params["cutoff"],
self._params["offset"]):
raise Exception(
"Could not set Lennard-Jones Cosine parameters")
_so_name = "Interactions::InteractionLJcos"

def is_active(self):
"""Check if interactions is active.
"""
return self.epsilon > 0.

def default_params(self):
return {"offset": 0.}
Expand Down Expand Up @@ -1582,8 +1564,6 @@ class NonBondedInteractionHandle(ScriptInterfaceHelper):
IF LENNARD_JONES_GENERIC:
self.generic_lennard_jones = GenericLennardJonesInteraction(
_type1, _type2)
IF LJCOS:
self.lennard_jones_cos = LennardJonesCosInteraction(_type1, _type2)
IF LJCOS2:
self.lennard_jones_cos2 = LennardJonesCos2Interaction(
_type1, _type2)
Expand Down
36 changes: 36 additions & 0 deletions src/script_interface/interactions/NonBondedInteraction.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,32 @@ class InteractionLJ : public InteractionPotentialInterface<::LJ_Parameters> {
};
#endif // LENNARD_JONES

#ifdef LJCOS
class InteractionLJcos
: public InteractionPotentialInterface<::LJcos_Parameters> {
protected:
CoreInteraction IA_parameters::*get_ptr_offset() const override {
return &::IA_parameters::ljcos;
}

public:
InteractionLJcos() {
add_parameters({
make_autoparameter(&CoreInteraction::eps, "epsilon"),
make_autoparameter(&CoreInteraction::sig, "sigma"),
make_autoparameter(&CoreInteraction::cut, "cutoff"),
make_autoparameter(&CoreInteraction::offset, "offset"),
});
}

void make_new_instance(VariantMap const &params) override {
m_ia_si =
make_shared_from_args<CoreInteraction, double, double, double, double>(
params, "epsilon", "sigma", "cutoff", "offset");
}
};
#endif // LJCOS

class NonBondedInteractionHandle
: public AutoParameters<NonBondedInteractionHandle> {
std::array<int, 2> m_types = {-1, -1};
Expand All @@ -206,6 +232,9 @@ class NonBondedInteractionHandle
#ifdef LENNARD_JONES
std::shared_ptr<InteractionLJ> m_lj;
#endif
#ifdef LJCOS
std::shared_ptr<InteractionLJcos> m_ljcos;
#endif

template <class T>
auto make_autoparameter(std::shared_ptr<T> &member, const char *key) const {
Expand All @@ -229,6 +258,9 @@ class NonBondedInteractionHandle
#endif
#ifdef LENNARD_JONES
make_autoparameter(m_lj, "lennard_jones"),
#endif
#ifdef LJCOS
make_autoparameter(m_ljcos, "lennard_jones_cos"),
#endif
});
}
Expand Down Expand Up @@ -275,6 +307,10 @@ class NonBondedInteractionHandle
#ifdef LENNARD_JONES
set_member<InteractionLJ>(m_lj, "lennard_jones",
"Interactions::InteractionLJ", params);
#endif
#ifdef LJCOS
set_member<InteractionLJcos>(m_ljcos, "lennard_jones_cos",
"Interactions::InteractionLJcos", params);
#endif
}

Expand Down
3 changes: 3 additions & 0 deletions src/script_interface/interactions/initialize.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,9 @@ void initialize(Utils::Factory<ObjectHandle> *om) {
#ifdef LENNARD_JONES
om->register_new<InteractionLJ>("Interactions::InteractionLJ");
#endif
#ifdef LJCOS
om->register_new<InteractionLJcos>("Interactions::InteractionLJcos");
#endif
#ifdef WCA
om->register_new<InteractionWCA>("Interactions::InteractionWCA");
#endif
Expand Down
7 changes: 7 additions & 0 deletions testsuite/python/interactions_non-bonded_interface.py
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,13 @@ def test_lj_exceptions(self):
{"epsilon": 1., "sigma": 1., "cutoff": 1.5, "shift": 0.2},
("epsilon", "sigma"))

@utx.skipIfMissingFeatures("LJCOS")
def test_lj_cos_exceptions(self):
self.check_potential_exceptions(
espressomd.interactions.LennardJonesCosInteraction,
{"epsilon": 1., "sigma": 1., "cutoff": 1.5, "offset": 0.2},
("epsilon", "sigma"))


if __name__ == "__main__":
ut.main()

0 comments on commit dbb08ef

Please sign in to comment.