36 #include "../base/base_uses.f90"
41 LOGICAL,
PRIVATE,
PARAMETER :: debug_this_module = .true.
42 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'xc_tpss'
59 SUBROUTINE tpss_lda_info(tpss_params, reference, shortform, needs, max_deriv)
60 TYPE(section_vals_type),
POINTER :: tpss_params
61 CHARACTER(LEN=*),
INTENT(OUT),
OPTIONAL :: reference, shortform
62 TYPE(xc_rho_cflags_type),
INTENT(inout),
OPTIONAL :: needs
63 INTEGER,
INTENT(out),
OPTIONAL :: max_deriv
65 REAL(kind=
dp) :: sc, sx
70 IF (
PRESENT(reference))
THEN
71 IF (sx == 1._dp .AND. sc == 1._dp)
THEN
72 reference =
"J. Tao, J.P.Perdew, V.N.Staroverov, E.Scuseria PRL, 91, 146401 (2003) {LDA version}"
74 WRITE (reference,
"(a,'sx=',f5.3,'sc=',f5.3,' {LDA version}')") &
75 "J. Tao, J.P.Perdew, V.N.Staroverov, E.Scuseria PRL, 91, 146401 (2003)", &
79 IF (
PRESENT(shortform))
THEN
80 IF (sx == 1._dp .AND. sc == 1._dp)
THEN
81 shortform =
"TPSS meta-GGA functional (LDA)"
83 WRITE (shortform,
"(a,'sx=',f5.3,'sc=',f5.3,' (LDA)')") &
84 "TPSS meta-GGA functional", &
88 IF (
PRESENT(needs))
THEN
91 needs%norm_drho = .true.
93 IF (
PRESENT(max_deriv)) max_deriv = 1
109 TYPE(xc_rho_set_type),
INTENT(IN) :: rho_set
110 TYPE(xc_derivative_set_type),
INTENT(IN) :: deriv_set
111 INTEGER,
INTENT(in) :: grad_deriv
112 TYPE(section_vals_type),
POINTER :: tpss_params
114 CHARACTER(len=*),
PARAMETER :: routinen =
'tpss_lda_eval'
116 INTEGER :: handle, non_coer, npoints
117 INTEGER,
DIMENSION(2, 3) :: bo
118 REAL(kind=
dp) :: epsilon_rho, epsilon_tau, scale_ec, &
120 REAL(kind=
dp),
CONTIGUOUS,
DIMENSION(:, :, :), &
121 POINTER :: dummy, e_0, e_ndrho, e_rho, e_tau, &
123 TYPE(cp_logger_type),
POINTER :: logger
124 TYPE(xc_derivative_type),
POINTER :: deriv
126 CALL timeset(routinen, handle)
131 norm_drho=norm_drho, local_bounds=bo, rho_cutoff=epsilon_rho, &
132 tau=tau, tau_cutoff=epsilon_tau)
133 npoints = (bo(2, 1) - bo(1, 1) + 1)*(bo(2, 2) - bo(1, 2) + 1)*(bo(2, 3) - bo(1, 3) + 1)
142 IF (grad_deriv >= 0)
THEN
144 allocate_deriv=.true.)
147 IF (grad_deriv >= 1 .OR. grad_deriv == -1)
THEN
149 allocate_deriv=.true.)
152 allocate_deriv=.true.)
155 allocate_deriv=.true.)
158 IF (grad_deriv > 1 .OR. grad_deriv < -1)
THEN
159 cpabort(
"derivatives bigger than 1 not implemented")
172 CALL tpss_lda_calc(rho=rho, norm_drho=norm_drho, &
173 tau=tau, e_0=e_0, e_rho=e_rho, e_ndrho=e_ndrho, e_tau=e_tau, &
174 grad_deriv=grad_deriv, npoints=npoints, epsilon_rho=epsilon_rho, &
175 epsilon_tau=epsilon_tau, scale_ec=scale_ec, scale_ex=scale_ex, non_coer=non_coer)
181 IF (non_coer > 0)
THEN
185 CALL timestop(handle)
209 SUBROUTINE tpss_lda_calc(rho, norm_drho, tau, e_0, e_rho, e_ndrho, e_tau, &
210 npoints, grad_deriv, epsilon_rho, epsilon_tau, &
211 scale_ec, scale_ex, non_coer)
212 REAL(kind=
dp),
DIMENSION(*),
INTENT(in) :: rho, norm_drho, tau
213 REAL(kind=
dp),
DIMENSION(*),
INTENT(inout) :: e_0, e_rho, e_ndrho, e_tau
214 INTEGER,
INTENT(in) :: npoints, grad_deriv
215 REAL(kind=
dp),
INTENT(in) :: epsilon_rho, epsilon_tau, scale_ec, &
217 INTEGER,
INTENT(inout) :: non_coer
219 INTEGER :: abs_grad_deriv, ii
220 LOGICAL :: t571, t639
221 REAL(kind=
dp) :: a, a_1, a_2, a_s1, a_s1rho, a_s2, a_s2rho, alpha, alpha_1_1, alpha_1_2, &
222 alphanorm_drho, alpharho, alphatau, arho, b, beta, beta_1_1, beta_1_2, beta_2_1, &
223 beta_2_2, beta_3_1, beta_3_2, beta_4_1, beta_4_2, c, d, e_c_u_0, e_c_u_0rho, e_c_u_1_s1, &
224 e_c_u_1_s1rho, e_c_u_1_s2, e_c_u_1_s2rho, e_var, epsilon_cgga, epsilon_cgga_0_1, &
225 epsilon_cgga_1_0, epsilon_cggarho, epsilon_crevpkzb, epsilon_crevpkzbnorm_drho, &
226 epsilon_crevpkzbrho, epsilon_crevpkzbtau, ex_unif, fx, gamma_var, hnorm_drho, k_f_s1, &
227 k_f_s1rho, k_s, k_s_s1, k_s_s2, kappa, m, ma, manorm_drho, marho, mb, mbnorm_drho, mbrho
228 REAL(kind=
dp) :: mu, my_ndrho, my_rho, my_tau, p, p_1, p_2, p_3, phi_s1, phi_s2, pnorm_drho, &
229 prho, rs, rs_s1, rs_s1rho, rs_s2, rs_s2rho, rsrho, t, t1, t100, t101, t111, t12, t13, &
230 t138, t14, t140, t143, t145, t146, t147, t151, t152, t16, t161, t168, t177, t186, t187, &
231 t189, t19, t190, t191, t193, t194, t196, t197, t198, t199, t2, t20, t201, t202, t204, &
232 t205, t208, t209, t21, t211, t212, t213, t215, t216, t218, t219, t22, t220, t221, t223, &
233 t224, t226, t227, t230, t231, t233, t234, t235, t238, t239, t241, t242, t243, t245, t246, &
234 t248, t249, t252, t253, t254, t256, t26, t260, t263, t264, t265
235 REAL(kind=
dp) :: t267, t268, t269, t27, t271, t272, t274, t275, t276, t277, t278, t279, t28, &
236 t280, t281, t284, t286, t288, t29, t290, t291, t293, t294, t295, t299, t3, t301, t302, &
237 t303, t305, t307, t310, t313, t316, t319, t322, t325, t327, t328, t329, t331, t337, t340, &
238 t343, t344, t35, t351, t36, t370, t371, t376, t383, t385, t386, t39, t390, t391, t395, &
239 t396, t398, t4, t403, t404, t406, t41, t410, t411, t419, t42, t430, t437, t445, t450, &
240 t452, t464, t472, t475, t485, t489, t49, t490, t5, t505, t513, t517, t536, t541, t542, &
241 t546, t547, t549, t55, t554, t555, t557, t561, t562, t569, t574
242 REAL(kind=
dp) :: t58, t585, t6, t60, t604, t609, t610, t614, t615, t617, t622, t623, t625, &
243 t629, t630, t637, t642, t645, t659, t67, t7, t71, t73, t77, t78, t79, t799, t80, t84, &
244 t85, t89, t9, t94, t95, t96, t_s1, t_s1norm_drho, t_s1rho, t_s2, t_s2norm_drho, t_s2rho, &
245 tau_w, tau_wnorm_drho, tau_wrho, tildeq_b, tildeq_bnorm_drho, tildeq_brho, tildeq_btau, &
246 tnorm_drho, trho, z, znorm_drho, zrho, ztau
255 my_ndrho = norm_drho(ii)
256 IF (grad_deriv >= 0)
THEN
257 e_0(ii) = e_0(ii) + my_tau*my_ndrho*my_rho
259 IF (grad_deriv >= 1 .OR. grad_deriv == -1)
THEN
260 e_rho(ii) = e_rho(ii) + my_tau*my_ndrho
261 e_ndrho(ii) = e_ndrho(ii) + my_tau*my_rho
262 e_tau(ii) = e_tau(ii) + my_rho*my_ndrho
269 abs_grad_deriv = abs(grad_deriv)
274 gamma_var = (0.1e1_dp - log(0.2e1_dp))/
pi**2
281 alpha_1_1 = 0.21370e0_dp
282 beta_1_1 = 0.75957e1_dp
283 beta_2_1 = 0.35876e1_dp
284 beta_3_1 = 0.16382e1_dp
285 beta_4_1 = 0.49294e0_dp
288 alpha_1_2 = 0.20548e0_dp
289 beta_1_2 = 0.141189e2_dp
290 beta_2_2 = 0.61977e1_dp
291 beta_3_2 = 0.33662e1_dp
292 beta_4_2 = 0.62517e0_dp
295 t1 = 3._dp**(0.1e1_dp/0.3e1_dp)
296 t2 = 4._dp**(0.1e1_dp/0.3e1_dp)
299 t5 = 2._dp**(0.1e1_dp/0.3e1_dp)
308 IF (my_rho > epsilon_rho .AND. my_tau > epsilon_tau)
THEN
309 my_ndrho = norm_drho(ii)
313 tau_w = t254*t7/0.8e1_dp
315 IF (my_tau < tau_w)
THEN
317 m = 0.5_dp*t254 + 4.0_dp*my_rho*my_tau
318 my_tau = m/8._dp/my_rho
321 non_coer = non_coer + 1
324 t9 = (t6*t7)**(0.1e1_dp/0.3e1_dp)
325 rs_s1 = t4*t5*t9/0.4e1_dp
326 phi_s1 = t12/0.2e1_dp
329 t16 = (t14*my_rho)**(0.1e1_dp/0.3e1_dp)
330 k_f_s1 = t13*t16/0.2e1_dp
331 t19 = sqrt(k_f_s1*t6)
332 k_s_s1 = 0.2e1_dp*t19
333 t20 = 0.1e1_dp/phi_s1
335 t22 = 0.1e1_dp/k_s_s1
336 t_s1 = t21*t22*t7/0.2e1_dp
339 t26 = sqrt(k_f_s1*t6)
340 k_s_s2 = 0.2e1_dp*t26
341 t27 = 0.1e1_dp/phi_s2
343 t29 = 0.1e1_dp/k_s_s2
344 t_s2 = t28*t29*t7/0.2e1_dp
350 t49 = log(0.1e1_dp + t35/(beta_1_1*t36 + beta_2_1*rs_s2 + &
351 beta_3_1*t39 + beta_4_1*t42)/0.2e1_dp)
355 t67 = log(0.1e1_dp + t35/(beta_1_1*t55 + beta_2_1*rs_s1 + &
356 beta_3_1*t58 + beta_4_1*t60)/0.2e1_dp)
357 t71 = 0.1e1_dp + alpha_1_2*rs_s2
362 t80 = beta_1_2*t36 + beta_2_2*rs_s2 + beta_3_2*t39 + t79
363 t84 = 0.1e1_dp + t73/t80/0.2e1_dp
365 e_c_u_1_s2 = -0.2e1_dp*a_2*t71*t85
366 t89 = 0.1e1_dp + alpha_1_2*rs_s1
369 t96 = beta_1_2*t55 + beta_2_2*rs_s1 + beta_3_2*t58 + t95
370 t100 = 0.1e1_dp + t73/t96/0.2e1_dp
372 e_c_u_1_s1 = -0.2e1_dp*a_2*t89*t101
375 t138 = 0.1e1_dp + alpha_1_1*rs
380 t147 = beta_1_1*t140 + beta_2_1*rs + beta_3_1*t143 + t146
381 t151 = 0.1e1_dp + t35/t147/0.2e1_dp
383 e_c_u_0 = -0.2e1_dp*a_1*t138*t152
385 t168 = log(0.1e1_dp + t73/(beta_1_2*t140 + beta_2_2*rs + &
386 beta_3_2*t143 + beta_4_2*t161)/0.2e1_dp)
388 t186 = 0.1e1_dp/gamma_var
393 t193 = exp(-e_c_u_1_s1*t186*t191)
394 t194 = t193 - 0.1e1_dp
396 t196 = gamma_var*t190
399 t199 = 0.1e1_dp + t198
402 t204 = 0.1e1_dp + t198 + t201*t202
404 t208 = 0.1e1_dp + t187*t197*t199*t205
406 epsilon_cgga_1_0 = e_c_u_1_s1 + t196*t209
410 t215 = exp(-e_c_u_1_s2*t186*t213)
411 t216 = t215 - 0.1e1_dp
413 t218 = gamma_var*t212
416 t221 = t220 + 0.1e1_dp
419 t226 = 0.1e1_dp + t220 + t223*t224
421 t230 = 0.1e1_dp + t187*t219*t221*t227
423 epsilon_cgga_0_1 = e_c_u_1_s2 + t218*t231
424 t233 = sqrt(t1*t16*t6)
429 t238 = exp(-e_c_u_0*t186)
430 t239 = -0.1e1_dp + t238
434 t243 = 0.1e1_dp + t242
437 t248 = 0.1e1_dp + t242 + t245*t246
439 t252 = 0.1e1_dp + t187*t241*t243*t249
441 epsilon_cgga = e_c_u_0 + gamma_var*t253
442 ma = max(epsilon_cgga_1_0, epsilon_cgga)
443 mb = max(epsilon_cgga_0_1, epsilon_cgga)
445 t260 = ma/0.2e1_dp + mb/0.2e1_dp
446 t263 = 0.53e0_dp*epsilon_cgga*t256 - 0.153e1_dp*t256*t260
449 epsilon_crevpkzb = epsilon_cgga + t263*t265
450 t267 = my_rho*epsilon_crevpkzb
451 t268 = d*epsilon_crevpkzb
453 t271 = 0.1e1_dp/t264/my_tau
455 t274 = 0.1e1_dp + t268*t272
457 t276 = t14**(0.1e1_dp/0.3e1_dp)
461 t280 = my_rho**(0.1e1_dp/0.3e1_dp)
463 t284 = t278/t281/t279
464 p = t275*t284/0.12e2_dp
465 t286 = 0.1e1_dp/my_tau
467 t288 = 0.1e1_dp/z - 0.1e1_dp
468 alpha = 0.5e1_dp/0.3e1_dp*p*t288
469 t290 = alpha - 0.1e1_dp
471 t293 = 0.1e1_dp + t291*t290
474 tildeq_b = 0.9e1_dp/0.20e2_dp*t290*t295 + 0.2e1_dp/0.3e1_dp*p
476 t301 = 0.1e1_dp + t299
479 t305 = 0.10e2_dp/0.81e2_dp + c*t299*t303
482 t313 = sqrt(0.18e2_dp*t299 + 0.50e2_dp*t310)
483 t316 = 0.1e1_dp/kappa
486 t325 = t305*p + 0.146e3_dp/0.2025e4_dp*t307 - 0.73e2_dp/ &
487 0.4050e4_dp*tildeq_b*t313 + 0.100e3_dp/0.6561e4_dp*t316* &
488 t310 + 0.4e1_dp/0.45e2_dp*t319*t299 + t322*t310*p
489 t327 = 0.1e1_dp + t319*p
492 t331 = 0.1e1_dp + t325*t329*t316
493 fx = 0.1e1_dp + kappa - kappa/t331
494 ex_unif = -0.3e1_dp/0.4e1_dp*t1*t16*t6
495 t337 = my_rho*ex_unif
497 IF (grad_deriv >= 0)
THEN
498 e_0(ii) = e_0(ii) + &
499 scale_ec*t267*t274 + scale_ex*t337*fx
502 IF (abs_grad_deriv > 0)
THEN
505 t344 = 0.1e1_dp/t340*t6*t343
506 rsrho = -t4*t344/0.12e2_dp
508 e_c_u_0rho = -0.2e1_dp*a_1*alpha_1_1*rsrho*t152 + t138/ &
509 t351*(beta_1_1/t140*rsrho/0.2e1_dp + beta_2_1*rsrho + &
510 0.3e1_dp/0.2e1_dp*beta_3_1*t140*rsrho + t146*t41*rsrho/ &
515 trho = -my_ndrho/t376*t7/t233*t1*t371*t14*t6 &
516 /0.6e1_dp - t235*t343/0.2e1_dp
520 arho = t385/t386*e_c_u_0rho*t238
525 t398 = 0.2e1_dp*t396*trho
532 epsilon_cggarho = e_c_u_0rho + gamma_var*(0.2e1_dp*t390*t391 &
533 *trho + t187*t241*(t395 + t398)*t249 - t403*t406*(t395 + &
534 t398 + 0.2e1_dp*a*t246*arho + 0.4e1_dp*t411*trho))*t419
535 tau_wrho = -t254*t343/0.8e1_dp
536 prho = -0.2e1_dp/0.9e1_dp*t275*t278/t281/t279/my_rho
539 alpharho = 0.5e1_dp/0.3e1_dp*prho*t288 - 0.5e1_dp/0.3e1_dp &
541 t437 = t290/t294/t293
542 tildeq_brho = 0.9e1_dp/0.20e2_dp*alpharho*t295 - 0.9e1_dp/ &
543 0.40e2_dp*t437*(b*alpharho*t290 + t291*alpharho) + &
544 0.2e1_dp/0.3e1_dp*prho
547 t452 = 0.1e1_dp/t302/t301
551 t485 = t325/t328/t327
554 rs_s1rho = -t4*t5*t344/0.12e2_dp
555 k_f_s1rho = t13*t371*t14/0.6e1_dp
557 t_s1rho = -t21/t505*t7/t19*k_f_s1rho*t6/0.2e1_dp - t21 &
561 e_c_u_1_s1rho = -0.2e1_dp*t513*rs_s1rho*t101 + t89/t517* &
562 (beta_1_2/t55*rs_s1rho/0.2e1_dp + beta_2_2*rs_s1rho + &
563 0.3e1_dp/0.2e1_dp*beta_3_2*t55*rs_s1rho + t95*t77* &
566 a_s1rho = t385/t536*e_c_u_1_s1rho*t191*t193
571 t549 = 0.2e1_dp*t547*t_s1rho
578 t571 = epsilon_cgga .LT. epsilon_cgga_1_0
580 marho = e_c_u_1_s1rho + t196*(0.2e1_dp*t541*t542 &
581 *t_s1rho + t187*t197*(t546 + t549)*t205 - t554*t557*(t546 &
582 + t549 + 0.2e1_dp*a_s1*t202*a_s1rho + 0.4e1_dp*t562* &
585 marho = epsilon_cggarho
589 t_s2rho = -t28/t574*t7/t26*k_f_s1rho*t6/0.2e1_dp - t28 &
592 e_c_u_1_s2rho = -0.2e1_dp*t513*rs_s2rho*t85 + t71/t585*( &
593 beta_1_2/t36*rs_s2rho/0.2e1_dp + beta_2_2*rs_s2rho + &
594 0.3e1_dp/0.2e1_dp*beta_3_2*t36*rs_s2rho + t79*t77* &
597 a_s2rho = t385/t604*e_c_u_1_s2rho*t213*t215
602 t617 = 0.2e1_dp*t615*t_s2rho
609 t639 = epsilon_cgga .LT. epsilon_cgga_0_1
611 mbrho = e_c_u_1_s2rho + t218*(0.2e1_dp*t609*t610 &
612 *t_s2rho + t187*t219*(t614 + t617)*t227 - t622*t625*(t614 &
613 + t617 + 0.2e1_dp*a_s2*t224*a_s2rho + 0.4e1_dp*t630* &
616 mbrho = epsilon_cggarho
618 t642 = epsilon_cgga*tau_w
620 epsilon_crevpkzbrho = epsilon_cggarho + (0.53e0_dp* &
621 epsilon_cggarho*t256 + 0.106e1_dp*t642*tau_wrho - 0.306e1_dp* &
622 t645*tau_wrho - 0.153e1_dp*t256*(marho/0.2e1_dp + mbrho/ &
626 IF (grad_deriv >= 1 .OR. grad_deriv == -1)
THEN
627 e_rho(ii) = e_rho(ii) + &
628 scale_ec*(epsilon_crevpkzb*t274 + my_rho* &
629 epsilon_crevpkzbrho*t274 + t267*(d*epsilon_crevpkzbrho*t272 &
630 + 0.3e1_dp*t268*t659*tau_wrho)) + scale_ex*(ex_unif*fx - &
631 my_rho*
pi*t1*t371*fx/0.4e1_dp + t337* &
632 t490*(((0.2e1_dp*t445*t303*zrho - 0.4e1_dp*t450*t452* &
633 zrho)*p + t305*prho + 0.292e3_dp/0.2025e4_dp*tildeq_b* &
634 tildeq_brho - 0.73e2_dp/0.4050e4_dp*tildeq_brho*t313 - &
635 0.73e2_dp/0.8100e4_dp*t464*(0.36e2_dp*z*zrho + 0.100e3_dp &
636 *p*prho) + 0.200e3_dp/0.6561e4_dp*t472*prho + 0.8e1_dp/ &
637 0.45e2_dp*t475*zrho + 0.3e1_dp*t322*t310*prho)*t329 - &
638 0.2e1_dp*t485*t319*prho))
641 tnorm_drho = t234*t7/0.2e1_dp
642 hnorm_drho = gamma_var*(0.2e1_dp*t390*t391*tnorm_drho + &
643 0.2e1_dp*t187*t410*a*tnorm_drho*t249 - t403*t406*( &
644 0.2e1_dp*t396*tnorm_drho + 0.4e1_dp*t411*tnorm_drho))*t419
645 tau_wnorm_drho = my_ndrho*t7/0.4e1_dp
646 pnorm_drho = my_ndrho*t1*t284/0.6e1_dp
647 znorm_drho = tau_wnorm_drho*t286
648 alphanorm_drho = 0.5e1_dp/0.3e1_dp*pnorm_drho*t288 - &
649 0.5e1_dp/0.3e1_dp*t430*znorm_drho
650 tildeq_bnorm_drho = 0.9e1_dp/0.20e2_dp*alphanorm_drho*t295 - &
651 0.9e1_dp/0.40e2_dp*t437*(b*alphanorm_drho*t290 + t291* &
652 alphanorm_drho) + 0.2e1_dp/0.3e1_dp*pnorm_drho
653 t_s1norm_drho = t20*t22*t7/0.2e1_dp
655 manorm_drho = t196*(0.2e1_dp*t541*t542* &
656 t_s1norm_drho + 0.2e1_dp*t187*t561*a_s1*t_s1norm_drho*t205 &
657 - t554*t557*(0.2e1_dp*t547*t_s1norm_drho + 0.4e1_dp*t562 &
658 *t_s1norm_drho))*t569
660 manorm_drho = hnorm_drho
662 t_s2norm_drho = t27*t29*t7/0.2e1_dp
664 mbnorm_drho = t218*(0.2e1_dp*t609*t610* &
665 t_s2norm_drho + 0.2e1_dp*t187*t629*a_s2*t_s2norm_drho*t227 &
666 - t622*t625*(0.2e1_dp*t615*t_s2norm_drho + 0.4e1_dp*t630 &
667 *t_s2norm_drho))*t637
669 mbnorm_drho = hnorm_drho
671 epsilon_crevpkzbnorm_drho = hnorm_drho + (0.53e0_dp*hnorm_drho* &
672 t256 + 0.106e1_dp*t642*tau_wnorm_drho - 0.306e1_dp*t645* &
673 tau_wnorm_drho - 0.153e1_dp*t256*(manorm_drho/0.2e1_dp + &
674 mbnorm_drho/0.2e1_dp))*t265
676 IF (grad_deriv >= 1 .OR. grad_deriv == -1)
THEN
677 e_ndrho(ii) = e_ndrho(ii) + &
678 scale_ec*(my_rho*epsilon_crevpkzbnorm_drho* &
679 t274 + t267*(d*epsilon_crevpkzbnorm_drho*t272 + 0.3e1_dp* &
680 t268*t659*tau_wnorm_drho)) + scale_ex*t337*t490*((( &
681 0.2e1_dp*t445*t303*znorm_drho - 0.4e1_dp*t450*t452* &
682 znorm_drho)*p + t305*pnorm_drho + 0.292e3_dp/0.2025e4_dp* &
683 tildeq_b*tildeq_bnorm_drho - 0.73e2_dp/0.4050e4_dp* &
684 tildeq_bnorm_drho*t313 - 0.73e2_dp/0.8100e4_dp*t464*( &
685 0.36e2_dp*z*znorm_drho + 0.100e3_dp*p*pnorm_drho) + &
686 0.200e3_dp/0.6561e4_dp*t472*pnorm_drho + 0.8e1_dp/0.45e2_dp &
687 *t475*znorm_drho + 0.3e1_dp*t322*t310*pnorm_drho)*t329 - &
688 0.2e1_dp*t485*t319*pnorm_drho)
691 epsilon_crevpkzbtau = -0.2e1_dp*t263*t271
694 alphatau = -0.5e1_dp/0.3e1_dp*t430*ztau
695 tildeq_btau = 0.9e1_dp/0.20e2_dp*alphatau*t295 - 0.9e1_dp/ &
696 0.40e2_dp*t437*(b*alphatau*t290 + t291*alphatau)
698 IF (grad_deriv >= 1 .OR. grad_deriv == -1)
THEN
699 e_tau(ii) = e_tau(ii) + &
700 scale_ec*(my_rho*epsilon_crevpkzbtau*t274 + t267* &
701 (d*epsilon_crevpkzbtau*t272 - 0.3e1_dp*t268*t269/t799)) + &
702 scale_ex*t337*t490*((0.2e1_dp*t445*t303*ztau - 0.4e1_dp &
703 *t450*t452*ztau)*p + 0.292e3_dp/0.2025e4_dp*tildeq_b* &
704 tildeq_btau - 0.73e2_dp/0.4050e4_dp*tildeq_btau*t313 - &
705 0.73e2_dp/0.225e3_dp*t464*z*ztau + 0.8e1_dp/0.45e2_dp* &
714 END SUBROUTINE tpss_lda_calc
collects all references to literature in CP2K as new algorithms / method are included from literature...
integer, save, public tao2003
various routines to log and control the output. The idea is that decisions about where to log should ...
type(cp_logger_type) function, pointer, public cp_get_default_logger()
returns the default logger
Defines the basic variable types.
integer, parameter, public dp
Definition of mathematical constants and functions.
real(kind=dp), parameter, public pi
Module with functions to handle derivative descriptors. derivative description are strings have the f...
integer, parameter, public deriv_norm_drho
integer, parameter, public deriv_tau
integer, parameter, public deriv_rho
represent a group ofunctional derivatives
type(xc_derivative_type) function, pointer, public xc_dset_get_derivative(derivative_set, description, allocate_deriv)
returns the requested xc_derivative
Provides types for the management of the xc-functionals and their derivatives.
subroutine, public xc_derivative_get(deriv, split_desc, order, deriv_data, accept_null_data)
returns various information on the given derivative
subroutine, public xc_rho_set_get(rho_set, can_return_null, rho, drho, norm_drho, rhoa, rhob, norm_drhoa, norm_drhob, rho_1_3, rhoa_1_3, rhob_1_3, laplace_rho, laplace_rhoa, laplace_rhob, drhoa, drhob, rho_cutoff, drho_cutoff, tau_cutoff, tau, tau_a, tau_b, local_bounds)
returns the various attributes of rho_set
Calculates the tpss functional.
subroutine, public tpss_lda_eval(rho_set, deriv_set, grad_deriv, tpss_params)
evaluates the tpss functional in the spin unpolarized (lda) case
subroutine, public tpss_lda_info(tpss_params, reference, shortform, needs, max_deriv)
return various information on the functional