Files
lammps/src/KOKKOS/atom_vec_angle_kokkos.h
2024-02-26 15:37:22 -07:00

105 lines
3.4 KiB
C++

/* -*- c++ -*- ----------------------------------------------------------
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
https://www.lammps.org/, Sandia National Laboratories
LAMMPS development team: developers@lammps.org
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 ATOM_CLASS
// clang-format off
AtomStyle(angle/kk,AtomVecAngleKokkos);
AtomStyle(angle/kk/device,AtomVecAngleKokkos);
AtomStyle(angle/kk/host,AtomVecAngleKokkos);
// clang-format on
#else
// clang-format off
#ifndef LMP_ATOM_VEC_ANGLE_KOKKOS_H
#define LMP_ATOM_VEC_ANGLE_KOKKOS_H
#include "atom_vec_kokkos.h"
#include "atom_vec_angle.h"
namespace LAMMPS_NS {
class AtomVecAngleKokkos : public AtomVecKokkos, public AtomVecAngle {
public:
AtomVecAngleKokkos(class LAMMPS *);
void grow(int) override;
void grow_pointers() override;
void sort_kokkos(Kokkos::BinSort<KeyViewType, BinOp> &Sorter) override;
int pack_border_kokkos(int n, DAT::tdual_int_1d k_sendlist,
DAT::tdual_xfloat_2d buf,
int pbc_flag, int *pbc, ExecutionSpace space) override;
void unpack_border_kokkos(const int &n, const int &nfirst,
const DAT::tdual_xfloat_2d &buf,
ExecutionSpace space) override;
int pack_exchange_kokkos(const int &nsend,DAT::tdual_xfloat_2d &buf,
DAT::tdual_int_1d k_sendlist,
DAT::tdual_int_1d k_copylist,
ExecutionSpace space) override;
int unpack_exchange_kokkos(DAT::tdual_xfloat_2d &k_buf, int nrecv,
int nlocal, int dim, X_FLOAT lo, X_FLOAT hi,
ExecutionSpace space,
DAT::tdual_int_1d &k_indices) override;
void sync(ExecutionSpace space, unsigned int mask) override;
void modified(ExecutionSpace space, unsigned int mask) override;
void sync_overlapping_device(ExecutionSpace space, unsigned int mask) override;
protected:
tagint *molecule;
tagint **special;
tagint **bond_atom;
tagint **angle_atom1,**angle_atom2,**angle_atom3;
DAT::t_tagint_1d d_tag;
DAT::t_int_1d d_type, d_mask;
HAT::t_tagint_1d h_tag;
HAT::t_int_1d h_type, h_mask;
DAT::t_imageint_1d d_image;
HAT::t_imageint_1d h_image;
DAT::t_x_array d_x;
DAT::t_v_array d_v;
DAT::t_f_array d_f;
HAT::t_x_array h_x;
HAT::t_v_array h_v;
HAT::t_f_array h_f;
DAT::t_tagint_1d d_molecule;
DAT::t_int_2d d_nspecial;
DAT::t_tagint_2d d_special;
DAT::t_int_1d d_num_bond;
DAT::t_int_2d d_bond_type;
DAT::t_tagint_2d d_bond_atom;
HAT::t_tagint_1d h_molecule;
HAT::t_int_2d h_nspecial;
HAT::t_tagint_2d h_special;
HAT::t_int_1d h_num_bond;
HAT::t_int_2d h_bond_type;
HAT::t_tagint_2d h_bond_atom;
DAT::t_int_1d d_num_angle;
DAT::t_int_2d d_angle_type;
DAT::t_tagint_2d d_angle_atom1,d_angle_atom2,d_angle_atom3;
HAT::t_int_1d h_num_angle;
HAT::t_int_2d h_angle_type;
HAT::t_tagint_2d h_angle_atom1,h_angle_atom2,h_angle_atom3;
};
} // namespace LAMMPS_NS
#endif
#endif