-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain_dipole.f90
325 lines (262 loc) · 9.77 KB
/
main_dipole.f90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
!
! ParaGauss, a program package for high-performance computations of
! molecular systems
!
! Copyright (C) 2014 T. Belling, T. Grauschopf, S. Krüger,
! F. Nörtemann, M. Staufer, M. Mayer, V. A. Nasluzov, U. Birkenheuer,
! A. Hu, A. V. Matveev, A. V. Shor, M. S. K. Fuchs-Rohr, K. M. Neyman,
! D. I. Ganyushin, T. Kerdcharoen, A. Woiterski, A. B. Gordienko,
! S. Majumder, M. H. i Rotllant, R. Ramakrishnan, G. Dixit,
! A. Nikodem, T. Soini, M. Roderus, N. Rösch
!
! This program is free software; you can redistribute it and/or modify
! it under the terms of the GNU General Public License version 2 as
! published by the Free Software Foundation [1].
!
! This program is distributed in the hope that it will be useful, but
! WITHOUT ANY WARRANTY; without even the implied warranty of
! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
! General Public License for more details.
!
! [1] http://www.gnu.org/licenses/gpl-2.0.html
!
! Please see the accompanying LICENSE file for further information.
!
!=====================================================================
! Public interface of module
!=====================================================================
subroutine main_dipole
!
! Main routine of dipole part. Runs dipole integral part,
! calculates dipole moments and prints them. Runs in a parallel
! context. Called by: main_master(). Important calls: call
! dipoleg_calculate().
!
! References: Ph.D. Thesis A Goerling
!
! Author: TB
! Date: 8/97
!
!
!-------------------------------------------------------------------
!===================================================================
! End of public interface of module
!===================================================================
!-------------------------------------------------------------------
! Modifications
!-------------------------------------------------------------------
!
! Author: HH
! Date: 10/97
! Description: For response module add following:
! If operations_response=T then call subroutine
! "dipole_trans_response" from dipol_module.f90.
! This subroutine writes all transition dip.mom.
! in an temporary, unformatted file in temp dir.
!
!-------------------------------------------------------------------
!
! Modification (Please copy before editing)
! Author: ...
! Date: ...
! Description: ...
!
!-------------------------------------------------------------------
# include "def.h"
!------------ Modules used -----------------------------------------
use type_module ! type specification parameters
use comm, only: comm_rank
use dipole_module, only: dipole_integrals, &
dipole_offdiagonals_calculated, dipole_xes_spectra, dipole_allocate, &
dipole_calculate, dipole_print, dipole_free, dipole_make_xes_spectra, &
dipole_trans_response, dipole_transitionmoment_uf, &
dipole_transitionmoment_f, dipole_write_simol
#ifdef WITH_GTENSOR
use hfc_module
use gtensor_module
#endif
use output_module
use integralpar_module, only: integralpar_set
use iounitadmin_module
use timer_module
use time_module
use filename_module
use operations_module, only: operations_response, operations_dipole, &
operations_gtensor, operations_hfc
#ifdef WITH_RESPONSE
use response_module, only: response_do_dipole
#endif
use options_module, only: options_spin_orbit
use interfaces, only: main_integral
implicit none
!------------ Declaration of local variables --------------------
logical :: offdiagonals_required, new_integrals_required, &
old_integrals_exist
integer :: iounit
!-------------------------------------------------------------------
!------------ Executable code -----------------------------------
hfcso: if (operations_hfc) then
#ifdef WITH_GTENSOR
call start_timer (timer_dipole)
DPRINT 'main_dipole : hfc part'
call start_timer (timer_dipole_integral)
call say ("new_integrals_required")
! allocate storage for integrals
call say ("allocate storage for integrals")
call hfc_allocate ()
! run integral part
call say ("integralpar_set_dipole")
call integralpar_set ('DipoleOff')
call say ("main_integral")
call main_integral ()
call stop_timer (timer_dipole_integral)
! calculate gtensors
call start_timer (timer_dipole_calculate)
call say ("calculate hfc")
call hfc_calculate ()
call stop_timer (timer_dipole_calculate)
call hfc_free ()
call stop_timer (timer_dipole)
elseif (operations_hfc .and. .not. options_spin_orbit) then
ABORT ('dead branch')
#else
ABORT ('recompile -DWITH_GTENSOR')
#endif
end if hfcso
opgt: if (operations_gtensor) then
#ifdef WITH_GTENSOR
call start_timer (timer_dipole)
DPRINT 'main_dipole : gtensor part'
call start_timer (timer_dipole_integral)
call say ("main_gten: new_integrals_required")
! allocate storage for integrals
call say ("main_gten: allocate storage for integrals")
! call dipoleg_allocate ()
call gtensor_allocate ()
! run integral part
call say ("main_gten: integralpar_set_dipole")
call integralpar_set ('DipoleOff')
call say ("main_gten: main_integral")
call main_integral ()
call stop_timer (timer_dipole_integral)
! calculate gtensors
call start_timer (timer_dipole_calculate)
call say ("calculate g-tensor")
call gtensor_calculate ()
call stop_timer (timer_dipole_calculate)
! call dipoleg_free ()
call gtensor_free ()
call stop_timer (timer_dipole)
#else
ABORT ('recompile -DWITH_GTENSOR')
#endif
end if opgt
opdip: if (operations_dipole) then
call start_timer (timer_dipole)
! determine what needs to be done
offdiagonals_required = &
output_dipole_transitionm_f .or. output_dipole_transitionm_uf &
& .or. operations_response.or. dipole_xes_spectra ()
old_integrals_exist = allocated (dipole_integrals)
if (old_integrals_exist) then
new_integrals_required = offdiagonals_required .and. &
.not. dipole_offdiagonals_calculated
else
new_integrals_required = .true.
endif
if (new_integrals_required) then
call start_timer (timer_dipole_integral)
call say ("new_integrals_required")
! deallocate old integrals before new ones are calculated
if (old_integrals_exist) then
call say ("deallocate old integrals")
call dipole_free ()
endif
! allocate storage for integrals
call say ("allocate storage for integrals")
call dipole_allocate (offdiagonals_required)
! run integral part
call say ("integralpar_set_dipole")
if (offdiagonals_required) then
call integralpar_set ('DipoleOff')
else
call integralpar_set ('Dipole')
endif
call say ("main_integral")
call main_integral ()
call stop_timer (timer_dipole_integral)
endif
! calculate dipole moments
call start_timer (timer_dipole_calculate)
call say ("calculate dipole moment")
call dipole_calculate ()
call stop_timer (timer_dipole_calculate)
call start_timer (timer_dipole_print)
!
! Print dipole moments. The struct with the data to be printed is
! only valid on master. See dipole_calculate().
!
if (comm_rank() == 0) then
call say ("call dipole_print()")
call dipole_print (output_unit, output_dipole_detailed)
call say ("done dipole_print()")
endif
! print total dipol moment to a special file used for simol frequency calculations
if (output_dipole_simol) then
call say ("write simol file")
call dipole_write_simol ()
endif
! calculate transition dipole moments and print them formatted
if (output_dipole_transitionm_f) then
call say ("calculate transition dipole moments and print them formatted")
call dipole_transitionmoment_f (output_unit)
endif
! calculate transition dipole moments and write them unformatted
if (output_dipole_transitionm_uf) then
call say ("calculate transition dipole moments and write them unformatted")
iounit = openget_iounit (trim (outfile ("dipoletransitionmoments")), &
form="UNFORMATTED", status="REPLACE", action="WRITE")
call dipole_transitionmoment_uf (iounit)
call returnclose_iounit (iounit, status="KEEP")
endif
! calculate transition dipol moments and write them unformatted to
! tmp-file for response module
if (operations_response) then
#ifdef WITH_RESPONSE
if (response_do_dipole ()) then
call say ("calculate transition dipole moments for response module")
iounit = openget_iounit (trim (tmpfile ("resp_dipoles_tmp.dat")), &
form="UNFORMATTED", status="REPLACE", action="WRITE")
call dipole_trans_response (iounit)
call returnclose_iounit (iounit, status="KEEP")
endif
#else
ABORT ('recompile -DWITH_RESPONSE')
#endif
endif
! calculate xes_spectra
if (dipole_xes_spectra ()) then
call say ("dipole_make_xes_spectra")
iounit = openget_iounit (trim (outfile ("xes.dat")), &
form="FORMATTED", status="REPLACE", action="WRITE")
call dipole_make_xes_spectra (iounit)
call returnclose_iounit (iounit, status="KEEP")
end if
call stop_timer (timer_dipole_print)
! deallocate integrals and calculated dipole moments
call say ("deallocate integrals and calculated dipole moments")
call dipole_free ()
call stop_timer (timer_dipole)
end if opdip
contains
subroutine say (phrase)
use output_module, only: output_main_dipole
use iounitadmin_module, only: write_to_output_units
implicit none
character (len=*), intent (in) :: phrase
! *** end of interface ***
if (output_main_dipole) then
call write_to_output_units ("main_dipole: " // phrase)
endif
end subroutine say
end subroutine main_dipole