diff --git a/examples/DIFFUSE/README b/examples/DIFFUSE/README
index df2a675f73b778dd3d4fda1bafff791f2bebf4a6..e78ca2eacf1a109ec3aeb79b3b13e3444ed7d7a9 100644
--- a/examples/DIFFUSE/README
+++ b/examples/DIFFUSE/README
@@ -47,7 +47,7 @@ compute the diffusion coefficient.  You can see that both measures
 give roughly the same answer and rapidly become roughly constant for
 the 100K step simulation.
 
-Dcoeff = 0.36
+Dcoeff = 0.33
 
 (2) in.vacf.2d
 
@@ -58,4 +58,4 @@ that point in time, converted into the diffusion coefficient.  You can
 see the VACF approach gives a more noise, fluctuating value for the
 diffusion coefficient, compared to the MSD approach.
 
-Dcoeff = 0.25 to 0.45
+Dcoeff = ~0.25
diff --git a/examples/DIFFUSE/log.13Oct16.msd.2d.g++.8 b/examples/DIFFUSE/log.13Oct16.msd.2d.g++.8
deleted file mode 100644
index 473aa565278ec6802b78373adcf4b510722c93da..0000000000000000000000000000000000000000
--- a/examples/DIFFUSE/log.13Oct16.msd.2d.g++.8
+++ /dev/null
@@ -1,245 +0,0 @@
-LAMMPS (13 Oct 2016)
-# sample LAMMPS input script for diffusion of 2d LJ liquid
-# mean-squared displacement via compute msd
-
-# settings
-
-variable	x equal 40
-variable	y equal 40
-
-variable	rho equal 0.6
-variable        t equal 1.0
-variable	rc equal 2.5
-
-# problem setup
-
-units		lj
-dimension	2
-atom_style	atomic
-neigh_modify	delay 0 every 1
-
-lattice         sq2 ${rho}
-lattice         sq2 0.6
-Lattice spacing in x,y,z = 1.82574 1.82574 1.82574
-region          simbox block 0 $x 0 $y -0.1 0.1
-region          simbox block 0 40 0 $y -0.1 0.1
-region          simbox block 0 40 0 40 -0.1 0.1
-create_box      1 simbox
-Created orthogonal box = (0 0 -0.182574) to (73.0297 73.0297 0.182574)
-  4 by 2 by 1 MPI processor grid
-create_atoms    1 box
-Created 3200 atoms
-
-pair_style      lj/cut ${rc}
-pair_style      lj/cut 2.5
-pair_coeff      * * 1 1
-
-mass            * 1.0
-velocity        all create $t 97287
-velocity        all create 1 97287
-
-fix             1 all nve
-fix	        2 all langevin $t $t 0.1 498094
-fix	        2 all langevin 1 $t 0.1 498094
-fix	        2 all langevin 1 1 0.1 498094
-fix	        3 all enforce2d
-
-# equilibration run
-
-thermo          1000
-run	        5000
-Neighbor list info ...
-  1 neighbor list requests
-  update every 1 steps, delay 0 steps, check yes
-  max neighbors/atom: 2000, page size: 100000
-  master list distance cutoff = 2.8
-  ghost atom cutoff = 2.8
-  binsize = 1.4 -> bins = 53 53 1
-Memory usage per processor = 2.478 Mbytes
-Step Temp E_pair E_mol TotEng Press 
-       0            1     -1.56492            0   -0.5652325   -1.5346995 
-    1000   0.97537833   -1.5723957            0   -0.5973222   0.92877783 
-    2000   0.99008371   -1.5748206            0  -0.58504633    1.0809416 
-    3000    1.0111412   -1.5848987            0  -0.57407352    1.0174297 
-    4000    1.0055417   -1.5857581            0  -0.58053054   0.95647691 
-    5000   0.97069905   -1.5851114            0  -0.61471567   0.90108287 
-Loop time of 0.554412 on 8 procs for 5000 steps with 3200 atoms
-
-Performance: 3896017.421 tau/day, 9018.559 timesteps/s
-98.9% CPU use with 8 MPI tasks x no OpenMP threads
-
-MPI task timing breakdown:
-Section |  min time  |  avg time  |  max time  |%varavg| %total
----------------------------------------------------------------
-Pair    | 0.23992    | 0.24608    | 0.25161    |   0.7 | 44.39
-Neigh   | 0.063106   | 0.064417   | 0.066279   |   0.4 | 11.62
-Comm    | 0.072465   | 0.085066   | 0.094837   |   2.3 | 15.34
-Output  | 0.00013208 | 0.00013691 | 0.00014591 |   0.0 |  0.02
-Modify  | 0.11441    | 0.11621    | 0.11769    |   0.3 | 20.96
-Other   |            | 0.04251    |            |       |  7.67
-
-Nlocal:    400 ave 406 max 394 min
-Histogram: 1 1 0 1 0 2 1 0 1 1
-Nghost:    202.5 ave 212 max 191 min
-Histogram: 1 0 0 0 3 1 0 2 0 1
-Neighs:    2800.88 ave 2903 max 2690 min
-Histogram: 1 1 0 0 1 2 1 0 1 1
-
-Total # of neighbors = 22407
-Ave neighs/atom = 7.00219
-Neighbor list builds = 599
-Dangerous builds = 0
-
-unfix		2
-
-# data gathering run
-
-reset_timestep  0
-
-# factor of 4 in 2 variables is for 2d
-
-compute         msd all msd com yes
-variable        twopoint equal c_msd[4]/4/(step*dt+1.0e-6)
-fix             9 all vector 10 c_msd[4]
-variable        fitslope equal slope(f_9)/4/(10*dt)
-
-thermo_style	custom step temp c_msd[4] v_twopoint v_fitslope
-
-# only need to run for 10K steps to make a good 100-frame movie
-
-#dump	        1 all custom 1 tmp.dump id type vx vy vz
-
-#dump		2 all image 100 image.*.jpg type type zoom 1.6 adiam 1.2
-
-thermo          1000
-run	        100000
-Memory usage per processor = 2.853 Mbytes
-Step Temp c_msd[4] v_twopoint v_fitslope 
-       0   0.97069905            0            0        5e+20 
-    1000   0.98138076    4.0484996   0.20242494   0.18046446 
-    2000   0.97606079    9.2121392   0.23030346    0.2091528 
-    3000   0.97924866    14.815034   0.24691721   0.22619184 
-    4000   0.98568451    20.516817   0.25646019   0.23715506 
-    5000   0.97551815     27.33922   0.27339219   0.24709999 
-    6000   0.98482252     34.37734   0.28647782   0.25735178 
-    7000    0.9672559    41.696689   0.29783348   0.26654059 
-    8000    0.9836541    48.340277   0.30212673   0.27440308 
-    9000   0.99087147    56.042692   0.31134828   0.28113047 
-   10000   0.99663166     63.69663   0.31848314   0.28767921 
-   11000   0.97776688    71.144109   0.32338231   0.29344527 
-   12000   0.98246011    78.301774   0.32625739   0.29849471 
-   13000   0.98788732    85.061923   0.32716124    0.3026655 
-   14000   0.96872483      91.1658   0.32559214   0.30601023 
-   15000   0.98955796    97.278388   0.32426129    0.3084275 
-   16000   0.99855196    104.23997    0.3257499   0.31049883 
-   17000   0.98600861    110.66055    0.3254722   0.31220348 
-   18000   0.98696963    116.90111   0.32472531   0.31352676 
-   19000    0.9881192    124.21305   0.32687644   0.31480062 
-   20000   0.98527319    131.09874   0.32774685   0.31596198 
-   21000   0.99015191    137.89263   0.32831579   0.31705324 
-   22000   0.97972418    146.68982   0.33338595   0.31833889 
-   23000   0.98911012     155.1264   0.33723129   0.31979515 
-   24000   0.98810498    162.88634   0.33934653   0.32131187 
-   25000   0.96961962    170.37907   0.34075814   0.32276215 
-   26000   0.99118408    179.26511   0.34474059   0.32427111 
-   27000   0.98515159    185.90764    0.3442734   0.32574529 
-   28000   0.98951677    192.12183   0.34307469   0.32700292 
-   29000    0.9832026    196.99457   0.33964581   0.32799023 
-   30000   0.98449493    203.48475   0.33914124    0.3287171 
-   31000   0.96585993    210.06193   0.33880956   0.32935775 
-   32000   0.98758117    218.94174   0.34209646   0.33001591 
-   33000   0.98875584    225.96489   0.34237104   0.33072947 
-   34000   0.98007229     233.5792   0.34349882    0.3314385 
-   35000   0.98415295    241.98148   0.34568783   0.33216634 
-   36000   0.98101154    250.30876   0.34765106   0.33295272 
-   37000   0.97606878     258.2127   0.34893608   0.33377673 
-   38000   0.97220293    266.40464   0.35053242   0.33459273 
-   39000     0.979783     272.8578   0.34981769   0.33539728 
-   40000   0.98375673    279.87598   0.34984497   0.33609699 
-   41000   0.97506523    288.07676   0.35131312   0.33677708 
-   42000   0.97106749    296.11647    0.3525196   0.33751312 
-   43000   0.97717259    304.46747   0.35403194   0.33823441 
-   44000   0.98541435    312.57228   0.35519578    0.3389771 
-   45000   0.97678287    321.82674   0.35758527   0.33973306 
-   46000   0.98169719    329.78197   0.35845866   0.34051748 
-   47000   0.99471466    337.11283   0.35863066   0.34127239 
-   48000   0.98332437     346.0754    0.3604952   0.34202442 
-   49000   0.98126947    356.11859   0.36338631   0.34282132 
-   50000   0.98809751    365.65248   0.36565248   0.34368171 
-   51000   0.95919516    373.91833   0.36658659   0.34454516 
-   52000   0.98097913    381.26492   0.36660089   0.34538506 
-   53000   0.97774072    388.81031   0.36680218   0.34618232 
-   54000   0.99096915    395.56767   0.36626636    0.3469296 
-   55000   0.97652739    401.72735   0.36520668   0.34760374 
-   56000   0.99185306    407.28834    0.3636503   0.34819906 
-   57000   0.96289342    414.75298    0.3638184   0.34871992 
-   58000   0.97871716    424.69443   0.36611588   0.34927986 
-   59000   0.98637393    433.14205   0.36706953   0.34986296 
-   60000   0.98009845    438.14533   0.36512111   0.35040349 
-   61000   0.99416712    446.08007    0.3656394   0.35088379 
-   62000   0.97612483    450.90846   0.36363585   0.35132647 
-   63000   0.97786531    455.36749   0.36140277   0.35167458 
-   64000   0.99080668    458.04873   0.35785057    0.3519105 
-   65000   0.97952497    461.31241    0.3548557    0.3520506 
-   66000   0.98095955    463.91727   0.35145248   0.35207764 
-   67000   0.98370788       468.93   0.34994776   0.35204043 
-   68000   0.96931818    471.07765   0.34638063   0.35192685 
-   69000   0.98512552    474.59146   0.34390685   0.35174053 
-   70000   0.98065743    478.66071    0.3419005   0.35149002 
-   71000   0.98971283    482.57357   0.33984054   0.35119434 
-   72000   0.99890324    485.32018    0.3370279   0.35084345 
-   73000   0.98649924    490.19497   0.33574998   0.35043722 
-   74000   0.98723422    496.04991   0.33516886   0.35003351 
-   75000    1.0025633     501.6313   0.33442087   0.34962094 
-   76000   0.97859959    505.97813   0.33288035   0.34921013 
-   77000   0.97973006    510.55334   0.33152814    0.3487692 
-   78000    0.9903944    515.06966   0.33017286   0.34830833 
-   79000   0.96847518    518.76483   0.32833217    0.3478214 
-   80000   0.99171112    524.18127   0.32761329   0.34733349 
-   81000   0.97202573    529.09959   0.32660468    0.3468315 
-   82000   0.99368438    535.80271   0.32670897   0.34633058 
-   83000   0.97932483    543.08233   0.32715803   0.34586259 
-   84000   0.99078651    547.57861   0.32593965   0.34540839 
-   85000   0.98973457    552.24581   0.32485048   0.34493584 
-   86000    0.9835873     557.3493   0.32404029   0.34446152 
-   87000   0.97180564    564.93434   0.32467491   0.34400358 
-   88000   0.99743353    571.39837   0.32465817    0.3435667 
-   89000   0.98993437    577.81703   0.32461631    0.3431411 
-   90000    0.9926071    583.39378   0.32410765     0.342724 
-   91000   0.98800458    591.08741    0.3247733   0.34232767 
-   92000   0.98501879    596.10133   0.32396811   0.34193949 
-   93000   0.98810082    604.02652   0.32474544    0.3415681 
-   94000   0.97563748    609.43676   0.32416849     0.341209 
-   95000   0.97283448    615.15754   0.32376713   0.34084828 
-   96000    0.9883071    622.30912   0.32411933   0.34049871 
-   97000   0.97717678    628.84457   0.32414669   0.34016355 
-   98000   0.97190208    634.37377   0.32366009    0.3398341 
-   99000   0.98687379    640.66666   0.32356902   0.33950845 
-  100000   0.97559757    646.96406   0.32348203   0.33919036 
-Loop time of 9.58779 on 8 procs for 100000 steps with 3200 atoms
-
-Performance: 4505729.040 tau/day, 10429.928 timesteps/s
-99.4% CPU use with 8 MPI tasks x no OpenMP threads
-
-MPI task timing breakdown:
-Section |  min time  |  avg time  |  max time  |%varavg| %total
----------------------------------------------------------------
-Pair    | 4.8572     | 4.9363     | 4.9822     |   1.7 | 51.49
-Neigh   | 1.3583     | 1.376      | 1.3991     |   1.2 | 14.35
-Comm    | 1.5192     | 1.7079     | 1.8264     |   7.2 | 17.81
-Output  | 0.0085125  | 0.0086059  | 0.0089455  |   0.1 |  0.09
-Modify  | 0.77663    | 0.7903     | 0.81378    |   1.3 |  8.24
-Other   |            | 0.7686     |            |       |  8.02
-
-Nlocal:    400 ave 413 max 391 min
-Histogram: 2 1 0 2 0 0 1 1 0 1
-Nghost:    204.75 ave 213 max 197 min
-Histogram: 1 1 0 1 0 3 0 1 0 1
-Neighs:    2800.62 ave 2959 max 2661 min
-Histogram: 1 1 1 2 0 0 0 1 1 1
-
-Total # of neighbors = 22405
-Ave neighs/atom = 7.00156
-Neighbor list builds = 12728
-Dangerous builds = 0
-Total wall time: 0:00:10
diff --git a/examples/DIFFUSE/log.3Aug18.msd.2d.g++.8 b/examples/DIFFUSE/log.3Aug18.msd.2d.g++.8
new file mode 100644
index 0000000000000000000000000000000000000000..113da9040d8a8eb37b84a4245ce3d904e219db3c
--- /dev/null
+++ b/examples/DIFFUSE/log.3Aug18.msd.2d.g++.8
@@ -0,0 +1,251 @@
+LAMMPS (2 Aug 2018)
+# sample LAMMPS input script for diffusion of 2d LJ liquid
+# mean-squared displacement via compute msd
+
+# settings
+
+variable	x equal 40
+variable	y equal 40
+
+variable	rho equal 0.6
+variable        t equal 1.0
+variable	rc equal 2.5
+
+# problem setup
+
+units		lj
+dimension	2
+atom_style	atomic
+neigh_modify	delay 0 every 1
+
+lattice         sq2 ${rho}
+lattice         sq2 0.6
+Lattice spacing in x,y,z = 1.82574 1.82574 1.82574
+region          simbox block 0 $x 0 $y -0.1 0.1
+region          simbox block 0 40 0 $y -0.1 0.1
+region          simbox block 0 40 0 40 -0.1 0.1
+create_box      1 simbox
+Created orthogonal box = (0 0 -0.182574) to (73.0297 73.0297 0.182574)
+  4 by 2 by 1 MPI processor grid
+create_atoms    1 box
+Created 3200 atoms
+  Time spent = 0.000706911 secs
+
+pair_style      lj/cut ${rc}
+pair_style      lj/cut 2.5
+pair_coeff      * * 1 1
+
+mass            * 1.0
+velocity        all create $t 97287
+velocity        all create 1 97287
+
+fix             1 all nve
+fix	        2 all langevin $t $t 0.1 498094
+fix	        2 all langevin 1 $t 0.1 498094
+fix	        2 all langevin 1 1 0.1 498094
+fix	        3 all enforce2d
+
+# equilibration run
+
+thermo          1000
+run	        5000
+Neighbor list info ...
+  update every 1 steps, delay 0 steps, check yes
+  max neighbors/atom: 2000, page size: 100000
+  master list distance cutoff = 2.8
+  ghost atom cutoff = 2.8
+  binsize = 1.4, bins = 53 53 1
+  1 neighbor lists, perpetual/occasional/extra = 1 0 0
+  (1) pair lj/cut, perpetual
+      attributes: half, newton on
+      pair build: half/bin/atomonly/newton
+      stencil: half/bin/2d/newton
+      bin: standard
+Per MPI rank memory allocation (min/avg/max) = 3.052 | 3.052 | 3.052 Mbytes
+Step Temp E_pair E_mol TotEng Press 
+       0            1     -1.56492            0   -0.5652325   -1.5346995 
+    1000   0.97537833   -1.5723957            0   -0.5973222   0.92877783 
+    2000   0.99008371   -1.5748206            0  -0.58504633    1.0809416 
+    3000    1.0111412   -1.5848987            0  -0.57407352    1.0174297 
+    4000    1.0055417   -1.5857581            0  -0.58053054   0.95647691 
+    5000   0.97069905   -1.5851114            0  -0.61471567   0.90108287 
+Loop time of 0.667446 on 8 procs for 5000 steps with 3200 atoms
+
+Performance: 3236214.756 tau/day, 7491.238 timesteps/s
+99.9% CPU use with 8 MPI tasks x no OpenMP threads
+
+MPI task timing breakdown:
+Section |  min time  |  avg time  |  max time  |%varavg| %total
+---------------------------------------------------------------
+Pair    | 0.22913    | 0.24877    | 0.28382    |   3.6 | 37.27
+Neigh   | 0.064419   | 0.071256   | 0.080013   |   1.7 | 10.68
+Comm    | 0.103      | 0.14054    | 0.17204    |   5.5 | 21.06
+Output  | 0.00010705 | 0.00013995 | 0.00021911 |   0.0 |  0.02
+Modify  | 0.13457    | 0.14973    | 0.16887    |   2.6 | 22.43
+Other   |            | 0.05701    |            |       |  8.54
+
+Nlocal:    400 ave 406 max 394 min
+Histogram: 1 1 0 1 0 2 1 0 1 1
+Nghost:    202.5 ave 212 max 191 min
+Histogram: 1 0 0 0 3 1 0 2 0 1
+Neighs:    2800.88 ave 2903 max 2690 min
+Histogram: 1 1 0 0 1 2 1 0 1 1
+
+Total # of neighbors = 22407
+Ave neighs/atom = 7.00219
+Neighbor list builds = 599
+Dangerous builds = 0
+
+unfix		2
+
+# data gathering run
+
+reset_timestep  0
+
+# factor of 4 in 2 variables is for 2d
+
+compute         msd all msd com yes
+variable        twopoint equal c_msd[4]/4/(step*dt+1.0e-6)
+fix             9 all vector 10 c_msd[4]
+variable        fitslope equal slope(f_9)/4/(10*dt)
+
+thermo_style	custom step temp c_msd[4] v_twopoint v_fitslope
+
+# only need to run for 10K steps to make a good 100-frame movie
+
+#dump	        1 all custom 1 tmp.dump id type vx vy vz
+
+#dump		2 all image 100 image.*.jpg type type zoom 1.6 adiam 1.2
+
+thermo          1000
+run	        100000
+Per MPI rank memory allocation (min/avg/max) = 3.427 | 3.427 | 3.427 Mbytes
+Step Temp c_msd[4] v_twopoint v_fitslope 
+       0   0.97069905            0            0        5e+20 
+    1000   0.98138076    4.0484996   0.20242494   0.20685564 
+    2000   0.97606079    9.2121392   0.23030346   0.23687918 
+    3000   0.97924866    14.815034   0.24691721   0.25405247 
+    4000   0.98568451    20.516817   0.25646019   0.26353644 
+    5000   0.97551815     27.33922   0.27339219   0.27544492 
+    6000   0.98482252     34.37734   0.28647782   0.28966619 
+    7000    0.9672559    41.696689   0.29783348   0.30165524 
+    8000    0.9836541    48.340277   0.30212673   0.31085371 
+    9000   0.99087147    56.042692   0.31134828   0.31811489 
+   10000   0.99663166     63.69663   0.31848314   0.32589374 
+   11000   0.97776688    71.144109   0.32338231   0.33219745 
+   12000   0.98246011    78.301774   0.32625739      0.33723 
+   13000   0.98788732    85.061923   0.32716124   0.34053027 
+   14000   0.96872483      91.1658   0.32559214   0.34231162 
+   15000   0.98955796    97.278388   0.32426129   0.34229511 
+   16000   0.99855196    104.23997    0.3257499   0.34217252 
+   17000   0.98600861    110.66055    0.3254722   0.34172446 
+   18000   0.98696963    116.90111   0.32472531    0.3408227 
+   19000    0.9881192    124.21305   0.32687644   0.34036538 
+   20000   0.98527319    131.09874   0.32774685   0.34003478 
+   21000   0.99015191    137.89263   0.32831579   0.33987868 
+   22000   0.97972418    146.68982   0.33338595   0.34060035 
+   23000   0.98911012     155.1264   0.33723129   0.34201036 
+   24000   0.98810498    162.88634   0.33934653   0.34371488 
+   25000   0.96961962    170.37907   0.34075814   0.34531409 
+   26000   0.99118408    179.26511   0.34474059   0.34717195 
+   27000   0.98515159    185.90764    0.3442734   0.34898035 
+   28000   0.98951677    192.12183   0.34307469   0.35021808 
+   29000    0.9832026    196.99457   0.33964581   0.35075459 
+   30000   0.98449493    203.48475   0.33914124   0.35066186 
+   31000   0.96585993    210.06193   0.33880956   0.35046715 
+   32000   0.98758117    218.94174   0.34209646   0.35046623 
+   33000   0.98875584    225.96489   0.34237104   0.35073944 
+   34000   0.98007229     233.5792   0.34349882   0.35109188 
+   35000   0.98415295    241.98148   0.34568783   0.35157879 
+   36000   0.98101154    250.30876   0.34765106    0.3523013 
+   37000   0.97606878     258.2127   0.34893608   0.35318097 
+   38000   0.97220293    266.40464   0.35053242    0.3540743 
+   39000     0.979783     272.8578   0.34981769   0.35496561 
+   40000   0.98375673    279.87598   0.34984497   0.35558182 
+   41000   0.97506523    288.07676   0.35131312   0.35618259 
+   42000   0.97106749    296.11647    0.3525196   0.35698571 
+   43000   0.97717259    304.46747   0.35403194    0.3577736 
+   44000   0.98541435    312.57228   0.35519578   0.35865003 
+   45000   0.97678287    321.82674   0.35758527   0.35958623 
+   46000   0.98169719    329.78197   0.35845866   0.36062236 
+   47000   0.99471466    337.11283   0.35863066   0.36158322 
+   48000   0.98332437     346.0754    0.3604952   0.36255042 
+   49000   0.98126947    356.11859   0.36338631    0.3636628 
+   50000   0.98809751    365.65248   0.36565248   0.36496809 
+   51000   0.95919516    373.91833   0.36658659   0.36628073 
+   52000   0.98097913    381.26492   0.36660089   0.36752237 
+   53000   0.97774072    388.81031   0.36680218   0.36863962 
+   54000   0.99096915    395.56767   0.36626636   0.36961521 
+   55000   0.97652739    401.72735   0.36520668   0.37038579 
+   56000   0.99185306    407.28834    0.3636503   0.37094092 
+   57000   0.96289342    414.75298    0.3638184   0.37130039 
+   58000   0.97871716    424.69443   0.36611588   0.37180428 
+   59000   0.98637393    433.14205   0.36706953   0.37239862 
+   60000   0.98009845    438.14533   0.36512111   0.37288487 
+   61000   0.99416712    446.08007    0.3656394   0.37321496 
+   62000   0.97612483    450.90846   0.36363585   0.37345792 
+   63000   0.97786531    455.36749   0.36140277   0.37344803 
+   64000   0.99080668    458.04873   0.35785057   0.37313914 
+   65000   0.97952497    461.31241    0.3548557    0.3725875 
+   66000   0.98095955    463.91727   0.35145248   0.37174735 
+   67000   0.98370788       468.93   0.34994776   0.37076942 
+   68000   0.96931818    471.07765   0.34638063   0.36961868 
+   69000   0.98512552    474.59146   0.34390685   0.36830908 
+   70000   0.98065743    478.66071    0.3419005   0.36686789 
+   71000   0.98971283    482.57357   0.33984054   0.36535224 
+   72000   0.99890324    485.32018    0.3370279   0.36373174 
+   73000   0.98649924    490.19497   0.33574998   0.36200692 
+   74000   0.98723422    496.04991   0.33516886   0.36034919 
+   75000    1.0025633     501.6313   0.33442087   0.35872052 
+   76000   0.97859959    505.97813   0.33288035   0.35714939 
+   77000   0.97973006    510.55334   0.33152814   0.35553808 
+   78000    0.9903944    515.06966   0.33017286   0.35391584 
+   79000   0.96847518    518.76483   0.32833217   0.35226287 
+   80000   0.99171112    524.18127   0.32761329   0.35065267 
+   81000   0.97202573    529.09959   0.32660468   0.34904364 
+   82000   0.99368438    535.80271   0.32670897   0.34747913 
+   83000   0.97932483    543.08233   0.32715803   0.34605097 
+   84000   0.99078651    547.57861   0.32593965   0.34469765 
+   85000   0.98973457    552.24581   0.32485048   0.34332115 
+   86000    0.9835873     557.3493   0.32404029   0.34197018 
+   87000   0.97180564    564.93434   0.32467491   0.34069702 
+   88000   0.99743353    571.39837   0.32465817   0.33951258 
+   89000   0.98993437    577.81703   0.32461631   0.33838511 
+   90000    0.9926071    583.39378   0.32410765   0.33730429 
+   91000   0.98800458    591.08741    0.3247733   0.33630505 
+   92000   0.98501879    596.10133   0.32396811   0.33534725 
+   93000   0.98810082    604.02652   0.32474544   0.33445545 
+   94000   0.97563748    609.43676   0.32416849   0.33361404 
+   95000   0.97283448    615.15754   0.32376713   0.33278044 
+   96000    0.9883071    622.30912   0.32411933   0.33199212 
+   97000   0.97717678    628.84457   0.32414669   0.33125729 
+   98000   0.97190208    634.37377   0.32366009   0.33054877 
+   99000   0.98687379    640.66666   0.32356902   0.32986014 
+  100000   0.97559757    646.96406   0.32348203   0.32920186 
+Loop time of 7.61838 on 8 procs for 100000 steps with 3200 atoms
+
+Performance: 5670494.518 tau/day, 13126.145 timesteps/s
+100.0% CPU use with 8 MPI tasks x no OpenMP threads
+
+MPI task timing breakdown:
+Section |  min time  |  avg time  |  max time  |%varavg| %total
+---------------------------------------------------------------
+Pair    | 3.5458     | 3.6709     | 3.8234     |   4.3 | 48.19
+Neigh   | 1.1363     | 1.1513     | 1.1753     |   1.0 | 15.11
+Comm    | 1.5901     | 1.7017     | 1.8664     |   6.9 | 22.34
+Output  | 0.0041966  | 0.0043583  | 0.0050626  |   0.4 |  0.06
+Modify  | 0.63816    | 0.65537    | 0.68918    |   2.0 |  8.60
+Other   |            | 0.4348     |            |       |  5.71
+
+Nlocal:    400 ave 413 max 391 min
+Histogram: 2 1 0 2 0 0 1 1 0 1
+Nghost:    204.75 ave 213 max 197 min
+Histogram: 1 1 0 1 0 3 0 1 0 1
+Neighs:    2800.62 ave 2959 max 2661 min
+Histogram: 1 1 1 2 0 0 0 1 1 1
+
+Total # of neighbors = 22405
+Ave neighs/atom = 7.00156
+Neighbor list builds = 12728
+Dangerous builds = 0
+Total wall time: 0:00:08
diff --git a/examples/DIFFUSE/log.13Oct16.vacf.2d.g++.8 b/examples/DIFFUSE/log.3Aug18.vacf.2d.g++.8
similarity index 84%
rename from examples/DIFFUSE/log.13Oct16.vacf.2d.g++.8
rename to examples/DIFFUSE/log.3Aug18.vacf.2d.g++.8
index 458315bc29de64e5a2102de7e98ed958e591252c..80c57ada9c31b8e299944689fd1cba2f6afb95f4 100644
--- a/examples/DIFFUSE/log.13Oct16.vacf.2d.g++.8
+++ b/examples/DIFFUSE/log.3Aug18.vacf.2d.g++.8
@@ -1,4 +1,4 @@
-LAMMPS (13 Oct 2016)
+LAMMPS (2 Aug 2018)
 # sample LAMMPS input script for diffusion of 2d LJ liquid
 # mean-squared displacement via compute msd
 
@@ -29,6 +29,7 @@ Created orthogonal box = (0 0 -0.182574) to (73.0297 73.0297 0.182574)
   4 by 2 by 1 MPI processor grid
 create_atoms    1 box
 Created 3200 atoms
+  Time spent = 0.000712872 secs
 
 pair_style      lj/cut ${rc}
 pair_style      lj/cut 2.5
@@ -49,13 +50,18 @@ fix	        3 all enforce2d
 thermo          1000
 run	        5000
 Neighbor list info ...
-  1 neighbor list requests
   update every 1 steps, delay 0 steps, check yes
   max neighbors/atom: 2000, page size: 100000
   master list distance cutoff = 2.8
   ghost atom cutoff = 2.8
-  binsize = 1.4 -> bins = 53 53 1
-Memory usage per processor = 2.478 Mbytes
+  binsize = 1.4, bins = 53 53 1
+  1 neighbor lists, perpetual/occasional/extra = 1 0 0
+  (1) pair lj/cut, perpetual
+      attributes: half, newton on
+      pair build: half/bin/atomonly/newton
+      stencil: half/bin/2d/newton
+      bin: standard
+Per MPI rank memory allocation (min/avg/max) = 3.052 | 3.052 | 3.052 Mbytes
 Step Temp E_pair E_mol TotEng Press 
        0            1     -1.56492            0   -0.5652325   -1.5346995 
     1000   0.97537833   -1.5723957            0   -0.5973222   0.92877783 
@@ -63,20 +69,20 @@ Step Temp E_pair E_mol TotEng Press
     3000    1.0111412   -1.5848987            0  -0.57407352    1.0174297 
     4000    1.0055417   -1.5857581            0  -0.58053054   0.95647691 
     5000   0.97069905   -1.5851114            0  -0.61471567   0.90108287 
-Loop time of 0.557588 on 8 procs for 5000 steps with 3200 atoms
+Loop time of 0.648098 on 8 procs for 5000 steps with 3200 atoms
 
-Performance: 3873826.669 tau/day, 8967.191 timesteps/s
-99.1% CPU use with 8 MPI tasks x no OpenMP threads
+Performance: 3332829.949 tau/day, 7714.884 timesteps/s
+99.9% CPU use with 8 MPI tasks x no OpenMP threads
 
 MPI task timing breakdown:
 Section |  min time  |  avg time  |  max time  |%varavg| %total
 ---------------------------------------------------------------
-Pair    | 0.23784    | 0.24683    | 0.25594    |   1.0 | 44.27
-Neigh   | 0.062975   | 0.06439    | 0.0662     |   0.4 | 11.55
-Comm    | 0.083826   | 0.092564   | 0.1035     |   2.1 | 16.60
-Output  | 0.00011778 | 0.00012615 | 0.00014257 |   0.1 |  0.02
-Modify  | 0.11466    | 0.11648    | 0.1187     |   0.4 | 20.89
-Other   |            | 0.0372     |            |       |  6.67
+Pair    | 0.22614    | 0.24602    | 0.27481    |   2.8 | 37.96
+Neigh   | 0.066875   | 0.07135    | 0.077825   |   1.2 | 11.01
+Comm    | 0.098293   | 0.12744    | 0.1569     |   5.6 | 19.66
+Output  | 0.0001049  | 0.00012228 | 0.00014496 |   0.0 |  0.02
+Modify  | 0.13725    | 0.14919    | 0.16903    |   2.4 | 23.02
+Other   |            | 0.05398    |            |       |  8.33
 
 Nlocal:    400 ave 406 max 394 min
 Histogram: 1 1 0 1 0 2 1 0 1 1
@@ -114,7 +120,7 @@ thermo_style	custom step temp c_vacf[4] v_vacf
 
 thermo          1000
 run	        100000
-Memory usage per processor = 2.853 Mbytes
+Per MPI rank memory allocation (min/avg/max) = 3.427 | 3.427 | 3.427 Mbytes
 Step Temp c_vacf[4] v_vacf 
        0   0.97069905    1.9407914            0 
     1000   0.98138076  0.029239763   0.22157396 
@@ -217,20 +223,20 @@ Step Temp c_vacf[4] v_vacf
    98000   0.97190208  0.015065013   0.20906937 
    99000   0.98687379 -0.036869401   0.22993959 
   100000   0.97559757  0.045464091   0.23369283 
-Loop time of 10.8346 on 8 procs for 100000 steps with 3200 atoms
+Loop time of 8.16691 on 8 procs for 100000 steps with 3200 atoms
 
-Performance: 3987213.825 tau/day, 9229.662 timesteps/s
-99.5% CPU use with 8 MPI tasks x no OpenMP threads
+Performance: 5289636.190 tau/day, 12244.528 timesteps/s
+100.0% CPU use with 8 MPI tasks x no OpenMP threads
 
 MPI task timing breakdown:
 Section |  min time  |  avg time  |  max time  |%varavg| %total
 ---------------------------------------------------------------
-Pair    | 4.8486     | 4.9469     | 5.0248     |   2.8 | 45.66
-Neigh   | 1.3613     | 1.374      | 1.3916     |   0.8 | 12.68
-Comm    | 1.8181     | 1.9534     | 2.0665     |   5.7 | 18.03
-Output  | 0.016565   | 0.016701   | 0.017039   |   0.1 |  0.15
-Modify  | 1.8395     | 1.9053     | 1.9704     |   2.8 | 17.59
-Other   |            | 0.6383     |            |       |  5.89
+Pair    | 3.5668     | 3.6612     | 3.7867     |   4.0 | 44.83
+Neigh   | 1.1409     | 1.1555     | 1.1804     |   1.4 | 14.15
+Comm    | 1.581      | 1.711      | 1.8239     |   7.1 | 20.95
+Output  | 0.016626   | 0.016831   | 0.017569   |   0.2 |  0.21
+Modify  | 1.225      | 1.2594     | 1.3008     |   2.0 | 15.42
+Other   |            | 0.363      |            |       |  4.45
 
 Nlocal:    400 ave 413 max 391 min
 Histogram: 2 1 0 2 0 0 1 1 0 1
@@ -243,4 +249,4 @@ Total # of neighbors = 22405
 Ave neighs/atom = 7.00156
 Neighbor list builds = 12728
 Dangerous builds = 0
-Total wall time: 0:00:11
+Total wall time: 0:00:08
diff --git a/src/variable.cpp b/src/variable.cpp
index 86296b4b402e4c066d2692d5362d579be635c54d..f005221400509f76fd5887f0323fa11cc8f30a32 100644
--- a/src/variable.cpp
+++ b/src/variable.cpp
@@ -1576,7 +1576,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
           newtree->nextra = 0;
           treestack[ntreestack++] = newtree;
 
-        } else print_var_error(FLERR,"Mismatched compute in variable formula",ivar);
+        } else print_var_error(FLERR,
+                               "Mismatched compute in variable formula",ivar);
 
       // ----------------
       // fix
@@ -1584,7 +1585,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
 
       } else if (strncmp(word,"f_",2) == 0 || strncmp(word,"F_",2) == 0) {
         if (domain->box_exist == 0)
-          print_var_error(FLERR,"Variable evaluation before simulation box is defined",ivar);
+          print_var_error(FLERR,"Variable evaluation before "
+                          "simulation box is defined",ivar);
 
         // uppercase used to force access of
         // global vector vs global scalar, and global array vs global vector
@@ -1667,11 +1669,14 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
 
           if (index1 > fix->size_array_rows &&
               fix->size_array_rows_variable == 0)
-            print_var_error(FLERR,"Variable formula fix array is accessed out-of-range",ivar);
+            print_var_error(FLERR,"Variable formula fix array is "
+                            "accessed out-of-range",ivar);
           if (index2 > fix->size_array_cols)
-            print_var_error(FLERR,"Variable formula fix array is accessed out-of-range",ivar);
+            print_var_error(FLERR,"Variable formula fix array is "
+                            "accessed out-of-range",ivar);
           if (update->whichflag > 0 && update->ntimestep % fix->global_freq)
-            print_var_error(FLERR,"Fix in variable not computed at a compatible time",ivar);
+            print_var_error(FLERR,"Fix in variable not computed at a "
+                            "compatible time",ivar);
 
           value1 = fix->compute_array(index1-1,index2-1);
           if (tree) {
@@ -1688,13 +1693,17 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
         } else if (nbracket == 0 && fix->vector_flag) {
 
           if (update->whichflag > 0 && update->ntimestep % fix->global_freq)
-            print_var_error(FLERR,"Fix in variable not computed at compatible time",ivar);
+            print_var_error(FLERR,"Fix in variable not computed at "
+                            "compatible time",ivar);
           if (tree == NULL)
-            print_var_error(FLERR,"Fix global vector in ""equal-style variable formula",ivar);
+            print_var_error(FLERR,"Fix global vector in "
+                            "equal-style variable formula",ivar);
           if (treetype == ATOM)
-            print_var_error(FLERR,"Fix global vector in ""atom-style variable formula",ivar);
+            print_var_error(FLERR,"Fix global vector in "
+                            "atom-style variable formula",ivar);
           if (fix->size_vector == 0)
-            print_var_error(FLERR,"Variable formula fix vector is zero length",ivar);
+            print_var_error(FLERR,"Variable formula "
+                            "fix vector is zero length",ivar);
 
           int nvec = fix->size_vector;
           double *vec;
@@ -1726,7 +1735,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
             print_var_error(FLERR,"Fix global vector in "
                             "atom-style variable formula",ivar);
           if (fix->size_array_rows == 0)
-            print_var_error(FLERR,"Variable formula fix array is zero length",ivar);
+            print_var_error(FLERR,"Variable formula fix array is "
+                            "zero length",ivar);
 
           int nvec = fix->size_array_rows;
           double *vec;
@@ -1785,10 +1795,12 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
                    fix->size_peratom_cols == 0) {
 
           if (tree == NULL)
-            print_var_error(FLERR,"Per-atom fix in equal-style variable formula",ivar);
+            print_var_error(FLERR,"Per-atom fix in "
+                            "equal-style variable formula",ivar);
           if (update->whichflag > 0 &&
               update->ntimestep % fix->peratom_freq)
-            print_var_error(FLERR,"Fix in variable not computed at compatible time",ivar);
+            print_var_error(FLERR,"Fix in variable not computed at "
+                            "compatible time",ivar);
 
           Tree *newtree = new Tree();
           newtree->type = ATOMARRAY;
@@ -1805,13 +1817,15 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
                    fix->size_peratom_cols > 0) {
 
           if (tree == NULL)
-            print_var_error(FLERR,"Per-atom fix in equal-style variable formula",ivar);
+            print_var_error(FLERR,"Per-atom fix in "
+                            "equal-style variable formula",ivar);
           if (index1 > fix->size_peratom_cols)
             print_var_error(FLERR,"Variable formula fix array "
                             "is accessed out-of-range",ivar);
           if (update->whichflag > 0 &&
               update->ntimestep % fix->peratom_freq)
-            print_var_error(FLERR,"Fix in variable not computed at compatible time",ivar);
+            print_var_error(FLERR,"Fix in variable not computed at "
+                            "compatible time",ivar);
 
           Tree *newtree = new Tree();
           newtree->type = ATOMARRAY;
@@ -1878,7 +1892,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
 
           char *var = retrieve(word+2);
           if (var == NULL)
-            print_var_error(FLERR,"Invalid variable evaluation in variable formula",ivar);
+            print_var_error(FLERR,"Invalid variable evaluation in "
+                            "variable formula",ivar);
           if (tree) {
             Tree *newtree = new Tree();
             newtree->type = VALUE;
@@ -1977,7 +1992,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
           double *vec;
           int nvec = compute_vector(ivar,&vec);
           if (index <= 0 || index > nvec)
-            print_var_error(FLERR,"Invalid index into vector-style variable",ivar);
+            print_var_error(FLERR,"Invalid index into "
+                            "vector-style variable",ivar);
           int m = index;   // convert from tagint to int
 
           if (tree) {
@@ -1989,7 +2005,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
             treestack[ntreestack++] = newtree;
           } else argstack[nargstack++] = vec[m-1];
 
-        } else print_var_error(FLERR,"Mismatched variable in variable formula",ivar);
+        } else print_var_error(FLERR,"Mismatched variable in "
+                               "variable formula",ivar);
 
       // ----------------
       // math/group/special function or atom value/vector or
@@ -2194,7 +2211,8 @@ double Variable::evaluate(char *str, Tree **tree, int ivar)
             if (value2 == 0.0)
               argstack[nargstack++] = 1.0;
             else if ((value1 == 0.0) && (value2 < 0.0))
-              print_var_error(FLERR,"Invalid power expression in variable formula",ivar);
+              print_var_error(FLERR,"Invalid power expression in "
+                              "variable formula",ivar);
             else argstack[nargstack++] = pow(value1,value2);
           } else if (opprevious == UNARY) {
             argstack[nargstack++] = -value2;
@@ -3368,7 +3386,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (tree) newtree->type = LN;
     else {
       if (value1 <= 0.0)
-        print_var_error(FLERR,"Log of zero/negative value in variable formula",ivar);
+        print_var_error(FLERR,"Log of zero/negative value in "
+                        "variable formula",ivar);
       argstack[nargstack++] = log(value1);
     }
   } else if (strcmp(word,"log") == 0) {
@@ -3377,7 +3396,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (tree) newtree->type = LOG;
     else {
       if (value1 <= 0.0)
-        print_var_error(FLERR,"Log of zero/negative value in variable formula",ivar);
+        print_var_error(FLERR,"Log of zero/negative value in "
+                        "variable formula",ivar);
       argstack[nargstack++] = log10(value1);
     }
   } else if (strcmp(word,"abs") == 0) {
@@ -3482,7 +3502,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (narg != 2)
       print_var_error(FLERR,"Invalid math function in variable formula",ivar);
     if (update->whichflag == 0)
-      print_var_error(FLERR,"Cannot use ramp in variable formula between runs",ivar);
+      print_var_error(FLERR,"Cannot use ramp in "
+                      "variable formula between runs",ivar);
     if (tree) newtree->type = RAMP;
     else {
       double delta = update->ntimestep - update->beginstep;
@@ -3617,7 +3638,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (narg != 2)
       print_var_error(FLERR,"Invalid math function in variable formula",ivar);
     if (update->whichflag == 0)
-      print_var_error(FLERR,"Cannot use vdisplace in variable formula between runs",ivar);
+      print_var_error(FLERR,"Cannot use vdisplace in "
+                      "variable formula between runs",ivar);
     if (tree) newtree->type = VDISPLACE;
     else {
       double delta = update->ntimestep - update->beginstep;
@@ -3629,7 +3651,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (narg != 3)
       print_var_error(FLERR,"Invalid math function in variable formula",ivar);
     if (update->whichflag == 0)
-      print_var_error(FLERR,"Cannot use swiggle in variable formula between runs",ivar);
+      print_var_error(FLERR,"Cannot use swiggle in "
+                      "variable formula between runs",ivar);
     if (tree) newtree->type = CWIGGLE;
     else {
       if (values[0] == 0.0)
@@ -3644,7 +3667,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
     if (narg != 3)
       print_var_error(FLERR,"Invalid math function in variable formula",ivar);
     if (update->whichflag == 0)
-      print_var_error(FLERR,"Cannot use cwiggle in variable formula between runs",ivar);
+      print_var_error(FLERR,"Cannot use cwiggle in "
+                      "variable formula between runs",ivar);
     if (tree) newtree->type = CWIGGLE;
     else {
       if (values[0] == 0.0)
@@ -3709,7 +3733,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
 
   if (strcmp(word,"count") == 0) {
     if (narg == 1) value = group->count(igroup);
-    else if (narg == 2) value = group->count(igroup,region_function(args[1],ivar));
+    else if (narg == 2) 
+      value = group->count(igroup,region_function(args[1],ivar));
     else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
 
   } else if (strcmp(word,"mass") == 0) {
@@ -3719,7 +3744,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"charge") == 0) {
     if (narg == 1) value = group->charge(igroup);
-    else if (narg == 2) value = group->charge(igroup,region_function(args[1],ivar));
+    else if (narg == 2) 
+      value = group->charge(igroup,region_function(args[1],ivar));
     else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
 
   } else if (strcmp(word,"xcm") == 0) {
@@ -3732,7 +3758,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       int iregion = region_function(args[2],ivar);
       double masstotal = group->mass(igroup,iregion);
       group->xcm(igroup,masstotal,xcm,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"x") == 0) value = xcm[0];
     else if (strcmp(args[1],"y") == 0) value = xcm[1];
     else if (strcmp(args[1],"z") == 0) value = xcm[2];
@@ -3748,7 +3775,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       int iregion = region_function(args[2],ivar);
       double masstotal = group->mass(igroup,iregion);
       group->vcm(igroup,masstotal,vcm,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"x") == 0) value = vcm[0];
     else if (strcmp(args[1],"y") == 0) value = vcm[1];
     else if (strcmp(args[1],"z") == 0) value = vcm[2];
@@ -3767,7 +3795,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
   } else if (strcmp(word,"bound") == 0) {
     double minmax[6];
     if (narg == 2) group->bounds(igroup,minmax);
-    else if (narg == 3) group->bounds(igroup,minmax,region_function(args[2],ivar));
+    else if (narg == 3) 
+      group->bounds(igroup,minmax,region_function(args[2],ivar));
     else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
     if (strcmp(args[1],"xmin") == 0) value = minmax[0];
     else if (strcmp(args[1],"xmax") == 0) value = minmax[1];
@@ -3789,7 +3818,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       double masstotal = group->mass(igroup,iregion);
       group->xcm(igroup,masstotal,xcm,iregion);
       value = group->gyration(igroup,masstotal,xcm,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
 
   } else if (strcmp(word,"ke") == 0) {
     if (narg == 1) value = group->ke(igroup);
@@ -3808,7 +3838,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       double masstotal = group->mass(igroup,iregion);
       group->xcm(igroup,masstotal,xcm,iregion);
       group->angmom(igroup,xcm,lmom,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"x") == 0) value = lmom[0];
     else if (strcmp(args[1],"y") == 0) value = lmom[1];
     else if (strcmp(args[1],"z") == 0) value = lmom[2];
@@ -3826,7 +3857,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       double masstotal = group->mass(igroup,iregion);
       group->xcm(igroup,masstotal,xcm,iregion);
       group->torque(igroup,xcm,tq,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"x") == 0) value = tq[0];
     else if (strcmp(args[1],"y") == 0) value = tq[1];
     else if (strcmp(args[1],"z") == 0) value = tq[2];
@@ -3844,7 +3876,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       double masstotal = group->mass(igroup,iregion);
       group->xcm(igroup,masstotal,xcm,iregion);
       group->inertia(igroup,xcm,inertia,iregion);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"xx") == 0) value = inertia[0][0];
     else if (strcmp(args[1],"yy") == 0) value = inertia[1][1];
     else if (strcmp(args[1],"zz") == 0) value = inertia[2][2];
@@ -3869,7 +3902,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
       group->angmom(igroup,xcm,angmom,iregion);
       group->inertia(igroup,xcm,inertia,iregion);
       group->omega(angmom,inertia,omega);
-    } else print_var_error(FLERR,"Invalid group function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid group function in "
+                           "variable formula",ivar);
     if (strcmp(args[1],"x") == 0) value = omega[0];
     else if (strcmp(args[1],"y") == 0) value = omega[1];
     else if (strcmp(args[1],"z") == 0) value = omega[2];
@@ -3924,7 +3958,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
                                Tree **treestack, int &ntreestack,
                                double *argstack, int &nargstack, int ivar)
 {
-  double value,xvalue,sx,sy,sxx,sxy;
+  bigint sx,sxx;
+  double value,xvalue,sy,sxy;
 
   // word not a match to any special function
 
@@ -4020,11 +4055,13 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
       } else index = 0;
 
       int ifix = modify->find_fix(&args[0][2]);
-      if (ifix < 0) print_var_error(FLERR,"Invalid fix ID in variable formula",ivar);
+      if (ifix < 0) 
+        print_var_error(FLERR,"Invalid fix ID in variable formula",ivar);
       fix = modify->fix[ifix];
       if (index == 0 && fix->vector_flag) {
         if (update->whichflag > 0 && update->ntimestep % fix->global_freq)
-          print_var_error(FLERR,"Fix in variable not computed at compatible time",ivar);
+          print_var_error(FLERR,"Fix in variable not computed at "
+                          "compatible time",ivar);
         nvec = fix->size_vector;
         nstride = 1;
       } else if (index && fix->array_flag) {
@@ -4032,7 +4069,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
           print_var_error(FLERR,"Variable formula fix array "
                           "is accessed out-of-range",ivar);
         if (update->whichflag > 0 && update->ntimestep % fix->global_freq)
-          print_var_error(FLERR,"Fix in variable not computed at compatible time",ivar);
+          print_var_error(FLERR,"Fix in variable not computed at "
+                          "compatible time",ivar);
         nvec = fix->size_array_rows;
         nstride = fix->size_array_cols;
       } else print_var_error(FLERR,"Mismatched fix in variable formula",ivar);
@@ -4048,10 +4086,12 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
       } else index = 0;
 
       if (index)
-        print_var_error(FLERR,"Invalid special function in variable formula",ivar);
+        print_var_error(FLERR,"Invalid special function in "
+                        "variable formula",ivar);
       ivar = find(&args[0][2]);
       if (ivar < 0)
-        print_var_error(FLERR,"Invalid special function in variable formula",ivar);
+        print_var_error(FLERR,"Invalid special function in "
+                        "variable formula",ivar);
       if (style[ivar] != VECTOR)
         print_var_error(FLERR,"Mis-matched special function variable "
                         "in variable formula",ivar);
@@ -4062,12 +4102,16 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
       nvec = compute_vector(ivar,&vec);
       nstride = 1;
 
-    } else print_var_error(FLERR,"Invalid special function in variable formula",ivar);
+    } else print_var_error(FLERR,"Invalid special function in "
+                           "variable formula",ivar);
 
     value = 0.0;
-    if (method == SLOPE) sx = sy = sxx = sxy = 0.0;
-    if (method == XMIN) value = BIG;
-    if (method == XMAX) value = -BIG;
+    if (method == SLOPE) {
+      sx = sxx = 0;
+      sy = sxy = 0.0;
+    }
+    else if (method == XMIN) value = BIG;
+    else if (method == XMAX) value = -BIG;
 
     if (compute) {
       double *vec;
@@ -4084,12 +4128,10 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
         else if (method == AVE) value += vec[j];
         else if (method == TRAP) value += vec[j];
         else if (method == SLOPE) {
-          if (nvec > 1) xvalue = (double) i / (nvec-1);
-          else xvalue = 0.0;
-          sx += xvalue;
+          sx += i;
           sy += vec[j];
-          sxx += xvalue*xvalue;
-          sxy += xvalue*vec[j];
+          sxx += i*i;
+          sxy += i*vec[j];
         }
         j += nstride;
       }
@@ -4107,12 +4149,10 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
         else if (method == AVE) value += one;
         else if (method == TRAP) value += one;
         else if (method == SLOPE) {
-          if (nvec > 1) xvalue = (double) i / (nvec-1);
-          else xvalue = 0.0;
-          sx += xvalue;
+          sx += i;
           sy += one;
-          sxx += xvalue*xvalue;
-          sxy += xvalue*one;
+          sxx += i*i;
+          sxy += i*one;
         }
       }
       if (method == TRAP) {
@@ -4134,12 +4174,10 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
         else if (method == AVE) value += one;
         else if (method == TRAP) value += one;
         else if (method == SLOPE) {
-          if (nvec > 1) xvalue = (double) i / (nvec-1);
-          else xvalue = 0.0;
-          sx += xvalue;
+          sx += i;
           sy += one;
-          sxx += xvalue*xvalue;
-          sxy += xvalue*one;
+          sxx += i*i;
+          sxy += i*one;
         }
       }
       if (method == TRAP) value -= 0.5*vec[0] + 0.5*vec[nvec-1];
@@ -4148,9 +4186,9 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
     if (method == AVE) value /= nvec;
 
     if (method == SLOPE) {
-      double numerator = sxy - sx*sy;
-      double denominator = sxx - sx*sx;
-      if (denominator != 0.0) value = numerator/denominator / nvec;
+      double numerator = nvec*sxy - sx*sy;
+      double denominator = nvec*sxx - sx*sx;
+      if (denominator != 0.0) value = numerator/denominator;
       else value = BIG;
     }
 
@@ -4169,7 +4207,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"gmask") == 0) {
     if (tree == NULL)
-      print_var_error(FLERR,"Gmask function in equal-style variable formula",ivar);
+      print_var_error(FLERR,"Gmask function in equal-style "
+                      "variable formula",ivar);
     if (narg != 1)
       print_var_error(FLERR,"Invalid special function in variable formula",ivar);
 
@@ -4186,7 +4225,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"rmask") == 0) {
     if (tree == NULL)
-      print_var_error(FLERR,"Rmask function in equal-style variable formula",ivar);
+      print_var_error(FLERR,"Rmask function in equal-style "
+                      "variable formula",ivar);
     if (narg != 1)
       print_var_error(FLERR,"Invalid special function in variable formula",ivar);
 
@@ -4202,7 +4242,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"grmask") == 0) {
     if (tree == NULL)
-      print_var_error(FLERR,"Grmask function in equal-style variable formula",ivar);
+      print_var_error(FLERR,"Grmask function in equal-style "
+                      "variable formula",ivar);
     if (narg != 2)
       print_var_error(FLERR,"Invalid special function in variable formula",ivar);
 
@@ -4228,7 +4269,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
     int ivar = find(args[0]);
     if (ivar < 0)
-      print_var_error(FLERR,"Variable ID in variable formula does not exist",ivar);
+      print_var_error(FLERR,"Variable ID in "
+                      "variable formula does not exist",ivar);
 
     // SCALARFILE has single current value, read next one
     // save value in tree or on argstack
@@ -4253,7 +4295,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
     } else if (style[ivar] == ATOMFILE) {
       if (tree == NULL)
-        print_var_error(FLERR,"Atomfile variable in equal-style variable formula",ivar);
+        print_var_error(FLERR,"Atomfile variable in "
+                        "equal-style variable formula",ivar);
 
       double *result;
       memory->create(result,atom->nlocal,"variable:result");
@@ -4271,11 +4314,13 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
       newtree->nextra = 0;
       treestack[ntreestack++] = newtree;
 
-    } else print_var_error(FLERR,"Invalid variable style in special function next",ivar);
+    } else print_var_error(FLERR,"Invalid variable style in "
+                           "special function next",ivar);
 
   } else if (strcmp(word,"is_active") == 0) {
     if (narg != 2)
-      print_var_error(FLERR,"Invalid is_active() function in variable formula",ivar);
+      print_var_error(FLERR,"Invalid is_active() function in "
+                      "variable formula",ivar);
 
     Info info(lmp);
     value = (info.is_active(args[0],args[1])) ? 1.0 : 0.0;
@@ -4293,7 +4338,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"is_available") == 0) {
     if (narg != 2)
-      print_var_error(FLERR,"Invalid is_available() function in variable formula",ivar);
+      print_var_error(FLERR,"Invalid is_available() function in "
+                      "variable formula",ivar);
 
     Info info(lmp);
     value = (info.is_available(args[0],args[1])) ? 1.0 : 0.0;
@@ -4311,7 +4357,8 @@ int Variable::special_function(char *word, char *contents, Tree **tree,
 
   } else if (strcmp(word,"is_defined") == 0) {
     if (narg != 2)
-      print_var_error(FLERR,"Invalid is_defined() function in variable formula",ivar);
+      print_var_error(FLERR,"Invalid is_defined() function in "
+                      "variable formula",ivar);
 
     Info info(lmp);
     value = (info.is_defined(args[0],args[1])) ? 1.0 : 0.0;