mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-10 13:08:23 +01:00
Added Long_basis in ocaml
This commit is contained in:
parent
caa59e03c7
commit
61d54ffbfc
@ -15,6 +15,7 @@ let read in_channel =
|
|||||||
|
|
||||||
(** Find an element in the basis set file *)
|
(** Find an element in the basis set file *)
|
||||||
let find in_channel element =
|
let find in_channel element =
|
||||||
|
In_channel.seek in_channel 0L;
|
||||||
let element_read = ref Element.X in
|
let element_read = ref Element.X in
|
||||||
while !element_read <> element
|
while !element_read <> element
|
||||||
do
|
do
|
||||||
@ -32,3 +33,7 @@ let read_element in_channel element =
|
|||||||
read in_channel ;
|
read in_channel ;
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
let to_string b =
|
||||||
|
List.map ~f:Gto.to_string b
|
||||||
|
|> String.concat ~sep:"\n"
|
||||||
|
;;
|
||||||
|
27
ocaml/Long_basis.ml
Normal file
27
ocaml/Long_basis.ml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
open Core.Std;;
|
||||||
|
|
||||||
|
type t = (Symmetry.Xyz.t * Gto.t) list;;
|
||||||
|
|
||||||
|
let of_basis b =
|
||||||
|
let rec do_work accu = function
|
||||||
|
| [] -> accu
|
||||||
|
| g::tail ->
|
||||||
|
begin
|
||||||
|
let new_accu =
|
||||||
|
Symmetry.Xyz.of_symmetry g.Gto.sym
|
||||||
|
|> List.map ~f:(fun x-> (x,g))
|
||||||
|
in
|
||||||
|
do_work (new_accu@accu) tail
|
||||||
|
end
|
||||||
|
in
|
||||||
|
do_work [] b
|
||||||
|
|> List.rev
|
||||||
|
;;
|
||||||
|
|
||||||
|
|
||||||
|
let to_string b =
|
||||||
|
List.map ~f:(fun (x,y) ->
|
||||||
|
(Symmetry.Xyz.to_string x)^" "^(Gto.to_string y)
|
||||||
|
) b
|
||||||
|
|> String.concat ~sep:"\n"
|
||||||
|
;;
|
@ -54,19 +54,24 @@ let to_l = function
|
|||||||
| K -> Positive_int.of_int 8
|
| K -> Positive_int.of_int 8
|
||||||
| L -> Positive_int.of_int 9
|
| L -> Positive_int.of_int 9
|
||||||
|
|
||||||
|
type st = t
|
||||||
|
;;
|
||||||
|
|
||||||
module Xyz : sig
|
module Xyz : sig
|
||||||
type t
|
type t
|
||||||
val of_string : string -> t
|
val of_string : string -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
val get_l : t -> Positive_int.t
|
val get_l : t -> Positive_int.t
|
||||||
|
val of_symmetry : st -> t list
|
||||||
end = struct
|
end = struct
|
||||||
type t = { x: Positive_int.t ;
|
type t = { x: Positive_int.t ;
|
||||||
y: Positive_int.t ;
|
y: Positive_int.t ;
|
||||||
z: Positive_int.t }
|
z: Positive_int.t }
|
||||||
|
|
||||||
type state_type = Null | X | Y | Z
|
type state_type = Null | X | Y | Z
|
||||||
(* Input string is like "x2z3" *)
|
|
||||||
|
|
||||||
|
(** Builds an XYZ triplet from a string.
|
||||||
|
* The input string is like "x2z3" *)
|
||||||
let of_string s =
|
let of_string s =
|
||||||
let flush state accu number =
|
let flush state accu number =
|
||||||
let n =
|
let n =
|
||||||
@ -106,6 +111,7 @@ end = struct
|
|||||||
z=Positive_int.of_int 0 } ""
|
z=Positive_int.of_int 0 } ""
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
(** Transforms an XYZ triplet to a string *)
|
||||||
let to_string t =
|
let to_string t =
|
||||||
let x = match (Positive_int.to_int t.x) with
|
let x = match (Positive_int.to_int t.x) with
|
||||||
| 0 -> ""
|
| 0 -> ""
|
||||||
@ -123,6 +129,7 @@ end = struct
|
|||||||
x^y^z
|
x^y^z
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
(** Returns the l quantum number from a XYZ powers triplet *)
|
||||||
let get_l t =
|
let get_l t =
|
||||||
let x = Positive_int.to_int t.x
|
let x = Positive_int.to_int t.x
|
||||||
and y = Positive_int.to_int t.y
|
and y = Positive_int.to_int t.y
|
||||||
@ -130,6 +137,7 @@ end = struct
|
|||||||
in Positive_int.of_int (x+y+z)
|
in Positive_int.of_int (x+y+z)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
(** Returns a list of XYZ powers for a given symmetry *)
|
||||||
let of_symmetry sym =
|
let of_symmetry sym =
|
||||||
let l = Positive_int.to_int (to_l sym) in
|
let l = Positive_int.to_int (to_l sym) in
|
||||||
let create_z xyz =
|
let create_z xyz =
|
@ -81,6 +81,7 @@ File : %s\n" c m b xyz_file;
|
|||||||
~rank:2 ~dim:[| nucl_num ; 3 |] ~data:coords);
|
~rank:2 ~dim:[| nucl_num ; 3 |] ~data:coords);
|
||||||
|
|
||||||
(* Write Basis set *)
|
(* Write Basis set *)
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let command =
|
let command =
|
||||||
|
26
ocaml/test_basis.ml
Normal file
26
ocaml/test_basis.ml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
open Core.Std;;
|
||||||
|
open Qputils;;
|
||||||
|
|
||||||
|
let test_module () =
|
||||||
|
|
||||||
|
let basis_channel =
|
||||||
|
let b = "cc-pvdz" in
|
||||||
|
In_channel.create (Qpackage.root / "data/basis" / (String.lowercase b))
|
||||||
|
in
|
||||||
|
|
||||||
|
let molecule =
|
||||||
|
let xyz_file = "F2.xyz" in
|
||||||
|
Molecule.of_xyz_file xyz_file
|
||||||
|
in
|
||||||
|
|
||||||
|
let basis =
|
||||||
|
(Basis.read_element basis_channel Element.F) @
|
||||||
|
(Basis.read_element basis_channel Element.F)
|
||||||
|
in
|
||||||
|
|
||||||
|
Long_basis.of_basis basis
|
||||||
|
|> Long_basis.to_string
|
||||||
|
|> print_endline
|
||||||
|
;;
|
||||||
|
|
||||||
|
test_module ();
|
Loading…
Reference in New Issue
Block a user