mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-03 10:05:57 +01:00
Added s-expressions (sexplib)
This commit is contained in:
parent
1d5b072775
commit
0a9de3c23a
@ -6,7 +6,7 @@ type t =
|
|||||||
{ element : Element.t ;
|
{ element : Element.t ;
|
||||||
charge : Charge.t ;
|
charge : Charge.t ;
|
||||||
coord : Point3d.t ;
|
coord : Point3d.t ;
|
||||||
}
|
} with sexp
|
||||||
|
|
||||||
(** Read xyz coordinates of the atom with unit u *)
|
(** Read xyz coordinates of the atom with unit u *)
|
||||||
let of_string u s =
|
let of_string u s =
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
open Core.Std;;
|
open Core.Std;;
|
||||||
open Qptypes;;
|
open Qptypes;;
|
||||||
|
|
||||||
type t = (Gto.t * Nucl_number.t) list;;
|
type t = (Gto.t * Nucl_number.t) list with sexp;;
|
||||||
|
|
||||||
(** Read all the basis functions of an element *)
|
(** Read all the basis functions of an element *)
|
||||||
let read in_channel at_number =
|
let read in_channel at_number =
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
open Core.Std;;
|
||||||
|
|
||||||
(*
|
(*
|
||||||
Type for bits
|
Type for bits
|
||||||
@ -10,6 +11,7 @@ Zero | One
|
|||||||
type bit =
|
type bit =
|
||||||
| One
|
| One
|
||||||
| Zero
|
| Zero
|
||||||
|
with sexp
|
||||||
|
|
||||||
let to_string = function
|
let to_string = function
|
||||||
| Zero -> "0"
|
| Zero -> "0"
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
open Core.Std;;
|
open Core.Std;;
|
||||||
|
|
||||||
type t = float
|
type t = float with sexp;;
|
||||||
|
|
||||||
let of_float x = x
|
let of_float x = x
|
||||||
let of_int i = Float.of_int i
|
let of_int i = Float.of_int i
|
||||||
let of_string s = Float.of_string s
|
let of_string s = Float.of_string s
|
||||||
|
|
||||||
|
|
||||||
let to_float x = x
|
let to_float x = x
|
||||||
let to_int x = Float.to_int x
|
let to_int x = Float.to_int x
|
||||||
let to_string x =
|
let to_string x =
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
type t = float
|
type t = float with sexp
|
||||||
|
|
||||||
val to_float : t -> float
|
val to_float : t -> float
|
||||||
val to_int : t -> int
|
val to_int : t -> int
|
||||||
|
@ -8,7 +8,7 @@ type t =
|
|||||||
|Li|Be |B |C |N |O |F |Ne
|
|Li|Be |B |C |N |O |F |Ne
|
||||||
|Na|Mg |Al|Si|P |S |Cl|Ar
|
|Na|Mg |Al|Si|P |S |Cl|Ar
|
||||||
|K |Ca|Sc|Ti|V |Cr|Mn|Fe|Co|Ni|Cu|Zn|Ga|Ge|As|Se|Br|Kr
|
|K |Ca|Sc|Ti|V |Cr|Mn|Fe|Co|Ni|Cu|Zn|Ga|Ge|As|Se|Br|Kr
|
||||||
;;
|
with sexp;;
|
||||||
|
|
||||||
let of_string x =
|
let of_string x =
|
||||||
match (String.capitalize (String.lowercase x)) with
|
match (String.capitalize (String.lowercase x)) with
|
||||||
|
@ -2,21 +2,21 @@ open Core.Std;;
|
|||||||
open Qptypes;;
|
open Qptypes;;
|
||||||
|
|
||||||
module Hole : sig
|
module Hole : sig
|
||||||
type t
|
type t with sexp
|
||||||
val to_mo_class : t -> MO_class.t
|
val to_mo_class : t -> MO_class.t
|
||||||
val of_mo_class : MO_class.t -> t
|
val of_mo_class : MO_class.t -> t
|
||||||
end = struct
|
end = struct
|
||||||
type t = MO_class.t
|
type t = MO_class.t with sexp
|
||||||
let of_mo_class x = x
|
let of_mo_class x = x
|
||||||
let to_mo_class x = x
|
let to_mo_class x = x
|
||||||
end
|
end
|
||||||
|
|
||||||
module Particle : sig
|
module Particle : sig
|
||||||
type t
|
type t with sexp
|
||||||
val to_mo_class : t -> MO_class.t
|
val to_mo_class : t -> MO_class.t
|
||||||
val of_mo_class : MO_class.t -> t
|
val of_mo_class : MO_class.t -> t
|
||||||
end = struct
|
end = struct
|
||||||
type t = MO_class.t
|
type t = MO_class.t with sexp
|
||||||
let of_mo_class x = x
|
let of_mo_class x = x
|
||||||
let to_mo_class x = x
|
let to_mo_class x = x
|
||||||
end
|
end
|
||||||
@ -24,7 +24,7 @@ end
|
|||||||
type t =
|
type t =
|
||||||
| Single of Hole.t*Particle.t
|
| Single of Hole.t*Particle.t
|
||||||
| Double of Hole.t*Particle.t*Hole.t*Particle.t
|
| Double of Hole.t*Particle.t*Hole.t*Particle.t
|
||||||
;;
|
with sexp;;
|
||||||
|
|
||||||
let failwith s = raise (Failure s)
|
let failwith s = raise (Failure s)
|
||||||
;;
|
;;
|
||||||
|
@ -7,7 +7,7 @@ exception End_Of_Basis
|
|||||||
type t =
|
type t =
|
||||||
{ sym : Symmetry.t ;
|
{ sym : Symmetry.t ;
|
||||||
lc : ((Primitive.t * AO_coef.t) list)
|
lc : ((Primitive.t * AO_coef.t) list)
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let of_prim_coef_list pc =
|
let of_prim_coef_list pc =
|
||||||
@ -62,6 +62,7 @@ let read_one in_channel =
|
|||||||
| _ -> raise (GTO_Read_Failure line_buffer)
|
| _ -> raise (GTO_Read_Failure line_buffer)
|
||||||
end
|
end
|
||||||
in read_lines [] n
|
in read_lines [] n
|
||||||
|
|> List.rev
|
||||||
|> of_prim_coef_list
|
|> of_prim_coef_list
|
||||||
;;
|
;;
|
||||||
|
|
||||||
@ -70,6 +71,6 @@ let read_one in_channel =
|
|||||||
let to_string { sym = sym ; lc = lc } =
|
let to_string { sym = sym ; lc = lc } =
|
||||||
let f (p,c) = Printf.sprintf "( %s, %f )" (Primitive.to_string p) (AO_coef.to_float c)
|
let f (p,c) = Printf.sprintf "( %s, %f )" (Primitive.to_string p) (AO_coef.to_float c)
|
||||||
in
|
in
|
||||||
Printf.sprintf "[ %s : %s ]" (Symmetry.to_string sym)
|
Printf.sprintf "( %s, %s )" (Symmetry.to_string sym)
|
||||||
(String.concat (List.map ~f:f lc) ~sep:", ")
|
(String.concat (List.map ~f:f lc) ~sep:", ")
|
||||||
;;
|
;;
|
||||||
|
@ -12,10 +12,11 @@ module Ao_basis : sig
|
|||||||
ao_power : Symmetry.Xyz.t array;
|
ao_power : Symmetry.Xyz.t array;
|
||||||
ao_coef : AO_coef.t array;
|
ao_coef : AO_coef.t array;
|
||||||
ao_expo : AO_expo.t array;
|
ao_expo : AO_expo.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
|
val debug : t -> string
|
||||||
end = struct
|
end = struct
|
||||||
type t =
|
type t =
|
||||||
{ ao_basis : string ;
|
{ ao_basis : string ;
|
||||||
@ -26,7 +27,7 @@ end = struct
|
|||||||
ao_power : Symmetry.Xyz.t array;
|
ao_power : Symmetry.Xyz.t array;
|
||||||
ao_coef : AO_coef.t array;
|
ao_coef : AO_coef.t array;
|
||||||
ao_expo : AO_expo.t array;
|
ao_expo : AO_expo.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "ao_basis";;
|
let get_default = Qpackage.get_ezfio_default "ao_basis";;
|
||||||
@ -104,16 +105,56 @@ end = struct
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
let to_string b =
|
let to_string b =
|
||||||
|
let ao_num = AO_number.to_int b.ao_num in
|
||||||
|
let gto_array = Array.init (AO_number.to_int b.ao_num)
|
||||||
|
~f:(fun i ->
|
||||||
|
let s = Symmetry.Xyz.to_symmetry b.ao_power.(i) in
|
||||||
|
let ao_prim_num = AO_prim_number.to_int b.ao_prim_num.(i) in
|
||||||
|
let prims = List.init ao_prim_num ~f:(fun j ->
|
||||||
|
let prim = { Primitive.sym = s ;
|
||||||
|
Primitive.expo = b.ao_expo.(ao_num*j+i)
|
||||||
|
}
|
||||||
|
in
|
||||||
|
let coef = b.ao_coef.(ao_num*j+i) in
|
||||||
|
(prim,coef)
|
||||||
|
) in
|
||||||
|
Gto.of_prim_coef_list prims
|
||||||
|
)
|
||||||
|
in
|
||||||
|
let long_basis =
|
||||||
|
let rec do_work accu sym gto nucl =
|
||||||
|
match (sym, gto, nucl) with
|
||||||
|
| (s::srest, g::grest, n::nrest) ->
|
||||||
|
do_work ((s,g,n)::accu) srest grest nrest
|
||||||
|
| ([],[],[]) -> List.rev accu
|
||||||
|
| _ -> assert false
|
||||||
|
in
|
||||||
|
do_work []
|
||||||
|
(Array.to_list b.ao_power)
|
||||||
|
(Array.to_list gto_array)
|
||||||
|
(Array.to_list b.ao_nucl)
|
||||||
|
in
|
||||||
Printf.sprintf "
|
Printf.sprintf "
|
||||||
ao_basis = \"%s\"
|
# AO Basis
|
||||||
ao_num = %s
|
# ========
|
||||||
ao_prim_num = %s
|
%s" (Long_basis.to_string long_basis)
|
||||||
ao_prim_num_max = %s
|
;;
|
||||||
ao_nucl = %s
|
|
||||||
ao_power = %s
|
|
||||||
ao_coef = %s
|
let debug b =
|
||||||
ao_expo = %s
|
Printf.sprintf "
|
||||||
"
|
# AO Basis
|
||||||
|
# ========
|
||||||
|
#
|
||||||
|
# ao_basis = %s
|
||||||
|
# ao_num = %s
|
||||||
|
# ao_prim_num = %s
|
||||||
|
# ao_prim_num_max = %s
|
||||||
|
# ao_nucl = %s
|
||||||
|
# ao_power = %s
|
||||||
|
# ao_coef = %s
|
||||||
|
# ao_expo = %s
|
||||||
|
#"
|
||||||
b.ao_basis
|
b.ao_basis
|
||||||
(AO_number.to_string b.ao_num)
|
(AO_number.to_string b.ao_num)
|
||||||
(b.ao_prim_num |> Array.to_list |> List.map
|
(b.ao_prim_num |> Array.to_list |> List.map
|
||||||
@ -128,6 +169,6 @@ ao_expo = %s
|
|||||||
(b.ao_expo |> Array.to_list |> List.map ~f:AO_expo.to_string
|
(b.ao_expo |> Array.to_list |> List.map ~f:AO_expo.to_string
|
||||||
|> String.concat ~sep:", ")
|
|> String.concat ~sep:", ")
|
||||||
|
|
||||||
|
;;
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ module Bielec_integrals : sig
|
|||||||
threshold_ao : Threshold.t;
|
threshold_ao : Threshold.t;
|
||||||
threshold_mo : Threshold.t;
|
threshold_mo : Threshold.t;
|
||||||
direct : bool;
|
direct : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -24,7 +24,7 @@ end = struct
|
|||||||
threshold_ao : Threshold.t;
|
threshold_ao : Threshold.t;
|
||||||
threshold_mo : Threshold.t;
|
threshold_mo : Threshold.t;
|
||||||
direct : bool;
|
direct : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "bielec_integrals";;
|
let get_default = Qpackage.get_ezfio_default "bielec_integrals";;
|
||||||
|
@ -8,7 +8,7 @@ module Bitmasks : sig
|
|||||||
bit_kind : Bit_kind.t;
|
bit_kind : Bit_kind.t;
|
||||||
n_mask_gen : Bitmask_number.t;
|
n_mask_gen : Bitmask_number.t;
|
||||||
generators : int64 array;
|
generators : int64 array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -18,7 +18,7 @@ end = struct
|
|||||||
bit_kind : Bit_kind.t;
|
bit_kind : Bit_kind.t;
|
||||||
n_mask_gen : Bitmask_number.t;
|
n_mask_gen : Bitmask_number.t;
|
||||||
generators : int64 array;
|
generators : int64 array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "bitmasks";;
|
let get_default = Qpackage.get_ezfio_default "bitmasks";;
|
||||||
|
@ -10,7 +10,7 @@ module Cis_dressed : sig
|
|||||||
mp2_dressing : bool;
|
mp2_dressing : bool;
|
||||||
standard_doubles : bool;
|
standard_doubles : bool;
|
||||||
en_2_2 : bool;
|
en_2_2 : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -22,7 +22,7 @@ end = struct
|
|||||||
mp2_dressing : bool;
|
mp2_dressing : bool;
|
||||||
standard_doubles : bool;
|
standard_doubles : bool;
|
||||||
en_2_2 : bool;
|
en_2_2 : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "cis_dressed";;
|
let get_default = Qpackage.get_ezfio_default "cis_dressed";;
|
||||||
|
@ -7,7 +7,7 @@ module Cisd_sc2 : sig
|
|||||||
{ n_det_max_cisd_sc2 : Det_number.t;
|
{ n_det_max_cisd_sc2 : Det_number.t;
|
||||||
pt2_max : PT2_energy.t;
|
pt2_max : PT2_energy.t;
|
||||||
do_pt2_end : bool;
|
do_pt2_end : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -16,7 +16,7 @@ end = struct
|
|||||||
{ n_det_max_cisd_sc2 : Det_number.t;
|
{ n_det_max_cisd_sc2 : Det_number.t;
|
||||||
pt2_max : PT2_energy.t;
|
pt2_max : PT2_energy.t;
|
||||||
do_pt2_end : bool;
|
do_pt2_end : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "cisd_sc2_selected";;
|
let get_default = Qpackage.get_ezfio_default "cisd_sc2_selected";;
|
||||||
|
@ -18,7 +18,7 @@ module Determinants : sig
|
|||||||
s2_eig : bool;
|
s2_eig : bool;
|
||||||
psi_coef : Det_coef.t array;
|
psi_coef : Det_coef.t array;
|
||||||
psi_det : Determinant.t array;
|
psi_det : Determinant.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -38,7 +38,7 @@ end = struct
|
|||||||
s2_eig : bool;
|
s2_eig : bool;
|
||||||
psi_coef : Det_coef.t array;
|
psi_coef : Det_coef.t array;
|
||||||
psi_det : Determinant.t array;
|
psi_det : Determinant.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "determinants";;
|
let get_default = Qpackage.get_ezfio_default "determinants";;
|
||||||
|
@ -7,7 +7,7 @@ module Electrons : sig
|
|||||||
{ elec_alpha_num : Elec_alpha_number.t;
|
{ elec_alpha_num : Elec_alpha_number.t;
|
||||||
elec_beta_num : Elec_beta_number.t;
|
elec_beta_num : Elec_beta_number.t;
|
||||||
elec_num : Elec_number.t;
|
elec_num : Elec_number.t;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -16,7 +16,7 @@ end = struct
|
|||||||
{ elec_alpha_num : Elec_alpha_number.t;
|
{ elec_alpha_num : Elec_alpha_number.t;
|
||||||
elec_beta_num : Elec_beta_number.t;
|
elec_beta_num : Elec_beta_number.t;
|
||||||
elec_num : Elec_number.t;
|
elec_num : Elec_number.t;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "electrons";;
|
let get_default = Qpackage.get_ezfio_default "electrons";;
|
||||||
|
@ -7,7 +7,7 @@ module Full_ci : sig
|
|||||||
{ n_det_max_fci : Det_number.t;
|
{ n_det_max_fci : Det_number.t;
|
||||||
pt2_max : PT2_energy.t;
|
pt2_max : PT2_energy.t;
|
||||||
do_pt2_end : bool;
|
do_pt2_end : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -16,7 +16,7 @@ end = struct
|
|||||||
{ n_det_max_fci : Det_number.t;
|
{ n_det_max_fci : Det_number.t;
|
||||||
pt2_max : PT2_energy.t;
|
pt2_max : PT2_energy.t;
|
||||||
do_pt2_end : bool;
|
do_pt2_end : bool;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "full_ci";;
|
let get_default = Qpackage.get_ezfio_default "full_ci";;
|
||||||
|
@ -6,7 +6,7 @@ module Hartree_fock : sig
|
|||||||
type t =
|
type t =
|
||||||
{ n_it_scf_max : Strictly_positive_int.t;
|
{ n_it_scf_max : Strictly_positive_int.t;
|
||||||
thresh_scf : Threshold.t;
|
thresh_scf : Threshold.t;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -14,7 +14,7 @@ end = struct
|
|||||||
type t =
|
type t =
|
||||||
{ n_it_scf_max : Strictly_positive_int.t;
|
{ n_it_scf_max : Strictly_positive_int.t;
|
||||||
thresh_scf : Threshold.t;
|
thresh_scf : Threshold.t;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "hartree_fock";;
|
let get_default = Qpackage.get_ezfio_default "hartree_fock";;
|
||||||
|
@ -8,7 +8,7 @@ module Mo_basis : sig
|
|||||||
mo_label : Non_empty_string.t;
|
mo_label : Non_empty_string.t;
|
||||||
mo_occ : Positive_float.t array;
|
mo_occ : Positive_float.t array;
|
||||||
mo_coef : MO_coef.t array;
|
mo_coef : MO_coef.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -18,7 +18,7 @@ end = struct
|
|||||||
mo_label : Non_empty_string.t;
|
mo_label : Non_empty_string.t;
|
||||||
mo_occ : Positive_float.t array;
|
mo_occ : Positive_float.t array;
|
||||||
mo_coef : MO_coef.t array;
|
mo_coef : MO_coef.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "mo_basis";;
|
let get_default = Qpackage.get_ezfio_default "mo_basis";;
|
||||||
|
@ -8,7 +8,7 @@ module Nuclei : sig
|
|||||||
nucl_label : Element.t array;
|
nucl_label : Element.t array;
|
||||||
nucl_charge : Charge.t array;
|
nucl_charge : Charge.t array;
|
||||||
nucl_coord : Point3d.t array;
|
nucl_coord : Point3d.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
val read : unit -> t
|
val read : unit -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
@ -18,7 +18,7 @@ end = struct
|
|||||||
nucl_label : Element.t array;
|
nucl_label : Element.t array;
|
||||||
nucl_charge : Charge.t array;
|
nucl_charge : Charge.t array;
|
||||||
nucl_coord : Point3d.t array;
|
nucl_coord : Point3d.t array;
|
||||||
}
|
} with sexp
|
||||||
;;
|
;;
|
||||||
|
|
||||||
let get_default = Qpackage.get_ezfio_default "nuclei";;
|
let get_default = Qpackage.get_ezfio_default "nuclei";;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
open Core.Std;;
|
open Core.Std;;
|
||||||
open Qptypes;;
|
open Qptypes;;
|
||||||
|
|
||||||
type t = (Symmetry.Xyz.t * Gto.t * Nucl_number.t ) list;;
|
type t = (Symmetry.Xyz.t * Gto.t * Nucl_number.t ) list with sexp
|
||||||
|
|
||||||
let of_basis b =
|
let of_basis b =
|
||||||
let rec do_work accu = function
|
let rec do_work accu = function
|
||||||
@ -21,9 +21,15 @@ let of_basis b =
|
|||||||
|
|
||||||
|
|
||||||
let to_string b =
|
let to_string b =
|
||||||
List.map ~f:(fun (x,y,z) ->
|
Sexp.to_string (sexp_of_t b)
|
||||||
(Int.to_string (Nucl_number.to_int z))^":"^
|
|
||||||
(Symmetry.Xyz.to_string x)^" "^(Gto.to_string y)
|
|
||||||
) b
|
|
||||||
|> String.concat ~sep:"\n"
|
|
||||||
;;
|
;;
|
||||||
|
(*
|
||||||
|
let middle = List.map ~f:(fun (x,y,z) ->
|
||||||
|
"( "^((Int.to_string (Nucl_number.to_int z)))^", "^
|
||||||
|
(Symmetry.Xyz.to_string x)^", "^(Gto.to_string y)
|
||||||
|
^" )"
|
||||||
|
) b
|
||||||
|
|> String.concat ~sep:",\n"
|
||||||
|
in "("^middle^")"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
@ -7,7 +7,7 @@ type t =
|
|||||||
| Active of MO_number.t list
|
| Active of MO_number.t list
|
||||||
| Virtual of MO_number.t list
|
| Virtual of MO_number.t list
|
||||||
| Deleted of MO_number.t list
|
| Deleted of MO_number.t list
|
||||||
;;
|
with sexp
|
||||||
|
|
||||||
|
|
||||||
let to_string x =
|
let to_string x =
|
||||||
|
@ -13,7 +13,7 @@ endif
|
|||||||
LIBS=
|
LIBS=
|
||||||
PKGS=
|
PKGS=
|
||||||
OCAMLCFLAGS=-g
|
OCAMLCFLAGS=-g
|
||||||
OCAMLBUILD=ocamlbuild -j 0 -cflags $(OCAMLCFLAGS) -lflags -g
|
OCAMLBUILD=ocamlbuild -j 0 -syntax camlp4o -cflags $(OCAMLCFLAGS) -lflags -g
|
||||||
MLFILES=$(wildcard *.ml) ezfio.ml Qptypes.ml
|
MLFILES=$(wildcard *.ml) ezfio.ml Qptypes.ml
|
||||||
MLIFILES=$(wildcard *.mli)
|
MLIFILES=$(wildcard *.mli)
|
||||||
ALL_TESTS=$(patsubst %.ml,%.byte,$(wildcard test_*.ml))
|
ALL_TESTS=$(patsubst %.ml,%.byte,$(wildcard test_*.ml))
|
||||||
|
@ -7,7 +7,7 @@ type t = {
|
|||||||
nuclei : Atom.t list ;
|
nuclei : Atom.t list ;
|
||||||
elec_alpha : Elec_alpha_number.t ;
|
elec_alpha : Elec_alpha_number.t ;
|
||||||
elec_beta : Elec_beta_number.t ;
|
elec_beta : Elec_beta_number.t ;
|
||||||
}
|
} with sexp
|
||||||
|
|
||||||
let get_charge { nuclei ; elec_alpha ; elec_beta } =
|
let get_charge { nuclei ; elec_alpha ; elec_beta } =
|
||||||
let result = (Elec_alpha_number.to_int elec_alpha) +
|
let result = (Elec_alpha_number.to_int elec_alpha) +
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
open Core.Std;;
|
open Core.Std;;
|
||||||
open Qptypes ;;
|
open Qptypes ;;
|
||||||
|
|
||||||
type t = Strictly_positive_int.t;;
|
type t = Strictly_positive_int.t with sexp
|
||||||
|
|
||||||
let of_int = Strictly_positive_int.of_int ;;
|
let of_int = Strictly_positive_int.of_int ;;
|
||||||
let to_int = Strictly_positive_int.to_int ;;
|
let to_int = Strictly_positive_int.to_int ;;
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@ type t = {
|
|||||||
x : float ;
|
x : float ;
|
||||||
y : float ;
|
y : float ;
|
||||||
z : float ;
|
z : float ;
|
||||||
}
|
} with sexp
|
||||||
|
|
||||||
(** Read x y z coordinates in string s with units u *)
|
(** Read x y z coordinates in string s with units u *)
|
||||||
let of_string u s =
|
let of_string u s =
|
||||||
|
@ -4,7 +4,7 @@ open Core.Std;;
|
|||||||
type t =
|
type t =
|
||||||
{ sym : Symmetry.t ;
|
{ sym : Symmetry.t ;
|
||||||
expo : AO_expo.t ;
|
expo : AO_expo.t ;
|
||||||
}
|
} with sexp
|
||||||
|
|
||||||
let to_string p =
|
let to_string p =
|
||||||
let { sym = s ; expo = e } = p in
|
let { sym = s ; expo = e } = p in
|
||||||
|
@ -12,7 +12,7 @@ open Core.Std;;
|
|||||||
*)
|
*)
|
||||||
|
|
||||||
|
|
||||||
type t = int list ;;
|
type t = int list with sexp
|
||||||
|
|
||||||
let expand_range r =
|
let expand_range r =
|
||||||
match String.lsplit2 ~on:'-' r with
|
match String.lsplit2 ~on:'-' r with
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
open Qptypes;;
|
open Qptypes;;
|
||||||
open Core.Std;;
|
open Core.Std;;
|
||||||
|
|
||||||
type t = S|P|D|F|G|H|I|J|K|L
|
type t = S|P|D|F|G|H|I|J|K|L with sexp
|
||||||
|
|
||||||
let to_string = function
|
let to_string = function
|
||||||
| S -> "S"
|
| S -> "S"
|
||||||
@ -53,6 +53,23 @@ let to_l = function
|
|||||||
| J -> Positive_int.of_int 7
|
| J -> Positive_int.of_int 7
|
||||||
| K -> Positive_int.of_int 8
|
| K -> Positive_int.of_int 8
|
||||||
| L -> Positive_int.of_int 9
|
| L -> Positive_int.of_int 9
|
||||||
|
;;
|
||||||
|
|
||||||
|
let of_l i =
|
||||||
|
let i = Positive_int.to_int i in
|
||||||
|
match i with
|
||||||
|
| 0 -> S
|
||||||
|
| 1 -> P
|
||||||
|
| 2 -> D
|
||||||
|
| 3 -> F
|
||||||
|
| 4 -> G
|
||||||
|
| 5 -> H
|
||||||
|
| 6 -> I
|
||||||
|
| 7 -> J
|
||||||
|
| 8 -> K
|
||||||
|
| 9 -> L
|
||||||
|
| x -> raise (Failure ("Symmetry should be S|P|D|F|G|H|I|J|K|L"))
|
||||||
|
;;
|
||||||
|
|
||||||
type st = t
|
type st = t
|
||||||
;;
|
;;
|
||||||
@ -60,15 +77,16 @@ type st = t
|
|||||||
module Xyz : sig
|
module Xyz : sig
|
||||||
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 } with sexp
|
||||||
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
|
val of_symmetry : st -> t list
|
||||||
|
val to_symmetry : t -> st
|
||||||
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 } with sexp
|
||||||
type state_type = Null | X | Y | Z
|
type state_type = Null | X | Y | Z
|
||||||
|
|
||||||
(** Builds an XYZ triplet from a string.
|
(** Builds an XYZ triplet from a string.
|
||||||
@ -127,7 +145,9 @@ end = struct
|
|||||||
| 1 -> "z"
|
| 1 -> "z"
|
||||||
| i -> Printf.sprintf "z%d" i
|
| i -> Printf.sprintf "z%d" i
|
||||||
in
|
in
|
||||||
x^y^z
|
let result = (x^y^z) in
|
||||||
|
if (result = "") then "s"
|
||||||
|
else result
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(** Returns the l quantum number from a XYZ powers triplet *)
|
(** Returns the l quantum number from a XYZ powers triplet *)
|
||||||
@ -169,5 +189,7 @@ end = struct
|
|||||||
z=Positive_int.of_int 0 }
|
z=Positive_int.of_int 0 }
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
let to_symmetry sym = of_l (get_l sym)
|
||||||
|
;;
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
true: package(core)
|
true: package(core,sexplib.syntax)
|
||||||
true: thread
|
true: thread
|
||||||
|
|
||||||
|
@ -126,12 +126,12 @@ let input_data = "
|
|||||||
|
|
||||||
let untouched = "
|
let untouched = "
|
||||||
module Determinant : sig
|
module Determinant : sig
|
||||||
type t
|
type t with sexp
|
||||||
val to_int64_array : t -> int64 array
|
val to_int64_array : t -> int64 array
|
||||||
val of_int64_array : int64 array -> t
|
val of_int64_array : int64 array -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
end = struct
|
end = struct
|
||||||
type t = int64 array
|
type t = int64 array with sexp
|
||||||
let to_int64_array x = x
|
let to_int64_array x = x
|
||||||
let of_int64_array x =
|
let of_int64_array x =
|
||||||
if (Ezfio.has_determinants_n_int ()) then
|
if (Ezfio.has_determinants_n_int ()) then
|
||||||
@ -149,12 +149,12 @@ end
|
|||||||
|
|
||||||
let template = format_of_string "
|
let template = format_of_string "
|
||||||
module %s : sig
|
module %s : sig
|
||||||
type t
|
type t with sexp
|
||||||
val to_%s : t -> %s
|
val to_%s : t -> %s
|
||||||
val of_%s : %s -> t
|
val of_%s : %s -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
end = struct
|
end = struct
|
||||||
type t = %s
|
type t = %s with sexp
|
||||||
let to_%s x = x
|
let to_%s x = x
|
||||||
let of_%s x = ( %s x )
|
let of_%s x = ( %s x )
|
||||||
let to_string x = %s.to_string x
|
let to_string x = %s.to_string x
|
||||||
|
@ -2,6 +2,7 @@ let test_ao () =
|
|||||||
Ezfio.set_file "F2.ezfio" ;
|
Ezfio.set_file "F2.ezfio" ;
|
||||||
let b = Input.Ao_basis.read ()
|
let b = Input.Ao_basis.read ()
|
||||||
in
|
in
|
||||||
|
print_endline (Input.Ao_basis.debug b);
|
||||||
print_endline (Input.Ao_basis.to_string b);
|
print_endline (Input.Ao_basis.to_string b);
|
||||||
;;
|
;;
|
||||||
|
|
||||||
@ -84,5 +85,7 @@ test_cis ();
|
|||||||
test_dets ();
|
test_dets ();
|
||||||
test_cisd_sc2 ();
|
test_cisd_sc2 ();
|
||||||
test_mo ();;
|
test_mo ();;
|
||||||
*)
|
|
||||||
test_nucl ();
|
test_nucl ();
|
||||||
|
*)
|
||||||
|
test_ao ();;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user