10
0
mirror of https://github.com/LCPQ/quantum_package synced 2024-11-15 02:23:56 +01:00
quantum_package/ocaml/Long_basis.ml

30 lines
607 B
OCaml

open Core.Std;;
open Qptypes;;
type t = (Symmetry.Xyz.t * Gto.t * Atom_number.t ) list;;
let of_basis b =
let rec do_work accu = function
| [] -> accu
| (g,n)::tail ->
begin
let new_accu =
Symmetry.Xyz.of_symmetry g.Gto.sym
|> List.map ~f:(fun x-> (x,g,n))
in
do_work (new_accu@accu) tail
end
in
do_work [] b
|> List.rev
;;
let to_string b =
List.map ~f:(fun (x,y,z) ->
(Int.to_string (Atom_number.to_int z))^":"^
(Symmetry.Xyz.to_string x)^" "^(Gto.to_string y)
) b
|> String.concat ~sep:"\n"
;;