forked from lijiext/lammps
Merge pull request #537 from lammps/neb
minor changes to NEB doc pages and examples
This commit is contained in:
commit
84b530cca1
|
@ -14,10 +14,10 @@ fix ID group-ID neb Kspring keyword value :pre
|
||||||
|
|
||||||
ID, group-ID are documented in "fix"_fix.html command :ulb,l
|
ID, group-ID are documented in "fix"_fix.html command :ulb,l
|
||||||
neb = style name of this fix command :l
|
neb = style name of this fix command :l
|
||||||
Kspring = parallel spring constant (force/distance units or force units, see nudge keyword) :l
|
Kspring = spring constant for parallel nudging force (force/distance units or force units, see parallel keyword) :l
|
||||||
zero or more keyword/value pairs may be appended :l
|
zero or more keyword/value pairs may be appended :l
|
||||||
keyword = {nudge} or {perp} or {ends} :l
|
keyword = {parallel} or {perp} or {end} :l
|
||||||
{nudge} value = {neigh} or {ideal}
|
{parallel} value = {neigh} or {ideal}
|
||||||
{neigh} = parallel nudging force based on distance to neighbor replicas (Kspring = force/distance units)
|
{neigh} = parallel nudging force based on distance to neighbor replicas (Kspring = force/distance units)
|
||||||
{ideal} = parallel nudging force based on interpolated ideal position (Kspring = force units)
|
{ideal} = parallel nudging force based on interpolated ideal position (Kspring = force units)
|
||||||
{perp} value = {Kspring2}
|
{perp} value = {Kspring2}
|
||||||
|
@ -28,7 +28,7 @@ keyword = {nudge} or {perp} or {ends} :l
|
||||||
{last} = apply force to last replica
|
{last} = apply force to last replica
|
||||||
{last/efirst} = apply force to last replica and set its target energy to that of first replica
|
{last/efirst} = apply force to last replica and set its target energy to that of first replica
|
||||||
{last/efirst/middle} = same as {last/efirst} plus prevent middle replicas having lower energy than first replica
|
{last/efirst/middle} = same as {last/efirst} plus prevent middle replicas having lower energy than first replica
|
||||||
{Kspring3} = spring constant for target energy term (1/distance units) :pre
|
{Kspring3} = spring constant for target energy term (1/distance units) :pre,ule
|
||||||
|
|
||||||
[Examples:]
|
[Examples:]
|
||||||
|
|
||||||
|
@ -59,22 +59,22 @@ interatomic force Fi = -Grad(V) for each replica I is altered. For
|
||||||
all intermediate replicas (i.e. for 1 < I < N, except the climbing
|
all intermediate replicas (i.e. for 1 < I < N, except the climbing
|
||||||
replica) the force vector becomes:
|
replica) the force vector becomes:
|
||||||
|
|
||||||
Fi = -Grad(V) + (Grad(V) dot T') T' + Fnudge_parallel + Fspring_perp :pre
|
Fi = -Grad(V) + (Grad(V) dot T') T' + Fnudge_parallel + Fnudge_perp :pre
|
||||||
|
|
||||||
T' is the unit "tangent" vector for replica I and is a function of Ri,
|
T' is the unit "tangent" vector for replica I and is a function of Ri,
|
||||||
Ri-1, Ri+1, and the potential energy of the 3 replicas; it points
|
Ri-1, Ri+1, and the potential energy of the 3 replicas; it points
|
||||||
roughly in the direction of (Ri+i - Ri-1); see the
|
roughly in the direction of (Ri+i - Ri-1); see the
|
||||||
"(Henkelman1)"_#Henkelman1 paper for details. Ri gives the atomic
|
"(Henkelman1)"_#Henkelman1 paper for details. Ri are the atomic
|
||||||
coordinates of replica I; Ri-1 and Ri+1 are the coordinates of its
|
coordinates of replica I; Ri-1 and Ri+1 are the coordinates of its
|
||||||
neighbor replicas. The term (Grad(V) dot T') is used to remove the
|
neighbor replicas. The term (Grad(V) dot T') is used to remove the
|
||||||
component of the gradient parallel to the path which would tend to
|
component of the gradient parallel to the path which would tend to
|
||||||
distribute the replica unevenly along the path. Fnudge_parallel is an
|
distribute the replica unevenly along the path. Fnudge_parallel is an
|
||||||
artificial nudging force which is applied only in the tangent
|
artificial nudging force which is applied only in the tangent
|
||||||
direction and which maintains the equal spacing between replicas (see
|
direction and which maintains the equal spacing between replicas (see
|
||||||
below for more information). Fspring_perp is an optional artificial
|
below for more information). Fnudge_perp is an optional artificial
|
||||||
spring which is applied only perpendicular to the tangent and which
|
spring which is applied in a direction perpendicular to the tangent
|
||||||
prevent the paths from forming acute kinks (see below for more
|
direction and which prevent the paths from forming acute kinks (see
|
||||||
information).
|
below for more information).
|
||||||
|
|
||||||
In the second stage of the NEB calculation, the interatomic force Fi
|
In the second stage of the NEB calculation, the interatomic force Fi
|
||||||
for the climbing replica (the replica of highest energy after the
|
for the climbing replica (the replica of highest energy after the
|
||||||
|
@ -86,7 +86,7 @@ and the relaxation procedure is continued to a new converged MEP.
|
||||||
|
|
||||||
:line
|
:line
|
||||||
|
|
||||||
The keyword {nudge} specifies how the parallel nudging force is
|
The keyword {parallel} specifies how the parallel nudging force is
|
||||||
computed. With a value of {neigh}, the parallel nudging force is
|
computed. With a value of {neigh}, the parallel nudging force is
|
||||||
computed as in "(Henkelman1)"_#Henkelman1 by connecting each
|
computed as in "(Henkelman1)"_#Henkelman1 by connecting each
|
||||||
intermediate replica with the previous and the next image:
|
intermediate replica with the previous and the next image:
|
||||||
|
@ -113,15 +113,16 @@ keeping the replicas equally spaced.
|
||||||
|
|
||||||
:line
|
:line
|
||||||
|
|
||||||
The keyword {perp} adds a spring force perpendicular to the path in
|
The keyword {perp} specifies if and how a perpendicual nudging force
|
||||||
order to prevent the path from becoming too kinky. It
|
is computed. It adds a spring force perpendicular to the path in
|
||||||
can significantly improve the convergence of the NEB calculation when
|
order to prevent the path from becoming too kinky. It can
|
||||||
the resolution is poor. I.e. when too few replicas are used; see
|
significantly improve the convergence of the NEB calculation when the
|
||||||
|
resolution is poor. I.e. when few replicas are used; see
|
||||||
"(Maras)"_#Maras1 for details.
|
"(Maras)"_#Maras1 for details.
|
||||||
|
|
||||||
The perpendicular spring force is given by
|
The perpendicular spring force is given by
|
||||||
|
|
||||||
Fspring_perp = {Kspring2} * F(Ri-1,Ri,Ri+1) (Ri+1 + Ri-1 - 2 Ri) :pre
|
Fnudge_perp = {Kspring2} * F(Ri-1,Ri,Ri+1) (Ri+1 + Ri-1 - 2 Ri) :pre
|
||||||
|
|
||||||
where {Kspring2} is the specified value. F(Ri-1 Ri R+1) is a smooth
|
where {Kspring2} is the specified value. F(Ri-1 Ri R+1) is a smooth
|
||||||
scalar function of the angle Ri-1 Ri Ri+1. It is equal to 0.0 when
|
scalar function of the angle Ri-1 Ri Ri+1. It is equal to 0.0 when
|
||||||
|
@ -133,11 +134,11 @@ force is added.
|
||||||
|
|
||||||
:line
|
:line
|
||||||
|
|
||||||
By default, no nudging forces act on the first and last replicas during
|
By default, no additional forces act on the first and last replicas
|
||||||
the NEB relaxation, so these replicas simply relax toward their
|
during the NEB relaxation, so these replicas simply relax toward their
|
||||||
respective local minima. By using the key word {end}, additional forces
|
respective local minima. By using the key word {end}, additional
|
||||||
can be applied to the first or last replica, to enable them to relax
|
forces can be applied to the first and/or last replicas, to enable
|
||||||
toward a MEP while constraining their energy.
|
them to relax toward a MEP while constraining their energy.
|
||||||
|
|
||||||
The interatomic force Fi for the specified replica becomes:
|
The interatomic force Fi for the specified replica becomes:
|
||||||
|
|
||||||
|
@ -177,9 +178,10 @@ only be done if a particular intermediate replica has a lower energy
|
||||||
than the first replica. This should effectively prevent the
|
than the first replica. This should effectively prevent the
|
||||||
intermediate replicas from over-relaxing.
|
intermediate replicas from over-relaxing.
|
||||||
|
|
||||||
After converging a NEB calculation using an {estyle} of {last/efirst/middle},
|
After converging a NEB calculation using an {estyle} of
|
||||||
you should check that all intermediate replicas have a larger energy than the
|
{last/efirst/middle}, you should check that all intermediate replicas
|
||||||
first replica. If this is not the case, the path is probably not a MEP.
|
have a larger energy than the first replica. If this is not the case,
|
||||||
|
the path is probably not a MEP.
|
||||||
|
|
||||||
Finally, note that if the last replica converges toward a local
|
Finally, note that if the last replica converges toward a local
|
||||||
minimum which has a larger energy than the energy of the first
|
minimum which has a larger energy than the energy of the first
|
||||||
|
|
|
@ -8,9 +8,7 @@ mpirun -np 3 lmp_g++ -partition 3x1 -in in.neb.sivac
|
||||||
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop1
|
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop1
|
||||||
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop2
|
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop2
|
||||||
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop1.end
|
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.hop1.end
|
||||||
mpirun -np 6 lmp_g++ -partition 3x2 -in in.neb.sivac
|
mpirun -np 8 lmp_g++ -partition 4x2 -in in.neb.sivac
|
||||||
mpirun -np 9 lmp_g++ -partition 3x3 -in in.neb.sivac
|
|
||||||
|
|
||||||
|
|
||||||
Note that more than 4 replicas should be used for a precise estimate
|
Note that more than 4 replicas should be used for a precise estimate
|
||||||
of the activation energy corresponding to a transition.
|
of the activation energy corresponding to a transition.
|
||||||
|
|
|
@ -51,7 +51,7 @@ set group nebatoms type 3
|
||||||
group nonneb subtract all nebatoms
|
group nonneb subtract all nebatoms
|
||||||
|
|
||||||
fix 1 lower setforce 0.0 0.0 0.0
|
fix 1 lower setforce 0.0 0.0 0.0
|
||||||
fix 2 nebatoms neb 1.0 #nudge ideal
|
fix 2 nebatoms neb 1.0 parallel ideal
|
||||||
fix 3 all enforce2d
|
fix 3 all enforce2d
|
||||||
|
|
||||||
thermo 100
|
thermo 100
|
||||||
|
|
|
@ -41,7 +41,7 @@ set group nebatoms type 3
|
||||||
group nonneb subtract all nebatoms
|
group nonneb subtract all nebatoms
|
||||||
|
|
||||||
fix 1 lower setforce 0.0 0.0 0.0
|
fix 1 lower setforce 0.0 0.0 0.0
|
||||||
fix 2 nebatoms neb 1.0 nudge ideal end first 1.0
|
fix 2 nebatoms neb 1.0 parallel ideal end first 1.0
|
||||||
fix 3 all enforce2d
|
fix 3 all enforce2d
|
||||||
|
|
||||||
thermo 100
|
thermo 100
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
LAMMPS (19 May 2017)
|
||||||
|
Running on 4 partitions of processors
|
||||||
|
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
||||||
|
0 4327.2753 2746.3378 0.082169072 4.9967651 4514.5424 0.42933428 0.42323635 1.8941131 0 -3.0535948 0.33333333 -2.6242605 0.66666667 -2.7623811 1 -3.0474969
|
||||||
|
87 0.095951502 0.052720903 0.005588927 0.065110105 0.12467831 0.0071014928 0.0022798007 2.3003372 0 -3.0535967 0.32435271 -3.0473127 0.62805027 -3.0464952 1 -3.048775
|
||||||
|
Climbing replica = 3
|
||||||
|
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
||||||
|
87 0.14137277 0.11108954 0.005588927 0.065110105 0.12467831 0.0071014928 0.0022798007 2.3003372 0 -3.0535967 0.32435271 -3.0473127 0.62805027 -3.0464952 1 -3.048775
|
||||||
|
124 0.099583263 0.085936899 0.0044220372 0.023873795 0.091308308 0.0071061754 0.0022863931 2.308121 0 -3.0535968 0.32223905 -3.0473329 0.61673898 -3.0464906 1 -3.048777
|
|
@ -0,0 +1,9 @@
|
||||||
|
LAMMPS (19 May 2017)
|
||||||
|
Running on 4 partitions of processors
|
||||||
|
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
||||||
|
0 4327.2753 2746.3378 0.082169072 4.9967651 4514.5424 0.42933428 0.42323635 1.8941131 0 -3.0535948 0.33333333 -2.6242605 0.66666667 -2.7623811 1 -3.0474969
|
||||||
|
87 0.095951792 0.052720902 0.0055889267 0.065110091 0.12467831 0.0071014928 0.0022798007 2.3003372 0 -3.0535967 0.32435271 -3.0473127 0.62805027 -3.0464952 1 -3.048775
|
||||||
|
Climbing replica = 3
|
||||||
|
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
||||||
|
87 0.14137297 0.11108954 0.0055889267 0.065110091 0.12467831 0.0071014928 0.0022798007 2.3003372 0 -3.0535967 0.32435271 -3.0473127 0.62805027 -3.0464952 1 -3.048775
|
||||||
|
124 0.099582186 0.08593683 0.0044220345 0.023873731 0.091308197 0.0071061754 0.0022863931 2.3081211 0 -3.0535968 0.32223904 -3.0473329 0.61673896 -3.0464906 1 -3.048777
|
|
@ -1,10 +0,0 @@
|
||||||
LAMMPS (19 May 2017)
|
|
||||||
Running on 4 partitions of processors
|
|
||||||
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
|
||||||
0 4327.2753 2746.3378 0.082169072 4.9967651 4514.5424 0.42933428 0.42323635 1.8941131 0 -3.0535948 0.33333333 -2.6242605 0.66666667 -2.7623811 1 -3.0474969
|
|
||||||
100 0.10482184 0.085218486 0.0051952047 0.04785954 0.19041553 0.0070900402 0.0022691875 2.3031875 0 -3.0535967 0.31839181 -3.0473647 0.63987598 -3.0465067 1 -3.0487759
|
|
||||||
111 0.096708467 0.07803707 0.0048656875 0.03613038 0.19671332 0.0070871172 0.0022668002 2.3052945 0 -3.0535968 0.31853431 -3.0473633 0.64178871 -3.0465096 1 -3.0487764
|
|
||||||
Climbing replica = 3
|
|
||||||
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
|
||||||
111 0.2023467 0.1777038 0.0048656875 0.03613038 0.19671332 0.0070871172 0.0022668002 2.3052945 0 -3.0535968 0.31853431 -3.0473633 0.64178871 -3.0465096 1 -3.0487764
|
|
||||||
179 0.096874474 0.090676856 0.0034851031 0.0094134782 0.093630619 0.0071047642 0.0022856172 2.3122768 0 -3.0535969 0.31577311 -3.0473955 0.61798541 -3.0464922 1 -3.0487778
|
|
|
@ -1,10 +0,0 @@
|
||||||
LAMMPS (19 May 2017)
|
|
||||||
Running on 4 partitions of processors
|
|
||||||
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
|
||||||
0 4327.2753 2746.3378 0.082169072 4.9967651 4514.5424 0.42933428 0.42323635 1.8941131 0 -3.0535948 0.33333333 -2.6242605 0.66666667 -2.7623811 1 -3.0474969
|
|
||||||
100 0.10482171 0.085218406 0.0051952008 0.047859379 0.1904156 0.0070900401 0.0022691875 2.3031875 0 -3.0535967 0.31839181 -3.0473647 0.639876 -3.0465067 1 -3.0487759
|
|
||||||
111 0.096708718 0.078036984 0.0048656841 0.036130268 0.1967134 0.0070871172 0.0022668002 2.3052946 0 -3.0535968 0.31853431 -3.0473633 0.64178873 -3.0465096 1 -3.0487764
|
|
||||||
Climbing replica = 3
|
|
||||||
Step MaxReplicaForce MaxAtomForce GradV0 GradV1 GradVc EBF EBR RDT RD1 PE1 RD2 PE2 ... RDN PEN
|
|
||||||
111 0.20234693 0.17770387 0.0048656841 0.036130268 0.1967134 0.0070871172 0.0022668002 2.3052946 0 -3.0535968 0.31853431 -3.0473633 0.64178873 -3.0465096 1 -3.0487764
|
|
||||||
178 0.09975409 0.093814031 0.0035463662 0.010006594 0.096949208 0.0071042931 0.0022851195 2.312004 0 -3.0535969 0.31607934 -3.0473923 0.618931 -3.0464926 1 -3.0487777
|
|
|
@ -49,8 +49,6 @@ FixNEB::FixNEB(LAMMPS *lmp, int narg, char **arg) :
|
||||||
displacements(NULL)
|
displacements(NULL)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (narg < 4) error->all(FLERR,"Illegal fix neb command");
|
if (narg < 4) error->all(FLERR,"Illegal fix neb command");
|
||||||
|
|
||||||
kspring = force->numeric(FLERR,arg[3]);
|
kspring = force->numeric(FLERR,arg[3]);
|
||||||
|
@ -68,7 +66,7 @@ FixNEB::FixNEB(LAMMPS *lmp, int narg, char **arg) :
|
||||||
|
|
||||||
int iarg = 4;
|
int iarg = 4;
|
||||||
while (iarg < narg) {
|
while (iarg < narg) {
|
||||||
if (strcmp(arg[iarg],"nudge") == 0) {
|
if (strcmp(arg[iarg],"parallel") == 0) {
|
||||||
if (iarg+2 > narg) error->all(FLERR,"Illegal fix neb command");
|
if (iarg+2 > narg) error->all(FLERR,"Illegal fix neb command");
|
||||||
if (strcmp(arg[iarg+1],"ideal") == 0) {
|
if (strcmp(arg[iarg+1],"ideal") == 0) {
|
||||||
NEBLongRange = true;
|
NEBLongRange = true;
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
|
|
||||||
using namespace LAMMPS_NS;
|
using namespace LAMMPS_NS;
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
// allocate space for static class variable
|
// allocate space for static class variable
|
||||||
Dump *Dump::dumpptr;
|
Dump *Dump::dumpptr;
|
||||||
#else
|
#else
|
||||||
|
@ -692,7 +692,7 @@ void Dump::sort()
|
||||||
index[idsort[i]-idlo] = i;
|
index[idsort[i]-idlo] = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
if (!reorderflag) {
|
if (!reorderflag) {
|
||||||
dumpptr = this;
|
dumpptr = this;
|
||||||
for (i = 0; i < nme; i++) index[i] = i;
|
for (i = 0; i < nme; i++) index[i] = i;
|
||||||
|
@ -728,7 +728,8 @@ void Dump::sort()
|
||||||
memcpy(&buf[i*size_one],&bufsort[index[i]*size_one],nbytes);
|
memcpy(&buf[i*size_one],&bufsort[index[i]*size_one],nbytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------
|
/* ----------------------------------------------------------------------
|
||||||
compare two atom IDs
|
compare two atom IDs
|
||||||
called via qsort() in sort() method
|
called via qsort() in sort() method
|
||||||
|
@ -795,6 +796,7 @@ int Dump::bufcompare_reverse(const void *pi, const void *pj)
|
||||||
compare two atom IDs
|
compare two atom IDs
|
||||||
called via merge_sort() in sort() method
|
called via merge_sort() in sort() method
|
||||||
------------------------------------------------------------------------- */
|
------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int Dump::idcompare(const int i, const int j, void *ptr)
|
int Dump::idcompare(const int i, const int j, void *ptr)
|
||||||
{
|
{
|
||||||
tagint *idsort = ((Dump *)ptr)->idsort;
|
tagint *idsort = ((Dump *)ptr)->idsort;
|
||||||
|
|
|
@ -23,17 +23,13 @@
|
||||||
|
|
||||||
using namespace LAMMPS_NS;
|
using namespace LAMMPS_NS;
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
// allocate space for static class variable
|
// allocate space for static class variable
|
||||||
// prototype for non-class function
|
// prototype for non-class function
|
||||||
|
|
||||||
int *Irregular::proc_recv_copy;
|
int *Irregular::proc_recv_copy;
|
||||||
static int compare_standalone(const void *, const void *);
|
static int compare_standalone(const void *, const void *);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#include "mergesort.h"
|
#include "mergesort.h"
|
||||||
|
|
||||||
// prototype for non-class function
|
// prototype for non-class function
|
||||||
static int compare_standalone(const int, const int, void *);
|
static int compare_standalone(const int, const int, void *);
|
||||||
#endif
|
#endif
|
||||||
|
@ -433,7 +429,7 @@ int Irregular::create_atom(int n, int *sizes, int *proclist, int sortflag)
|
||||||
|
|
||||||
for (i = 0; i < nrecv_proc; i++) order[i] = i;
|
for (i = 0; i < nrecv_proc; i++) order[i] = i;
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
proc_recv_copy = proc_recv;
|
proc_recv_copy = proc_recv;
|
||||||
qsort(order,nrecv_proc,sizeof(int),compare_standalone);
|
qsort(order,nrecv_proc,sizeof(int),compare_standalone);
|
||||||
#else
|
#else
|
||||||
|
@ -464,7 +460,7 @@ int Irregular::create_atom(int n, int *sizes, int *proclist, int sortflag)
|
||||||
return nrecvsize;
|
return nrecvsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------
|
/* ----------------------------------------------------------------------
|
||||||
comparison function invoked by qsort()
|
comparison function invoked by qsort()
|
||||||
|
@ -705,12 +701,13 @@ int Irregular::create_data(int n, int *proclist, int sortflag)
|
||||||
|
|
||||||
for (i = 0; i < nrecv_proc; i++) order[i] = i;
|
for (i = 0; i < nrecv_proc; i++) order[i] = i;
|
||||||
|
|
||||||
#if defined(LMP_USE_LIBC_QSORT)
|
#if defined(LMP_QSORT)
|
||||||
proc_recv_copy = proc_recv;
|
proc_recv_copy = proc_recv;
|
||||||
qsort(order,nrecv_proc,sizeof(int),compare_standalone);
|
qsort(order,nrecv_proc,sizeof(int),compare_standalone);
|
||||||
#else
|
#else
|
||||||
merge_sort(order,nrecv_proc,(void *)proc_recv,compare_standalone);
|
merge_sort(order,nrecv_proc,(void *)proc_recv,compare_standalone);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int j;
|
int j;
|
||||||
for (i = 0; i < nrecv_proc; i++) {
|
for (i = 0; i < nrecv_proc; i++) {
|
||||||
j = order[i];
|
j = order[i];
|
||||||
|
|
Loading…
Reference in New Issue