pair_e3gnn.h 1.33 KB
Newer Older
zcxzcx1's avatar
zcxzcx1 committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/* -*- c++ -*- ----------------------------------------------------------
   LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
http://lammps.sandia.gov, Sandia National Laboratories
Steve Plimpton, sjplimp@sandia.gov

Copyright (2003) Sandia Corporation.  Under the terms of Contract
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
certain rights in this software.  This software is distributed under
the GNU General Public License.

See the README file in the top-level LAMMPS directory.
------------------------------------------------------------------------- */

#ifdef PAIR_CLASS
PairStyle(e3gnn, PairE3GNN)

#else

#ifndef LMP_PAIR_E3GNN
#define LMP_PAIR_E3GNN

#include "pair.h"

#include <torch/torch.h>

namespace LAMMPS_NS {
class PairE3GNN : public Pair {
private:
  double cutoff;
  double cutoff_square;
  torch::jit::Module model;
  torch::Device device = torch::kCPU;
  int nelements;
  bool print_info = false;

  int nedges_bound = -1;

public:
  PairE3GNN(class LAMMPS *);
  ~PairE3GNN();
  void compute(int, int);

  void settings(int, char **);
  // read Atom type string from input script & related coeff
  void coeff(int, char **);
  void allocate();

  void init_style();
  double init_one(int, int);
};
} // namespace LAMMPS_NS

#endif
#endif