Octopus
unfold.F90
Go to the documentation of this file.
1!! Copyright (C) 2018-2019 M. S. Mrudul, N. Tancogne-Dejean
2!!
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
21#include "global.h"
22
23
24program oct_unfold
25 use batch_oct_m
28 use comm_oct_m
30 use cube_oct_m
32 use debug_oct_m
34 use fft_oct_m
37 use global_oct_m
38 use grid_oct_m
39 use io_oct_m
42 use, intrinsic :: iso_fortran_env
46 use loct_oct_m
47 use math_oct_m
48 use mesh_oct_m
51 use mpi_oct_m
54 use parser_oct_m
58 use space_oct_m
62 use unit_oct_m
64 use utils_oct_m
66 use v_ks_oct_m
67 use xc_oct_m
68
69 implicit none
70
71 type(electrons_t), pointer :: sys
72 integer :: ik, nkpoints
73 type(restart_t) :: restart
74 type(cube_t) :: zcube
75 type(cube_function_t) :: cf
76
77 type(lattice_vectors_t) :: pc
78 integer :: ierr, run_mode, file_gvec
79 type(block_t) :: blk
80 integer :: nhighsympoints, nsegments
81 integer :: icol, idir, ncols
82
83 integer, allocatable :: resolution(:)
84 real(real64), allocatable :: highsympoints(:,:), coord_along_path(:)
85 type(kpoints_grid_t) :: path_kpoints_grid
86
87
88 ! the usual initializations
89 call global_init()
90 call parser_init()
91
92 call messages_init()
93
94 call io_init()
96
97 call print_header()
98 call messages_print_with_emphasis(msg="Unfolding Band-structure", namespace=global_namespace)
100
101 call messages_experimental("oct-unfold utility")
104
105 call calc_mode_par%set_parallelization(p_strategy_states, default = .false.)
107
108 if (sys%space%periodic_dim == 0) then
109 message(1) = "oct-unfold can only be used for periodic systems."
110 call messages_fatal(1)
111 end if
112
113 if (sys%st%parallel_in_states) then
114 call messages_not_implemented("oct-unfold with states parallelization")
115 end if
116
117 if (sys%st%d%ispin == spinors) then
118 call messages_not_implemented("oct-unfold for spinors")
119 end if
120
121
122 !%Variable UnfoldMode
123 !%Type flag
124 !%Default none
125 !%Section Utilities::oct-unfold
126 !%Description
127 !% Specifies which stage of the unfolding tool to use
128 !%Option unfold_setup bit(1)
129 !% Writes the list of k-points corresponding to the path specified by <tt>UnfoldKPointPath</tt>.
130 !% This list of k-point (unfold_kpt.dat) must be used for an unocc calculation of the supercell,
131 !% adding the line "include 'unfold_kpt.dat'" to the inp file and removing the KPointGrid information.
132 !%Option unfold_run bit(2)
133 !% Perform the actual unfolding, based on the states obtained from the previous unocc run.
134 !%End
135 call parse_variable(global_namespace, 'UnfoldMode', 0, run_mode)
136 if (.not. varinfo_valid_option('UnfoldMode', run_mode)) then
137 call messages_input_error(global_namespace, "UnfoldMode must be set to a value different from 0.")
138 end if
139
140 !%Variable UnfoldLatticeParameters
141 !%Type block
142 !%Section Utilities::oct-unfold
143 !%Description
144 !% The lattice parameters of the primitive cell, on which unfolding is performed.
145 !% See the LatticeParameters variable for a more detailed description.
146 !%End
147
148 !%Variable UnfoldLatticeVectors
149 !%Type block
150 !%Default simple cubic
151 !%Section Utilities::oct-unfold
152 !%Description
153 !% Lattice vectors of the primitive cell on which the unfolding is performed.
154 !% See the LatticeVectors variable for a more detailed description.
155 !%End
156 pc = lattice_vectors_t(global_namespace, sys%space, variable_prefix='Unfold')
157
158 !%Variable UnfoldKPointsPath
159 !%Type block
160 !%Section Utilities::oct-unfold
161 !%Description
162 !% Specifies the k-point path for which the unfolding need to be done.
163 !% The syntax is identical to <tt>KPointsPath</tt>.
164 !%End
165 if (parse_block(global_namespace, 'UnfoldKPointsPath', blk) /= 0) then
166 write(message(1),'(a)') 'Error while reading UnfoldPointsPath.'
167 call messages_fatal(1)
168 end if
169
170 ! There is one high symmetry k-point per line
171 nsegments = parse_block_cols(blk, 0)
172 nhighsympoints = parse_block_n(blk) - 1
173 if (nhighsympoints /= nsegments+1) then
174 write(message(1),'(a,i3,a,i3)') 'The first row of UnfoldPointsPath is not compatible with the number of specified k-points.'
175 call messages_fatal(1)
176 end if
177
178 safe_allocate(resolution(1:nsegments))
179 do icol = 1, nsegments
180 call parse_block_integer(blk, 0, icol-1, resolution(icol))
181 end do
182 !Total number of points in the segment
183 nkpoints = sum(resolution) + 1
184
185 safe_allocate(highsympoints(1:sys%space%dim, 1:nhighsympoints))
186 do ik = 1, nhighsympoints
187 !Sanity check
188 ncols = parse_block_cols(blk, ik)
189 if (ncols /= sys%space%dim) then
190 write(message(1),'(a,i8,a,i3)') 'UnfoldPointsPath row ', ik, ' has ', ncols, ' columns but must have ', sys%space%dim
191 call messages_fatal(1)
192 end if
193
194 do idir = 1, sys%space%dim
195 call parse_block_float(blk, ik, idir-1, highsympoints(idir, ik))
196 end do
197 end do
198
199 call parse_block_end(blk)
200
201 call kpoints_grid_init(sys%space%dim, path_kpoints_grid, nkpoints, 1)
202 ! For the output of band-structures
203 safe_allocate(coord_along_path(1:nkpoints))
204
205 call kpoints_path_generate(sys%space%dim, pc, nkpoints, nsegments, resolution, &
206 highsympoints, path_kpoints_grid%point, coord_along_path)
207
208 safe_deallocate_a(resolution)
209 safe_deallocate_a(highsympoints)
210
211 !We convert the k-point to the reduced coordinate of the supercell
212 do ik = 1, path_kpoints_grid%npoints
213 call kpoints_to_reduced(sys%kpoints%latt, path_kpoints_grid%point(:, ik), path_kpoints_grid%red_point(:, ik))
214 end do
215
216 call kpoints_fold_to_1bz(path_kpoints_grid, pc)
217
218 if (run_mode == option__unfoldmode__unfold_setup) then
219
220 call unfold_setup()
221
222 else if (run_mode == option__unfoldmode__unfold_run) then
223
224 !Sanity check
225 file_gvec = io_open('unfold_gvec.dat', global_namespace, action='read')
226 read(file_gvec, *)
227 read(file_gvec, *) ik
228 if (ik /= path_kpoints_grid%npoints) then
229 message(1) = 'There is an inconsistency between unfold_gvec.dat and the input file'
230 call messages_fatal(1)
231 end if
232 call io_close(file_gvec)
233
234 call states_elec_allocate_wfns(sys%st, sys%gr)
235
236 call restart%init(global_namespace, restart_unocc, restart_type_load, sys%mc, ierr, mesh=sys%gr, exact=.true.)
237 if (ierr == 0) then
238 call states_elec_load(restart, global_namespace, sys%space, sys%st, sys%gr, sys%kpoints, fixed_occ=.true., &
239 ierr=ierr, label = ": unfold")
240 end if
241 if (ierr /= 0) then
242 message(1) = 'Unable to read unocc wavefunctions.'
243 call messages_fatal(1)
244 end if
245 call restart%end()
246
247 call cube_init(zcube, sys%gr%idx%ll, global_namespace, sys%space, sys%gr%spacing, &
248 sys%gr%coord_system, fft_type = fft_complex, dont_optimize = .true.)
249 call cube_init_cube_map(zcube, sys%gr)
250
251 call zcube_function_alloc_rs(zcube, cf)
252 call cube_function_alloc_fs(zcube, cf)
253
254 call wfs_extract_spec_fn(sys%space, sys%st, sys%gr, zcube, cf)
255
256 call cube_function_free_fs(zcube, cf)
257 call zcube_function_free_rs(zcube, cf)
258 call cube_end(zcube)
259
260 else
261 message(1) = "Unsupported or incorrect value of UnfoldMode."
262 call messages_fatal(1)
263 end if
264
265 safe_deallocate_a(coord_along_path)
266
267 call kpoints_grid_end(path_kpoints_grid)
268
269 safe_deallocate_p(sys)
270 call fft_all_end()
272 call io_end()
273 call print_date("Calculation ended on ")
274 call messages_end()
275 call parser_end()
276 call global_end()
277
278
279
280contains
281 !-----------------------------------------------------------------
282 subroutine unfold_setup()
283 integer :: file_gvec, file_kpts, idir
284 integer :: gvec(sys%space%dim)
285
286 push_sub(unfold_setup)
287
288 if (mpi_world%is_root()) then
289 file_gvec = io_open('unfold_gvec.dat', global_namespace, action='write')
290 file_kpts = io_open('unfold_kpt.dat', global_namespace, action='write')
291 write(file_kpts,'(a)') '%KpointsReduced'
292 write(file_gvec,'(a)') '#Created by oct-unfold'
293 write(file_gvec,'(i5)') path_kpoints_grid%npoints
294
295 !We convert the k-point to the reduce coordinate of the supercell
296 do ik = 1, path_kpoints_grid%npoints
297 gvec(:) = nint(path_kpoints_grid%red_point(:, ik) + m_half * 1e-7_real64)
298 write(file_kpts,'(a3)', advance='no') ' 1.'
299 write(file_kpts,'(*(a3,f12.8))') &
300 (' | ', path_kpoints_grid%red_point(idir, ik) - gvec(idir), idir = 1, sys%space%dim)
301 write(file_gvec,'(*(i5))') (gvec(idir), idir = 1, sys%space%dim)
302 end do
303 write(file_kpts,'(a)') '%'
304 call io_close(file_gvec)
305 call io_close(file_kpts)
306 end if
307
308 pop_sub(unfold_setup)
309 end subroutine unfold_setup
310
311 !--------------------------------------------------------------------
312 subroutine wfs_extract_spec_fn(space, st, gr, zcube, cf)
313 class(space_t), intent(in) :: space
314 type(states_elec_t), intent(in) :: st
315 type(grid_t), intent(in) :: gr
316 type(cube_t), intent(inout) :: zcube
317 type(cube_function_t), intent(inout) :: cf
318
319 real(real64), allocatable :: pkm(:,:), ake(:,:), eigs(:)
320 complex(real64), allocatable :: zpsi(:), field_g(:)
321 integer :: file_ake, iq, ist, idim, nenergy
322 integer :: ig, ix, iy, iz, ik, ie, gmin, gmax
323 real(real64) :: eigmin, eigmax, de, norm
324 real(real64), parameter :: tol = 1e-7_real64
325 integer, parameter :: nextend = 10
326 real(real64) :: vec_pc(space%dim), vec_sc(space%dim)
327 type(fourier_shell_t) :: shell
328 character(len=MAX_PATH_LEN) :: filename
329 real(real64), allocatable :: gvec_abs(:,:)
330 logical, allocatable :: g_select(:)
331
332 push_sub(wfs_extract_spec_fn)
333
334 safe_allocate(zpsi(1:gr%np))
335
336 !%Variable UnfoldEnergyStep
337 !%Type float
338 !%Default 0
339 !%Section Utilities::oct-unfold
340 !%Description
341 !% Specifies the energy resolution for the unfolded band structure.
342 !% If you specify 0, the resolution will be set to be 1/1000 points between <tt>UnfoldMinEnergy</tt>
343 !% and <tt>UnfoldMaxEnergy</tt>
344 !%End
345 call parse_variable(global_namespace, 'UnfoldEnergyStep', m_zero, de)
346 if (de < m_zero) then
347 message(1) = "UnfoldEnergyStep must be positive"
348 call messages_fatal(1)
349 end if
350
351 !%Variable UnfoldMinEnergy
352 !%Type float
353 !%Section Utilities::oct-unfold
354 !%Description
355 !% Specifies the start of the energy range for the unfolded band structure.
356 !% The default value correspond to the samllest eigenvalue.
357 !%End
358 call parse_variable(global_namespace, 'UnfoldMinEnergy', minval(st%eigenval(:, :)), eigmin)
359
360 !%Variable UnfoldMaxEnergy
361 !%Type float
362 !%Section Utilities::oct-unfold
363 !%Description
364 !% Specifies the end of the energy range for the unfolded band structure.
365 !% The default value correspond to the largest eigenvalue.
366 !%End
367 call parse_variable(global_namespace, 'UnfoldMaxEnergy', maxval(st%eigenval(:, :)), eigmax)
368
369 if (abs(de) <= m_epsilon) then
370 de = (eigmax - eigmin) / 1000_real64
371 end if
372
373 !We increase a bit the energy range
374 nenergy = nint((eigmax - eigmin + 2 * nextend * de) / de)
375 safe_allocate(eigs(1:nenergy))
376 do ie = 1, nenergy
377 eigs(ie) = eigmin - nextend * de + (ie - 1) * de
378 end do
379
380 safe_allocate(gvec_abs(1:sys%space%periodic_dim, 1:sys%kpoints%reduced%npoints))
381 gvec_abs = 0
382 file_gvec = io_open('./unfold_gvec.dat', global_namespace, action='read')
383 read(file_gvec,*)
384 read(file_gvec,*)
385 do ik = 1, sys%kpoints%reduced%npoints
386 read(file_gvec,*) vec_sc(1:space%dim)
387 call kpoints_to_absolute(sys%kpoints%latt, vec_sc, gvec_abs(:, ik))
388 end do
389 call io_close(file_gvec)
390
391 if (mpi_world%is_root()) call loct_progress_bar(-1, (st%d%kpt%end - st%d%kpt%start + 1) * st%nst)
392
393 safe_allocate(ake(1:nenergy, 1:st%nik))
394 ake(:, :) = m_zero
395
396 safe_allocate(pkm(st%d%kpt%start:st%d%kpt%end, 1:st%nst))
397 pkm(:, :) = m_zero
398 do ik = st%d%kpt%start, st%d%kpt%end
399 iq = st%d%get_kpoint_index(ik)
400
401 call fourier_shell_init(shell, global_namespace, space, zcube, gr, kk = sys%kpoints%reduced%red_point(:, iq))
402
403 gmin = minval(shell%red_gvec(:,:))
404 gmax = maxval(shell%red_gvec(:,:))
405
406 safe_allocate(g_select(1:shell%ngvectors))
407 g_select(:) = .false.
408
409 select case (sys%space%periodic_dim)
410 case (3)
411 do ig = 1, shell%ngvectors
412 call kpoints_to_absolute(sys%kpoints%latt, real(shell%red_gvec(:,ig), real64), vec_sc(:))
413 do ix = gmin, gmax
414 do iy = gmin, gmax
415 do iz = gmin, gmax
416 vec_pc(1:3) = ix * pc%klattice(1:3,1) + iy * pc%klattice(1:3,2) + iz * pc%klattice(1:3,3)
417 if (abs(vec_sc(1) - vec_pc(1) - gvec_abs(1, iq)) < tol &
418 .and. abs(vec_sc(2) - vec_pc(2)-gvec_abs(2, iq)) < tol &
419 .and. abs(vec_sc(3) - vec_pc(3)-gvec_abs(3, iq)) < tol) then
420 g_select(ig) = .true.
421 end if
422 end do !iz
423 end do !iy
424 end do !ix
425 end do !ig
426
427 case (2)
428
429 do ig = 1, shell%ngvectors
430 call kpoints_to_absolute(sys%kpoints%latt, real(shell%red_gvec(:,ig), real64), vec_sc(:))
431 do ix = gmin, gmax
432 do iy = gmin, gmax
433 vec_pc(1:2) = ix * pc%klattice(1:2,1) + iy * pc%klattice(1:2,2)
434 if (abs(vec_sc(1) - vec_pc(1) - gvec_abs(1, iq)) < tol &
435 .and. abs(vec_sc(2) - vec_pc(2) - gvec_abs(2, iq)) < tol) then
436 g_select(ig) = .true.
437 end if
438 end do !ix
439 end do !ix
440 end do !ig
441
442 case default
443 call messages_not_implemented("Unfolding for periodic dimensions other than 2 or 3")
444 end select
445
446 if (mpi_grp_is_root(gr%mpi_grp)) then
447 write(filename,"(a,i3.3,a4)") trim(adjustl(static_dir))//"ake_",ik,".dat"
448 file_ake = io_open(trim(filename), global_namespace, action='write')
449 write(file_ake, '(a)') '#Energy Ak(E)'
450 write(file_ake, '(a, i5)') '#Number of points in energy window ', nenergy
451 end if
452
453 do ist = 1, st%nst
454 !loop over states
455 do idim = 1, st%d%dim
456 ! Getting wavefunctions
457 ! for the moment we treat all functions as complex
458 call states_elec_get_state(st, gr, idim, ist, ik, zpsi)
459
460 call zmesh_to_cube(gr, zpsi, zcube, cf)
461
462 !Fourier transform from real-space to fourier space
463 call zcube_function_rs2fs(zcube, cf)
464
465 ! Normalisation
466 safe_allocate(field_g(1:shell%ngvectors))
467 norm = m_zero
468 do ig = 1, shell%ngvectors
469 field_g(ig) = cf%fs(shell%coords(1, ig), shell%coords(2, ig), shell%coords(3, ig))
470 norm = norm + abs(field_g(ig))**2
471 end do
472 field_g(:) = field_g(:) / sqrt(norm)
473
474 !Finding sub-g and calculating the Projection Pkm
475 do ig = 1, shell%ngvectors
476 if (.not. g_select(ig)) cycle
477 pkm(ik,ist) = pkm(ik,ist) + abs(field_g(ig))**2
478 end do
479
480 safe_deallocate_a(field_g)
481 end do !idim
482
483 !ist loop end
484 if (mpi_world%is_root()) then
485 call loct_progress_bar((ik - st%d%kpt%start) * st%nst + ist, &
486 (st%d%kpt%end - st%d%kpt%start + 1) * st%nst)
487 end if
488 end do !ist
489
490 ! Calculating the spectral function
491 !TODO: We could implement here a different broadening
492 do ist = 1, st%nst
493 do ie = 1, nenergy
494 ake(ie, ik) = ake(ie, ik) + pkm(ik, ist) * (m_three * de / m_pi) / &
495 ((eigs(ie) - st%eigenval(ist, ik))**2 + (m_three * de)**2)
496 end do
497 end do
498
499 ! writing Spectral-Function
500 if (mpi_grp_is_root(gr%mpi_grp)) then
501 do ie = 1, nenergy
502 write(file_ake, '(1es19.12,1x,1es19.12)') eigs(ie), ake(ie, ik)
503 end do
504
505 call io_close(file_ake)
506 end if
507
508 call fourier_shell_end(shell)
509 safe_deallocate_a(g_select)
510
511 end do !ik
512
513 if (st%d%kpt%parallel) then
514 call comm_allreduce(st%st_kpt_mpi_grp, ake)
515 end if
516
517 if (mpi_world%is_root()) then
518 file_ake = io_open(trim(adjustl(static_dir))//"ake.dat", global_namespace, action='write')
519 write(file_ake, '(a)') '#Energy Ak(E)'
520 write(file_ake, '(a, i5)') '#Number of points in energy window ', nenergy
521 do ik = 1, nkpoints
522 do ie = 1, nenergy
523 write(file_ake,fmt ='(1es19.12,1x,1es19.12,1x,1es19.12)') coord_along_path(ik), &
524 eigs(ie), ake(ie, ik)
525 end do
526 end do
527
528 call io_close(file_ake)
529 end if
530
531 safe_deallocate_a(eigs)
532 safe_deallocate_a(ake)
533
534 safe_deallocate_a(gvec_abs)
535 safe_deallocate_a(pkm)
536 safe_deallocate_a(zpsi)
537 pop_sub(wfs_extract_spec_fn)
538
539 end subroutine wfs_extract_spec_fn
540 !------------------------------------------------------------
541
542end program oct_unfold
543!! Local Variables:
544!! mode: f90
545!! coding: utf-8
546!! End:
This module implements batches of mesh functions.
Definition: batch.F90:135
This module implements common operations on batches of mesh functions.
Definition: batch_ops.F90:118
This module handles the calculation mode.
type(calc_mode_par_t), public calc_mode_par
Singleton instance of parallel calculation mode.
integer, parameter, public p_strategy_states
parallelization in states
subroutine, public zmesh_to_cube(mesh, mf, cube, cf)
Convert a function from the mesh to the cube.
subroutine, public zcube_function_free_rs(cube, cf)
Deallocates the real space grid.
subroutine, public zcube_function_alloc_rs(cube, cf, in_device, force_alloc)
Allocates locally the real space grid, if PFFT library is not used. Otherwise, it assigns the PFFT re...
subroutine, public cube_init(cube, nn, namespace, space, spacing, coord_system, fft_type, fft_library, dont_optimize, nn_out, mpi_grp, need_partition, tp_enlarge, blocksize)
Definition: cube.F90:204
subroutine, public cube_end(cube)
Definition: cube.F90:387
subroutine, public cube_init_cube_map(cube, mesh)
Definition: cube.F90:824
integer, parameter, public spinors
Fast Fourier Transform module. This module provides a single interface that works with different FFT ...
Definition: fft.F90:120
subroutine, public fft_all_init(namespace)
initialize the table
Definition: fft.F90:269
subroutine, public fft_all_end()
delete all plans
Definition: fft.F90:380
integer, parameter, public fft_complex
Definition: fft.F90:174
subroutine, public fourier_shell_init(this, namespace, space, cube, mesh, kk)
subroutine, public fourier_shell_end(this)
subroutine, public cube_function_free_fs(cube, cf)
Deallocates the Fourier space grid.
subroutine, public zcube_function_rs2fs(cube, cf)
The following routines convert the function between real space and Fourier space Note that the dimens...
subroutine, public cube_function_alloc_fs(cube, cf, force_alloc)
Allocates locally the Fourier space grid, if PFFT library is not used. Otherwise, it assigns the PFFT...
subroutine, public global_end()
Finalise parser varinfo file, and MPI.
Definition: global.F90:494
real(real64), parameter, public m_zero
Definition: global.F90:200
real(real64), parameter, public m_pi
some mathematical constants
Definition: global.F90:198
real(real64), parameter, public m_epsilon
Definition: global.F90:216
character(len= *), parameter, public static_dir
Definition: global.F90:279
subroutine, public global_init(communicator)
Initialise Octopus.
Definition: global.F90:375
real(real64), parameter, public m_half
Definition: global.F90:206
real(real64), parameter, public m_three
Definition: global.F90:203
This module implements the underlying real-space grid.
Definition: grid.F90:119
Definition: io.F90:116
subroutine, public io_init(defaults)
If the argument defaults is present and set to true, then the routine will not try to read anything f...
Definition: io.F90:165
subroutine, public io_close(iunit, grp)
Definition: io.F90:467
subroutine, public io_end()
Definition: io.F90:271
integer function, public io_open(file, namespace, action, status, form, position, die, recl, grp)
Definition: io.F90:402
subroutine, public kpoints_path_generate(dim, latt, nkpoints, nsegments, resolution, highsympoints, kpoints, coord)
Generate the k-point along a path.
Definition: kpoints.F90:1400
subroutine, public kpoints_fold_to_1bz(grid, latt)
Definition: kpoints.F90:1590
subroutine, public kpoints_grid_end(this)
Definition: kpoints.F90:254
subroutine, public kpoints_to_reduced(latt, kin, kout)
Definition: kpoints.F90:1150
subroutine, public kpoints_to_absolute(latt, kin, kout)
Definition: kpoints.F90:1137
subroutine, public kpoints_grid_init(dim, this, npoints, nshifts)
Definition: kpoints.F90:233
System information (time, memory, sysname)
Definition: loct.F90:117
subroutine, public loct_progress_bar(a, maxcount)
A wrapper around the progress bar, such that it can be silenced without needing to dress the call wit...
Definition: loct.F90:276
This module is intended to contain "only mathematical" functions and procedures.
Definition: math.F90:117
This module defines various routines, operating on mesh functions.
This module defines the meshes, which are used in Octopus.
Definition: mesh.F90:120
subroutine, public messages_end()
Definition: messages.F90:273
subroutine, public messages_print_with_emphasis(msg, iunit, namespace)
Definition: messages.F90:898
subroutine, public messages_not_implemented(feature, namespace)
Definition: messages.F90:1068
character(len=512), private msg
Definition: messages.F90:167
subroutine, public messages_init(output_dir)
Definition: messages.F90:220
subroutine, public print_date(str)
Definition: messages.F90:983
character(len=256), dimension(max_lines), public message
to be output by fatal, warning
Definition: messages.F90:162
subroutine, public messages_fatal(no_lines, only_root_writes, namespace)
Definition: messages.F90:410
subroutine, public messages_input_error(namespace, var, details, row, column)
Definition: messages.F90:691
subroutine, public messages_experimental(name, namespace)
Definition: messages.F90:1040
logical function mpi_grp_is_root(grp)
Is the current MPI process of grpcomm, root.
Definition: mpi.F90:407
type(mpi_grp_t), public mpi_world
Definition: mpi.F90:272
This module handles the communicators for the various parallelization strategies.
Definition: multicomm.F90:147
type(namespace_t), public global_namespace
Definition: namespace.F90:135
subroutine, public parser_init()
Initialise the Octopus parser.
Definition: parser.F90:410
subroutine, public parser_end()
End the Octopus parser.
Definition: parser.F90:442
integer function, public parse_block(namespace, name, blk, check_varinfo_)
Definition: parser.F90:623
subroutine, public profiling_end(namespace)
Definition: profiling.F90:415
subroutine, public profiling_init(namespace)
Create profiling subdirectory.
Definition: profiling.F90:257
integer, parameter, public restart_type_load
Definition: restart.F90:184
integer, parameter, public restart_unocc
Definition: restart.F90:156
subroutine, public states_elec_allocate_wfns(st, mesh, wfs_type, skip, packed)
Allocates the KS wavefunctions defined within a states_elec_t structure.
This module handles reading and writing restart information for the states_elec_t.
subroutine, public states_elec_load(restart, namespace, space, st, mesh, kpoints, fixed_occ, ierr, iter, lr, lowest_missing, label, verbose, skip)
returns in ierr: <0 => Fatal error, or nothing read =0 => read all wavefunctions >0 => could only rea...
brief This module defines the class unit_t which is used by the unit_systems_oct_m module.
Definition: unit.F90:134
This module defines the unit system, used for input and output.
subroutine, public unit_system_init(namespace)
This module is intended to contain simple general-purpose utility functions and procedures.
Definition: utils.F90:120
subroutine, public print_header()
This subroutine prints the logo followed by information about the compilation and the system....
Definition: utils.F90:304
Definition: xc.F90:120
Class describing the electron system.
Definition: electrons.F90:221
Description of the grid, containing information on derivatives, stencil, and symmetries.
Definition: grid.F90:171
The states_elec_t class contains all electronic wave functions.
int true(void)
subroutine unfold_setup()
Definition: unfold.F90:378
subroutine wfs_extract_spec_fn(space, st, gr, zcube, cf)
Definition: unfold.F90:408
program oct_unfold
Definition: unfold.F90:119