~ubuntu-branches/ubuntu/trusty/nwchem/trusty-proposed

« back to all changes in this revision

Viewing changes to src/nwpw/pspw/cell_optimize/stress_fd.F

  • Committer: Package Import Robot
  • Author(s): Michael Banck, Daniel Leidert, Andreas Tille, Michael Banck
  • Date: 2013-07-04 12:14:55 UTC
  • mfrom: (1.1.2)
  • Revision ID: package-import@ubuntu.com-20130704121455-5tvsx2qabor3nrui
Tags: 6.3-1
* New upstream release.
* Fixes anisotropic properties (Closes: #696361).
* New features include:
  + Multi-reference coupled cluster (MRCC) approaches
  + Hybrid DFT calculations with short-range HF 
  + New density-functionals including Minnesota (M08, M11) and HSE hybrid
    functionals
  + X-ray absorption spectroscopy (XAS) with TDDFT
  + Analytical gradients for the COSMO solvation model
  + Transition densities from TDDFT 
  + DFT+U and Electron-Transfer (ET) methods for plane wave calculations
  + Exploitation of space group symmetry in plane wave geometry optimizations
  + Local density of states (LDOS) collective variable added to Metadynamics
  + Various new XC functionals added for plane wave calculations, including
    hybrid and range-corrected ones
  + Electric field gradients with relativistic corrections 
  + Nudged Elastic Band optimization method
  + Updated basis sets and ECPs 

[ Daniel Leidert ]
* debian/watch: Fixed.

[ Andreas Tille ]
* debian/upstream: References

[ Michael Banck ]
* debian/upstream (Name): New field.
* debian/patches/02_makefile_flags.patch: Refreshed.
* debian/patches/06_statfs_kfreebsd.patch: Likewise.
* debian/patches/07_ga_target_force_linux.patch: Likewise.
* debian/patches/05_avoid_inline_assembler.patch: Removed, no longer needed.
* debian/patches/09_backported_6.1.1_fixes.patch: Likewise.
* debian/control (Build-Depends): Added gfortran-4.7 and gcc-4.7.
* debian/patches/10_force_gcc-4.7.patch: New patch, explicitly sets
  gfortran-4.7 and gcc-4.7, fixes test suite hang with gcc-4.8 (Closes:
  #701328, #713262).
* debian/testsuite: Added tests for COSMO analytical gradients and MRCC.
* debian/rules (MRCC_METHODS): New variable, required to enable MRCC methods.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
*
2
 
* $Id: stress_fd.F 20166 2011-03-31 17:34:07Z bylaska $
 
2
* $Id: stress_fd.F 22672 2012-08-07 00:42:38Z bylaska $
3
3
*
4
4
      logical function stress_fd(rtdb)
5
5
      implicit none
38
38
      double precision ehsic_stress(3,3)
39
39
      double precision excsic_stress(3,3)
40
40
      double precision hfx_stress(3,3)
 
41
      double precision LJ_stress(3,3)
 
42
      double precision Q_stress(3,3)
 
43
      double precision spring_stress(3,3)
 
44
      double precision dftu_stress(3,3)
41
45
 
42
46
      double precision lattice(6)
43
47
      double precision lattice2(6)
56
60
      double precision ehsic_lstress(6)
57
61
      double precision excsic_lstress(6)
58
62
      double precision hfx_lstress(6)
 
63
      double precision LJ_lstress(6)
 
64
      double precision Q_lstress(6)
 
65
      double precision spring_lstress(6)
 
66
      double precision dftu_lstress(6)
59
67
 
60
68
      integer date_len
61
69
      character*40 date_string
99
107
      call dcopy(9,0.0d0,0,ehsic_stress,1)
100
108
      call dcopy(9,0.0d0,0,excsic_stress,1)
101
109
      call dcopy(9,0.0d0,0,hfx_stress,1)
 
110
      call dcopy(9,0.0d0,0,LJ_stress,1)
 
111
      call dcopy(9,0.0d0,0,Q_stress,1)
 
112
      call dcopy(9,0.0d0,0,spring_stress,1)
 
113
      call dcopy(9,0.0d0,0,dftu_stress,1)
102
114
 
103
115
      do j=1,3
104
116
      do i=1,3
161
173
     >        rtdb_get(rtdb,'pspw:E_hfx',mt_dbl,1,E)
162
174
      hfx_stress(i,j) = E
163
175
 
 
176
      value = value.and.
 
177
     >        rtdb_get(rtdb,'pspw:E_LJ',mt_dbl,1,E)
 
178
      LJ_stress(i,j) = E
 
179
 
 
180
      value = value.and.
 
181
     >        rtdb_get(rtdb,'pspw:E_Q',mt_dbl,1,E)
 
182
      Q_stress(i,j) = E
 
183
 
 
184
      value = value.and.
 
185
     >        rtdb_get(rtdb,'pspw:E_spring',mt_dbl,1,E)
 
186
      spring_stress(i,j) = E
 
187
 
 
188
      value = value.and.
 
189
     >        rtdb_get(rtdb,'pspw:E_dftu',mt_dbl,1,E)
 
190
      dftu_stress(i,j) = E
 
191
 
164
192
*     *****************************
165
193
*     **** - finite difference ****
166
194
*     *****************************
209
237
      value = value.and.rtdb_get(rtdb,'pspw:E_hfx',mt_dbl,1,E)
210
238
      hfx_stress(i,j) = hfx_stress(i,j) - E
211
239
 
 
240
      value = value.and.rtdb_get(rtdb,'pspw:E_LJ',mt_dbl,1,E)
 
241
      LJ_stress(i,j) = LJ_stress(i,j) - E
 
242
 
 
243
      value = value.and.rtdb_get(rtdb,'pspw:E_Q',mt_dbl,1,E)
 
244
      Q_stress(i,j) = Q_stress(i,j) - E
 
245
 
 
246
      value = value.and.rtdb_get(rtdb,'pspw:E_spring',mt_dbl,1,E)
 
247
      spring_stress(i,j) = spring_stress(i,j) - E
 
248
 
 
249
      value = value.and.rtdb_get(rtdb,'pspw:E_dftu',mt_dbl,1,E)
 
250
      dftu_stress(i,j) = dftu_stress(i,j) - E
 
251
 
212
252
      end do
213
253
      end do
214
254
      call dscal(9,(0.5d0/alpha),ke_stress,1)
220
260
      call dscal(9,(0.5d0/alpha),ehsic_stress,1)
221
261
      call dscal(9,(0.5d0/alpha),excsic_stress,1)
222
262
      call dscal(9,(0.5d0/alpha),hfx_stress,1)
 
263
      call dscal(9,(0.5d0/alpha),LJ_stress,1)
 
264
      call dscal(9,(0.5d0/alpha),Q_stress,1)
 
265
      call dscal(9,(0.5d0/alpha),spring_stress,1)
 
266
      call dscal(9,(0.5d0/alpha),dftu_stress,1)
223
267
 
224
268
      call write_stress(ke_stress,"ke FD")
225
269
      call write_stress(hartree_stress,"coulomb FD")
230
274
      call write_stress(ehsic_stress,"Eh SIC FD")
231
275
      call write_stress(excsic_stress,"Exc SIC FD")
232
276
      call write_stress(hfx_stress,"HFX FD")
 
277
      call write_stress(LJ_stress,"LJ FD")
 
278
      call write_stress(Q_stress,"Q FD")
 
279
      call write_stress(spring_stress,"spring FD")
 
280
      call write_stress(dftu_stress,"DFTU FD")
233
281
 
234
282
      call dcopy(9,ke_stress,1,stress,1)
235
283
      call daxpy(9,1.0d0,xc_stress,1,stress,1)
240
288
      call daxpy(9,1.0d0,ehsic_stress,1,stress,1)
241
289
      call daxpy(9,1.0d0,excsic_stress,1,stress,1)
242
290
      call daxpy(9,1.0d0,hfx_stress,1,stress,1)
 
291
      call daxpy(9,1.0d0,LJ_stress,1,stress,1)
 
292
      call daxpy(9,1.0d0,Q_stress,1,stress,1)
 
293
      call daxpy(9,1.0d0,spring_stress,1,stress,1)
 
294
      call daxpy(9,1.0d0,dftu_stress,1,stress,1)
243
295
      call write_stress(stress,"TOTAL FD")
244
296
 
245
297
*     **************************************
299
351
            value = value.and.
300
352
     >              rtdb_get(rtdb,'pspw:E_hfx',mt_dbl,1,E)
301
353
            hfx_lstress(i) = E
 
354
            value = value.and.
 
355
     >              rtdb_get(rtdb,'pspw:E_LJ',mt_dbl,1,E)
 
356
            LJ_lstress(i) = E
 
357
            value = value.and.
 
358
     >              rtdb_get(rtdb,'pspw:E_Q',mt_dbl,1,E)
 
359
            Q_lstress(i) = E
 
360
            value = value.and.
 
361
     >              rtdb_get(rtdb,'pspw:E_spring',mt_dbl,1,E)
 
362
            spring_lstress(i) = E
 
363
            value = value.and.
 
364
     >              rtdb_get(rtdb,'pspw:E_dftu',mt_dbl,1,E)
 
365
            dftu_lstress(i) = E
302
366
 
303
367
*           *****************************
304
368
*           **** - finite difference ****
348
412
 
349
413
            value = value.and.rtdb_get(rtdb,'pspw:E_hfx',mt_dbl,1,E)
350
414
            hfx_lstress(i) = hfx_lstress(i) - E
 
415
 
 
416
            value = value.and.rtdb_get(rtdb,'pspw:E_LJ',mt_dbl,1,E)
 
417
            LJ_lstress(i) = LJ_lstress(i) - E
 
418
 
 
419
            value = value.and.rtdb_get(rtdb,'pspw:E_Q',mt_dbl,1,E)
 
420
            Q_lstress(i) = Q_lstress(i) - E
 
421
 
 
422
            value = value.and.rtdb_get(rtdb,'pspw:E_spring',mt_dbl,1,E)
 
423
            spring_lstress(i) = spring_lstress(i) - E
 
424
 
 
425
            value = value.and.rtdb_get(rtdb,'pspw:E_dftu',mt_dbl,1,E)
 
426
            dftu_lstress(i) = dftu_lstress(i) - E
351
427
         end do
352
428
 
353
429
         call dscal(6,(0.5d0/alpha),ke_lstress,1)
359
435
         call dscal(6,(0.5d0/alpha),ehsic_lstress,1)
360
436
         call dscal(6,(0.5d0/alpha),excsic_lstress,1)
361
437
         call dscal(6,(0.5d0/alpha),hfx_lstress,1)
 
438
         call dscal(6,(0.5d0/alpha),LJ_lstress,1)
 
439
         call dscal(6,(0.5d0/alpha),Q_lstress,1)
 
440
         call dscal(6,(0.5d0/alpha),spring_lstress,1)
 
441
         call dscal(6,(0.5d0/alpha),dftu_lstress,1)
362
442
 
363
443
         call write_lstress(ke_lstress,"ke FD")
364
444
         call write_lstress(hartree_lstress,"coulomb FD")
369
449
         call write_lstress(ehsic_lstress,"Eh SIC FD")
370
450
         call write_lstress(excsic_lstress,"Exc SIC FD")
371
451
         call write_lstress(hfx_lstress,"HFX FD")
 
452
         call write_lstress(LJ_lstress,"LJ FD")
 
453
         call write_lstress(Q_lstress,"Q FD")
 
454
         call write_lstress(spring_lstress,"spring FD")
 
455
         call write_lstress(dftu_lstress,"dftu FD")
372
456
 
373
457
         call dcopy(6,ke_lstress,1,lstress,1)
374
458
         call daxpy(6,1.0d0,xc_lstress,1,lstress,1)
379
463
         call daxpy(6,1.0d0,ehsic_lstress,1,lstress,1)
380
464
         call daxpy(6,1.0d0,excsic_lstress,1,lstress,1)
381
465
         call daxpy(6,1.0d0,hfx_lstress,1,lstress,1)
 
466
         call daxpy(6,1.0d0,LJ_lstress,1,lstress,1)
 
467
         call daxpy(6,1.0d0,Q_lstress,1,lstress,1)
 
468
         call daxpy(6,1.0d0,spring_lstress,1,lstress,1)
 
469
         call daxpy(6,1.0d0,dftu_lstress,1,lstress,1)
382
470
         call write_lstress(lstress,"TOTAL FD")
383
471
 
384
472
*        **************************************