mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-03 10:05:57 +01:00
Fixed overlap in Ocaml
This commit is contained in:
parent
7f0f90b442
commit
873112cb84
@ -1,6 +1,12 @@
|
||||
(**
|
||||
* Computes the overlap <Psi_0 | Psi_1> where both Psi_0 and Psi_1 are truncated in the set
|
||||
* of common determinants and normalized
|
||||
*)
|
||||
|
||||
open Input_determinants_by_hand
|
||||
open Qptypes
|
||||
|
||||
|
||||
let () =
|
||||
let ezfio, ezfio' =
|
||||
try
|
||||
@ -40,26 +46,16 @@ let () =
|
||||
in
|
||||
|
||||
let overlap wf wf' =
|
||||
let norm =
|
||||
Hashtbl.fold (fun k c norm ->
|
||||
norm +. c *. c ) wf 0.
|
||||
and norm' =
|
||||
Hashtbl.fold (fun k c norm ->
|
||||
norm +. c *. c ) wf' 0.
|
||||
let result, norm, norm' =
|
||||
Hashtbl.fold (fun k c (accu,norm,norm') ->
|
||||
let (c',c) =
|
||||
try (Hashtbl.find wf' k, c)
|
||||
with Not_found -> (0.,0.)
|
||||
in
|
||||
let get_result wf wf' =
|
||||
Hashtbl.fold (fun k c accu ->
|
||||
let c' =
|
||||
try Hashtbl.find wf' k
|
||||
with Not_found -> 0.
|
||||
in
|
||||
accu +. c *. c' ) wf 0.
|
||||
in
|
||||
let result =
|
||||
if Hashtbl.length wf < Hashtbl.length wf' then
|
||||
get_result wf wf'
|
||||
else
|
||||
get_result wf' wf
|
||||
(accu +. c *. c' ,
|
||||
norm +. c *. c ,
|
||||
norm'+. c'*. c' )
|
||||
) wf (0.,0.,0.)
|
||||
in
|
||||
result /. (sqrt (norm *. norm'))
|
||||
in
|
||||
@ -72,6 +68,6 @@ let () =
|
||||
let o =
|
||||
overlap wf wf'
|
||||
in
|
||||
print_float (abs_float o);
|
||||
print_float (abs_float o) ;
|
||||
print_newline ()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user