lammps-sys 0.6.0

Generates bindings to LAMMPS' C interface (with optional builds from source)
Documentation
/* -*- 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 FIX_CLASS

FixStyle(ehex,FixEHEX)

#else

#ifndef LMP_FIX_EHEX_H
#define LMP_FIX_EHEX_H

#include "fix.h"
#define EHEX_DEBUG 0

namespace LAMMPS_NS {

class FixEHEX : public Fix {

 public:
  FixEHEX(class LAMMPS *, int, char **);
  ~FixEHEX();
  int  setmask();
  void init();
  void end_of_step();
  void   rescale();
  double compute_scalar();
  double memory_usage();
  void update_scalingmask();
  void com_properties(double *, double *, double *, double*, double *, double*);
  bool rescale_atom(int i, class Region *region);
  virtual void grow_arrays(int nmax);
  bool check_cluster(tagint *shake_atom, int n, class Region *region);

 private:
  int iregion;
  double heat_input;
  double masstotal;
  double scale;
  char *idregion;
  int me;

  double **x;               // coordinates
  double **f;               // forces
  double **v;               // velocities
  double *mass;             // masses
  double *rmass;            // reduced masses
  int    *type;             // atom types
  int   nlocal;             // number of local atoms
  class FixShake * fshake;  // pointer to fix_shake/fix_rattle
  int constraints;          // constraints (0/1)
  int cluster;              // rescaling entire clusters (0/1)
  int hex;                  // HEX mode (0/1)
  bool *scalingmask;       // scalingmask[i] determines whether
                            // the velocity of atom i is to be rescaled
};

}

#endif
#endif

/* ERROR/WARNING messages:

E: Illegal fix ehex command: wrong number of parameters

UNDOCUMENTED

E: Illegal ... command

UNDOCUMENTED

E: Region ID for fix ehex does not exist

Self-explanatory.

E: Illegal fix ehex keyword

UNDOCUMENTED

E: You can only use the keyword 'com' together with the keyword 'constrain'

UNDOCUMENTED

E: Fix ehex group has no atoms

Self-explanatory.

E: Multiple instances of fix shake/rattle detected (not supported yet)

You can only have one instance of fix rattle/shake at the moment.

E: Fix ehex was configured with keyword constrain, but shake/rattle was not defined

The option constrain requires either fix shake or fix rattle which is missing in the input script.

E: Fix ehex kinetic energy went negative

UNDOCUMENTED

E: Internal error: shake_flag[m] has to be between 1 and 4 for m in nlist

Contact developers.

E: Fix ehex shake cluster has almost zero mass.

UNDOCUMENTED

E: Fix ehex error mass of region is close to zero

Check your configuration.

U: Illegal fix ehex command: wrong number of parameters

Self-explanatory.  Check the input script syntax and compare to the
documentation for the command.  You can use -echo screen as a
command-line option when running LAMMPS to see the offending line.

U: Illegal fix ehex command: integer value expected

Self-explanatory. Check the value for nevery.

U: You can only use the keyword 'com' together with the keyword 'constrain' .

Self-explanatory.

U: Illegal fix ehex keyword

Self-explanatory.

U: Fix heat kinetic energy went negative

This will cause the velocity rescaling about to be performed by fix
heat to be invalid.

U: Fix heat kinetic energy of an atom went negative

This will cause the velocity rescaling about to be performed by fix
heat to be invalid.

*/