1 /* ---------------------------------------------------------------------- 2 This is the 3 4 ██╗ ██╗ ██████╗ ██████╗ ██████╗ ██╗ ██╗████████╗███████╗ 5 ██║ ██║██╔════╝ ██╔════╝ ██╔════╝ ██║ ██║╚══██╔══╝██╔════╝ 6 ██║ ██║██║ ███╗██║ ███╗██║ ███╗███████║ ██║ ███████╗ 7 ██║ ██║██║ ██║██║ ██║██║ ██║██╔══██║ ██║ ╚════██║ 8 ███████╗██║╚██████╔╝╚██████╔╝╚██████╔╝██║ ██║ ██║ ███████║ 9 ╚══════╝╚═╝ ╚═════╝ ╚═════╝ ╚═════╝ ╚═╝ ╚═╝ ╚═╝ ╚══════╝® 10 11 DEM simulation engine, released by 12 DCS Computing Gmbh, Linz, Austria 13 http://www.dcs-computing.com, office@dcs-computing.com 14 15 LIGGGHTS® is part of CFDEM®project: 16 http://www.liggghts.com | http://www.cfdem.com 17 18 Core developer and main author: 19 Christoph Kloss, christoph.kloss@dcs-computing.com 20 21 LIGGGHTS® is open-source, distributed under the terms of the GNU Public 22 License, version 2 or later. It is distributed in the hope that it will 23 be useful, but WITHOUT ANY WARRANTY; without even the implied warranty 24 of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. You should have 25 received a copy of the GNU General Public License along with LIGGGHTS®. 26 If not, see http://www.gnu.org/licenses . See also top-level README 27 and LICENSE files. 28 29 LIGGGHTS® and CFDEM® are registered trade marks of DCS Computing GmbH, 30 the producer of the LIGGGHTS® software and the CFDEM®coupling software 31 See http://www.cfdem.com/terms-trademark-policy for details. 32 33 ------------------------------------------------------------------------- 34 Contributing author and copyright for this file: 35 This file is from LAMMPS 36 LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator 37 http://lammps.sandia.gov, Sandia National Laboratories 38 Steve Plimpton, sjplimp@sandia.gov 39 40 Copyright (2003) Sandia Corporation. Under the terms of Contract 41 DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains 42 certain rights in this software. This software is distributed under 43 the GNU General Public License. 44 ------------------------------------------------------------------------- */ 45 46 #ifdef ATOM_CLASS 47 48 AtomStyle(charge,AtomVecCharge) 49 50 #else 51 52 #ifndef LMP_ATOM_VEC_CHARGE_H 53 #define LMP_ATOM_VEC_CHARGE_H 54 55 #include "atom_vec.h" 56 57 namespace LAMMPS_NS { 58 59 class AtomVecCharge : public AtomVec { 60 public: 61 AtomVecCharge(class LAMMPS *); 62 virtual ~AtomVecCharge() {} 63 void grow(int); 64 void grow_reset(); 65 void copy(int, int, int); 66 virtual int pack_comm(int, int *, double *, int, int *); 67 virtual int pack_comm_vel(int, int *, double *, int, int *); 68 virtual void unpack_comm(int, int, double *); 69 virtual void unpack_comm_vel(int, int, double *); 70 int pack_reverse(int, int, double *); 71 void unpack_reverse(int, int *, double *); 72 virtual int pack_border(int, int *, double *, int, int *); 73 virtual int pack_border_vel(int, int *, double *, int, int *); 74 int pack_border_hybrid(int, int *, double *); 75 virtual void unpack_border(int, int, double *); 76 virtual void unpack_border_vel(int, int, double *); 77 int unpack_border_hybrid(int, int, double *); 78 virtual int pack_exchange(int, double *); 79 virtual int unpack_exchange(double *); 80 int size_restart(); 81 int pack_restart(int, double *); 82 int unpack_restart(double *); 83 void create_atom(int, double *); 84 void data_atom(double *, tagint, char **); 85 int data_atom_hybrid(int, char **); 86 void pack_data(double **); 87 int pack_data_hybrid(int, double *); 88 void write_data(FILE *, int, double **); 89 int write_data_hybrid(FILE *, double *); 90 bigint memory_usage(); 91 92 protected: 93 int *tag,*type,*mask; 94 tagint *image; 95 double **x,**v,**f; 96 double *q; 97 }; 98 99 } 100 101 #endif 102 #endif 103 104 /* ERROR/WARNING messages: 105 106 E: Per-processor system is too big 107 108 The number of owned atoms plus ghost atoms on a single 109 processor must fit in 32-bit integer. 110 111 E: Invalid atom ID in Atoms section of data file 112 113 Atom IDs must be positive integers. 114 115 E: Invalid atom type in Atoms section of data file 116 117 Atom types must range from 1 to specified # of types. 118 119 */ 120