mirror of
https://github.com/TREX-CoE/qmckl.git
synced 2025-01-03 18:16:28 +01:00
Fixed sign error in jastrow gradient
This commit is contained in:
parent
04d599649b
commit
5c019b06e3
@ -2771,20 +2771,20 @@ integer function qmckl_compute_jastrow_champ_factor_ee_gl_doc_f( &
|
|||||||
do nw =1, walk_num
|
do nw =1, walk_num
|
||||||
factor_ee_gl(:,:,nw) = 0.0d0
|
factor_ee_gl(:,:,nw) = 0.0d0
|
||||||
|
|
||||||
do i = 1, elec_num
|
do j = 1, elec_num
|
||||||
do j = 1, elec_num
|
do i = 1, elec_num
|
||||||
if (j==i) cycle
|
if (i == j) cycle
|
||||||
|
|
||||||
x = ee_distance_rescaled(j,i,nw)
|
x = ee_distance_rescaled(i,j,nw)
|
||||||
|
|
||||||
denom = 1.0d0 + b_vector(2) * x
|
denom = 1.0d0 + b_vector(2) * x
|
||||||
invdenom = 1.0d0 / denom
|
invdenom = 1.0d0 / denom
|
||||||
invdenom2 = invdenom * invdenom
|
invdenom2 = invdenom * invdenom
|
||||||
|
|
||||||
dx(1) = ee_distance_rescaled_gl(1, j, i, nw)
|
dx(1) = ee_distance_rescaled_gl(1, i, j, nw)
|
||||||
dx(2) = ee_distance_rescaled_gl(2, j, i, nw)
|
dx(2) = ee_distance_rescaled_gl(2, i, j, nw)
|
||||||
dx(3) = ee_distance_rescaled_gl(3, j, i, nw)
|
dx(3) = ee_distance_rescaled_gl(3, i, j, nw)
|
||||||
dx(4) = ee_distance_rescaled_gl(4, j, i, nw)
|
dx(4) = ee_distance_rescaled_gl(4, i, j, nw)
|
||||||
|
|
||||||
grad_c2 = dx(1)*dx(1) + dx(2)*dx(2) + dx(3)*dx(3)
|
grad_c2 = dx(1)*dx(1) + dx(2)*dx(2) + dx(3)*dx(3)
|
||||||
|
|
||||||
@ -2855,20 +2855,20 @@ qmckl_exit_code qmckl_compute_jastrow_champ_factor_ee_gl_hpc(
|
|||||||
memset(factor_ee_gl, 0, elec_num*4*walk_num*sizeof(double));
|
memset(factor_ee_gl, 0, elec_num*4*walk_num*sizeof(double));
|
||||||
|
|
||||||
for (int nw = 0; nw < walk_num; ++nw) {
|
for (int nw = 0; nw < walk_num; ++nw) {
|
||||||
for (int i = 0; i < elec_num; ++i) {
|
for (int j = 0; j < elec_num; ++j) {
|
||||||
const double* dxj = &ee_distance_rescaled_gl[4*elec_num*(i+nw*elec_num)];
|
const double* dxj = &ee_distance_rescaled_gl[4*elec_num*(j+nw*elec_num)];
|
||||||
const double* xj = &ee_distance_rescaled [ elec_num*(i+nw*elec_num)];
|
const double* xj = &ee_distance_rescaled [ elec_num*(j+nw*elec_num)];
|
||||||
|
|
||||||
for (int j = 0; j < elec_num; ++j) {
|
for (int i = 0; i < elec_num; ++i) {
|
||||||
if (j == i) continue;
|
if (j == i) continue;
|
||||||
|
|
||||||
double x = xj[j];
|
double x = xj[i];
|
||||||
|
|
||||||
const double denom = 1.0 + b_vector[1]*x;
|
const double denom = 1.0 + b_vector[1]*x;
|
||||||
const double invdenom = 1.0 / denom;
|
const double invdenom = 1.0 / denom;
|
||||||
const double invdenom2 = invdenom * invdenom;
|
const double invdenom2 = invdenom * invdenom;
|
||||||
|
|
||||||
const double* restrict dx = dxj + 4*j;
|
const double* restrict dx = dxj + 4*i;
|
||||||
|
|
||||||
const double grad_c2 = dx[0]*dx[0] + dx[1]*dx[1] + dx[2]*dx[2];
|
const double grad_c2 = dx[0]*dx[0] + dx[1]*dx[1] + dx[2]*dx[2];
|
||||||
|
|
||||||
@ -3045,16 +3045,16 @@ def make_dist_deriv(elec_coord):
|
|||||||
for i in range(elec_num):
|
for i in range(elec_num):
|
||||||
for j in range(elec_num):
|
for j in range(elec_num):
|
||||||
rij = np.linalg.norm(elec_coord[i] - elec_coord[j])
|
rij = np.linalg.norm(elec_coord[i] - elec_coord[j])
|
||||||
rijm = np.linalg.norm(elec_coord[i] - elec_coord[j]+np.array((dx,0.,0.)))
|
rijm = np.linalg.norm(elec_coord[i]+np.array((dx,0.,0.)) - elec_coord[j])
|
||||||
rijp = np.linalg.norm(elec_coord[i] - elec_coord[j]-np.array((dx,0.,0.)))
|
rijp = np.linalg.norm(elec_coord[i]-np.array((dx,0.,0.)) - elec_coord[j])
|
||||||
elec_dist_d[0, i, j] = (rijp-rijm)/(2.*dx)
|
elec_dist_d[0, i, j] = (rijp-rijm)/(2.*dx)
|
||||||
elec_dist_d[3, i, j] = (rijp+rijm-2.*rij)/(dx**2)
|
elec_dist_d[3, i, j] = (rijp+rijm-2.*rij)/(dx**2)
|
||||||
rijm = np.linalg.norm(elec_coord[i] - elec_coord[j]+np.array((0.,dx,0.)))
|
rijm = np.linalg.norm(elec_coord[i]+np.array((0.,dx,0.)) - elec_coord[j])
|
||||||
rijp = np.linalg.norm(elec_coord[i] - elec_coord[j]-np.array((0.,dx,0.)))
|
rijp = np.linalg.norm(elec_coord[i]-np.array((0.,dx,0.)) - elec_coord[j])
|
||||||
elec_dist_d[1, i, j] = (rijp-rijm)/(2.*dx)
|
elec_dist_d[1, i, j] = (rijp-rijm)/(2.*dx)
|
||||||
elec_dist_d[3, i, j] += (rijp+rijm-2.*rij)/(dx**2)
|
elec_dist_d[3, i, j] += (rijp+rijm-2.*rij)/(dx**2)
|
||||||
rijm = np.linalg.norm(elec_coord[i] - elec_coord[j]+np.array((0.,0.,dx)))
|
rijm = np.linalg.norm(elec_coord[i]+np.array((0.,0.,dx)) - elec_coord[j])
|
||||||
rijp = np.linalg.norm(elec_coord[i] - elec_coord[j]-np.array((0.,0.,dx)))
|
rijp = np.linalg.norm(elec_coord[i]-np.array((0.,0.,dx)) - elec_coord[j])
|
||||||
elec_dist_d[2, i, j] = (rijp-rijm)/(2.*dx)
|
elec_dist_d[2, i, j] = (rijp-rijm)/(2.*dx)
|
||||||
elec_dist_d[3, i, j] += (rijp+rijm-2.*rij)/(dx**2)
|
elec_dist_d[3, i, j] += (rijp+rijm-2.*rij)/(dx**2)
|
||||||
return elec_dist_d
|
return elec_dist_d
|
||||||
@ -3068,7 +3068,7 @@ def func(elec_coord):
|
|||||||
for i in range(elec_num):
|
for i in range(elec_num):
|
||||||
rij_inv = 1.0 / elec_dist[i, j]
|
rij_inv = 1.0 / elec_dist[i, j]
|
||||||
for ii in range(3):
|
for ii in range(3):
|
||||||
elec_dist_gl[ii, i, j] = (elec_coord[j][ii] - elec_coord[i][ii]) * rij_inv
|
elec_dist_gl[ii, i, j] = (elec_coord[i][ii] - elec_coord[j][ii]) * rij_inv
|
||||||
elec_dist_gl[3, i, j] = 2.0 * rij_inv
|
elec_dist_gl[3, i, j] = 2.0 * rij_inv
|
||||||
elec_dist_gl[:, j, j] = 6.0
|
elec_dist_gl[:, j, j] = 6.0
|
||||||
|
|
||||||
@ -3134,9 +3134,9 @@ print("factor_ee_gl[3][0]:",factor_ee_gl[3][0])
|
|||||||
: asym_one : 0.43340325572525706
|
: asym_one : 0.43340325572525706
|
||||||
: asymp_jasb[0] : 0.31567342786262853
|
: asymp_jasb[0] : 0.31567342786262853
|
||||||
: asymp_jasb[1] : 0.5323750557252571
|
: asymp_jasb[1] : 0.5323750557252571
|
||||||
: factor_ee_gl[0][0]: 0.16364894652107934
|
: factor_ee_gl[0][0]: -0.16364894652107934
|
||||||
: factor_ee_gl[1][0]: -0.6927548119830084
|
: factor_ee_gl[1][0]: 0.6927548119830084
|
||||||
: factor_ee_gl[2][0]: 0.073267755223968
|
: factor_ee_gl[2][0]: -0.073267755223968
|
||||||
: factor_ee_gl[3][0]: 1.5111672803213185
|
: factor_ee_gl[3][0]: 1.5111672803213185
|
||||||
|
|
||||||
|
|
||||||
@ -3149,14 +3149,14 @@ double factor_ee_gl[walk_num][4][elec_num];
|
|||||||
rc = qmckl_get_jastrow_champ_factor_ee_gl(context, &(factor_ee_gl[0][0][0]),walk_num*4*elec_num);
|
rc = qmckl_get_jastrow_champ_factor_ee_gl(context, &(factor_ee_gl[0][0][0]),walk_num*4*elec_num);
|
||||||
|
|
||||||
// check factor_ee_gl
|
// check factor_ee_gl
|
||||||
printf("%f %f\n", factor_ee_gl[0][0][0], 0.16364894652107934);
|
printf("%f %f\n", factor_ee_gl[0][0][0], -0.16364894652107934);
|
||||||
assert(fabs(factor_ee_gl[0][0][0]-0.16364894652107934) < 1.e-12);
|
assert(fabs(factor_ee_gl[0][0][0]+0.16364894652107934) < 1.e-12);
|
||||||
|
|
||||||
printf("%f %f\n", factor_ee_gl[0][1][0],-0.6927548119830084 );
|
printf("%f %f\n", factor_ee_gl[0][1][0], 0.6927548119830084 );
|
||||||
assert(fabs(factor_ee_gl[0][1][0]+0.6927548119830084 ) < 1.e-12);
|
assert(fabs(factor_ee_gl[0][1][0]-0.6927548119830084 ) < 1.e-12);
|
||||||
|
|
||||||
printf("%f %f\n", factor_ee_gl[0][2][0], 0.073267755223968 );
|
printf("%f %f\n", factor_ee_gl[0][2][0],-0.073267755223968 );
|
||||||
assert(fabs(factor_ee_gl[0][2][0]-0.073267755223968 ) < 1.e-12);
|
assert(fabs(factor_ee_gl[0][2][0]+0.073267755223968 ) < 1.e-12);
|
||||||
|
|
||||||
printf("%f %f\n", factor_ee_gl[0][3][0], 1.5111672803213185 );
|
printf("%f %f\n", factor_ee_gl[0][3][0], 1.5111672803213185 );
|
||||||
assert(fabs(factor_ee_gl[0][3][0]-1.5111672803213185 ) < 1.e-12);
|
assert(fabs(factor_ee_gl[0][3][0]-1.5111672803213185 ) < 1.e-12);
|
||||||
|
Loading…
Reference in New Issue
Block a user