mirror of
https://github.com/TREX-CoE/qmckl.git
synced 2025-01-10 21:18:37 +01:00
Fixed dimensions in call to DGEMM. #32
This commit is contained in:
parent
97749325b1
commit
25bb2fd97e
@ -252,7 +252,7 @@ integer(qmckl_exit_code) function test_qmckl_dgemm(context) bind(C)
|
|||||||
|
|
||||||
TransA = .False.
|
TransA = .False.
|
||||||
TransB = .False.
|
TransB = .False.
|
||||||
m = 5_8
|
m = 1_8
|
||||||
k = 4_8
|
k = 4_8
|
||||||
n = 6_8
|
n = 6_8
|
||||||
LDA = m
|
LDA = m
|
||||||
|
@ -489,41 +489,44 @@ integer function qmckl_compute_mo_basis_gaussian_vgl_f(context, &
|
|||||||
! TODO : Use numerical precision here
|
! TODO : Use numerical precision here
|
||||||
cutoff = -dlog(1.d-15)
|
cutoff = -dlog(1.d-15)
|
||||||
M = 1_8
|
M = 1_8
|
||||||
N = 1_8
|
N = mo_num * 1_8
|
||||||
K = mo_num * 1_8
|
K = ao_num * 1_8
|
||||||
|
LDA = M
|
||||||
|
LDB = K
|
||||||
|
LDC = M
|
||||||
|
|
||||||
do iwalk = 1, walk_num
|
do iwalk = 1, walk_num
|
||||||
do ielec = 1, elec_num
|
do ielec = 1, elec_num
|
||||||
! Value
|
! Value
|
||||||
info_qmckl_dgemm_value = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
info_qmckl_dgemm_value = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
||||||
ao_vgl(:, ielec, iwalk, 1), size(ao_vgl,1) * 1_8, &
|
ao_vgl(:, ielec, iwalk, 1), LDA, &
|
||||||
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
||||||
beta, &
|
beta, &
|
||||||
mo_vgl(:,ielec,iwalk,1),1_8)
|
mo_vgl(:,ielec,iwalk,1),LDC)
|
||||||
! Grad_x
|
! Grad_x
|
||||||
info_qmckl_dgemm_Gx = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
info_qmckl_dgemm_Gx = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
||||||
ao_vgl(:, ielec, iwalk, 2), size(ao_vgl,1) * 1_8, &
|
ao_vgl(:, ielec, iwalk, 2), LDA, &
|
||||||
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
||||||
beta, &
|
beta, &
|
||||||
mo_vgl(:,ielec,iwalk,2),1_8)
|
mo_vgl(:,ielec,iwalk,2),LDC)
|
||||||
! Grad_y
|
! Grad_y
|
||||||
info_qmckl_dgemm_Gy = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
info_qmckl_dgemm_Gy = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
||||||
ao_vgl(:, ielec, iwalk, 3), size(ao_vgl,1) * 1_8, &
|
ao_vgl(:, ielec, iwalk, 3), LDA, &
|
||||||
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
||||||
beta, &
|
beta, &
|
||||||
mo_vgl(:,ielec,iwalk,3),1_8)
|
mo_vgl(:,ielec,iwalk,3),LDC)
|
||||||
! Grad_z
|
! Grad_z
|
||||||
info_qmckl_dgemm_Gz = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
info_qmckl_dgemm_Gz = qmckl_dgemm(context,TransA, TransB, M, N, K, alpha, &
|
||||||
ao_vgl(:, ielec, iwalk, 4), size(ao_vgl,1) * 1_8, &
|
ao_vgl(:, ielec, iwalk, 4), LDA, &
|
||||||
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
||||||
beta, &
|
beta, &
|
||||||
mo_vgl(:,ielec,iwalk,4),1_8)
|
mo_vgl(:,ielec,iwalk,4),LDC)
|
||||||
! Lapl_z
|
! Lapl_z
|
||||||
info_qmckl_dgemm_lap = qmckl_dgemm(context, TransA, TransB, M, N, K, alpha, &
|
info_qmckl_dgemm_lap = qmckl_dgemm(context, TransA, TransB, M, N, K, alpha, &
|
||||||
ao_vgl(:, ielec, iwalk, 5), size(ao_vgl,1) * 1_8, &
|
ao_vgl(:, ielec, iwalk, 5), LDA, &
|
||||||
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
coef_normalized(1:mo_num,1:ao_num),size(coef_normalized,1) * 1_8, &
|
||||||
beta, &
|
beta, &
|
||||||
mo_vgl(:,ielec,iwalk,5),1_8)
|
mo_vgl(:,ielec,iwalk,5),LDC)
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -782,8 +785,7 @@ assert(qmckl_mo_basis_provided(context));
|
|||||||
|
|
||||||
double mo_vgl[5][walk_num][elec_num][chbrclf_ao_num];
|
double mo_vgl[5][walk_num][elec_num][chbrclf_ao_num];
|
||||||
rc = qmckl_get_mo_basis_vgl(context, &(mo_vgl[0][0][0][0]));
|
rc = qmckl_get_mo_basis_vgl(context, &(mo_vgl[0][0][0][0]));
|
||||||
//assert (rc == QMCKL_SUCCESS);
|
assert (rc == QMCKL_SUCCESS);
|
||||||
|
|
||||||
|
|
||||||
printf("\n");
|
printf("\n");
|
||||||
printf(" mo_vgl mo_vgl[0][0][26][219] %25.15e\n", mo_vgl[0][0][2][3]);
|
printf(" mo_vgl mo_vgl[0][0][26][219] %25.15e\n", mo_vgl[0][0][2][3]);
|
||||||
|
Loading…
Reference in New Issue
Block a user