10
1
mirror of https://gitlab.com/scemama/QCaml.git synced 2025-01-05 02:48:37 +01:00

Changed sign of exchange matrix

This commit is contained in:
Anthony Scemama 2020-04-20 02:06:49 +02:00
parent d7be3ac86e
commit 0094b36c86
2 changed files with 14 additions and 14 deletions

View File

@ -53,11 +53,11 @@ let make_rhf ~density ?(threshold=Constants.epsilon) ao_basis =
in in
if (integral <> 0.) then begin if (integral <> 0.) then begin
m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral; m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral;
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. integral m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *. integral
end end
done; done;
for mu = nu+1 to sigma do for mu = nu+1 to sigma do
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *.
ERI.get_phys m_G mu lambda nu sigma ERI.get_phys m_G mu lambda nu sigma
done done
end end
@ -69,7 +69,7 @@ let make_rhf ~density ?(threshold=Constants.epsilon) ao_basis =
in in
if (integral <> 0.) then begin if (integral <> 0.) then begin
m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral; m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral;
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. integral m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *. integral
end end
done; done;
for mu = sigma+1 to nu do for mu = sigma+1 to nu do
@ -80,7 +80,7 @@ let make_rhf ~density ?(threshold=Constants.epsilon) ao_basis =
| (false, true , _) -> | (false, true , _) ->
for mu = 1 to sigma do for mu = 1 to sigma do
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) <-
m_Ksigma.(mu-1) -. pK *. ERI.get_phys m_G mu lambda nu sigma m_Ksigma.(mu-1) +. pK *. ERI.get_phys m_G mu lambda nu sigma
done done
| (true , false, _) -> | (true , false, _) ->
for mu = 1 to nu do for mu = 1 to nu do
@ -103,7 +103,7 @@ let make_rhf ~density ?(threshold=Constants.epsilon) ao_basis =
let m_J = Mat.of_array m_J let m_J = Mat.of_array m_J
and m_K = Mat.of_array m_K and m_K = Mat.of_array m_K
in in
{ fock = Mat.add m_Hc (Mat.add m_J m_K) ; { fock = Mat.add m_Hc (Mat.sub m_J m_K) ;
core = m_Hc ; coulomb = m_J ; exchange = m_K } core = m_Hc ; coulomb = m_J ; exchange = m_K }
@ -141,11 +141,11 @@ let make_uhf ~density_same ~density_other ?(threshold=Constants.epsilon) ao_basi
in in
if (integral <> 0.) then begin if (integral <> 0.) then begin
m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral; m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral;
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. integral m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *. integral
end end
done; done;
for mu = nu+1 to sigma do for mu = nu+1 to sigma do
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *.
ERI.get_phys m_G mu lambda nu sigma ERI.get_phys m_G mu lambda nu sigma
done done
end end
@ -157,7 +157,7 @@ let make_uhf ~density_same ~density_other ?(threshold=Constants.epsilon) ao_basi
in in
if (integral <> 0.) then begin if (integral <> 0.) then begin
m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral; m_Jnu.(mu-1) <- m_Jnu.(mu-1) +. pJ *. integral;
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) -. pK *. integral m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) +. pK *. integral
end end
done; done;
for mu = sigma+1 to nu do for mu = sigma+1 to nu do
@ -168,7 +168,7 @@ let make_uhf ~density_same ~density_other ?(threshold=Constants.epsilon) ao_basi
| (false, true , _) -> | (false, true , _) ->
for mu = 1 to sigma do for mu = 1 to sigma do
m_Ksigma.(mu-1) <- m_Ksigma.(mu-1) <-
m_Ksigma.(mu-1) -. pK *. ERI.get_phys m_G mu lambda nu sigma m_Ksigma.(mu-1) +. pK *. ERI.get_phys m_G mu lambda nu sigma
done done
| (true , false, _) -> | (true , false, _) ->
for mu = 1 to nu do for mu = 1 to nu do
@ -191,7 +191,7 @@ let make_uhf ~density_same ~density_other ?(threshold=Constants.epsilon) ao_basi
let m_J = Mat.of_array m_J let m_J = Mat.of_array m_J
and m_K = Mat.of_array m_K and m_K = Mat.of_array m_K
in in
{ fock = Mat.add m_Hc (Mat.add m_J m_K) ; { fock = Mat.add m_Hc (Mat.sub m_J m_K) ;
core = m_Hc ; coulomb = m_J ; exchange = m_K } core = m_Hc ; coulomb = m_J ; exchange = m_K }
@ -207,7 +207,7 @@ let op ~f f1 f2 =
and m_K = f f1.exchange f2.exchange and m_K = f f1.exchange f2.exchange
in in
{ {
fock = Mat.add m_Hc (Mat.add m_J m_K); fock = Mat.add m_Hc (Mat.sub m_J m_K);
core = m_Hc; core = m_Hc;
coulomb = m_J; coulomb = m_J;
exchange = m_K; exchange = m_K;
@ -226,7 +226,7 @@ let scale alpha f1 =
Mat.scal alpha m_J; Mat.scal alpha m_J;
Mat.scal alpha m_K; Mat.scal alpha m_K;
{ {
fock = Mat.add m_Hc (Mat.add m_J m_K); fock = Mat.add m_Hc (Mat.sub m_J m_K);
core = m_Hc; core = m_Hc;
coulomb = m_J; coulomb = m_J;
exchange = m_K; exchange = m_K;

View File

@ -171,7 +171,7 @@ let exchange_energy t =
| RHF -> let m_P = of_some data.density in | RHF -> let m_P = of_some data.density in
let fock = of_some data.fock in let fock = of_some data.fock in
let m_K = Fock.exchange fock in let m_K = Fock.exchange fock in
0.5 *. Mat.gemm_trace m_P m_K -. 0.5 *. Mat.gemm_trace m_P m_K
| ROHF -> let m_P_a = of_some data.density_a in | ROHF -> let m_P_a = of_some data.density_a in
let m_P_b = of_some data.density_b in let m_P_b = of_some data.density_b in
@ -179,7 +179,7 @@ let exchange_energy t =
let fock_b = of_some data.fock_b in let fock_b = of_some data.fock_b in
let m_K_a = Fock.exchange fock_a in let m_K_a = Fock.exchange fock_a in
let m_K_b = Fock.exchange fock_b in let m_K_b = Fock.exchange fock_b in
0.5 *. ( (Mat.gemm_trace m_P_a m_K_a) +. (Mat.gemm_trace m_P_b m_K_b) ) -. 0.5 *. ( (Mat.gemm_trace m_P_a m_K_a) +. (Mat.gemm_trace m_P_b m_K_b) )
| _ -> failwith "Not implemented" | _ -> failwith "Not implemented"