mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-08 20:33:26 +01:00
Fixed Pseudo and dummy atoms
This commit is contained in:
parent
5e1b077576
commit
2dcb4eba0d
244
ocaml/Pseudo.ml
244
ocaml/Pseudo.ml
@ -124,23 +124,27 @@ let to_string t =
|
|||||||
let find in_channel element =
|
let find in_channel element =
|
||||||
In_channel.seek in_channel 0L;
|
In_channel.seek in_channel 0L;
|
||||||
|
|
||||||
let element_read, old_pos =
|
let loop, element_read, old_pos =
|
||||||
ref Element.X,
|
ref true,
|
||||||
|
ref None,
|
||||||
ref (In_channel.pos in_channel)
|
ref (In_channel.pos in_channel)
|
||||||
in
|
in
|
||||||
while !element_read <> element
|
|
||||||
|
while !loop
|
||||||
do
|
do
|
||||||
let buffer =
|
|
||||||
old_pos := In_channel.pos in_channel;
|
|
||||||
match In_channel.input_line in_channel with
|
|
||||||
| Some line -> String.split ~on:' ' line
|
|
||||||
|> List.hd_exn
|
|
||||||
| None -> ""
|
|
||||||
in
|
|
||||||
try
|
try
|
||||||
element_read := Element.of_string buffer
|
let buffer =
|
||||||
|
old_pos := In_channel.pos in_channel;
|
||||||
|
match In_channel.input_line in_channel with
|
||||||
|
| Some line -> String.split ~on:' ' line
|
||||||
|
|> List.hd_exn
|
||||||
|
| None -> raise End_of_file
|
||||||
|
in
|
||||||
|
element_read := Some (Element.of_string buffer);
|
||||||
|
loop := !element_read <> (Some element)
|
||||||
with
|
with
|
||||||
| Element.ElementError _ -> ()
|
| Element.ElementError _ -> ()
|
||||||
|
| End_of_file -> loop := false
|
||||||
done ;
|
done ;
|
||||||
In_channel.seek in_channel !old_pos;
|
In_channel.seek in_channel !old_pos;
|
||||||
!element_read
|
!element_read
|
||||||
@ -148,123 +152,125 @@ let find in_channel element =
|
|||||||
|
|
||||||
(** Read the Pseudopotential in GAMESS format *)
|
(** Read the Pseudopotential in GAMESS format *)
|
||||||
let read_element in_channel element =
|
let read_element in_channel element =
|
||||||
ignore (find in_channel element);
|
match find in_channel element with
|
||||||
|
| Some e when e = element ->
|
||||||
let rec read result =
|
|
||||||
match In_channel.input_line in_channel with
|
|
||||||
| None -> result
|
|
||||||
| Some line ->
|
|
||||||
if (String.strip line = "") then
|
|
||||||
result
|
|
||||||
else
|
|
||||||
read (line::result)
|
|
||||||
in
|
|
||||||
|
|
||||||
let data =
|
|
||||||
read []
|
|
||||||
|> List.rev
|
|
||||||
in
|
|
||||||
|
|
||||||
let debug_data =
|
|
||||||
String.concat ~sep:"\n" data
|
|
||||||
in
|
|
||||||
|
|
||||||
let decode_first_line = function
|
|
||||||
| first_line :: rest ->
|
|
||||||
begin
|
begin
|
||||||
let first_line_split =
|
let rec read result =
|
||||||
String.split first_line ~on:' '
|
match In_channel.input_line in_channel with
|
||||||
|> List.filter ~f:(fun x -> (String.strip x) <> "")
|
| None -> result
|
||||||
|
| Some line ->
|
||||||
|
if (String.strip line = "") then
|
||||||
|
result
|
||||||
|
else
|
||||||
|
read (line::result)
|
||||||
in
|
in
|
||||||
match first_line_split with
|
|
||||||
| e :: "GEN" :: n :: p ->
|
|
||||||
{ element = Element.of_string e ;
|
|
||||||
n_elec = Int.of_string n |> Positive_int.of_int ;
|
|
||||||
local = [] ;
|
|
||||||
non_local = []
|
|
||||||
}, rest
|
|
||||||
| _ -> failwith (
|
|
||||||
Printf.sprintf "Unable to read Pseudopotential : \n%s\n"
|
|
||||||
debug_data )
|
|
||||||
end
|
|
||||||
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
|
||||||
in
|
|
||||||
|
|
||||||
let rec loop create_primitive accu = function
|
let data =
|
||||||
| (0,rest) -> List.rev accu, rest
|
read []
|
||||||
| (n,line::rest) ->
|
|> List.rev
|
||||||
begin
|
in
|
||||||
match
|
|
||||||
String.split line ~on:' '
|
let debug_data =
|
||||||
|> List.filter ~f:(fun x -> String.strip x <> "")
|
String.concat ~sep:"\n" data
|
||||||
with
|
in
|
||||||
| c :: i :: e :: [] ->
|
|
||||||
let i =
|
let decode_first_line = function
|
||||||
Int.of_string i
|
| first_line :: rest ->
|
||||||
in
|
begin
|
||||||
let elem =
|
let first_line_split =
|
||||||
( create_primitive
|
String.split first_line ~on:' '
|
||||||
(Float.of_string e |> AO_expo.of_float)
|
|> List.filter ~f:(fun x -> (String.strip x) <> "")
|
||||||
(i-2 |> R_power.of_int),
|
in
|
||||||
Float.of_string c |> AO_coef.of_float
|
match first_line_split with
|
||||||
)
|
| e :: "GEN" :: n :: p ->
|
||||||
in
|
{ element = Element.of_string e ;
|
||||||
loop create_primitive (elem::accu) (n-1, rest)
|
n_elec = Int.of_string n |> Positive_int.of_int ;
|
||||||
|
local = [] ;
|
||||||
|
non_local = []
|
||||||
|
}, rest
|
||||||
|
| _ -> failwith (
|
||||||
|
Printf.sprintf "Unable to read Pseudopotential : \n%s\n"
|
||||||
|
debug_data )
|
||||||
|
end
|
||||||
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
||||||
end
|
|
||||||
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
|
||||||
in
|
|
||||||
|
|
||||||
let decode_local (pseudo,data) =
|
|
||||||
let decode_local_n n rest =
|
|
||||||
let result, rest =
|
|
||||||
loop Primitive_local.of_expo_r_power [] (Positive_int.to_int n,rest)
|
|
||||||
in
|
in
|
||||||
{ pseudo with local = result }, rest
|
|
||||||
in
|
let rec loop create_primitive accu = function
|
||||||
match data with
|
| (0,rest) -> List.rev accu, rest
|
||||||
| n :: rest ->
|
| (n,line::rest) ->
|
||||||
let n =
|
begin
|
||||||
String.strip n
|
match
|
||||||
|> Int.of_string
|
String.split line ~on:' '
|
||||||
|> Positive_int.of_int
|
|> List.filter ~f:(fun x -> String.strip x <> "")
|
||||||
|
with
|
||||||
|
| c :: i :: e :: [] ->
|
||||||
|
let i =
|
||||||
|
Int.of_string i
|
||||||
|
in
|
||||||
|
let elem =
|
||||||
|
( create_primitive
|
||||||
|
(Float.of_string e |> AO_expo.of_float)
|
||||||
|
(i-2 |> R_power.of_int),
|
||||||
|
Float.of_string c |> AO_coef.of_float
|
||||||
|
)
|
||||||
|
in
|
||||||
|
loop create_primitive (elem::accu) (n-1, rest)
|
||||||
|
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
||||||
|
end
|
||||||
|
| _ -> failwith ("Error reading pseudopotential\n"^debug_data)
|
||||||
|
in
|
||||||
|
|
||||||
|
let decode_local (pseudo,data) =
|
||||||
|
let decode_local_n n rest =
|
||||||
|
let result, rest =
|
||||||
|
loop Primitive_local.of_expo_r_power [] (Positive_int.to_int n,rest)
|
||||||
|
in
|
||||||
|
{ pseudo with local = result }, rest
|
||||||
in
|
in
|
||||||
decode_local_n n rest
|
match data with
|
||||||
| _ -> failwith ("Unable to read (non-)local pseudopotential\n"^debug_data)
|
| n :: rest ->
|
||||||
in
|
let n =
|
||||||
|
String.strip n
|
||||||
let decode_non_local (pseudo,data) =
|
|> Int.of_string
|
||||||
let decode_non_local_n proj n (pseudo,data) =
|
|> Positive_int.of_int
|
||||||
let result, rest =
|
in
|
||||||
loop (Primitive_non_local.of_proj_expo_r_power proj)
|
decode_local_n n rest
|
||||||
[] (Positive_int.to_int n, data)
|
| _ -> failwith ("Unable to read (non-)local pseudopotential\n"^debug_data)
|
||||||
in
|
in
|
||||||
{ pseudo with non_local = pseudo.non_local @ result }, rest
|
|
||||||
in
|
|
||||||
let rec new_proj (pseudo,data) proj =
|
|
||||||
match data with
|
|
||||||
| n :: rest ->
|
|
||||||
let n =
|
|
||||||
String.strip n
|
|
||||||
|> Int.of_string
|
|
||||||
|> Positive_int.of_int
|
|
||||||
in
|
|
||||||
let result =
|
|
||||||
decode_non_local_n proj n (pseudo,rest)
|
|
||||||
and proj_next =
|
|
||||||
(Positive_int.to_int proj)+1
|
|
||||||
|> Positive_int.of_int
|
|
||||||
in
|
|
||||||
new_proj result proj_next
|
|
||||||
| _ -> pseudo
|
|
||||||
in
|
|
||||||
new_proj (pseudo,data) (Positive_int.of_int 0)
|
|
||||||
in
|
|
||||||
|
|
||||||
decode_first_line data
|
let decode_non_local (pseudo,data) =
|
||||||
|> decode_local
|
let decode_non_local_n proj n (pseudo,data) =
|
||||||
|> decode_non_local
|
let result, rest =
|
||||||
|
loop (Primitive_non_local.of_proj_expo_r_power proj)
|
||||||
|
[] (Positive_int.to_int n, data)
|
||||||
|
in
|
||||||
|
{ pseudo with non_local = pseudo.non_local @ result }, rest
|
||||||
|
in
|
||||||
|
let rec new_proj (pseudo,data) proj =
|
||||||
|
match data with
|
||||||
|
| n :: rest ->
|
||||||
|
let n =
|
||||||
|
String.strip n
|
||||||
|
|> Int.of_string
|
||||||
|
|> Positive_int.of_int
|
||||||
|
in
|
||||||
|
let result =
|
||||||
|
decode_non_local_n proj n (pseudo,rest)
|
||||||
|
and proj_next =
|
||||||
|
(Positive_int.to_int proj)+1
|
||||||
|
|> Positive_int.of_int
|
||||||
|
in
|
||||||
|
new_proj result proj_next
|
||||||
|
| _ -> pseudo
|
||||||
|
in
|
||||||
|
new_proj (pseudo,data) (Positive_int.of_int 0)
|
||||||
|
in
|
||||||
|
|
||||||
|
decode_first_line data
|
||||||
|
|> decode_local
|
||||||
|
|> decode_non_local
|
||||||
|
end
|
||||||
|
| _ -> empty element
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
program e_curve
|
program e_curve
|
||||||
use bitmasks
|
use bitmasks
|
||||||
implicit none
|
implicit none
|
||||||
integer :: i,j,k, nab, m, l
|
integer :: i,j,k, kk, nab, m, l
|
||||||
double precision :: norm, E, hij, num, ci, cj
|
double precision :: norm, E, hij, num, ci, cj
|
||||||
integer, allocatable :: iorder(:)
|
integer, allocatable :: iorder(:)
|
||||||
double precision , allocatable :: norm_sort(:)
|
double precision , allocatable :: norm_sort(:)
|
||||||
@ -60,7 +60,7 @@ program e_curve
|
|||||||
num = 0.d0
|
num = 0.d0
|
||||||
norm = 0.d0
|
norm = 0.d0
|
||||||
m = 0
|
m = 0
|
||||||
!$OMP PARALLEL DEFAULT(SHARED) PRIVATE(k,l,det_i,det_j,ci,cj,hij) REDUCTION(+:norm,m,num)
|
!$OMP PARALLEL DEFAULT(SHARED) PRIVATE(k,kk,l,det_i,det_j,ci,cj,hij) REDUCTION(+:norm,m,num)
|
||||||
allocate( det_i(N_int,2), det_j(N_int,2))
|
allocate( det_i(N_int,2), det_j(N_int,2))
|
||||||
!$OMP DO SCHEDULE(guided)
|
!$OMP DO SCHEDULE(guided)
|
||||||
do k=1,n_det
|
do k=1,n_det
|
||||||
@ -68,15 +68,19 @@ program e_curve
|
|||||||
cycle
|
cycle
|
||||||
endif
|
endif
|
||||||
ci = psi_bilinear_matrix_values(k,1)
|
ci = psi_bilinear_matrix_values(k,1)
|
||||||
det_i(:,1) = psi_det_alpha_unique(:,psi_bilinear_matrix_rows(k))
|
do kk=1,N_int
|
||||||
det_i(:,2) = psi_det_beta_unique(:,psi_bilinear_matrix_columns(k))
|
det_i(kk,1) = psi_det_alpha_unique(kk,psi_bilinear_matrix_rows(k))
|
||||||
|
det_i(kk,2) = psi_det_beta_unique(kk,psi_bilinear_matrix_columns(k))
|
||||||
|
enddo
|
||||||
do l=1,n_det
|
do l=1,n_det
|
||||||
if (psi_bilinear_matrix_values(l,1) == 0.d0) then
|
if (psi_bilinear_matrix_values(l,1) == 0.d0) then
|
||||||
cycle
|
cycle
|
||||||
endif
|
endif
|
||||||
cj = psi_bilinear_matrix_values(l,1)
|
cj = psi_bilinear_matrix_values(l,1)
|
||||||
det_j(:,1) = psi_det_alpha_unique(:,psi_bilinear_matrix_rows(l))
|
do kk=1,N_int
|
||||||
det_j(:,2) = psi_det_beta_unique(:,psi_bilinear_matrix_columns(l))
|
det_j(kk,1) = psi_det_alpha_unique(kk,psi_bilinear_matrix_rows(l))
|
||||||
|
det_j(kk,2) = psi_det_beta_unique(kk,psi_bilinear_matrix_columns(l))
|
||||||
|
enddo
|
||||||
call i_h_j(det_i, det_j, N_int, hij)
|
call i_h_j(det_i, det_j, N_int, hij)
|
||||||
num = num + ci*cj*hij
|
num = num + ci*cj*hij
|
||||||
enddo
|
enddo
|
||||||
|
Loading…
Reference in New Issue
Block a user