22 USE dbcsr_api,
ONLY: &
23 dbcsr_add, dbcsr_add_on_diag, dbcsr_copy, dbcsr_create, dbcsr_desymmetrize, &
24 dbcsr_distribution_get, dbcsr_distribution_type, dbcsr_dot, dbcsr_filter, dbcsr_finalize, &
25 dbcsr_frobenius_norm, dbcsr_func_inverse, dbcsr_function_of_elements, dbcsr_get_diag, &
26 dbcsr_get_info, dbcsr_get_stored_coordinates, dbcsr_hadamard_product, &
27 dbcsr_iterator_blocks_left, dbcsr_iterator_next_block, dbcsr_iterator_start, &
28 dbcsr_iterator_stop, dbcsr_iterator_type, dbcsr_multiply, dbcsr_nblkcols_total, &
29 dbcsr_nblkrows_total, dbcsr_norm, dbcsr_norm_maxabsnorm, dbcsr_release, &
30 dbcsr_reserve_block2d, dbcsr_scale, dbcsr_set, dbcsr_set_diag, dbcsr_transposed, &
31 dbcsr_type, dbcsr_type_no_symmetry, dbcsr_work_create
38 #include "./base/base_uses.f90"
44 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'ct_methods'
60 TYPE(ct_step_env_type) :: cts_env
62 CHARACTER(len=*),
PARAMETER :: routinen =
'ct_step_execute'
64 INTEGER :: handle, n, preconditioner_type, unit_nr
65 REAL(kind=
dp) :: gap_estimate, safety_margin
66 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: evals
67 TYPE(cp_logger_type),
POINTER :: logger
68 TYPE(dbcsr_type) :: matrix_pp, matrix_pq, matrix_qp, &
69 matrix_qp_save, matrix_qq, oo1, &
70 oo1_sqrt, oo1_sqrt_inv, t_corr, tmp1, &
80 CALL timeset(routinen, handle)
83 IF (logger%para_env%is_source())
THEN
90 IF (cts_env%update_q .AND. (.NOT. cts_env%update_p))
THEN
91 cpabort(
"q-update is possible only with p-update")
95 cpabort(
"riccati is not implemented for biorthogonal basis")
98 IF (.NOT.
ASSOCIATED(cts_env%matrix_ks))
THEN
99 cpabort(
"KS matrix is not associated")
102 IF (cts_env%use_virt_orbs .AND. (.NOT. cts_env%use_occ_orbs))
THEN
103 cpabort(
"virtual orbs can be used only with occupied orbs")
106 IF (cts_env%use_occ_orbs)
THEN
107 IF (.NOT.
ASSOCIATED(cts_env%matrix_t))
THEN
108 cpabort(
"T matrix is not associated")
110 IF (.NOT.
ASSOCIATED(cts_env%matrix_qp_template))
THEN
111 cpabort(
"QP template is not associated")
113 IF (.NOT.
ASSOCIATED(cts_env%matrix_pq_template))
THEN
114 cpabort(
"PQ template is not associated")
118 IF (cts_env%use_virt_orbs)
THEN
119 IF (.NOT.
ASSOCIATED(cts_env%matrix_v))
THEN
120 cpabort(
"V matrix is not associated")
123 IF (.NOT.
ASSOCIATED(cts_env%matrix_p))
THEN
124 cpabort(
"P matrix is not associated")
130 cpabort(
"illegal tensor flag")
134 IF (cts_env%use_occ_orbs)
THEN
137 CALL dbcsr_create(matrix_pp, &
138 template=cts_env%p_index_up, &
139 matrix_type=dbcsr_type_no_symmetry)
140 CALL dbcsr_create(matrix_qp, &
141 template=cts_env%matrix_qp_template, &
142 matrix_type=dbcsr_type_no_symmetry)
143 CALL dbcsr_create(matrix_qq, &
144 template=cts_env%q_index_up, &
145 matrix_type=dbcsr_type_no_symmetry)
146 CALL dbcsr_create(matrix_pq, &
147 template=cts_env%matrix_pq_template, &
148 matrix_type=dbcsr_type_no_symmetry)
151 CALL dbcsr_create(cts_env%matrix_res, &
152 template=cts_env%matrix_qp_template)
154 CALL assemble_ks_qp_blocks(cts_env%matrix_ks, &
158 cts_env%q_index_down, &
159 cts_env%p_index_up, &
160 cts_env%q_index_up, &
165 cts_env%tensor_type, &
166 cts_env%use_virt_orbs, &
170 CALL dbcsr_create(cts_env%matrix_x, &
171 template=cts_env%matrix_qp_template)
172 IF (
ASSOCIATED(cts_env%matrix_x_guess))
THEN
173 CALL dbcsr_copy(cts_env%matrix_x, &
174 cts_env%matrix_x_guess)
179 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%q_index_down, &
180 cts_env%matrix_x, 0.0_dp, cts_env%matrix_res, &
181 filter_eps=cts_env%eps_filter)
182 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%matrix_res, &
183 cts_env%p_index_up, 0.0_dp, &
185 filter_eps=cts_env%eps_filter)
189 CALL dbcsr_set(cts_env%matrix_x, 0.0_dp)
194 preconditioner_type = 1
195 safety_margin = 2.0_dp
196 gap_estimate = 0.0001_dp
197 SELECT CASE (preconditioner_type)
202 CALL dbcsr_create(u_pp, template=matrix_pp, &
203 matrix_type=dbcsr_type_no_symmetry)
206 CALL dbcsr_get_info(matrix_pp, nfullrows_total=n)
209 cts_env%para_env, cts_env%blacs_env)
215 CALL dbcsr_create(u_qq, template=matrix_qq, &
216 matrix_type=dbcsr_type_no_symmetry)
219 CALL dbcsr_get_info(matrix_qq, nfullrows_total=n)
222 cts_env%para_env, cts_env%blacs_env)
229 CALL matrix_forward_transform(matrix_pp, u_pp, u_pp, &
231 CALL matrix_forward_transform(matrix_qq, u_qq, u_qq, &
233 CALL matrix_forward_transform(matrix_qp, u_qq, u_pp, &
235 CALL matrix_forward_transform(matrix_pq, u_pp, u_qq, &
237 CALL matrix_forward_transform(cts_env%matrix_x, u_qq, u_pp, &
240 IF (cts_env%max_iter .GE. 0)
THEN
242 CALL solve_riccati_equation( &
247 x=cts_env%matrix_x, &
248 res=cts_env%matrix_res, &
249 neglect_quadratic_term=cts_env%neglect_quadratic_term, &
250 conjugator=cts_env%conjugator, &
251 max_iter=cts_env%max_iter, &
252 eps_convergence=cts_env%eps_convergence, &
253 eps_filter=cts_env%eps_filter, &
254 converged=cts_env%converged)
256 IF (cts_env%converged)
THEN
264 cpabort(
"RICCATI: CG algorithm has NOT converged")
269 IF (cts_env%calculate_energy_corr)
THEN
271 CALL dbcsr_dot(matrix_qp, cts_env%matrix_x, cts_env%energy_correction)
275 CALL dbcsr_release(matrix_pp)
276 CALL dbcsr_release(matrix_qp)
277 CALL dbcsr_release(matrix_qq)
278 CALL dbcsr_release(matrix_pq)
281 CALL matrix_backward_transform(cts_env%matrix_x, u_qq, &
282 u_pp, cts_env%eps_filter)
284 CALL dbcsr_release(u_qq)
285 CALL dbcsr_release(u_pp)
292 CALL dbcsr_create(u_pp, template=matrix_pp, &
293 matrix_type=dbcsr_type_no_symmetry)
294 CALL dbcsr_copy(u_pp, matrix_pp)
295 CALL dbcsr_scale(u_pp, -1.0_dp)
296 CALL dbcsr_add_on_diag(u_pp, &
297 abs(safety_margin*gap_estimate))
299 para_env=cts_env%para_env, &
300 blacs_env=cts_env%blacs_env)
302 para_env=cts_env%para_env, &
303 blacs_env=cts_env%blacs_env, &
304 upper_to_full=.true.)
307 CALL dbcsr_create(u_qq, template=matrix_qq, &
308 matrix_type=dbcsr_type_no_symmetry)
309 CALL dbcsr_copy(u_qq, matrix_qq)
310 CALL dbcsr_add_on_diag(u_qq, &
311 abs(safety_margin*gap_estimate))
313 para_env=cts_env%para_env, &
314 blacs_env=cts_env%blacs_env)
316 para_env=cts_env%para_env, &
317 blacs_env=cts_env%blacs_env, &
318 upper_to_full=.true.)
321 CALL dbcsr_create(tmp1, template=matrix_qq, &
322 matrix_type=dbcsr_type_no_symmetry)
323 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, u_qq, &
324 matrix_qq, 0.0_dp, tmp1, &
325 filter_eps=cts_env%eps_filter)
326 CALL dbcsr_copy(matrix_qq, tmp1)
327 CALL dbcsr_release(tmp1)
329 CALL dbcsr_create(tmp1, template=matrix_pp, &
330 matrix_type=dbcsr_type_no_symmetry)
331 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, matrix_pp, &
332 u_pp, 0.0_dp, tmp1, &
333 filter_eps=cts_env%eps_filter)
334 CALL dbcsr_copy(matrix_pp, tmp1)
335 CALL dbcsr_release(tmp1)
337 CALL dbcsr_create(matrix_qp_save, template=matrix_qp, &
338 matrix_type=dbcsr_type_no_symmetry)
339 CALL dbcsr_copy(matrix_qp_save, matrix_qp)
341 CALL dbcsr_create(tmp1, template=matrix_qp, &
342 matrix_type=dbcsr_type_no_symmetry)
343 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, matrix_qp, &
344 u_pp, 0.0_dp, tmp1, &
345 filter_eps=cts_env%eps_filter)
346 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, u_qq, tmp1, &
348 filter_eps=cts_env%eps_filter)
349 CALL dbcsr_release(tmp1)
354 IF (cts_env%max_iter .GE. 0)
THEN
356 CALL solve_riccati_equation( &
363 x=cts_env%matrix_x, &
364 res=cts_env%matrix_res, &
365 neglect_quadratic_term=cts_env%neglect_quadratic_term, &
366 conjugator=cts_env%conjugator, &
367 max_iter=cts_env%max_iter, &
368 eps_convergence=cts_env%eps_convergence, &
369 eps_filter=cts_env%eps_filter, &
370 converged=cts_env%converged)
372 IF (cts_env%converged)
THEN
380 cpabort(
"RICCATI: CG algorithm has NOT converged")
385 IF (cts_env%calculate_energy_corr)
THEN
387 CALL dbcsr_dot(matrix_qp_save, cts_env%matrix_x, cts_env%energy_correction)
390 CALL dbcsr_release(matrix_qp_save)
392 CALL dbcsr_release(matrix_pp)
393 CALL dbcsr_release(matrix_qp)
394 CALL dbcsr_release(matrix_qq)
395 CALL dbcsr_release(matrix_pq)
397 CALL dbcsr_release(u_qq)
398 CALL dbcsr_release(u_pp)
401 cpabort(
"illegal preconditioner type")
404 IF (cts_env%update_p)
THEN
407 cpabort(
"orbital update is NYI for this tensor type")
412 CALL dbcsr_create(oo1, &
413 template=cts_env%p_index_up, &
414 matrix_type=dbcsr_type_no_symmetry)
415 CALL dbcsr_create(oo1_sqrt_inv, &
417 CALL dbcsr_create(oo1_sqrt, &
421 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, cts_env%matrix_x, &
422 cts_env%matrix_x, 0.0_dp, oo1, &
423 filter_eps=cts_env%eps_filter)
424 CALL dbcsr_add_on_diag(oo1, 1.0_dp)
432 threshold=cts_env%eps_filter, &
433 order=cts_env%order_lanczos, &
434 eps_lanczos=cts_env%eps_lancsoz, &
435 max_iter_lanczos=cts_env%max_iter_lanczos)
436 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%p_index_up, &
437 oo1_sqrt_inv, 0.0_dp, oo1, &
438 filter_eps=cts_env%eps_filter)
439 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, oo1, &
440 cts_env%p_index_down, 0.0_dp, oo1_sqrt, &
441 filter_eps=cts_env%eps_filter)
442 CALL dbcsr_release(oo1)
443 CALL dbcsr_release(oo1_sqrt_inv)
446 CALL dbcsr_create(matrix_qp, &
447 template=cts_env%matrix_qp_template, &
448 matrix_type=dbcsr_type_no_symmetry)
449 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%q_index_up, &
450 cts_env%matrix_x, 0.0_dp, matrix_qp, &
451 filter_eps=cts_env%eps_filter)
452 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, matrix_qp, &
453 cts_env%p_index_down, 0.0_dp, &
455 filter_eps=cts_env%eps_filter)
456 CALL dbcsr_release(matrix_qp)
459 CALL dbcsr_create(t_corr, template=cts_env%matrix_t)
460 IF (cts_env%use_virt_orbs)
THEN
461 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%matrix_v, &
462 cts_env%matrix_x, 0.0_dp, t_corr, &
463 filter_eps=cts_env%eps_filter)
464 CALL dbcsr_add(cts_env%matrix_t, t_corr, &
467 CALL dbcsr_add(cts_env%matrix_t, cts_env%matrix_x, &
471 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%matrix_t, oo1_sqrt, &
472 0.0_dp, t_corr, filter_eps=cts_env%eps_filter)
473 CALL dbcsr_copy(cts_env%matrix_t, t_corr)
475 CALL dbcsr_release(t_corr)
476 CALL dbcsr_release(oo1_sqrt)
482 CALL dbcsr_create(matrix_qp, &
483 template=cts_env%matrix_qp_template, &
484 matrix_type=dbcsr_type_no_symmetry)
485 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, cts_env%q_index_up, &
486 cts_env%matrix_x, 0.0_dp, matrix_qp, &
487 filter_eps=cts_env%eps_filter)
488 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, matrix_qp, &
489 cts_env%p_index_down, 0.0_dp, &
491 filter_eps=cts_env%eps_filter)
492 CALL dbcsr_release(matrix_qp)
498 cpabort(
"illegal occ option")
501 CALL timestop(handle)
525 SUBROUTINE assemble_ks_qp_blocks(ks, p, t, v, q_index_down, &
526 p_index_up, q_index_up, pp, qq, qp, pq, tensor_type, use_virt_orbs, eps_filter)
528 TYPE(dbcsr_type),
INTENT(IN) :: ks, p, t, v, q_index_down, p_index_up, &
530 TYPE(dbcsr_type),
INTENT(OUT) :: pp, qq, qp, pq
531 INTEGER,
INTENT(IN) :: tensor_type
532 LOGICAL,
INTENT(IN) :: use_virt_orbs
533 REAL(kind=
dp),
INTENT(IN) :: eps_filter
535 CHARACTER(len=*),
PARAMETER :: routinen =
'assemble_ks_qp_blocks'
538 LOGICAL :: library_fixed
539 TYPE(dbcsr_type) :: kst, ksv, no, on, oo, q_index_up_nosym, &
542 CALL timeset(routinen, handle)
544 IF (use_virt_orbs)
THEN
547 CALL dbcsr_create(t_or, template=t)
548 CALL dbcsr_create(v_or, template=v)
549 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, t, p_index_up, &
550 0.0_dp, t_or, filter_eps=eps_filter)
551 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, v, q_index_up, &
552 0.0_dp, v_or, filter_eps=eps_filter)
555 CALL dbcsr_create(kst, template=t)
556 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, ks, t_or, &
557 0.0_dp, kst, filter_eps=eps_filter)
559 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, t_or, kst, &
560 0.0_dp, pp, filter_eps=eps_filter)
562 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, v_or, kst, &
563 0.0_dp, qp, filter_eps=eps_filter)
564 CALL dbcsr_release(kst)
567 CALL dbcsr_create(ksv, template=v)
568 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, ks, v_or, &
569 0.0_dp, ksv, filter_eps=eps_filter)
571 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, t_or, ksv, &
572 0.0_dp, pq, filter_eps=eps_filter)
574 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, v_or, ksv, &
575 0.0_dp, qq, filter_eps=eps_filter)
576 CALL dbcsr_release(ksv)
578 CALL dbcsr_release(t_or)
579 CALL dbcsr_release(v_or)
584 CALL dbcsr_create(sp, template=q_index_down, &
585 matrix_type=dbcsr_type_no_symmetry)
586 CALL dbcsr_create(spf, template=q_index_down, &
587 matrix_type=dbcsr_type_no_symmetry)
590 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, ks, t, 0.0_dp, qp, &
591 filter_eps=eps_filter)
593 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, t, qp, 0.0_dp, pp, &
594 filter_eps=eps_filter)
596 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, q_index_down, p, 0.0_dp, sp, &
597 filter_eps=eps_filter)
600 SELECT CASE (tensor_type)
602 CALL dbcsr_add_on_diag(sp, 1.0_dp)
604 CALL dbcsr_create(q_index_up_nosym, template=q_index_up, &
605 matrix_type=dbcsr_type_no_symmetry)
606 CALL dbcsr_desymmetrize(q_index_up, q_index_up_nosym)
607 CALL dbcsr_add(sp, q_index_up_nosym, 1.0_dp, 1.0_dp)
608 CALL dbcsr_release(q_index_up_nosym)
612 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, sp, ks, 0.0_dp, spf, &
613 filter_eps=eps_filter)
616 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, spf, t, 0.0_dp, qp, &
617 filter_eps=eps_filter)
619 SELECT CASE (tensor_type)
622 CALL dbcsr_transposed(pq, qp, transpose_distribution=.false.)
625 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, p_index_up, qp, 0.0_dp, pq, &
626 filter_eps=eps_filter)
627 library_fixed = .false.
628 IF (library_fixed)
THEN
629 CALL dbcsr_transposed(qp, pq, transpose_distribution=.false.)
631 CALL dbcsr_create(no, template=qp, &
632 matrix_type=dbcsr_type_no_symmetry)
633 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, qp, p_index_up, 0.0_dp, no, &
634 filter_eps=eps_filter)
635 CALL dbcsr_copy(qp, no)
636 CALL dbcsr_release(no)
641 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, spf, sp, 0.0_dp, qq, &
642 filter_eps=eps_filter)
644 SELECT CASE (tensor_type)
647 CALL dbcsr_create(oo, template=pp, &
648 matrix_type=dbcsr_type_no_symmetry)
649 CALL dbcsr_create(no, template=qp, &
650 matrix_type=dbcsr_type_no_symmetry)
653 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, q_index_up, qq, 0.0_dp, spf, &
654 filter_eps=eps_filter)
655 CALL dbcsr_copy(qq, spf)
656 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, q_index_up, qp, 0.0_dp, no, &
657 filter_eps=eps_filter)
658 CALL dbcsr_copy(qp, no)
659 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, p_index_up, pp, 0.0_dp, oo, &
660 filter_eps=eps_filter)
661 CALL dbcsr_copy(pp, oo)
662 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, p_index_up, pq, 0.0_dp, on, &
663 filter_eps=eps_filter)
664 CALL dbcsr_copy(pq, on)
666 CALL dbcsr_release(no)
667 CALL dbcsr_release(oo)
671 CALL dbcsr_create(oo, template=pp, &
672 matrix_type=dbcsr_type_no_symmetry)
675 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, p_index_up, pp, 0.0_dp, oo, &
676 filter_eps=eps_filter)
677 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, oo, p_index_up, 0.0_dp, pp, &
678 filter_eps=eps_filter)
680 CALL dbcsr_release(oo)
684 CALL dbcsr_release(sp)
685 CALL dbcsr_release(spf)
689 CALL timestop(handle)
691 END SUBROUTINE assemble_ks_qp_blocks
717 RECURSIVE SUBROUTINE solve_riccati_equation(pp, qq, qp, pq, oo, vv, x, res, &
718 neglect_quadratic_term, &
719 conjugator, max_iter, eps_convergence, eps_filter, &
722 TYPE(dbcsr_type),
INTENT(IN) :: pp, qq
723 TYPE(dbcsr_type),
INTENT(INOUT) :: qp
724 TYPE(dbcsr_type),
INTENT(IN) :: pq
725 TYPE(dbcsr_type),
INTENT(IN),
OPTIONAL :: oo, vv
726 TYPE(dbcsr_type),
INTENT(INOUT) :: x
727 TYPE(dbcsr_type),
INTENT(OUT) :: res
728 LOGICAL,
INTENT(IN) :: neglect_quadratic_term
729 INTEGER,
INTENT(IN) :: conjugator, max_iter
730 REAL(kind=
dp),
INTENT(IN) :: eps_convergence, eps_filter
731 LOGICAL,
INTENT(OUT) :: converged
733 CHARACTER(len=*),
PARAMETER :: routinen =
'solve_riccati_equation'
735 INTEGER :: handle, istep, iteration, nsteps, &
736 unit_nr, update_prec_freq
737 LOGICAL :: prepare_to_exit, present_oo, present_vv, &
738 quadratic_term, restart_conjugator
739 REAL(kind=
dp) :: best_norm, best_step_size, beta, c0, c1, &
740 c2, c3, denom, kappa, numer, &
741 obj_function, t1, t2, tau
742 REAL(kind=
dp),
DIMENSION(3) :: step_size
743 TYPE(cp_logger_type),
POINTER :: logger
744 TYPE(dbcsr_type) :: aux1, aux2, grad, m, n, oo1, oo2, prec, &
745 res_trial, step, step_oo, vv_step
749 CALL timeset(routinen, handle)
752 IF (logger%para_env%is_source())
THEN
777 quadratic_term = .NOT. neglect_quadratic_term
778 present_oo =
PRESENT(oo)
779 present_vv =
PRESENT(vv)
782 CALL dbcsr_create(aux1, template=pp)
783 CALL dbcsr_copy(aux1, pp)
784 CALL dbcsr_scale(aux1, -1.0_dp)
787 CALL dbcsr_create(aux2, template=qq)
788 CALL dbcsr_copy(aux2, qq)
791 CALL dbcsr_create(grad, template=x)
792 CALL dbcsr_set(grad, 0.0_dp)
796 CALL dbcsr_create(prec, template=x)
801 CALL dbcsr_create(step, template=x)
805 CALL dbcsr_create(n, template=x)
806 CALL dbcsr_create(m, template=x)
807 CALL dbcsr_create(oo1, template=pp)
808 CALL dbcsr_create(oo2, template=pp)
809 CALL dbcsr_create(res_trial, template=res)
810 CALL dbcsr_create(vv_step, template=res)
811 CALL dbcsr_create(step_oo, template=res)
816 prepare_to_exit = .false.
818 best_step_size = 0.0_dp
819 best_norm = 1.0e+100_dp
822 restart_conjugator = .false.
823 update_prec_freq = 20
827 IF (iteration .EQ. 0)
THEN
828 CALL dbcsr_copy(res, qp)
830 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, qq, x, 0.0_dp, res_trial, &
831 filter_eps=eps_filter)
832 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, res_trial, oo, 1.0_dp, res, &
833 filter_eps=eps_filter)
835 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, qq, x, 1.0_dp, res, &
836 filter_eps=eps_filter)
839 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, x, pp, 0.0_dp, res_trial, &
840 filter_eps=eps_filter)
841 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, vv, res_trial, 1.0_dp, res, &
842 filter_eps=eps_filter)
844 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, x, pp, 1.0_dp, res, &
845 filter_eps=eps_filter)
847 IF (quadratic_term)
THEN
849 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, pq, x, 0.0_dp, oo1, &
850 filter_eps=eps_filter)
851 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, oo1, oo, 0.0_dp, oo2, &
852 filter_eps=eps_filter)
854 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, pq, x, 0.0_dp, oo2, &
855 filter_eps=eps_filter)
858 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, x, oo2, 0.0_dp, res_trial, &
859 filter_eps=eps_filter)
860 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, vv, res_trial, 1.0_dp, res, &
861 filter_eps=eps_filter)
863 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, x, oo2, 1.0_dp, res, &
864 filter_eps=eps_filter)
867 CALL dbcsr_norm(res, dbcsr_norm_maxabsnorm, norm_scalar=best_norm)
869 CALL dbcsr_add(res, m, 1.0_dp, best_step_size)
870 CALL dbcsr_add(res, n, 1.0_dp, -best_step_size*best_step_size)
871 CALL dbcsr_filter(res, eps_filter)
875 converged = (best_norm .LT. eps_convergence)
876 IF (converged .OR. (iteration .GE. max_iter))
THEN
877 prepare_to_exit = .true.
880 IF (.NOT. prepare_to_exit)
THEN
883 IF (quadratic_term)
THEN
884 IF (iteration .EQ. 0)
THEN
886 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, pq, x, 0.0_dp, oo1, &
887 filter_eps=eps_filter)
888 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, oo1, oo, 1.0_dp, aux1, &
889 filter_eps=eps_filter)
891 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, pq, x, 1.0_dp, aux1, &
892 filter_eps=eps_filter)
895 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, vv, x, 0.0_dp, res_trial, &
896 filter_eps=eps_filter)
897 CALL dbcsr_multiply(
"N",
"N", +1.0_dp, res_trial, pq, 1.0_dp, aux2, &
898 filter_eps=eps_filter)
900 CALL dbcsr_multiply(
"N",
"N", -1.0_dp, x, pq, 1.0_dp, aux2, &
901 filter_eps=eps_filter)
905 CALL dbcsr_multiply(
"N",
"N", -best_step_size, pq, step_oo, 1.0_dp, aux1, &
906 filter_eps=eps_filter)
908 CALL dbcsr_multiply(
"N",
"N", -best_step_size, pq, step, 1.0_dp, aux1, &
909 filter_eps=eps_filter)
912 CALL dbcsr_multiply(
"N",
"N", -best_step_size, vv_step, pq, 1.0_dp, aux2, &
913 filter_eps=eps_filter)
915 CALL dbcsr_multiply(
"N",
"N", -best_step_size, step, pq, 1.0_dp, aux2, &
916 filter_eps=eps_filter)
925 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, res, aux1, 0.0_dp, res_trial, &
926 filter_eps=eps_filter)
927 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, vv, res_trial, 0.0_dp, m, &
928 filter_eps=eps_filter)
930 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, res, aux1, 0.0_dp, m, &
931 filter_eps=eps_filter)
934 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, aux1, res, 0.0_dp, res_trial, &
935 filter_eps=eps_filter)
936 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, res_trial, oo, 1.0_dp, m, &
937 filter_eps=eps_filter)
939 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, aux2, res, 1.0_dp, m, &
940 filter_eps=eps_filter)
945 IF (iteration .EQ. 0)
THEN
946 CALL create_preconditioner(prec, aux1, aux2, eps_filter)
953 IF ((iteration .EQ. 0) .OR. restart_conjugator)
THEN
956 restart_conjugator = .false.
957 SELECT CASE (conjugator)
959 CALL dbcsr_add(grad, m, -1.0_dp, 1.0_dp)
960 CALL dbcsr_hadamard_product(prec, grad, n)
961 CALL dbcsr_dot(n, m, numer)
962 CALL dbcsr_dot(grad, step, denom)
965 CALL dbcsr_hadamard_product(prec, grad, n)
966 CALL dbcsr_dot(grad, n, denom)
967 CALL dbcsr_hadamard_product(prec, m, n)
968 CALL dbcsr_dot(m, n, numer)
971 CALL dbcsr_hadamard_product(prec, grad, n)
972 CALL dbcsr_dot(grad, n, denom)
973 CALL dbcsr_add(grad, m, -1.0_dp, 1.0_dp)
974 CALL dbcsr_hadamard_product(prec, grad, n)
975 CALL dbcsr_dot(n, m, numer)
978 CALL dbcsr_hadamard_product(prec, m, n)
979 CALL dbcsr_dot(m, n, numer)
980 CALL dbcsr_dot(grad, step, denom)
981 beta = -1.0_dp*numer/denom
983 CALL dbcsr_dot(grad, step, denom)
984 CALL dbcsr_add(grad, m, -1.0_dp, 1.0_dp)
985 CALL dbcsr_hadamard_product(prec, grad, n)
986 CALL dbcsr_dot(n, m, numer)
987 beta = -1.0_dp*numer/denom
989 CALL dbcsr_hadamard_product(prec, m, n)
990 CALL dbcsr_dot(m, n, numer)
991 CALL dbcsr_add(grad, m, -1.0_dp, 1.0_dp)
992 CALL dbcsr_dot(grad, step, denom)
995 CALL dbcsr_add(grad, m, -1.0_dp, 1.0_dp)
996 CALL dbcsr_dot(grad, step, denom)
997 CALL dbcsr_hadamard_product(prec, grad, n)
998 CALL dbcsr_dot(n, grad, numer)
999 kappa = 2.0_dp*numer/denom
1000 CALL dbcsr_dot(n, m, numer)
1002 CALL dbcsr_dot(step, m, numer)
1003 beta = tau - kappa*numer/denom
1007 cpabort(
"illegal conjugator")
1012 CALL dbcsr_copy(grad, m)
1015 CALL dbcsr_hadamard_product(prec, grad, m)
1016 CALL dbcsr_filter(m, eps_filter)
1019 CALL dbcsr_add(step, m, beta, -1.0_dp)
1020 CALL dbcsr_filter(step, eps_filter)
1048 IF (present_vv)
THEN
1049 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, vv, step, 0.0_dp, vv_step, &
1050 filter_eps=eps_filter)
1051 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, vv_step, aux1, 0.0_dp, m, &
1052 filter_eps=eps_filter)
1054 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, step, aux1, 0.0_dp, m, &
1055 filter_eps=eps_filter)
1057 IF (present_oo)
THEN
1058 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, step, oo, 0.0_dp, step_oo, &
1059 filter_eps=eps_filter)
1060 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, aux2, step_oo, 1.0_dp, m, &
1061 filter_eps=eps_filter)
1063 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, aux2, step, 1.0_dp, m, &
1064 filter_eps=eps_filter)
1067 IF (quadratic_term)
THEN
1069 IF (present_oo)
THEN
1070 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, pq, step, 0.0_dp, oo1, &
1071 filter_eps=eps_filter)
1072 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, oo1, oo, 0.0_dp, oo2, &
1073 filter_eps=eps_filter)
1075 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, pq, step, 0.0_dp, oo2, &
1076 filter_eps=eps_filter)
1078 IF (present_vv)
THEN
1079 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, step, oo2, 0.0_dp, res_trial, &
1080 filter_eps=eps_filter)
1081 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, vv, res_trial, 0.0_dp, n, &
1082 filter_eps=eps_filter)
1084 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, step, oo2, 0.0_dp, n, &
1085 filter_eps=eps_filter)
1089 CALL dbcsr_set(n, 0.0_dp)
1093 c0 = 2.0_dp*(dbcsr_frobenius_norm(n))**2
1095 CALL dbcsr_dot(m, n, c1)
1098 CALL dbcsr_dot(res, n, c2)
1099 c2 = -2.0_dp*c2 + (dbcsr_frobenius_norm(m))**2
1101 CALL dbcsr_dot(res, m, c3)
1106 IF (nsteps .EQ. 0)
THEN
1107 cpabort(
"no step sizes!")
1111 best_norm = 1.0e+100_dp
1112 best_step_size = 0.0_dp
1113 DO istep = 1, nsteps
1115 CALL dbcsr_copy(res_trial, res)
1116 CALL dbcsr_add(res_trial, m, 1.0_dp, step_size(istep))
1117 CALL dbcsr_add(res_trial, n, 1.0_dp, -step_size(istep)*step_size(istep))
1118 CALL dbcsr_filter(res_trial, eps_filter)
1122 CALL dbcsr_norm(res_trial, dbcsr_norm_maxabsnorm, norm_scalar=obj_function)
1123 IF (obj_function .LT. best_norm)
THEN
1124 best_norm = obj_function
1125 best_step_size = step_size(istep)
1132 CALL dbcsr_add(x, step, 1.0_dp, best_step_size)
1133 CALL dbcsr_filter(x, eps_filter)
1141 converged = (best_norm .LT. eps_convergence)
1142 IF (converged .OR. (iteration .GE. max_iter))
THEN
1143 prepare_to_exit = .true.
1148 IF (unit_nr > 0)
THEN
1149 WRITE (unit_nr,
'(T6,A,1X,I4,1X,E12.3,F8.3)') &
1150 "RICCATI iter ", iteration, best_norm, t2 - t1
1157 iteration = iteration + 1
1159 IF (prepare_to_exit)
EXIT
1163 CALL dbcsr_release(aux1)
1164 CALL dbcsr_release(aux2)
1165 CALL dbcsr_release(grad)
1166 CALL dbcsr_release(step)
1167 CALL dbcsr_release(n)
1168 CALL dbcsr_release(m)
1169 CALL dbcsr_release(oo1)
1170 CALL dbcsr_release(oo2)
1171 CALL dbcsr_release(res_trial)
1172 CALL dbcsr_release(vv_step)
1173 CALL dbcsr_release(step_oo)
1175 CALL timestop(handle)
1177 END SUBROUTINE solve_riccati_equation
1192 SUBROUTINE create_preconditioner(prec, pp, qq, eps_filter)
1194 TYPE(dbcsr_type),
INTENT(OUT) :: prec
1195 TYPE(dbcsr_type),
INTENT(IN) :: pp, qq
1196 REAL(kind=
dp),
INTENT(IN) :: eps_filter
1198 CHARACTER(len=*),
PARAMETER :: routinen =
'create_preconditioner'
1200 INTEGER :: col, handle, hold, iblock_col, &
1201 iblock_row, mynode, nblkcols_tot, &
1202 nblkrows_tot, p_nrows, q_nrows, row
1204 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: p_diagonal, q_diagonal
1205 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: p_new_block
1206 TYPE(dbcsr_distribution_type) :: dist
1207 TYPE(dbcsr_type) :: pp_diag, qq_diag, t1, t2, tmp
1211 CALL timeset(routinen, handle)
1224 CALL dbcsr_create(tmp, template=prec)
1228 CALL dbcsr_get_info(tmp, distribution=dist)
1229 CALL dbcsr_distribution_get(dist, mynode=mynode)
1230 CALL dbcsr_work_create(tmp, work_mutable=.true.)
1231 nblkrows_tot = dbcsr_nblkrows_total(tmp)
1232 nblkcols_tot = dbcsr_nblkcols_total(tmp)
1233 DO row = 1, nblkrows_tot
1234 DO col = 1, nblkcols_tot
1238 CALL dbcsr_get_stored_coordinates(tmp, iblock_row, iblock_col, hold)
1239 IF (hold .EQ. mynode)
THEN
1240 NULLIFY (p_new_block)
1241 CALL dbcsr_reserve_block2d(tmp, iblock_row, iblock_col, p_new_block)
1242 cpassert(
ASSOCIATED(p_new_block))
1243 p_new_block(:, :) = 1.0_dp
1247 CALL dbcsr_finalize(tmp)
1250 CALL dbcsr_get_info(pp, nfullrows_total=p_nrows)
1251 CALL dbcsr_create(pp_diag, template=pp)
1252 ALLOCATE (p_diagonal(p_nrows))
1253 CALL dbcsr_get_diag(pp, p_diagonal)
1254 CALL dbcsr_add_on_diag(pp_diag, 1.0_dp)
1255 CALL dbcsr_set_diag(pp_diag, p_diagonal)
1258 CALL dbcsr_create(t2, template=prec)
1259 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, tmp, pp_diag, &
1260 0.0_dp, t2, filter_eps=eps_filter)
1263 CALL dbcsr_get_info(qq, nfullrows_total=q_nrows)
1264 CALL dbcsr_create(qq_diag, template=qq)
1265 ALLOCATE (q_diagonal(q_nrows))
1266 CALL dbcsr_get_diag(qq, q_diagonal)
1267 CALL dbcsr_add_on_diag(qq_diag, 1.0_dp)
1268 CALL dbcsr_set_diag(qq_diag, q_diagonal)
1269 CALL dbcsr_set(tmp, 1.0_dp)
1270 CALL dbcsr_create(t1, template=prec)
1271 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, qq_diag, tmp, &
1272 0.0_dp, t1, filter_eps=eps_filter)
1274 CALL dbcsr_hadamard_product(t1, t2, prec)
1275 CALL dbcsr_release(t1)
1276 CALL dbcsr_scale(prec, 2.0_dp)
1279 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, qq, qq, &
1280 0.0_dp, qq_diag, retain_sparsity=.true., &
1281 filter_eps=eps_filter)
1282 CALL dbcsr_get_diag(qq_diag, q_diagonal)
1283 CALL dbcsr_set(qq_diag, 0.0_dp)
1284 CALL dbcsr_add_on_diag(qq_diag, 1.0_dp)
1285 CALL dbcsr_set_diag(qq_diag, q_diagonal)
1286 DEALLOCATE (q_diagonal)
1287 CALL dbcsr_set(tmp, 1.0_dp)
1288 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, qq_diag, tmp, &
1289 0.0_dp, t2, filter_eps=eps_filter)
1290 CALL dbcsr_release(qq_diag)
1291 CALL dbcsr_add(prec, t2, 1.0_dp, 1.0_dp)
1294 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, pp, pp, &
1295 0.0_dp, pp_diag, retain_sparsity=.true., &
1296 filter_eps=eps_filter)
1297 CALL dbcsr_get_diag(pp_diag, p_diagonal)
1298 CALL dbcsr_set(pp_diag, 0.0_dp)
1299 CALL dbcsr_add_on_diag(pp_diag, 1.0_dp)
1300 CALL dbcsr_set_diag(pp_diag, p_diagonal)
1301 DEALLOCATE (p_diagonal)
1302 CALL dbcsr_set(tmp, 1.0_dp)
1303 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, tmp, pp_diag, &
1304 0.0_dp, t2, filter_eps=eps_filter)
1305 CALL dbcsr_release(tmp)
1306 CALL dbcsr_release(pp_diag)
1307 CALL dbcsr_add(prec, t2, 1.0_dp, 1.0_dp)
1312 CALL dbcsr_release(t2)
1313 CALL dbcsr_function_of_elements(prec, func=dbcsr_func_inverse)
1314 CALL dbcsr_filter(prec, eps_filter)
1316 CALL timestop(handle)
1318 END SUBROUTINE create_preconditioner
1366 REAL(kind=
dp),
INTENT(IN) :: a, b, c, d
1367 REAL(kind=
dp),
DIMENSION(3),
INTENT(OUT) :: minima
1368 INTEGER,
INTENT(OUT) :: nmins
1370 INTEGER :: i, nroots
1371 REAL(kind=
dp) :: dd, der, p, phi, pi, q, temp1, temp2, u, &
1372 v, y1, y2, y2i, y2r, y3
1373 REAL(kind=
dp),
DIMENSION(3) :: x
1380 IF (a .EQ. 0.0_dp)
THEN
1381 IF (b .EQ. 0.0_dp)
THEN
1382 IF (c .EQ. 0.0_dp)
THEN
1392 dd = c*c - 4.0_dp*b*d
1393 IF (dd .GT. 0.0_dp)
THEN
1395 x(1) = (-c + sqrt(dd))/2.0_dp/b
1396 x(2) = (-c - sqrt(dd))/2.0_dp/b
1397 ELSE IF (dd .LT. 0.0_dp)
THEN
1407 p = c/a - b*b/a/a/3.0_dp
1408 q = (2.0_dp*b*b*b/a/a/a - 9.0_dp*b*c/a/a + 27.0_dp*d/a)/27.0_dp
1411 dd = p*p*p/27.0_dp + q*q/4.0_dp
1413 IF (dd .LT. 0.0_dp)
THEN
1415 phi = acos(-q/2.0_dp/sqrt(abs(p*p*p)/27.0_dp))
1416 temp1 = 2.0_dp*sqrt(abs(p)/3.0_dp)
1417 y1 = temp1*cos(phi/3.0_dp)
1418 y2 = -temp1*cos((phi + pi)/3.0_dp)
1419 y3 = -temp1*cos((phi - pi)/3.0_dp)
1422 temp1 = -q/2.0_dp + sqrt(dd)
1423 temp2 = -q/2.0_dp - sqrt(dd)
1424 u = abs(temp1)**(1.0_dp/3.0_dp)
1425 v = abs(temp2)**(1.0_dp/3.0_dp)
1426 IF (temp1 .LT. 0.0_dp) u = -u
1427 IF (temp2 .LT. 0.0_dp) v = -v
1429 y2r = -(u + v)/2.0_dp
1430 y2i = (u - v)*sqrt(3.0_dp)/2.0_dp
1441 IF (dd .LT. 0.0_dp)
THEN
1446 ELSE IF (dd .EQ. 0.0_dp)
THEN
1465 der = 3.0_dp*a*x(i)*x(i) + 2.0_dp*b*x(i) + c
1466 IF (der .GT. 0.0_dp)
THEN
1468 minima(nmins) = x(i)
1489 TYPE(dbcsr_type),
INTENT(IN) :: matrix
1490 TYPE(dbcsr_type),
INTENT(OUT) :: c
1491 TYPE(dbcsr_type),
INTENT(OUT),
OPTIONAL :: e
1493 CHARACTER(len=*),
PARAMETER :: routinen =
'diagonalize_diagonal_blocks'
1495 INTEGER :: handle, iblock_col, iblock_row, &
1496 iblock_size, info, lwork,
orbital
1497 LOGICAL :: block_needed, do_eigenvalues
1498 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: eigenvalues, work
1499 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :) :: data_copy
1500 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: data_p, p_new_block
1501 TYPE(dbcsr_iterator_type) :: iter
1503 CALL timeset(routinen, handle)
1505 IF (
PRESENT(e))
THEN
1506 do_eigenvalues = .true.
1508 do_eigenvalues = .false.
1512 CALL dbcsr_work_create(c, work_mutable=.true.)
1513 IF (do_eigenvalues) &
1514 CALL dbcsr_work_create(e, work_mutable=.true.)
1516 CALL dbcsr_iterator_start(iter, matrix)
1518 DO WHILE (dbcsr_iterator_blocks_left(iter))
1520 CALL dbcsr_iterator_next_block(iter, iblock_row, iblock_col, data_p, row_size=iblock_size)
1522 block_needed = .false.
1523 IF (iblock_row == iblock_col) block_needed = .true.
1525 IF (block_needed)
THEN
1528 ALLOCATE (eigenvalues(iblock_size))
1529 ALLOCATE (data_copy(iblock_size, iblock_size))
1530 data_copy(:, :) = data_p(:, :)
1534 ALLOCATE (work(max(1, lwork)))
1535 CALL dsyev(
'V',
'L', iblock_size, data_copy, iblock_size, eigenvalues, work, lwork, info)
1536 lwork = int(work(1))
1540 ALLOCATE (work(max(1, lwork)))
1541 CALL dsyev(
'V',
'L', iblock_size, data_copy, iblock_size, eigenvalues, work, lwork, info)
1542 IF (info .NE. 0)
THEN
1543 cpabort(
"DSYEV failed")
1547 NULLIFY (p_new_block)
1548 CALL dbcsr_reserve_block2d(c, iblock_row, iblock_col, p_new_block)
1549 cpassert(
ASSOCIATED(p_new_block))
1550 p_new_block(:, :) = data_copy(:, :)
1553 IF (do_eigenvalues)
THEN
1554 NULLIFY (p_new_block)
1555 CALL dbcsr_reserve_block2d(e, iblock_row, iblock_col, p_new_block)
1556 cpassert(
ASSOCIATED(p_new_block))
1557 p_new_block(:, :) = 0.0_dp
1564 DEALLOCATE (data_copy)
1565 DEALLOCATE (eigenvalues)
1571 CALL dbcsr_iterator_stop(iter)
1573 CALL dbcsr_finalize(c)
1574 IF (do_eigenvalues)
CALL dbcsr_finalize(e)
1576 CALL timestop(handle)
1590 SUBROUTINE matrix_forward_transform(matrix, u1, u2, eps_filter)
1592 TYPE(dbcsr_type),
INTENT(INOUT) :: matrix
1593 TYPE(dbcsr_type),
INTENT(IN) :: u1, u2
1594 REAL(kind=
dp),
INTENT(IN) :: eps_filter
1596 CHARACTER(len=*),
PARAMETER :: routinen =
'matrix_forward_transform'
1599 TYPE(dbcsr_type) :: tmp
1601 CALL timeset(routinen, handle)
1603 CALL dbcsr_create(tmp, template=matrix, &
1604 matrix_type=dbcsr_type_no_symmetry)
1605 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, matrix, u2, 0.0_dp, tmp, &
1606 filter_eps=eps_filter)
1607 CALL dbcsr_multiply(
"T",
"N", 1.0_dp, u1, tmp, 0.0_dp, matrix, &
1608 filter_eps=eps_filter)
1609 CALL dbcsr_release(tmp)
1611 CALL timestop(handle)
1613 END SUBROUTINE matrix_forward_transform
1625 SUBROUTINE matrix_backward_transform(matrix, u1, u2, eps_filter)
1627 TYPE(dbcsr_type),
INTENT(INOUT) :: matrix
1628 TYPE(dbcsr_type),
INTENT(IN) :: u1, u2
1629 REAL(kind=
dp),
INTENT(IN) :: eps_filter
1631 CHARACTER(len=*),
PARAMETER :: routinen =
'matrix_backward_transform'
1634 TYPE(dbcsr_type) :: tmp
1636 CALL timeset(routinen, handle)
1638 CALL dbcsr_create(tmp, template=matrix, &
1639 matrix_type=dbcsr_type_no_symmetry)
1640 CALL dbcsr_multiply(
"N",
"T", 1.0_dp, matrix, u2, 0.0_dp, tmp, &
1641 filter_eps=eps_filter)
1642 CALL dbcsr_multiply(
"N",
"N", 1.0_dp, u1, tmp, 0.0_dp, matrix, &
1643 filter_eps=eps_filter)
1644 CALL dbcsr_release(tmp)
1646 CALL timestop(handle)
1648 END SUBROUTINE matrix_backward_transform
Interface to (sca)lapack for the Cholesky based procedures.
subroutine, public cp_dbcsr_cholesky_decompose(matrix, n, para_env, blacs_env)
used to replace a symmetric positive def. matrix M with its cholesky decomposition U: M = U^T * U,...
subroutine, public cp_dbcsr_cholesky_invert(matrix, n, para_env, blacs_env, upper_to_full)
used to replace the cholesky decomposition by the inverse
Interface to (sca)lapack for the Cholesky based procedures.
subroutine, public cp_dbcsr_syevd(matrix, eigenvectors, eigenvalues, para_env, blacs_env)
...
various routines to log and control the output. The idea is that decisions about where to log should ...
recursive integer function, public cp_logger_get_default_unit_nr(logger, local, skip_not_ionode)
asks the default unit number of the given logger. try to use cp_logger_get_unit_nr
type(cp_logger_type) function, pointer, public cp_get_default_logger()
returns the default logger
Cayley transformation methods.
subroutine, public analytic_line_search(a, b, c, d, minima, nmins)
Finds real roots of a cubic equation a*x**3 + b*x**2 + c*x + d = 0 and returns only those roots for w...
subroutine, public diagonalize_diagonal_blocks(matrix, c, e)
Diagonalizes diagonal blocks of a symmetric dbcsr matrix and returs its eigenvectors.
subroutine, public ct_step_execute(cts_env)
Performs Cayley transformation.
Types for all cayley transformation methods.
Routines useful for iterative matrix calculations.
subroutine, public matrix_sqrt_newton_schulz(matrix_sqrt, matrix_sqrt_inv, matrix, threshold, order, eps_lanczos, max_iter_lanczos, symmetrize, converged)
compute the sqrt of a matrix via the sign function and the corresponding Newton-Schulz iterations the...
Defines the basic variable types.
integer, parameter, public dp
Machine interface based on Fortran 2003 and POSIX.
real(kind=dp) function, public m_walltime()
returns time from a real-time clock, protected against rolling early/easily
Orbital angular momentum.