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:
parent
17b4438313
commit
34cdca5927
@ -74,17 +74,54 @@ 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
|
||||||
|
(* close all in_channels *)
|
||||||
|
result
|
||||||
in
|
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
|
||||||
|
Loading…
Reference in New Issue
Block a user