Commit b72c1c0e authored by Anne Gunn's avatar Anne Gunn
Browse files

Per suggestion from Axel, reformat code to what I believe to be

LAMMPS standards. I used the .clang-format file from the unit-test
folder but changed all spacing settings to 2 from 4.
parent 0c067700
Loading
Loading
Loading
Loading
+157 −146
Original line number Diff line number Diff line
@@ -16,10 +16,10 @@

#include "compute_pressure_bocs.h"

#include <mpi.h>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <cstring>
#include <mpi.h>

#include "angle.h"
#include "atom.h"
@@ -37,14 +37,12 @@
#include "pair.h"
#include "update.h"


using namespace LAMMPS_NS;

/* ---------------------------------------------------------------------- */

ComputePressureBocs::ComputePressureBocs(LAMMPS *lmp, int narg, char **arg) :
  Compute(lmp, narg, arg),
  vptr(NULL), id_temp(NULL)
    Compute(lmp, narg, arg), vptr(NULL), id_temp(NULL)
{
  if (narg < 4) error->all(FLERR, "Illegal compute pressure/bocs command");
  if (igroup) error->all(FLERR, "Compute pressure/bocs must use group all");
@@ -62,15 +60,15 @@ ComputePressureBocs::ComputePressureBocs(LAMMPS *lmp, int narg, char **arg) :
  // store temperature ID used by pressure computation
  // insure it is valid for temperature computation

  if (strcmp(arg[3],"NULL") == 0) id_temp = NULL;
  if (strcmp(arg[3], "NULL") == 0)
    id_temp = NULL;
  else {
    int n   = strlen(arg[3]) + 1;
    id_temp = new char[n];
    strcpy(id_temp, arg[3]);

    int icompute = modify->find_compute(id_temp);
    if (icompute < 0)
      error->all(FLERR,"Could not find compute pressure/bocs temperature ID");
    if (icompute < 0) error->all(FLERR, "Could not find compute pressure/bocs temperature ID");
    if (modify->compute[icompute]->tempflag == 0)
      error->all(FLERR, "Compute pressure/bocs temperature ID does not "
                        "compute temperature");
@@ -83,26 +81,37 @@ ComputePressureBocs::ComputePressureBocs(LAMMPS *lmp, int narg, char **arg) :
    pairflag = 1;
    bondflag = angleflag = dihedralflag = improperflag = 1;
    kspaceflag = fixflag = 1;
  } else {
  }
  else {
    keflag   = 0;
    pairflag = 0;
    bondflag = angleflag = dihedralflag = improperflag = 0;
    kspaceflag = fixflag = 0;
    int iarg             = 4;
    while (iarg < narg) {
      if (strcmp(arg[iarg],"ke") == 0) keflag = 1;
      else if (strcmp(arg[iarg],"pair") == 0) pairflag = 1;
      else if (strcmp(arg[iarg],"bond") == 0) bondflag = 1;
      else if (strcmp(arg[iarg],"angle") == 0) angleflag = 1;
      else if (strcmp(arg[iarg],"dihedral") == 0) dihedralflag = 1;
      else if (strcmp(arg[iarg],"improper") == 0) improperflag = 1;
      else if (strcmp(arg[iarg],"kspace") == 0) kspaceflag = 1;
      else if (strcmp(arg[iarg],"fix") == 0) fixflag = 1;
      if (strcmp(arg[iarg], "ke") == 0)
        keflag = 1;
      else if (strcmp(arg[iarg], "pair") == 0)
        pairflag = 1;
      else if (strcmp(arg[iarg], "bond") == 0)
        bondflag = 1;
      else if (strcmp(arg[iarg], "angle") == 0)
        angleflag = 1;
      else if (strcmp(arg[iarg], "dihedral") == 0)
        dihedralflag = 1;
      else if (strcmp(arg[iarg], "improper") == 0)
        improperflag = 1;
      else if (strcmp(arg[iarg], "kspace") == 0)
        kspaceflag = 1;
      else if (strcmp(arg[iarg], "fix") == 0)
        fixflag = 1;
      else if (strcmp(arg[iarg], "virial") == 0) {
        pairflag = 1;
        bondflag = angleflag = dihedralflag = improperflag = 1;
        kspaceflag = fixflag = 1;
      } else error->all(FLERR,"Illegal compute pressure/bocs command");
      }
      else
        error->all(FLERR, "Illegal compute pressure/bocs command");
      iarg++;
    }
  }
@@ -144,8 +153,7 @@ void ComputePressureBocs::init()

  if (keflag) {
    int icompute = modify->find_compute(id_temp);
    if (icompute < 0)
      error->all(FLERR,"Could not find compute pressure/bocs temperature ID");
    if (icompute < 0) error->all(FLERR, "Could not find compute pressure/bocs temperature ID");
    temperature = modify->compute[icompute];
  }

@@ -171,20 +179,19 @@ void ComputePressureBocs::init()
    if (pairflag && force->pair) vptr[nvirial++] = force->pair->virial;
    if (bondflag && force->bond) vptr[nvirial++] = force->bond->virial;
    if (angleflag && force->angle) vptr[nvirial++] = force->angle->virial;
    if (dihedralflag && force->dihedral)
      vptr[nvirial++] = force->dihedral->virial;
    if (improperflag && force->improper)
      vptr[nvirial++] = force->improper->virial;
    if (dihedralflag && force->dihedral) vptr[nvirial++] = force->dihedral->virial;
    if (improperflag && force->improper) vptr[nvirial++] = force->improper->virial;
    if (fixflag)
      for (int i = 0; i < modify->nfix; i++)
        if (modify->fix[i]->virial_flag)
          vptr[nvirial++] = modify->fix[i]->virial;
        if (modify->fix[i]->virial_flag) vptr[nvirial++] = modify->fix[i]->virial;
  }

  // flag Kspace contribution separately, since not summed across procs

  if (kspaceflag && force->kspace) kspace_virial = force->kspace->virial;
  else kspace_virial = NULL;
  if (kspaceflag && force->kspace)
    kspace_virial = force->kspace->virial;
  else
    kspace_virial = NULL;
}

/* Extra functions added for BOCS */
@@ -192,14 +199,12 @@ void ComputePressureBocs::init()
/* ----------------------------------------------------------------------
   Compute the pressure correction for the analytical basis set
------------------------------------------------------------------------- */
double ComputePressureBocs::get_cg_p_corr(int N_basis, double *phi_coeff,
                                      int N_mol, double vavg, double vCG)
double ComputePressureBocs::get_cg_p_corr(int N_basis, double *phi_coeff, int N_mol, double vavg,
                                          double vCG)
{
  double correction = 0.0;
  for (int i = 1; i <= N_basis; ++i)
  {
    correction -= phi_coeff[i-1] * ( N_mol * i / vavg ) *
                                   pow( ( 1 / vavg ) * ( vCG - vavg ),i-1);
  for (int i = 1; i <= N_basis; ++i) {
    correction -= phi_coeff[i - 1] * (N_mol * i / vavg) * pow((1 / vavg) * (vCG - vavg), i - 1);
  }
  return correction;
}
@@ -212,16 +217,18 @@ double ComputePressureBocs::find_index(double * grid, double value)
  int i;
  double spacing = fabs(grid[1] - grid[0]);
  int gridsize   = spline_length;
  for (i = 0; i < (gridsize-1); ++i)
  {
    if (value >= grid[i] && value <= grid[i+1]) { return i; }
  for (i = 0; i < (gridsize - 1); ++i) {
    if (value >= grid[i] && value <= grid[i + 1]) {
      return i;
    }
  }

  if (value >= grid[i] && value <= (grid[i] + spacing)) { return i; }
  if (value >= grid[i] && value <= (grid[i] + spacing)) {
    return i;
  }

  error->all(FLERR, fmt::format("find_index could not find value in grid for value: {}", value));
  for (int i = 0; i < gridsize; ++i)
  {
  for (int i = 0; i < gridsize; ++i) {
    fprintf(stderr, "grid %d: %f\n", i, grid[i]);
  }

@@ -232,24 +239,20 @@ double ComputePressureBocs::find_index(double * grid, double value)
   Compute the pressure correction for a spline basis set
------------------------------------------------------------------------- */

double ComputePressureBocs::get_cg_p_corr(double ** grid, int basis_type,
                                                               double vCG)
double ComputePressureBocs::get_cg_p_corr(double **grid, int basis_type, double vCG)
{
  int i = find_index(grid[0], vCG);
  double correction, deltax = vCG - grid[0][i];

  if (basis_type == BASIS_LINEAR_SPLINE)
  {
    correction = grid[1][i] + (deltax) *
          ( grid[1][i+1] - grid[1][i] ) / ( grid[0][i+1] - grid[0][i] );
  if (basis_type == BASIS_LINEAR_SPLINE) {
    correction =
        grid[1][i] + (deltax) * (grid[1][i + 1] - grid[1][i]) / (grid[0][i + 1] - grid[0][i]);
  }
  else if (basis_type == BASIS_CUBIC_SPLINE)
  {
    correction = grid[1][i] + (grid[2][i] * deltax) +
            (grid[3][i] * pow(deltax,2)) + (grid[4][i] * pow(deltax,3));
  else if (basis_type == BASIS_CUBIC_SPLINE) {
    correction = grid[1][i] + (grid[2][i] * deltax) + (grid[3][i] * pow(deltax, 2)) +
                 (grid[4][i] * pow(deltax, 3));
  }
  else
  {
  else {
    error->all(FLERR, "bad spline type passed to get_cg_p_corr()\n");
  }
  return correction;
@@ -259,12 +262,13 @@ double ComputePressureBocs::get_cg_p_corr(double ** grid, int basis_type,
   send cg info from fix_bocs to compute_pressure_bocs for the analytical
   basis set
------------------------------------------------------------------------- */
void ComputePressureBocs::send_cg_info(int basis_type, int sent_N_basis,
                double *sent_phi_coeff, int sent_N_mol, double sent_vavg)
{
  if (basis_type == BASIS_ANALYTIC) { p_basis_type = BASIS_ANALYTIC; }
  else
void ComputePressureBocs::send_cg_info(int basis_type, int sent_N_basis, double *sent_phi_coeff,
                                       int sent_N_mol, double sent_vavg)
{
  if (basis_type == BASIS_ANALYTIC) {
    p_basis_type = BASIS_ANALYTIC;
  }
  else {
    error->all(FLERR, "Incorrect basis type passed to ComputePressureBocs\n");
  }

@@ -273,7 +277,9 @@ void ComputePressureBocs::send_cg_info(int basis_type, int sent_N_basis,
  N_basis = sent_N_basis;
  if (phi_coeff) free(phi_coeff);
  phi_coeff = ((double *)calloc(N_basis, sizeof(double)));
  for (int i=0; i<N_basis; i++) { phi_coeff[i] = sent_phi_coeff[i]; }
  for (int i = 0; i < N_basis; i++) {
    phi_coeff[i] = sent_phi_coeff[i];
  }

  N_mol = sent_N_mol;
  vavg  = sent_vavg;
@@ -283,13 +289,15 @@ void ComputePressureBocs::send_cg_info(int basis_type, int sent_N_basis,
   send cg info from fix_bocs to compute_pressure_bocs for a spline basis
   set
------------------------------------------------------------------------- */
void ComputePressureBocs::send_cg_info(int basis_type,
                                         double ** in_splines, int gridsize)
{
  if (basis_type == BASIS_LINEAR_SPLINE) { p_basis_type = BASIS_LINEAR_SPLINE; }
  else if (basis_type == BASIS_CUBIC_SPLINE) { p_basis_type = BASIS_CUBIC_SPLINE; }
  else
void ComputePressureBocs::send_cg_info(int basis_type, double **in_splines, int gridsize)
{
  if (basis_type == BASIS_LINEAR_SPLINE) {
    p_basis_type = BASIS_LINEAR_SPLINE;
  }
  else if (basis_type == BASIS_CUBIC_SPLINE) {
    p_basis_type = BASIS_CUBIC_SPLINE;
  }
  else {
    error->all(FLERR, "Incorrect basis type passed to ComputePressureBocs\n");
  }
  splines       = in_splines;
@@ -315,7 +323,8 @@ double ComputePressureBocs::compute_scalar()
  if (keflag) {
    if (temperature->invoked_scalar != update->ntimestep)
      t = temperature->compute_scalar();
    else t = temperature->scalar;
    else
      t = temperature->scalar;
  }

  if (dimension == 3) {
@@ -323,34 +332,30 @@ double ComputePressureBocs::compute_scalar()
    volume     = (domain->xprd * domain->yprd * domain->zprd);

    /* MRD NJD if block */
    if ( p_basis_type == BASIS_ANALYTIC )
    {
    if (p_basis_type == BASIS_ANALYTIC) {
      correction = get_cg_p_corr(N_basis, phi_coeff, N_mol, vavg, volume);
    }
    else if ( p_basis_type == BASIS_LINEAR_SPLINE || p_basis_type == BASIS_CUBIC_SPLINE )
    {
    else if (p_basis_type == BASIS_LINEAR_SPLINE || p_basis_type == BASIS_CUBIC_SPLINE) {
      correction = get_cg_p_corr(splines, p_basis_type, volume);
    }

    virial_compute(3, 3);
    if (keflag)
      scalar = (temperature->dof * boltz * t +
                virial[0] + virial[1] + virial[2]) / 3.0 *
                inv_volume * nktv2p + (correction);
      scalar = (temperature->dof * boltz * t + virial[0] + virial[1] + virial[2]) / 3.0 *
                   inv_volume * nktv2p +
               (correction);
    else
      scalar = (virial[0] + virial[1] + virial[2]) / 3.0 *
               inv_volume * nktv2p + (correction);
  } else {
    if (p_match_flag)
    {
      scalar = (virial[0] + virial[1] + virial[2]) / 3.0 * inv_volume * nktv2p + (correction);
  }
  else {
    if (p_match_flag) {
      error->all(FLERR, "Pressure matching not implemented in 2-d.\n");
      exit(1);
    } // The rest of this can probably be deleted.
    inv_volume = 1.0 / (domain->xprd * domain->yprd);
    virial_compute(2, 2);
    if (keflag)
      scalar = (temperature->dof * boltz * t +
                virial[0] + virial[1]) / 2.0 * inv_volume * nktv2p;
      scalar = (temperature->dof * boltz * t + virial[0] + virial[1]) / 2.0 * inv_volume * nktv2p;
    else
      scalar = (virial[0] + virial[1]) / 2.0 * inv_volume * nktv2p;
  }
@@ -377,8 +382,7 @@ void ComputePressureBocs::compute_vector()

  double *ke_tensor;
  if (keflag) {
    if (temperature->invoked_vector != update->ntimestep)
      temperature->compute_vector();
    if (temperature->invoked_vector != update->ntimestep) temperature->compute_vector();
    ke_tensor = temperature->vector;
  }

@@ -388,10 +392,12 @@ void ComputePressureBocs::compute_vector()
    if (keflag) {
      for (int i = 0; i < 6; i++)
        vector[i] = (ke_tensor[i] + virial[i]) * inv_volume * nktv2p;
    } else
    }
    else
      for (int i = 0; i < 6; i++)
        vector[i] = virial[i] * inv_volume * nktv2p;
  } else {
  }
  else {
    inv_volume = 1.0 / (domain->xprd * domain->yprd);
    virial_compute(4, 2);
    if (keflag) {
@@ -399,7 +405,8 @@ void ComputePressureBocs::compute_vector()
      vector[1] = (ke_tensor[1] + virial[1]) * inv_volume * nktv2p;
      vector[3] = (ke_tensor[3] + virial[3]) * inv_volume * nktv2p;
      vector[2] = vector[4] = vector[5] = 0.0;
    } else {
    }
    else {
      vector[0] = virial[0] * inv_volume * nktv2p;
      vector[1] = virial[1] * inv_volume * nktv2p;
      vector[3] = virial[3] * inv_volume * nktv2p;
@@ -415,13 +422,15 @@ void ComputePressureBocs::virial_compute(int n, int ndiag)
  int i, j;
  double v[6], *vcomponent;

  for (i = 0; i < n; i++) v[i] = 0.0;
  for (i = 0; i < n; i++)
    v[i] = 0.0;

  // sum contributions to virial from forces and fixes

  for (j = 0; j < nvirial; j++) {
    vcomponent = vptr[j];
    for (i = 0; i < n; i++) v[i] += vcomponent[i];
    for (i = 0; i < n; i++)
      v[i] += vcomponent[i];
  }

  // sum virial across procs
@@ -431,12 +440,14 @@ void ComputePressureBocs::virial_compute(int n, int ndiag)
  // KSpace virial contribution is already summed across procs

  if (kspace_virial)
    for (i = 0; i < n; i++) virial[i] += kspace_virial[i];
    for (i = 0; i < n; i++)
      virial[i] += kspace_virial[i];

  // LJ long-range tail correction, only if pair contributions are included

  if (force->pair && pairflag && force->pair->tail_flag)
    for (i = 0; i < ndiag; i++) virial[i] += force->pair->ptail * inv_volume;
    for (i = 0; i < ndiag; i++)
      virial[i] += force->pair->ptail * inv_volume;
}

/* ---------------------------------------------------------------------- */
+44 −45
Original line number Diff line number Diff line
@@ -20,7 +20,6 @@ ComputeStyle(PRESSURE/BOCS,ComputePressureBocs)

#else


#ifndef LMP_COMPUTE_PRESSURE_BOCS_H
#define LMP_COMPUTE_PRESSURE_BOCS_H

@@ -77,7 +76,7 @@ class ComputePressureBocs : public Compute {
  void virial_compute(int, int);
};

}
} // namespace LAMMPS_NS

#endif
#endif
+746 −743

File changed.

Preview size limit exceeded, changes collapsed.