Octopus
perturbation_ionic.F90
Go to the documentation of this file.
1!! Copyright (C) 2007 X. Andrade
2!! Copyright (C) 2021 N. Tancogne-Dejean
3!!
4!! This program is free software; you can redistribute it and/or modify
5!! it under the terms of the GNU General Public License as published by
6!! the Free Software Foundation; either version 2, or (at your option)
7!! any later version.
8!!
9!! This program is distributed in the hope that it will be useful,
10!! but WITHOUT ANY WARRANTY; without even the implied warranty of
11!! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12!! GNU General Public License for more details.
13!!
14!! You should have received a copy of the GNU General Public License
15!! along with this program; if not, write to the Free Software
16!! Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17!! 02110-1301, USA.
18!!
19
20#include "global.h"
21
25 use debug_oct_m
27 use epot_oct_m
28 use global_oct_m
29 use grid_oct_m
32 use ions_oct_m
34 use math_oct_m
35 use mesh_oct_m
39 use mpi_oct_m
44 use space_oct_m
50
51 implicit none
52
53 private
54 public :: &
58
59 type, extends(perturbation_t) :: perturbation_ionic_t
60 private
61
62 type(ions_t), pointer :: ions => null()
63
68 logical :: pure_dir
69 integer :: atom1, atom2
70 real(real64), allocatable :: mix1(:,:)
71 real(real64), allocatable :: mix2(:,:)
72
73 contains
74 procedure :: copy_to => perturbation_ionic_copy
75 generic :: assignment(=) => copy_to
76 procedure :: info => perturbation_ionic_info
77 procedure :: dapply => dperturbation_ionic_apply
78 procedure :: zapply => zperturbation_ionic_apply
79 procedure :: dapply_order_2 => dperturbation_ionic_apply_order_2
80 procedure :: zapply_order_2 => zperturbation_ionic_apply_order_2
81 procedure :: setup_dir => perturbation_ionic_setup_dir
82 procedure :: setup_atom => perturbation_ionic_setup_atom
83 procedure :: setup_mix_dir => perturbation_ionic_setup_mixed_dir
86
87 interface perturbation_ionic_t
88 procedure perturbation_ionic_constructor
89 end interface perturbation_ionic_t
90
91contains
92
93 ! ---------------------------------------------------------
98 function perturbation_ionic_constructor(namespace, ions) result(pert)
99 class(perturbation_ionic_t), pointer :: pert
100 type(namespace_t), intent(in) :: namespace
101 type(ions_t), target, intent(in) :: ions
102
104
105 safe_allocate(pert)
106
107 call perturbation_ionic_init(pert, namespace, ions)
108
111
112
113 ! --------------------------------------------------------------------
114 subroutine perturbation_ionic_init(this, namespace, ions)
115 type(perturbation_ionic_t), intent(out) :: this
116 type(namespace_t), intent(in) :: namespace
117 type(ions_t), target, intent(in) :: ions
118
120
121 this%dir = -1
122 this%dir2 = -1
123 this%atom1 = -1
124 this%atom2 = -1
125
126 this%ions => ions
127
128 this%pure_dir = .false.
129
130 safe_allocate(this%mix1(1:ions%natoms, 1:ions%space%dim))
131 safe_allocate(this%mix2(1:ions%natoms, 1:ions%space%dim))
132
134 end subroutine perturbation_ionic_init
135
136 ! --------------------------------------------------------------------
137 subroutine perturbation_ionic_copy(this, source)
138 class(perturbation_ionic_t), intent(out) :: this
139 class(perturbation_ionic_t), intent(in) :: source
140
142
143 call perturbation_copy(this, source)
144 this%atom1 = source%atom1
145 this%atom2 = source%atom2
146 this%ions => source%ions
147
148 this%pure_dir = source%pure_dir
149
150 safe_allocate(this%mix1(1:source%ions%natoms, 1:source%ions%space%dim))
151 safe_allocate(this%mix2(1:source%ions%natoms, 1:source%ions%space%dim))
152 this%mix1 = source%mix1
153 this%mix2 = source%mix2
156 end subroutine perturbation_ionic_copy
158
159 ! --------------------------------------------------------------------
160 subroutine perturbation_ionic_finalize(this)
161 type(perturbation_ionic_t), intent(inout) :: this
162
165 safe_deallocate_a(this%mix1)
166 safe_deallocate_a(this%mix2)
167
171 ! --------------------------------------------------------------------
172 subroutine perturbation_ionic_info(this)
173 class(perturbation_ionic_t), intent(in) :: this
180 ! --------------------------------------------------------------------
181 subroutine perturbation_ionic_setup_dir(this, dir, dir2)
182 class(perturbation_ionic_t), intent(inout) :: this
183 integer, intent(in) :: dir
184 integer, optional, intent(in) :: dir2
185
187
188 this%dir = dir
189 if (present(dir2)) this%dir2 = dir2
190
191 this%pure_dir = .true.
192
193 this%mix1 = m_zero
194 this%mix2 = m_zero
195
196 if (this%dir > 0 .and. this%atom1 > 0) this%mix1(this%atom1, this%dir ) = m_one
197 if (this%dir2 > 0 .and. this%atom2 > 0) this%mix2(this%atom2, this%dir2) = m_one
198
200 end subroutine perturbation_ionic_setup_dir
201
202 ! --------------------------------------------------------------------
203 subroutine perturbation_ionic_setup_atom(this, iatom, iatom2)
204 class(perturbation_ionic_t), intent(inout) :: this
205 integer, intent(in) :: iatom
206 integer, optional, intent(in) :: iatom2
207
210 this%atom1 = iatom
211 if (present(iatom2)) this%atom2 = iatom2
212
213 this%pure_dir = .true.
214
215 this%mix1 = m_zero
216 this%mix2 = m_zero
217
218 if (this%dir > 0 .and. this%atom1 > 0) this%mix1(this%atom1, this%dir ) = m_one
219 if (this%dir2 > 0 .and. this%atom2 > 0) this%mix2(this%atom2, this%dir2) = m_one
220
222 end subroutine perturbation_ionic_setup_atom
223
224 ! --------------------------------------------------------------------
225 subroutine perturbation_ionic_setup_mixed_dir(this, iatom, idir, val, jatom, jdir, valuej)
226 class(perturbation_ionic_t), intent(inout) :: this
227 integer, intent(in) :: iatom
228 integer, intent(in) :: idir
229 real(real64), intent(in) :: val
230 integer, optional, intent(in) :: jatom
231 integer, optional, intent(in) :: jdir
232 real(real64), optional, intent(in) :: valuej
233
234 logical :: have_dir_2
235
237
238 this%pure_dir = .false.
239
240 this%mix1(iatom, idir) = val
241
242 have_dir_2 = present(jatom) .and. present(jdir) .and. present(jatom)
243
244 if (have_dir_2) then
245 this%mix1(jatom, jdir) = valuej
246 else
247 assert(.not. present(jatom) .and. .not. present(jdir) .and. .not. present(jatom))
248 end if
249
252
253
254
255#include "undef.F90"
256#include "real.F90"
257#include "perturbation_ionic_inc.F90"
258
259#include "undef.F90"
260#include "complex.F90"
261#include "perturbation_ionic_inc.F90"
262
264
265!! Local Variables:
266!! mode: f90
267!! coding: utf-8
268!! End:
This module implements common operations on batches of mesh functions.
Definition: batch_ops.F90:118
Module implementing boundary conditions in Octopus.
Definition: boundaries.F90:124
This module calculates the derivatives (gradients, Laplacians, etc.) of a function.
real(real64), parameter, public m_zero
Definition: global.F90:200
real(real64), parameter, public m_one
Definition: global.F90:201
This module implements the underlying real-space grid.
Definition: grid.F90:119
This module is intended to contain "only mathematical" functions and procedures.
Definition: math.F90:117
This module defines functions over batches of mesh functions.
Definition: mesh_batch.F90:118
This module defines various routines, operating on mesh functions.
This module defines the meshes, which are used in Octopus.
Definition: mesh.F90:120
subroutine perturbation_ionic_setup_mixed_dir(this, iatom, idir, val, jatom, jdir, valuej)
subroutine, public zionic_pert_matrix_elements_2(gr, namespace, space, ions, hm, ik, st, vib, matrix)
Computes the second order term.
subroutine perturbation_ionic_setup_atom(this, iatom, iatom2)
subroutine perturbation_ionic_init(this, namespace, ions)
subroutine perturbation_ionic_copy(this, source)
subroutine dperturbation_ionic_apply(this, namespace, space, gr, hm, ik, f_in, f_out, set_bc)
Returns f_out = H' f_in, where H' is perturbation Hamiltonian Note that e^ikr phase is applied to f_i...
subroutine, public dionic_pert_matrix_elements_2(gr, namespace, space, ions, hm, ik, st, vib, matrix)
Computes the second order term.
subroutine perturbation_ionic_info(this)
subroutine zperturbation_ionic_apply_order_2(this, namespace, space, gr, hm, ik, f_in, f_out)
subroutine zperturbation_ionic_apply(this, namespace, space, gr, hm, ik, f_in, f_out, set_bc)
Returns f_out = H' f_in, where H' is perturbation Hamiltonian Note that e^ikr phase is applied to f_i...
subroutine perturbation_ionic_finalize(this)
subroutine perturbation_ionic_setup_dir(this, dir, dir2)
class(perturbation_ionic_t) function, pointer perturbation_ionic_constructor(namespace, ions)
The factory routine (or constructor) allocates a pointer of the corresponding type and then calls the...
subroutine dperturbation_ionic_apply_order_2(this, namespace, space, gr, hm, ik, f_in, f_out)
subroutine, public perturbation_copy(this, source)
This module handles spin dimensions of the states and the k-point distribution.
int true(void)