mirror of
https://github.com/TREX-CoE/qmckl.git
synced 2025-01-03 01:56:18 +01:00
Fixed bug in cusp
This commit is contained in:
parent
9553059bbe
commit
96eea27713
@ -719,14 +719,14 @@ qmckl_vector_of_double(const qmckl_context context,
|
|||||||
if (vector.size == 0) {
|
if (vector.size == 0) {
|
||||||
return qmckl_failwith( context,
|
return qmckl_failwith( context,
|
||||||
QMCKL_INVALID_ARG_4,
|
QMCKL_INVALID_ARG_4,
|
||||||
"qmckl_double_of_vector",
|
"qmckl_vector_of_double",
|
||||||
"Vector not allocated");
|
"Vector not allocated");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vector.size != size_max) {
|
if (vector.size != size_max) {
|
||||||
return qmckl_failwith( context,
|
return qmckl_failwith( context,
|
||||||
QMCKL_INVALID_ARG_4,
|
QMCKL_INVALID_ARG_4,
|
||||||
"qmckl_double_of_vector",
|
"qmckl_vector_of_double",
|
||||||
"Wrong vector size");
|
"Wrong vector size");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
108
org/qmckl_mo.org
108
org/qmckl_mo.org
@ -551,16 +551,16 @@ qmckl_set_mo_basis_r_cusp(qmckl_context context,
|
|||||||
const double eta = qmckl_mat(mo_value_at_nucl_no_s,i,inucl);
|
const double eta = qmckl_mat(mo_value_at_nucl_no_s,i,inucl);
|
||||||
|
|
||||||
qmckl_ten3(ctx->mo_basis.cusp_param,i,0,inucl) =
|
qmckl_ten3(ctx->mo_basis.cusp_param,i,0,inucl) =
|
||||||
-(R*(2.*eta*Z-6.*grad_phi)+lap_phi*R*R+6.*phi)/(2.*R*Z-6.);
|
-(R*(2.*eta*Z-6.*grad_phi)+lap_phi*R*R+6.*phi)/(2.*R*Z-6.+1.e-12);
|
||||||
|
|
||||||
qmckl_ten3(ctx->mo_basis.cusp_param,i,1,inucl) =
|
qmckl_ten3(ctx->mo_basis.cusp_param,i,1,inucl) =
|
||||||
(lap_phi*R*R*Z-6.*grad_phi*R*Z+6.*phi*Z+6.*eta*Z)/(2.*R*Z-6.);
|
(lap_phi*R*R*Z-6.*grad_phi*R*Z+6.*phi*Z+6.*eta*Z)/(2.*R*Z-6.+1.e-12);
|
||||||
|
|
||||||
qmckl_ten3(ctx->mo_basis.cusp_param,i,2,inucl) =
|
qmckl_ten3(ctx->mo_basis.cusp_param,i,2,inucl) =
|
||||||
-(R*(-5.*grad_phi*Z-1.5*lap_phi)+lap_phi*R*R*Z+3.*phi*Z+3.*eta*Z+6.*grad_phi)/(R*R*Z-3.*R);
|
-(R*(-5.*grad_phi*Z-1.5*lap_phi)+lap_phi*R*R*Z+3.*phi*Z+3.*eta*Z+6.*grad_phi)/(R*R*Z-3.*R+1.e-12);
|
||||||
|
|
||||||
qmckl_ten3(ctx->mo_basis.cusp_param,i,3,inucl) =
|
qmckl_ten3(ctx->mo_basis.cusp_param,i,3,inucl) =
|
||||||
(R*(-2.*grad_phi*Z-lap_phi)+0.5*lap_phi*R*R*Z+phi*Z+eta*Z+3.*grad_phi)/(R*R*R*Z-3.*R*R);
|
(R*(-2.*grad_phi*Z-lap_phi)+0.5*lap_phi*R*R*Z+phi*Z+eta*Z+3.*grad_phi)/(R*R*R*Z-3.*R*R+1.e-12);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -829,6 +829,14 @@ qmckl_mo_basis_select_mo (const qmckl_context context,
|
|||||||
ctx->mo_basis.coefficient = coefficient;
|
ctx->mo_basis.coefficient = coefficient;
|
||||||
ctx->mo_basis.mo_num = mo_num_new;
|
ctx->mo_basis.mo_num = mo_num_new;
|
||||||
|
|
||||||
|
if (ctx->mo_basis.r_cusp != NULL) {
|
||||||
|
double * r_cusp_old = calloc(ctx->nucleus.num, sizeof(double));
|
||||||
|
assert (r_cusp_old != NULL);
|
||||||
|
memcpy(r_cusp_old, ctx->mo_basis.r_cusp, ctx->nucleus.num*sizeof(double));
|
||||||
|
qmckl_set_mo_basis_r_cusp(context, r_cusp_old, ctx->nucleus.num);
|
||||||
|
free(r_cusp_old);
|
||||||
|
}
|
||||||
|
|
||||||
rc = qmckl_finalize_mo_basis(context);
|
rc = qmckl_finalize_mo_basis(context);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@ -1825,12 +1833,6 @@ integer function qmckl_compute_mo_basis_mo_vgl_doc_f(context, &
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! print *, 'coucou'
|
|
||||||
! info = qmckl_dgemm(context,'N', 'N', mo_num, point_num*5_8, ao_num, 1.d0, &
|
|
||||||
! coefficient_t, int(size(coefficient_t,1),8), &
|
|
||||||
! ao_vgl, int(size(ao_vgl,1),8), 0.d0, &
|
|
||||||
! mo_vgl, int(size(mo_vgl,1),8))
|
|
||||||
|
|
||||||
end function qmckl_compute_mo_basis_mo_vgl_doc_f
|
end function qmckl_compute_mo_basis_mo_vgl_doc_f
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
@ -2669,51 +2671,55 @@ integer function qmckl_compute_mo_basis_mo_vgl_cusp_doc_f(context, &
|
|||||||
! Initial contribution of the MO
|
! Initial contribution of the MO
|
||||||
mo_vgl(:,:,j) = 0.d0
|
mo_vgl(:,:,j) = 0.d0
|
||||||
do k=1,ao_num
|
do k=1,ao_num
|
||||||
if (ao_vgl(k,1,j) == 0.d0) cycle
|
if (ao_vgl(k,1,j) /= 0.d0) then
|
||||||
inucl = ao_nucl(k)+1
|
inucl = ao_nucl(k)+1
|
||||||
if ( (en_distance(inucl,j) < r_cusp(inucl)) .and. (ao_ang_mom(k) == 0) ) cycle
|
if ( (en_distance(inucl,j) > r_cusp(inucl)) .or. (ao_ang_mom(k) > 0) ) then
|
||||||
c1 = ao_vgl(k,1,j)
|
c1 = ao_vgl(k,1,j)
|
||||||
c2 = ao_vgl(k,2,j)
|
c2 = ao_vgl(k,2,j)
|
||||||
c3 = ao_vgl(k,3,j)
|
c3 = ao_vgl(k,3,j)
|
||||||
c4 = ao_vgl(k,4,j)
|
c4 = ao_vgl(k,4,j)
|
||||||
c5 = ao_vgl(k,5,j)
|
c5 = ao_vgl(k,5,j)
|
||||||
do i=1,mo_num
|
do i=1,mo_num
|
||||||
mo_vgl(i,1,j) = mo_vgl(i,1,j) + coefficient_t(i,k) * c1
|
mo_vgl(i,1,j) = mo_vgl(i,1,j) + coefficient_t(i,k) * c1
|
||||||
mo_vgl(i,2,j) = mo_vgl(i,2,j) + coefficient_t(i,k) * c2
|
mo_vgl(i,2,j) = mo_vgl(i,2,j) + coefficient_t(i,k) * c2
|
||||||
mo_vgl(i,3,j) = mo_vgl(i,3,j) + coefficient_t(i,k) * c3
|
mo_vgl(i,3,j) = mo_vgl(i,3,j) + coefficient_t(i,k) * c3
|
||||||
mo_vgl(i,4,j) = mo_vgl(i,4,j) + coefficient_t(i,k) * c4
|
mo_vgl(i,4,j) = mo_vgl(i,4,j) + coefficient_t(i,k) * c4
|
||||||
mo_vgl(i,5,j) = mo_vgl(i,5,j) + coefficient_t(i,k) * c5
|
mo_vgl(i,5,j) = mo_vgl(i,5,j) + coefficient_t(i,k) * c5
|
||||||
end do
|
end do
|
||||||
|
end if
|
||||||
|
end if
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Cusp adjustment
|
! Cusp adjustment
|
||||||
do inucl=1,nucl_num
|
do inucl=1,nucl_num
|
||||||
r = en_distance(inucl,j)
|
r = en_distance(inucl,j)
|
||||||
if (r > r_cusp(inucl)) cycle
|
if (r < r_cusp(inucl)) then
|
||||||
|
|
||||||
r_vec(1:3) = point_coord(j,1:3) - nucl_coord(inucl,1:3)
|
r_vec(1:3) = point_coord(j,1:3) - nucl_coord(inucl,1:3)
|
||||||
r_inv = 1.d0/r
|
r_inv = 1.d0/r
|
||||||
|
|
||||||
|
do i=1,mo_num
|
||||||
|
mo_vgl(i,1,j) = mo_vgl(i,1,j) + &
|
||||||
|
cusp_param(i,1,inucl) + r*( &
|
||||||
|
cusp_param(i,2,inucl) + r*( &
|
||||||
|
cusp_param(i,3,inucl) + r*( &
|
||||||
|
cusp_param(i,4,inucl) )))
|
||||||
|
|
||||||
do i=1,mo_num
|
c1 = r_inv * cusp_param(i,2,inucl) + 2.d0*cusp_param(i,3,inucl) + &
|
||||||
mo_vgl(i,1,j) = mo_vgl(i,1,j) + &
|
r * 3.d0 * cusp_param(i,4,inucl)
|
||||||
cusp_param(i,1,inucl) + r*(cusp_param(i,2,inucl) + r*( &
|
|
||||||
cusp_param(i,3,inucl) + r* cusp_param(i,4,inucl) ))
|
|
||||||
|
|
||||||
c1 = r_inv * cusp_param(i,2,inucl) + 2.d0*cusp_param(i,3,inucl) + &
|
mo_vgl(i,2,j) = mo_vgl(i,2,j) + r_vec(1) * c1
|
||||||
r * 3.d0 * cusp_param(i,4,inucl)
|
mo_vgl(i,3,j) = mo_vgl(i,3,j) + r_vec(2) * c1
|
||||||
|
mo_vgl(i,4,j) = mo_vgl(i,4,j) + r_vec(3) * c1
|
||||||
|
|
||||||
mo_vgl(i,2,j) = mo_vgl(i,2,j) + r_vec(1) * c1
|
mo_vgl(i,5,j) = mo_vgl(i,5,j) + &
|
||||||
mo_vgl(i,3,j) = mo_vgl(i,3,j) + r_vec(2) * c1
|
2.d0*cusp_param(i,2,inucl)*r_inv + &
|
||||||
mo_vgl(i,4,j) = mo_vgl(i,4,j) + r_vec(3) * c1
|
6.d0*cusp_param(i,3,inucl) + &
|
||||||
|
12.d0*cusp_param(i,4,inucl)*r
|
||||||
|
|
||||||
mo_vgl(i,5,j) = mo_vgl(i,5,j) + &
|
end do
|
||||||
2.d0*cusp_param(i,2,inucl)*r_inv + &
|
end if
|
||||||
6.d0*cusp_param(i,3,inucl) + &
|
end do ! inucl
|
||||||
12.d0*cusp_param(i,4,inucl)*r
|
|
||||||
|
|
||||||
enddo
|
|
||||||
enddo ! inucl
|
|
||||||
end do
|
end do
|
||||||
info = QMCKL_SUCCESS
|
info = QMCKL_SUCCESS
|
||||||
|
|
||||||
@ -3029,17 +3035,17 @@ qmckl_compute_mo_basis_mo_vgl_cusp_hpc (const qmckl_context context,
|
|||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
for (int64_t inucl=0 ; inucl<nucl_num ; ++inucl) {
|
for (int64_t inucl=0 ; inucl<nucl_num ; ++inucl) {
|
||||||
if (ria[inucl] < r_cusp[inucl]) {
|
const double r = ria[inucl];
|
||||||
const double r = ria[inucl];
|
if (r < r_cusp[inucl]) {
|
||||||
const double r_vec[3] = {
|
const double r_vec[3] = {
|
||||||
qmckl_mat(point_coord,ipoint,0) - qmckl_mat(nucl_coord,inucl,0),
|
qmckl_mat(point_coord,ipoint,0) - qmckl_mat(nucl_coord,inucl,0),
|
||||||
qmckl_mat(point_coord,ipoint,1) - qmckl_mat(nucl_coord,inucl,1),
|
qmckl_mat(point_coord,ipoint,1) - qmckl_mat(nucl_coord,inucl,1),
|
||||||
qmckl_mat(point_coord,ipoint,2) - qmckl_mat(nucl_coord,inucl,2) };
|
qmckl_mat(point_coord,ipoint,2) - qmckl_mat(nucl_coord,inucl,2) };
|
||||||
const double r_inv = 1./r;
|
const double r_inv = 1./r;
|
||||||
|
|
||||||
IVDEP
|
|
||||||
for (int64_t i=0 ; i<mo_num ; ++i) {
|
for (int64_t i=0 ; i<mo_num ; ++i) {
|
||||||
vgl1[i] = vgl1[i] + qmckl_ten3(cusp_param,i,0,inucl) + r*(
|
vgl1[i] = vgl1[i] +
|
||||||
|
qmckl_ten3(cusp_param,i,0,inucl) + r*(
|
||||||
qmckl_ten3(cusp_param,i,1,inucl) + r*(
|
qmckl_ten3(cusp_param,i,1,inucl) + r*(
|
||||||
qmckl_ten3(cusp_param,i,2,inucl) + r*(
|
qmckl_ten3(cusp_param,i,2,inucl) + r*(
|
||||||
qmckl_ten3(cusp_param,i,3,inucl) )));
|
qmckl_ten3(cusp_param,i,3,inucl) )));
|
||||||
|
Loading…
Reference in New Issue
Block a user