10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-05 19:08:52 +01:00

Alternate basis in qp_create_ezfio_from_xyz

This commit is contained in:
Anthony Scemama 2014-11-15 11:01:30 +01:00
parent 17b4438313
commit 34cdca5927

View File

@ -74,18 +74,55 @@ let run ?o b c m xyz_file =
(* Write Basis set *) (* Write Basis set *)
let basis = let basis =
let alternate_basis_table = Hashtbl.Poly.create () in
let alternate_basis_channel element =
let key = Element.to_string element in
match Hashtbl.find alternate_basis_table key with
| Some in_channel ->
in_channel
| None ->
begin
Printf.printf "%s is not defined in basis %s.\nEnter alternate basis : %!"
(Element.to_long_string element) b ;
let bas =
match In_channel.input_line stdin with
| Some line -> String.strip line |> String.lowercase
| None -> failwith "Aborted"
in
let new_channel = In_channel.create
(Qpackage.root ^ "/data/basis/" ^ bas)
in
Hashtbl.add_exn alternate_basis_table ~key:key ~data:new_channel;
new_channel
end
in
let nmax = Nucl_number.get_max () in let nmax = Nucl_number.get_max () in
let rec do_work (accu:(Atom.t*Nucl_number.t) list) (n:int) = function let rec do_work (accu:(Atom.t*Nucl_number.t) list) (n:int) = function
| [] -> accu | [] -> accu
| e::tail -> let new_accu = (e,(Nucl_number.of_int ~max:nmax n))::accu in | e::tail ->
let new_accu = (e,(Nucl_number.of_int ~max:nmax n))::accu in
do_work new_accu (n+1) tail do_work new_accu (n+1) tail
in in
do_work [] 1 nuclei let result = do_work [] 1 nuclei
|> List.rev |> List.rev
|> List.map ~f:(fun (x,i) -> |> List.map ~f:(fun (x,i) ->
Basis.read_element basis_channel i x.Atom.element) try
Basis.read_element basis_channel i x.Atom.element
with
| End_of_file ->
begin
let alt_channel = alternate_basis_channel x.Atom.element in
Basis.read_element alt_channel i x.Atom.element
end
| _ -> assert false
)
|> List.concat |> List.concat
in in
(* close all in_channels *)
result
in
let long_basis = Long_basis.of_basis basis in let long_basis = Long_basis.of_basis basis in
let ao_num = List.length long_basis in let ao_num = List.length long_basis in
Ezfio.set_ao_basis_ao_num ao_num; Ezfio.set_ao_basis_ao_num ao_num;