mirror of
https://gitlab.com/scemama/QCaml.git
synced 2025-01-03 01:55:40 +01:00
Working on determinants
This commit is contained in:
parent
7dbbf1a352
commit
796c696a8a
@ -1,86 +1,40 @@
|
|||||||
type phase_type =
|
type t =
|
||||||
| Plus
|
|
||||||
| Minus
|
|
||||||
|
|
||||||
type spin_determinant_type =
|
|
||||||
{
|
{
|
||||||
bitstring : Z.t ;
|
alpha : Spindeterminant.t ;
|
||||||
phase : phase_type;
|
beta : Spindeterminant.t ;
|
||||||
}
|
|
||||||
|
|
||||||
type determinant_type =
|
|
||||||
{
|
|
||||||
alpha : Z.t ;
|
|
||||||
beta : Z.t ;
|
|
||||||
phase : phase_type;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
type t = determinant_type
|
|
||||||
|
let alpha t = t.alpha
|
||||||
|
|
||||||
|
let beta t = t.beta
|
||||||
|
|
||||||
|
let phase t =
|
||||||
|
match Spindeterminant.(phase t.alpha, phase t.beta) with
|
||||||
|
| Phase.Pos, Phase.Pos
|
||||||
|
| Phase.Neg, Phase.Neg -> Phase.Pos
|
||||||
|
| _ -> Phase.Neg
|
||||||
|
|
||||||
|
|
||||||
let spindet_of_list l =
|
let of_spindeterminants a b =
|
||||||
let rec aux accu nperm = function
|
{
|
||||||
| [] -> accu, if nperm mod 2 = 0 then Plus else Minus
|
alpha = a ;
|
||||||
| i :: rest ->
|
beta = b
|
||||||
let i = pred i in
|
}
|
||||||
let x = Z.(shift_left one i) in
|
|
||||||
let accu = Z.logor accu x in
|
|
||||||
let nperm =
|
|
||||||
let mask = Z.(x-one) in
|
|
||||||
let r = Z.logand accu mask in
|
|
||||||
if r = Z.zero then
|
|
||||||
nperm
|
|
||||||
else
|
|
||||||
nperm + (Z.popcount r)
|
|
||||||
in
|
|
||||||
aux accu nperm rest
|
|
||||||
in
|
|
||||||
List.rev l
|
|
||||||
|> aux Z.zero 0
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(* TODO Phase *)
|
|
||||||
let rec to_list spindet =
|
|
||||||
let rec aux accu z =
|
|
||||||
if z <> Z.zero then
|
|
||||||
let element = (Z.(trailing_zeros z)+1) in
|
|
||||||
aux (element::accu) Z.(z land (pred z))
|
|
||||||
else List.rev accu
|
|
||||||
in aux [] spindet
|
|
||||||
|
|
||||||
|
|
||||||
let of_lists a b =
|
let of_lists a b =
|
||||||
let alpha, phase_a =
|
{
|
||||||
spindet_of_list a
|
alpha = Spindeterminant.of_list a ;
|
||||||
in
|
beta = Spindeterminant.of_list b
|
||||||
let beta, phase_b =
|
}
|
||||||
spindet_of_list b
|
|
||||||
in
|
|
||||||
let phase =
|
|
||||||
match phase_a, phase_b with
|
|
||||||
| Plus , Plus -> Plus
|
|
||||||
| Minus, Minus-> Plus
|
|
||||||
| _ -> Minus
|
|
||||||
in
|
|
||||||
{ alpha ; beta ; phase }
|
|
||||||
|
|
||||||
let alpha det = det.alpha
|
|
||||||
let beta det = det.beta
|
|
||||||
|
|
||||||
let sgn det =
|
|
||||||
match det.phase with
|
|
||||||
| Plus -> 1.
|
|
||||||
| Minus -> -1.
|
|
||||||
|
|
||||||
let pp_spindet ppf spindet =
|
|
||||||
String.init (Z.numbits spindet) (fun i -> if (Z.testbit spindet i) then '+' else '-')
|
|
||||||
|> Format.fprintf ppf "@[<v> @[<h> %s @]@]"
|
|
||||||
|
|
||||||
|
|
||||||
let pp_det ppf det =
|
let pp_det ppf t =
|
||||||
Format.fprintf ppf "@[<v> a: %a @; b: %a @]@." pp_spindet det.alpha pp_spindet det.beta
|
Format.fprintf ppf "@[<v> a: %a @; b: %a @]@."
|
||||||
|
Spindeterminant.pp_spindet t.alpha
|
||||||
|
Spindeterminant.pp_spindet t.beta
|
||||||
|
|
||||||
|
|
||||||
let test_case () =
|
let test_case () =
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user