mirror of
https://gitlab.com/scemama/QCaml.git
synced 2025-01-08 20:33:03 +01:00
Cleaned examples
This commit is contained in:
parent
f23fbe8006
commit
aa40a995b2
@ -14,7 +14,7 @@ fi
|
|||||||
|
|
||||||
DIR=${1%/}
|
DIR=${1%/}
|
||||||
|
|
||||||
cat << EOF > ${PWD}/tmpfile
|
cat << EOF > ${PWD}/tmpfile_$DIR
|
||||||
(package-initialize)
|
(package-initialize)
|
||||||
(add-to-list 'package-archives
|
(add-to-list 'package-archives
|
||||||
'("gnu" . "https://elpa.gnu.org/packages/"))
|
'("gnu" . "https://elpa.gnu.org/packages/"))
|
||||||
@ -92,10 +92,10 @@ cd $DIR
|
|||||||
for i in *.org
|
for i in *.org
|
||||||
do
|
do
|
||||||
echo "--- $i ----"
|
echo "--- $i ----"
|
||||||
emacs --batch ./$i --load=../tmpfile
|
emacs --batch ./$i --load=../tmpfile_$DIR
|
||||||
done
|
done
|
||||||
|
|
||||||
rm ../tmpfile
|
rm ../tmpfile_$DIR
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -66,13 +66,13 @@ val to_string : t -> string
|
|||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Angular_momentum.of_char 'p';;
|
Angular_momentum.of_char 'p';;
|
||||||
- : Angular_momentum.t = Qcaml.Common.Angular_momentum.P
|
- : Angular_momentum.t = P
|
||||||
|
|
||||||
Angular_momentum.(to_char P);;
|
Angular_momentum.(to_char P);;
|
||||||
- : char = 'P'
|
- : char = 'P'
|
||||||
|
|
||||||
Angular_momentum.of_int 2;;
|
Angular_momentum.of_int 2;;
|
||||||
- : Angular_momentum.t = Qcaml.Common.Angular_momentum.D
|
- : Angular_momentum.t = D
|
||||||
|
|
||||||
Angular_momentum.(to_int D);;
|
Angular_momentum.(to_int D);;
|
||||||
- : int = 2
|
- : int = 2
|
||||||
@ -148,10 +148,9 @@ Angular_momentum.(n_functions D) ;;
|
|||||||
|
|
||||||
Angular_momentum.( zkey_array (Doublet (P,S)) );;
|
Angular_momentum.( zkey_array (Doublet (P,S)) );;
|
||||||
- : Zkey.t array =
|
- : Zkey.t array =
|
||||||
[| {Zkey.left = 0; right = 1125899906842624} ;
|
[|< 01125899906842624 | 1, 0, 0, 0, 0, 0 >;
|
||||||
{Zkey.left = 0; right = 1099511627776} ;
|
< 01099511627776 | 0, 1, 0, 0, 0, 0 >;
|
||||||
{Zkey.left = 0; right = 1073741824} |]
|
< 01073741824 | 0, 0, 1, 0, 0, 0 >|]
|
||||||
|
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
@ -248,10 +247,10 @@ val ( - ) : t -> t -> t
|
|||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Angular_momentum.(D + P);;
|
Angular_momentum.(D + P);;
|
||||||
- : Angular_momentum.t = Qcaml.Common.Angular_momentum.F
|
- : Angular_momentum.t = F
|
||||||
|
|
||||||
Angular_momentum.(F - P);;
|
Angular_momentum.(F - P);;
|
||||||
- : Angular_momentum.t = Qcaml.Common.Angular_momentum.D
|
- : Angular_momentum.t = D
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
|
@ -176,95 +176,89 @@ val permutations : int -> int -> t list
|
|||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
let of_int x =
|
let of_int x =
|
||||||
One (One.of_int x)
|
One (One.of_int x)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "of_x" true (one_x = (of_int x));
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let of_z x =
|
let of_z x =
|
||||||
if Z.numbits x < 64 then One (Z.to_int x) else Many (Many.of_z x)
|
if Z.numbits x < 64 then One (Z.to_int x) else Many (Many.of_z x)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
||||||
|
check_bool "of_x" true (one_x = (of_int x));
|
||||||
check_bool "of_z" true (one_x = (of_z (Z.of_int x)));
|
check_bool "of_z" true (one_x = (of_z (Z.of_int x)));
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
#+begin_example
|
||||||
|
Bitstring.of_int 15;;
|
||||||
|
- : Bitstring.t =
|
||||||
|
++++------------------------------------------------------------
|
||||||
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
let zero = function
|
let zero = function
|
||||||
| n when n < 64 -> One (One.zero)
|
| n when n < 64 -> One (One.zero)
|
||||||
| _ -> Many (Many.zero)
|
| _ -> Many (Many.zero)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let numbits = function
|
let numbits = function
|
||||||
| One x -> One.numbits x
|
| One x -> One.numbits x
|
||||||
| Many x -> Many.numbits x
|
| Many x -> Many.numbits x
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let is_zero = function
|
let is_zero = function
|
||||||
| One x -> One.is_zero x
|
| One x -> One.is_zero x
|
||||||
| Many x -> Many.is_zero x
|
| Many x -> Many.is_zero x
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let neg = function
|
let neg = function
|
||||||
| One x -> One (One.neg x)
|
| One x -> One (One.neg x)
|
||||||
| Many x -> Many (Many.neg x)
|
| Many x -> Many (Many.neg x)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let shift_left x i = match x with
|
let shift_left x i = match x with
|
||||||
| One x -> One (One.shift_left x i)
|
| One x -> One (One.shift_left x i)
|
||||||
| Many x -> Many (Many.shift_left x i)
|
| Many x -> Many (Many.shift_left x i)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "shift_left1" true (of_int (x lsl 3) = shift_left one_x 3);
|
|
||||||
check_bool "shift_left2" true (of_z (Z.shift_left z 3) = shift_left many_x 3);
|
|
||||||
check_bool "shift_left3" true (of_z (Z.shift_left z 100) = shift_left many_x 100);
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let shift_right x i = match x with
|
let shift_right x i = match x with
|
||||||
| One x -> One (One.shift_right x i)
|
| One x -> One (One.shift_right x i)
|
||||||
| Many x -> Many (Many.shift_right x i)
|
| Many x -> Many (Many.shift_right x i)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "shift_right1" true (of_int (x lsr 3) = shift_right one_x 3);
|
|
||||||
check_bool "shift_right2" true (of_z (Z.shift_right z 3) = shift_right many_x 3);
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let shift_left_one = function
|
let shift_left_one = function
|
||||||
| n when n < 64 -> fun i -> One (One.shift_left_one i)
|
| n when n < 64 -> fun i -> One (One.shift_left_one i)
|
||||||
| _ -> fun i -> Many (Many.shift_left_one i)
|
| _ -> fun i -> Many (Many.shift_left_one i)
|
||||||
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "shift_left_one1" true (of_int (1 lsl 3) = shift_left_one 4 3);
|
|
||||||
check_bool "shift_left_one2" true (of_z (Z.shift_left Z.one 200) = shift_left_one 300 200);
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let testbit = function
|
let testbit = function
|
||||||
| One x -> One.testbit x
|
| One x -> One.testbit x
|
||||||
| Many x -> Many.testbit x
|
| Many x -> Many.testbit x
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
#+begin_example
|
||||||
|
Bitstring.(shift_left (of_int 15) 2);;
|
||||||
|
- : Bitstring.t =
|
||||||
|
--++++----------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.(shift_right (of_int 15) 2);;
|
||||||
|
- : Bitstring.t =
|
||||||
|
++--------------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.shift_left_one 32 4;;
|
||||||
|
- : Bitstring.t =
|
||||||
|
----+-----------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.(testbit (of_int 15) 3);;
|
||||||
|
- : bool = true
|
||||||
|
|
||||||
|
Bitstring.(testbit (of_int 15) 4);;
|
||||||
|
- : bool = false
|
||||||
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
||||||
|
check_bool "shift_left1" true (of_int (x lsl 3) = shift_left one_x 3);
|
||||||
|
check_bool "shift_left2" true (of_z (Z.shift_left z 3) = shift_left many_x 3);
|
||||||
|
check_bool "shift_left3" true (of_z (Z.shift_left z 100) = shift_left many_x 100);
|
||||||
|
check_bool "shift_right1" true (of_int (x lsr 3) = shift_right one_x 3);
|
||||||
|
check_bool "shift_right2" true (of_z (Z.shift_right z 3) = shift_right many_x 3);
|
||||||
|
check_bool "shift_left_one1" true (of_int (1 lsl 3) = shift_left_one 4 3);
|
||||||
|
check_bool "shift_left_one2" true (of_z (Z.shift_left Z.one 200) = shift_left_one 300 200);
|
||||||
check_bool "testbit1" true (testbit (of_int 8) 3);
|
check_bool "testbit1" true (testbit (of_int 8) 3);
|
||||||
check_bool "testbit2" false (testbit (of_int 8) 2);
|
check_bool "testbit2" false (testbit (of_int 8) 2);
|
||||||
check_bool "testbit3" false (testbit (of_int 8) 4);
|
check_bool "testbit3" false (testbit (of_int 8) 4);
|
||||||
@ -280,44 +274,22 @@ let logor a b =
|
|||||||
| One a, One b -> One (One.logor a b)
|
| One a, One b -> One (One.logor a b)
|
||||||
| Many a, Many b -> Many (Many.logor a b)
|
| Many a, Many b -> Many (Many.logor a b)
|
||||||
| _ -> invalid_arg "Bitstring.logor"
|
| _ -> invalid_arg "Bitstring.logor"
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "logor1" true (of_int (1 lor 2) = logor (of_int 1) (of_int 2));
|
|
||||||
check_bool "logor2" true (of_z (Z.of_int (1 lor 2)) = logor (of_z Z.one) (of_z (Z.of_int 2)));
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let logxor a b =
|
let logxor a b =
|
||||||
match a,b with
|
match a,b with
|
||||||
| One a, One b -> One (One.logxor a b)
|
| One a, One b -> One (One.logxor a b)
|
||||||
| Many a, Many b -> Many (Many.logxor a b)
|
| Many a, Many b -> Many (Many.logxor a b)
|
||||||
| _ -> invalid_arg "Bitstring.logxor"
|
| _ -> invalid_arg "Bitstring.logxor"
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "logxor1" true (of_int (1 lxor 2) = logxor (of_int 1) (of_int 2));
|
|
||||||
check_bool "logxor2" true (of_z (Z.of_int (1 lxor 2)) = logxor (of_z Z.one) (of_z (Z.of_int 2)));
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let logand a b =
|
let logand a b =
|
||||||
match a,b with
|
match a,b with
|
||||||
| One a, One b -> One (One.logand a b)
|
| One a, One b -> One (One.logand a b)
|
||||||
| Many a, Many b -> Many (Many.logand a b)
|
| Many a, Many b -> Many (Many.logand a b)
|
||||||
| _ -> invalid_arg "Bitstring.logand"
|
| _ -> invalid_arg "Bitstring.logand"
|
||||||
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
|
||||||
check_bool "logand1" true (of_int (1 land 3) = logand (of_int 1) (of_int 3));
|
|
||||||
check_bool "logand2" true (of_z (Z.of_int (1 land 3)) = logand (of_z Z.one) (of_z (Z.of_int 3)));
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let lognot = function
|
let lognot = function
|
||||||
| One x -> One (One.lognot x)
|
| One x -> One (One.lognot x)
|
||||||
| Many x -> Many (Many.lognot x)
|
| Many x -> Many (Many.lognot x)
|
||||||
@ -325,42 +297,65 @@ let lognot = function
|
|||||||
|
|
||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
minus_one (of_int 10) = of_int 9
|
Bitstring.(logor (of_int 15) (of_int 73));;
|
||||||
|
- : Bitstring.t =
|
||||||
|
++++--+---------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.(logand (of_int 15) (of_int 10));;
|
||||||
|
- : Bitstring.t =
|
||||||
|
-+-+------------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.(logxor (of_int 15) (of_int 73));;
|
||||||
|
- : Bitstring.t =
|
||||||
|
-++---+---------------------------------------------------------
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
|
|
||||||
|
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
||||||
|
check_bool "logor1" true (of_int (1 lor 2) = logor (of_int 1) (of_int 2));
|
||||||
|
check_bool "logor2" true (of_z (Z.of_int (1 lor 2)) = logor (of_z Z.one) (of_z (Z.of_int 2)));
|
||||||
|
check_bool "logxor1" true (of_int (1 lxor 2) = logxor (of_int 1) (of_int 2));
|
||||||
|
check_bool "logxor2" true (of_z (Z.of_int (1 lxor 2)) = logxor (of_z Z.one) (of_z (Z.of_int 2)));
|
||||||
|
check_bool "logand1" true (of_int (1 land 3) = logand (of_int 1) (of_int 3));
|
||||||
|
check_bool "logand2" true (of_z (Z.of_int (1 land 3)) = logand (of_z Z.one) (of_z (Z.of_int 3)));
|
||||||
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
let minus_one = function
|
let minus_one = function
|
||||||
| One x -> One (One.minus_one x)
|
| One x -> One (One.minus_one x)
|
||||||
| Many x -> Many (Many.minus_one x)
|
| Many x -> Many (Many.minus_one x)
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_example
|
|
||||||
plus_one (of_int 10) = of_int 11
|
|
||||||
#+end_example
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let plus_one = function
|
let plus_one = function
|
||||||
| One x -> One (One.plus_one x)
|
| One x -> One (One.plus_one x)
|
||||||
| Many x -> Many (Many.plus_one x)
|
| Many x -> Many (Many.plus_one x)
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
|
#+begin_example
|
||||||
|
Bitstring.(plus_one (of_int 15));;
|
||||||
|
- : Bitstring.t =
|
||||||
|
----+-----------------------------------------------------------
|
||||||
|
|
||||||
|
Bitstring.(minus_one (of_int 15));;
|
||||||
|
- : Bitstring.t =
|
||||||
|
-+++------------------------------------------------------------
|
||||||
|
#+end_example
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
let trailing_zeros = function
|
let trailing_zeros = function
|
||||||
| One x -> One.trailing_zeros x
|
| One x -> One.trailing_zeros x
|
||||||
| Many x -> Many.trailing_zeros x
|
| Many x -> Many.trailing_zeros x
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let hamdist a b = match a, b with
|
let hamdist a b = match a, b with
|
||||||
| One a, One b -> One.hamdist a b
|
| One a, One b -> One.hamdist a b
|
||||||
| Many a, Many b -> Many.hamdist a b
|
| Many a, Many b -> Many.hamdist a b
|
||||||
| _ -> invalid_arg "Bitstring.hamdist"
|
| _ -> invalid_arg "Bitstring.hamdist"
|
||||||
#+end_src
|
|
||||||
|
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
|
||||||
let popcount = function
|
let popcount = function
|
||||||
| One x -> One.popcount x
|
| One x -> One.popcount x
|
||||||
| Many x -> Many.popcount x
|
| Many x -> Many.popcount x
|
||||||
@ -368,8 +363,14 @@ let popcount = function
|
|||||||
|
|
||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Bitstring.to_list (of_int 5);;
|
Bitstring.(trailing_zeros (of_int 12));;
|
||||||
- : int list = [1; 3]
|
- : int = 2
|
||||||
|
|
||||||
|
Bitstring.(hamdist (of_int 15) (of_int 73));;
|
||||||
|
- : int = 3
|
||||||
|
|
||||||
|
Bitstring.(popcount (of_int 15));;
|
||||||
|
- : int = 4
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
@ -387,15 +388,8 @@ check_bool "to_list" true ([ 1 ; 3 ; 4 ; 6 ] = (to_list (of_int 45)));
|
|||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Bitstring.permutations 2 4
|
Bitstring.(to_list (of_int 45));;
|
||||||
|> List.map (fun x -> Format.asprintf "%a" Bitstring.pp x) ;;
|
- : int list = [1; 3; 4; 6]
|
||||||
- : string list =
|
|
||||||
["++--------------------------------------------------------------";
|
|
||||||
"+-+-------------------------------------------------------------";
|
|
||||||
"-++-------------------------------------------------------------";
|
|
||||||
"+--+------------------------------------------------------------";
|
|
||||||
"-+-+------------------------------------------------------------";
|
|
||||||
"--++------------------------------------------------------------"]
|
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval ml) :exports none
|
#+begin_src ocaml :tangle (eval ml) :exports none
|
||||||
@ -418,6 +412,17 @@ let permutations m n =
|
|||||||
aux (Util.binom n m) (minus_one (shift_left_one n m)) []
|
aux (Util.binom n m) (minus_one (shift_left_one n m)) []
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
#+begin_example
|
||||||
|
Bitstring.permutations 2 4;;
|
||||||
|
- : Bitstring.t list =
|
||||||
|
[++--------------------------------------------------------------;
|
||||||
|
+-+-------------------------------------------------------------;
|
||||||
|
-++-------------------------------------------------------------;
|
||||||
|
+--+------------------------------------------------------------;
|
||||||
|
-+-+------------------------------------------------------------;
|
||||||
|
--++------------------------------------------------------------]
|
||||||
|
#+end_example
|
||||||
|
|
||||||
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
#+begin_src ocaml :tangle (eval test-ml) :exports none
|
||||||
check "permutations"
|
check "permutations"
|
||||||
(permutations 2 4 = List.map of_int
|
(permutations 2 4 = List.map of_int
|
||||||
|
@ -111,7 +111,7 @@ val ( |- ) : t -> t -> t
|
|||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Coordinate.neg { x=1. ; y=2. ; z=3. } ;;
|
Coordinate.neg { x=1. ; y=2. ; z=3. } ;;
|
||||||
- : Coordinate.t = {Qcaml.Common.Coordinate.x = -1.; y = -2.; z = -3.}
|
- : Coordinate.t = -1.0000 -2.0000 -3.0000
|
||||||
|
|
||||||
Coordinate.(get Y { x=1. ; y=2. ; z=3. }) ;;
|
Coordinate.(get Y { x=1. ; y=2. ; z=3. }) ;;
|
||||||
- : float = 2.
|
- : float = 2.
|
||||||
@ -119,17 +119,17 @@ Coordinate.(get Y { x=1. ; y=2. ; z=3. }) ;;
|
|||||||
Coordinate.(
|
Coordinate.(
|
||||||
2. |. { x=1. ; y=2. ; z=3. }
|
2. |. { x=1. ; y=2. ; z=3. }
|
||||||
) ;;
|
) ;;
|
||||||
- : Coordinate.t = {Qcaml.Common.Coordinate.x = 2.; y = 4.; z = 6.}
|
- : Coordinate.t = 2.0000 4.0000 6.0000
|
||||||
|
|
||||||
Coordinate.(
|
Coordinate.(
|
||||||
{ x=1. ; y=2. ; z=3. } |+ { x=2. ; y=3. ; z=1. }
|
{ x=1. ; y=2. ; z=3. } |+ { x=2. ; y=3. ; z=1. }
|
||||||
);;
|
);;
|
||||||
- : Coordinate.t = {Qcaml.Common.Coordinate.x = 3.; y = 5.; z = 4.}
|
- : Coordinate.t = 3.0000 5.0000 4.0000
|
||||||
|
|
||||||
Coordinate.(
|
Coordinate.(
|
||||||
{ x=1. ; y=2. ; z=3. } |- { x=2. ; y=3. ; z=1. }
|
{ x=1. ; y=2. ; z=3. } |- { x=2. ; y=3. ; z=1. }
|
||||||
);;
|
);;
|
||||||
- : Coordinate.t = {Qcaml.Common.Coordinate.x = -1.; y = -1.; z = 2.}
|
- : Coordinate.t = -1.0000 -1.0000 2.0000
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,13 +33,13 @@ open Powers
|
|||||||
*
|
*
|
||||||
* #+begin_example
|
* #+begin_example
|
||||||
* Angular_momentum.of_char 'p';;
|
* Angular_momentum.of_char 'p';;
|
||||||
* - : Angular_momentum.t = Qcaml.Common.Angular_momentum.P
|
* - : Angular_momentum.t = P
|
||||||
*
|
*
|
||||||
* Angular_momentum.(to_char P);;
|
* Angular_momentum.(to_char P);;
|
||||||
* - : char = 'P'
|
* - : char = 'P'
|
||||||
*
|
*
|
||||||
* Angular_momentum.of_int 2;;
|
* Angular_momentum.of_int 2;;
|
||||||
* - : Angular_momentum.t = Qcaml.Common.Angular_momentum.D
|
* - : Angular_momentum.t = D
|
||||||
*
|
*
|
||||||
* Angular_momentum.(to_int D);;
|
* Angular_momentum.(to_int D);;
|
||||||
* - : int = 2
|
* - : int = 2
|
||||||
@ -111,10 +111,9 @@ let of_int = function
|
|||||||
*
|
*
|
||||||
* Angular_momentum.( zkey_array (Doublet (P,S)) );;
|
* Angular_momentum.( zkey_array (Doublet (P,S)) );;
|
||||||
* - : Zkey.t array =
|
* - : Zkey.t array =
|
||||||
* [| {Zkey.left = 0; right = 1125899906842624} ;
|
* [|< 01125899906842624 | 1, 0, 0, 0, 0, 0 >;
|
||||||
* {Zkey.left = 0; right = 1099511627776} ;
|
* < 01099511627776 | 0, 1, 0, 0, 0, 0 >;
|
||||||
* {Zkey.left = 0; right = 1073741824} |]
|
* < 01073741824 | 0, 0, 1, 0, 0, 0 >|]
|
||||||
*
|
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
@ -207,10 +206,10 @@ let zkey_array a =
|
|||||||
|
|
||||||
(* #+begin_example
|
(* #+begin_example
|
||||||
* Angular_momentum.(D + P);;
|
* Angular_momentum.(D + P);;
|
||||||
* - : Angular_momentum.t = Qcaml.Common.Angular_momentum.F
|
* - : Angular_momentum.t = F
|
||||||
*
|
*
|
||||||
* Angular_momentum.(F - P);;
|
* Angular_momentum.(F - P);;
|
||||||
* - : Angular_momentum.t = Qcaml.Common.Angular_momentum.D
|
* - : Angular_momentum.t = D
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
@ -107,147 +107,145 @@ type t =
|
|||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:2]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:2]] *)
|
||||||
let of_int x =
|
let of_int x =
|
||||||
One (One.of_int x)
|
One (One.of_int x)
|
||||||
(* General implementation:2 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:4]] *)
|
|
||||||
let of_z x =
|
let of_z x =
|
||||||
if Z.numbits x < 64 then One (Z.to_int x) else Many (Many.of_z x)
|
if Z.numbits x < 64 then One (Z.to_int x) else Many (Many.of_z x)
|
||||||
(* General implementation:4 ends here *)
|
(* General implementation:2 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:6]] *)
|
|
||||||
|
|
||||||
|
(* #+begin_example
|
||||||
|
* Bitstring.of_int 15;;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* ++++------------------------------------------------------------
|
||||||
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:4]] *)
|
||||||
let zero = function
|
let zero = function
|
||||||
| n when n < 64 -> One (One.zero)
|
| n when n < 64 -> One (One.zero)
|
||||||
| _ -> Many (Many.zero)
|
| _ -> Many (Many.zero)
|
||||||
(* General implementation:6 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:7]] *)
|
|
||||||
let numbits = function
|
let numbits = function
|
||||||
| One x -> One.numbits x
|
| One x -> One.numbits x
|
||||||
| Many x -> Many.numbits x
|
| Many x -> Many.numbits x
|
||||||
(* General implementation:7 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:8]] *)
|
|
||||||
let is_zero = function
|
let is_zero = function
|
||||||
| One x -> One.is_zero x
|
| One x -> One.is_zero x
|
||||||
| Many x -> Many.is_zero x
|
| Many x -> Many.is_zero x
|
||||||
(* General implementation:8 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:9]] *)
|
|
||||||
let neg = function
|
let neg = function
|
||||||
| One x -> One (One.neg x)
|
| One x -> One (One.neg x)
|
||||||
| Many x -> Many (Many.neg x)
|
| Many x -> Many (Many.neg x)
|
||||||
(* General implementation:9 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:10]] *)
|
|
||||||
let shift_left x i = match x with
|
let shift_left x i = match x with
|
||||||
| One x -> One (One.shift_left x i)
|
| One x -> One (One.shift_left x i)
|
||||||
| Many x -> Many (Many.shift_left x i)
|
| Many x -> Many (Many.shift_left x i)
|
||||||
(* General implementation:10 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:12]] *)
|
|
||||||
let shift_right x i = match x with
|
let shift_right x i = match x with
|
||||||
| One x -> One (One.shift_right x i)
|
| One x -> One (One.shift_right x i)
|
||||||
| Many x -> Many (Many.shift_right x i)
|
| Many x -> Many (Many.shift_right x i)
|
||||||
(* General implementation:12 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:14]] *)
|
|
||||||
let shift_left_one = function
|
let shift_left_one = function
|
||||||
| n when n < 64 -> fun i -> One (One.shift_left_one i)
|
| n when n < 64 -> fun i -> One (One.shift_left_one i)
|
||||||
| _ -> fun i -> Many (Many.shift_left_one i)
|
| _ -> fun i -> Many (Many.shift_left_one i)
|
||||||
(* General implementation:14 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:16]] *)
|
|
||||||
let testbit = function
|
let testbit = function
|
||||||
| One x -> One.testbit x
|
| One x -> One.testbit x
|
||||||
| Many x -> Many.testbit x
|
| Many x -> Many.testbit x
|
||||||
(* General implementation:16 ends here *)
|
(* General implementation:4 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:18]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:6]] *)
|
||||||
let logor a b =
|
let logor a b =
|
||||||
match a,b with
|
match a,b with
|
||||||
| One a, One b -> One (One.logor a b)
|
| One a, One b -> One (One.logor a b)
|
||||||
| Many a, Many b -> Many (Many.logor a b)
|
| Many a, Many b -> Many (Many.logor a b)
|
||||||
| _ -> invalid_arg "Bitstring.logor"
|
| _ -> invalid_arg "Bitstring.logor"
|
||||||
(* General implementation:18 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:20]] *)
|
|
||||||
let logxor a b =
|
let logxor a b =
|
||||||
match a,b with
|
match a,b with
|
||||||
| One a, One b -> One (One.logxor a b)
|
| One a, One b -> One (One.logxor a b)
|
||||||
| Many a, Many b -> Many (Many.logxor a b)
|
| Many a, Many b -> Many (Many.logxor a b)
|
||||||
| _ -> invalid_arg "Bitstring.logxor"
|
| _ -> invalid_arg "Bitstring.logxor"
|
||||||
(* General implementation:20 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:22]] *)
|
|
||||||
let logand a b =
|
let logand a b =
|
||||||
match a,b with
|
match a,b with
|
||||||
| One a, One b -> One (One.logand a b)
|
| One a, One b -> One (One.logand a b)
|
||||||
| Many a, Many b -> Many (Many.logand a b)
|
| Many a, Many b -> Many (Many.logand a b)
|
||||||
| _ -> invalid_arg "Bitstring.logand"
|
| _ -> invalid_arg "Bitstring.logand"
|
||||||
(* General implementation:22 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:24]] *)
|
|
||||||
let lognot = function
|
let lognot = function
|
||||||
| One x -> One (One.lognot x)
|
| One x -> One (One.lognot x)
|
||||||
| Many x -> Many (Many.lognot x)
|
| Many x -> Many (Many.lognot x)
|
||||||
(* General implementation:24 ends here *)
|
(* General implementation:6 ends here *)
|
||||||
|
|
||||||
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:8]] *)
|
||||||
|
|
||||||
|
|
||||||
(* #+begin_example
|
|
||||||
* minus_one (of_int 10) = of_int 9
|
|
||||||
* #+end_example *)
|
|
||||||
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:25]] *)
|
|
||||||
let minus_one = function
|
let minus_one = function
|
||||||
| One x -> One (One.minus_one x)
|
| One x -> One (One.minus_one x)
|
||||||
| Many x -> Many (Many.minus_one x)
|
| Many x -> Many (Many.minus_one x)
|
||||||
(* General implementation:25 ends here *)
|
|
||||||
|
|
||||||
|
let plus_one = function
|
||||||
|
| One x -> One (One.plus_one x)
|
||||||
|
| Many x -> Many (Many.plus_one x)
|
||||||
|
(* General implementation:8 ends here *)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(* #+begin_example
|
(* #+begin_example
|
||||||
* plus_one (of_int 10) = of_int 11
|
* Bitstring.(plus_one (of_int 15));;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* ----+-----------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.(minus_one (of_int 15));;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* -+++------------------------------------------------------------
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:26]] *)
|
|
||||||
let plus_one = function
|
|
||||||
| One x -> One (One.plus_one x)
|
|
||||||
| Many x -> Many (Many.plus_one x)
|
|
||||||
(* General implementation:26 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:27]] *)
|
|
||||||
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:9]] *)
|
||||||
let trailing_zeros = function
|
let trailing_zeros = function
|
||||||
| One x -> One.trailing_zeros x
|
| One x -> One.trailing_zeros x
|
||||||
| Many x -> Many.trailing_zeros x
|
| Many x -> Many.trailing_zeros x
|
||||||
(* General implementation:27 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:28]] *)
|
|
||||||
let hamdist a b = match a, b with
|
let hamdist a b = match a, b with
|
||||||
| One a, One b -> One.hamdist a b
|
| One a, One b -> One.hamdist a b
|
||||||
| Many a, Many b -> Many.hamdist a b
|
| Many a, Many b -> Many.hamdist a b
|
||||||
| _ -> invalid_arg "Bitstring.hamdist"
|
| _ -> invalid_arg "Bitstring.hamdist"
|
||||||
(* General implementation:28 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:29]] *)
|
|
||||||
let popcount = function
|
let popcount = function
|
||||||
| One x -> One.popcount x
|
| One x -> One.popcount x
|
||||||
| Many x -> Many.popcount x
|
| Many x -> Many.popcount x
|
||||||
(* General implementation:29 ends here *)
|
(* General implementation:9 ends here *)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(* #+begin_example
|
(* #+begin_example
|
||||||
* Bitstring.to_list (of_int 5);;
|
* Bitstring.(trailing_zeros (of_int 12));;
|
||||||
* - : int list = [1; 3]
|
* - : int = 2
|
||||||
|
*
|
||||||
|
* Bitstring.(hamdist (of_int 15) (of_int 73));;
|
||||||
|
* - : int = 3
|
||||||
|
*
|
||||||
|
* Bitstring.(popcount (of_int 15));;
|
||||||
|
* - : int = 4
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:30]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:10]] *)
|
||||||
let rec to_list ?(accu=[]) = function
|
let rec to_list ?(accu=[]) = function
|
||||||
| t when (is_zero t) -> List.rev accu
|
| t when (is_zero t) -> List.rev accu
|
||||||
| t -> let newlist =
|
| t -> let newlist =
|
||||||
@ -255,24 +253,17 @@ let rec to_list ?(accu=[]) = function
|
|||||||
in
|
in
|
||||||
logand t @@ minus_one t
|
logand t @@ minus_one t
|
||||||
|> (to_list [@tailcall]) ~accu:newlist
|
|> (to_list [@tailcall]) ~accu:newlist
|
||||||
(* General implementation:30 ends here *)
|
(* General implementation:10 ends here *)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(* #+begin_example
|
(* #+begin_example
|
||||||
* Bitstring.permutations 2 4
|
* Bitstring.(to_list (of_int 45));;
|
||||||
* |> List.map (fun x -> Format.asprintf "%a" Bitstring.pp x) ;;
|
* - : int list = [1; 3; 4; 6]
|
||||||
* - : string list =
|
|
||||||
* ["++--------------------------------------------------------------";
|
|
||||||
* "+-+-------------------------------------------------------------";
|
|
||||||
* "-++-------------------------------------------------------------";
|
|
||||||
* "+--+------------------------------------------------------------";
|
|
||||||
* "-+-+------------------------------------------------------------";
|
|
||||||
* "--++------------------------------------------------------------"]
|
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:32]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:12]] *)
|
||||||
let permutations m n =
|
let permutations m n =
|
||||||
|
|
||||||
let rec aux k u rest =
|
let rec aux k u rest =
|
||||||
@ -290,7 +281,7 @@ let permutations m n =
|
|||||||
(aux [@tailcall]) (k-1) (logor t' t'') (u :: rest)
|
(aux [@tailcall]) (k-1) (logor t' t'') (u :: rest)
|
||||||
in
|
in
|
||||||
aux (Util.binom n m) (minus_one (shift_left_one n m)) []
|
aux (Util.binom n m) (minus_one (shift_left_one n m)) []
|
||||||
(* General implementation:32 ends here *)
|
(* General implementation:12 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*Printers][Printers:2]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*Printers][Printers:2]] *)
|
||||||
let pp ppf = function
|
let pp ppf = function
|
||||||
|
@ -63,7 +63,7 @@ let angstrom_to_bohr { x ; y ; z } =
|
|||||||
*
|
*
|
||||||
* #+begin_example
|
* #+begin_example
|
||||||
* Coordinate.neg { x=1. ; y=2. ; z=3. } ;;
|
* Coordinate.neg { x=1. ; y=2. ; z=3. } ;;
|
||||||
* - : Coordinate.t = {Qcaml.Common.Coordinate.x = -1.; y = -2.; z = -3.}
|
* - : Coordinate.t = -1.0000 -2.0000 -3.0000
|
||||||
*
|
*
|
||||||
* Coordinate.(get Y { x=1. ; y=2. ; z=3. }) ;;
|
* Coordinate.(get Y { x=1. ; y=2. ; z=3. }) ;;
|
||||||
* - : float = 2.
|
* - : float = 2.
|
||||||
@ -71,17 +71,17 @@ let angstrom_to_bohr { x ; y ; z } =
|
|||||||
* Coordinate.(
|
* Coordinate.(
|
||||||
* 2. |. { x=1. ; y=2. ; z=3. }
|
* 2. |. { x=1. ; y=2. ; z=3. }
|
||||||
* ) ;;
|
* ) ;;
|
||||||
* - : Coordinate.t = {Qcaml.Common.Coordinate.x = 2.; y = 4.; z = 6.}
|
* - : Coordinate.t = 2.0000 4.0000 6.0000
|
||||||
*
|
*
|
||||||
* Coordinate.(
|
* Coordinate.(
|
||||||
* { x=1. ; y=2. ; z=3. } |+ { x=2. ; y=3. ; z=1. }
|
* { x=1. ; y=2. ; z=3. } |+ { x=2. ; y=3. ; z=1. }
|
||||||
* );;
|
* );;
|
||||||
* - : Coordinate.t = {Qcaml.Common.Coordinate.x = 3.; y = 5.; z = 4.}
|
* - : Coordinate.t = 3.0000 5.0000 4.0000
|
||||||
*
|
*
|
||||||
* Coordinate.(
|
* Coordinate.(
|
||||||
* { x=1. ; y=2. ; z=3. } |- { x=2. ; y=3. ; z=1. }
|
* { x=1. ; y=2. ; z=3. } |- { x=2. ; y=3. ; z=1. }
|
||||||
* );;
|
* );;
|
||||||
* - : Coordinate.t = {Qcaml.Common.Coordinate.x = -1.; y = -1.; z = 2.}
|
* - : Coordinate.t = -1.0000 -1.0000 2.0000
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ type t = {
|
|||||||
|
|
||||||
(* #+begin_example
|
(* #+begin_example
|
||||||
* Powers.of_int_tuple (2,3,1);;
|
* Powers.of_int_tuple (2,3,1);;
|
||||||
* - : Powers.t = {Qcaml.Common.Powers.x = 2; y = 3; z = 1; tot = 6}
|
* - : Powers.t = x^2 + y^3 + z^1
|
||||||
*
|
*
|
||||||
* Powers.(to_int_tuple (of_int_tuple (2,3,1)));;
|
* Powers.(to_int_tuple (of_int_tuple (2,3,1)));;
|
||||||
* - : int * int * int = (2, 3, 1)
|
* - : int * int * int = (2, 3, 1)
|
||||||
@ -51,10 +51,10 @@ let to_int_tuple { x ; y ; z ; _ } = (x,y,z)
|
|||||||
* - : int = 3
|
* - : int = 3
|
||||||
*
|
*
|
||||||
* Powers.incr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
* Powers.incr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
||||||
* - : Powers.t = {Qcaml.Common.Powers.x = 2; y = 4; z = 1; tot = 7}
|
* - : Powers.t = x^2 + y^4 + z^1
|
||||||
*
|
*
|
||||||
* Powers.decr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
* Powers.decr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
||||||
* - : Powers.t = {Qcaml.Common.Powers.x = 2; y = 2; z = 1; tot = 5}
|
* - : Powers.t = x^2 + y^2 + z^1
|
||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ val to_int_tuple : t -> int * int * int
|
|||||||
|
|
||||||
#+begin_example
|
#+begin_example
|
||||||
Powers.of_int_tuple (2,3,1);;
|
Powers.of_int_tuple (2,3,1);;
|
||||||
- : Powers.t = {Qcaml.Common.Powers.x = 2; y = 3; z = 1; tot = 6}
|
- : Powers.t = x^2 + y^3 + z^1
|
||||||
|
|
||||||
Powers.(to_int_tuple (of_int_tuple (2,3,1)));;
|
Powers.(to_int_tuple (of_int_tuple (2,3,1)));;
|
||||||
- : int * int * int = (2, 3, 1)
|
- : int * int * int = (2, 3, 1)
|
||||||
@ -87,10 +87,10 @@ Powers.get Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
|||||||
- : int = 3
|
- : int = 3
|
||||||
|
|
||||||
Powers.incr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
Powers.incr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
||||||
- : Powers.t = {Qcaml.Common.Powers.x = 2; y = 4; z = 1; tot = 7}
|
- : Powers.t = x^2 + y^4 + z^1
|
||||||
|
|
||||||
Powers.decr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
Powers.decr Coordinate.Y (Powers.of_int_tuple (2,3,1));;
|
||||||
- : Powers.t = {Qcaml.Common.Powers.x = 2; y = 2; z = 1; tot = 5}
|
- : Powers.t = x^2 + y^2 + z^1
|
||||||
#+end_example
|
#+end_example
|
||||||
|
|
||||||
|
|
||||||
|
@ -14,61 +14,99 @@ let test_all () =
|
|||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:3]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:3]] *)
|
||||||
check_bool "of_x" true (one_x = (of_int x));
|
check_bool "of_x" true (one_x = (of_int x));
|
||||||
|
check_bool "of_z" true (one_x = (of_z (Z.of_int x)));
|
||||||
(* General implementation:3 ends here *)
|
(* General implementation:3 ends here *)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(* #+begin_example
|
||||||
|
* Bitstring.(shift_left (of_int 15) 2);;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* --++++----------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.(shift_right (of_int 15) 2);;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* ++--------------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.shift_left_one 32 4;;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* ----+-----------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.(testbit (of_int 15) 3);;
|
||||||
|
* - : bool = true
|
||||||
|
*
|
||||||
|
* Bitstring.(testbit (of_int 15) 4);;
|
||||||
|
* - : bool = false
|
||||||
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:5]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:5]] *)
|
||||||
check_bool "of_z" true (one_x = (of_z (Z.of_int x)));
|
check_bool "shift_left1" true (of_int (x lsl 3) = shift_left one_x 3);
|
||||||
(* General implementation:5 ends here *)
|
check_bool "shift_left2" true (of_z (Z.shift_left z 3) = shift_left many_x 3);
|
||||||
|
check_bool "shift_left3" true (of_z (Z.shift_left z 100) = shift_left many_x 100);
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:11]] *)
|
check_bool "shift_right1" true (of_int (x lsr 3) = shift_right one_x 3);
|
||||||
check_bool "shift_left1" true (of_int (x lsl 3) = shift_left one_x 3);
|
check_bool "shift_right2" true (of_z (Z.shift_right z 3) = shift_right many_x 3);
|
||||||
check_bool "shift_left2" true (of_z (Z.shift_left z 3) = shift_left many_x 3);
|
|
||||||
check_bool "shift_left3" true (of_z (Z.shift_left z 100) = shift_left many_x 100);
|
|
||||||
(* General implementation:11 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:13]] *)
|
|
||||||
check_bool "shift_right1" true (of_int (x lsr 3) = shift_right one_x 3);
|
|
||||||
check_bool "shift_right2" true (of_z (Z.shift_right z 3) = shift_right many_x 3);
|
|
||||||
(* General implementation:13 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:15]] *)
|
|
||||||
check_bool "shift_left_one1" true (of_int (1 lsl 3) = shift_left_one 4 3);
|
check_bool "shift_left_one1" true (of_int (1 lsl 3) = shift_left_one 4 3);
|
||||||
check_bool "shift_left_one2" true (of_z (Z.shift_left Z.one 200) = shift_left_one 300 200);
|
check_bool "shift_left_one2" true (of_z (Z.shift_left Z.one 200) = shift_left_one 300 200);
|
||||||
(* General implementation:15 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:17]] *)
|
|
||||||
check_bool "testbit1" true (testbit (of_int 8) 3);
|
check_bool "testbit1" true (testbit (of_int 8) 3);
|
||||||
check_bool "testbit2" false (testbit (of_int 8) 2);
|
check_bool "testbit2" false (testbit (of_int 8) 2);
|
||||||
check_bool "testbit3" false (testbit (of_int 8) 4);
|
check_bool "testbit3" false (testbit (of_int 8) 4);
|
||||||
check_bool "testbit4" true (testbit (of_z (Z.of_int 8)) 3);
|
check_bool "testbit4" true (testbit (of_z (Z.of_int 8)) 3);
|
||||||
check_bool "testbit5" false (testbit (of_z (Z.of_int 8)) 2);
|
check_bool "testbit5" false (testbit (of_z (Z.of_int 8)) 2);
|
||||||
check_bool "testbit6" false (testbit (of_z (Z.of_int 8)) 4);
|
check_bool "testbit6" false (testbit (of_z (Z.of_int 8)) 4);
|
||||||
(* General implementation:17 ends here *)
|
(* General implementation:5 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:19]] *)
|
|
||||||
|
|
||||||
|
|
||||||
|
(* #+begin_example
|
||||||
|
* Bitstring.(logor (of_int 15) (of_int 73));;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* ++++--+---------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.(logand (of_int 15) (of_int 10));;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* -+-+------------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Bitstring.(logxor (of_int 15) (of_int 73));;
|
||||||
|
* - : Bitstring.t =
|
||||||
|
* -++---+---------------------------------------------------------
|
||||||
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:7]] *)
|
||||||
check_bool "logor1" true (of_int (1 lor 2) = logor (of_int 1) (of_int 2));
|
check_bool "logor1" true (of_int (1 lor 2) = logor (of_int 1) (of_int 2));
|
||||||
check_bool "logor2" true (of_z (Z.of_int (1 lor 2)) = logor (of_z Z.one) (of_z (Z.of_int 2)));
|
check_bool "logor2" true (of_z (Z.of_int (1 lor 2)) = logor (of_z Z.one) (of_z (Z.of_int 2)));
|
||||||
(* General implementation:19 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:21]] *)
|
|
||||||
check_bool "logxor1" true (of_int (1 lxor 2) = logxor (of_int 1) (of_int 2));
|
check_bool "logxor1" true (of_int (1 lxor 2) = logxor (of_int 1) (of_int 2));
|
||||||
check_bool "logxor2" true (of_z (Z.of_int (1 lxor 2)) = logxor (of_z Z.one) (of_z (Z.of_int 2)));
|
check_bool "logxor2" true (of_z (Z.of_int (1 lxor 2)) = logxor (of_z Z.one) (of_z (Z.of_int 2)));
|
||||||
(* General implementation:21 ends here *)
|
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:23]] *)
|
|
||||||
check_bool "logand1" true (of_int (1 land 3) = logand (of_int 1) (of_int 3));
|
check_bool "logand1" true (of_int (1 land 3) = logand (of_int 1) (of_int 3));
|
||||||
check_bool "logand2" true (of_z (Z.of_int (1 land 3)) = logand (of_z Z.one) (of_z (Z.of_int 3)));
|
check_bool "logand2" true (of_z (Z.of_int (1 land 3)) = logand (of_z Z.one) (of_z (Z.of_int 3)));
|
||||||
(* General implementation:23 ends here *)
|
(* General implementation:7 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:31]] *)
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:11]] *)
|
||||||
check_bool "to_list" true ([ 1 ; 3 ; 4 ; 6 ] = (to_list (of_int 45)));
|
check_bool "to_list" true ([ 1 ; 3 ; 4 ; 6 ] = (to_list (of_int 45)));
|
||||||
(* General implementation:31 ends here *)
|
(* General implementation:11 ends here *)
|
||||||
|
|
||||||
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:33]] *)
|
|
||||||
|
|
||||||
|
(* #+begin_example
|
||||||
|
* Bitstring.permutations 2 4;;
|
||||||
|
* - : Bitstring.t list =
|
||||||
|
* [++--------------------------------------------------------------;
|
||||||
|
* +-+-------------------------------------------------------------;
|
||||||
|
* -++-------------------------------------------------------------;
|
||||||
|
* +--+------------------------------------------------------------;
|
||||||
|
* -+-+------------------------------------------------------------;
|
||||||
|
* --++------------------------------------------------------------]
|
||||||
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
|
(* [[file:~/QCaml/common/bitstring.org::*General%20implementation][General implementation:13]] *)
|
||||||
check "permutations"
|
check "permutations"
|
||||||
(permutations 2 4 = List.map of_int
|
(permutations 2 4 = List.map of_int
|
||||||
[ 3 ; 5 ; 6 ; 9 ; 10 ; 12 ]);
|
[ 3 ; 5 ; 6 ; 9 ; 10 ; 12 ]);
|
||||||
(* General implementation:33 ends here *)
|
(* General implementation:13 ends here *)
|
||||||
|
|
||||||
(* Tests :noexport: *)
|
(* Tests :noexport: *)
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
(* [[file:../element.org::*Type][Type:2]] *)
|
(* [[file:~/QCaml/particles/element.org::*Type][Type:2]] *)
|
||||||
type t =
|
type t =
|
||||||
|X
|
|X
|
||||||
|H |He
|
|H |He
|
||||||
@ -41,7 +41,7 @@ open Common
|
|||||||
* #+end_example *)
|
* #+end_example *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:../element.org::*Conversion][Conversion:2]] *)
|
(* [[file:~/QCaml/particles/element.org::*Conversion][Conversion:2]] *)
|
||||||
let of_string x =
|
let of_string x =
|
||||||
match (String.capitalize_ascii (String.lowercase_ascii x)) with
|
match (String.capitalize_ascii (String.lowercase_ascii x)) with
|
||||||
| "X" | "Dummy" -> X | "H" | "Hydrogen" -> H
|
| "X" | "Dummy" -> X | "H" | "Hydrogen" -> H
|
||||||
@ -165,7 +165,7 @@ let of_charge c =
|
|||||||
* | ~large_core~ | Number of electrons in the large core model (all except the outermost shell) | *)
|
* | ~large_core~ | Number of electrons in the large core model (all except the outermost shell) | *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:../element.org::*Database information][Database information:2]] *)
|
(* [[file:~/QCaml/particles/element.org::*Database information][Database information:2]] *)
|
||||||
let covalent_radius x =
|
let covalent_radius x =
|
||||||
let result = function
|
let result = function
|
||||||
| X -> 0. | H -> 0.37 | He -> 0.70 | Li -> 1.23
|
| X -> 0. | H -> 0.37 | He -> 0.70 | Li -> 1.23
|
||||||
@ -266,7 +266,7 @@ let small_core t =
|
|||||||
|> loop
|
|> loop
|
||||||
(* Database information:2 ends here *)
|
(* Database information:2 ends here *)
|
||||||
|
|
||||||
(* [[file:../element.org::*Printers][Printers:2]] *)
|
(* [[file:~/QCaml/particles/element.org::*Printers][Printers:2]] *)
|
||||||
let pp ppf t =
|
let pp ppf t =
|
||||||
Format.fprintf ppf "@[%s@]" (to_string t)
|
Format.fprintf ppf "@[%s@]" (to_string t)
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
*
|
*
|
||||||
* #+NAME: types *)
|
* #+NAME: types *)
|
||||||
|
|
||||||
(* [[file:../element.org::types][types]] *)
|
(* [[file:~/QCaml/particles/element.org::types][types]] *)
|
||||||
type t =
|
type t =
|
||||||
|X
|
|X
|
||||||
|H |He
|
|H |He
|
||||||
@ -20,7 +20,7 @@ open Common
|
|||||||
(* Conversion *)
|
(* Conversion *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:../element.org::*Conversion][Conversion:1]] *)
|
(* [[file:~/QCaml/particles/element.org::*Conversion][Conversion:1]] *)
|
||||||
val of_string : string -> t
|
val of_string : string -> t
|
||||||
val to_string : t -> string
|
val to_string : t -> string
|
||||||
val to_long_string : t -> string
|
val to_long_string : t -> string
|
||||||
@ -35,7 +35,7 @@ val of_charge : Charge.t -> t
|
|||||||
(* Database information *)
|
(* Database information *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:../element.org::*Database information][Database information:1]] *)
|
(* [[file:~/QCaml/particles/element.org::*Database information][Database information:1]] *)
|
||||||
val covalent_radius : t -> Non_negative_float.t
|
val covalent_radius : t -> Non_negative_float.t
|
||||||
val vdw_radius : t -> Non_negative_float.t
|
val vdw_radius : t -> Non_negative_float.t
|
||||||
val mass : t -> Mass.t
|
val mass : t -> Mass.t
|
||||||
@ -46,7 +46,7 @@ val large_core : t -> int
|
|||||||
(* Printers *)
|
(* Printers *)
|
||||||
|
|
||||||
|
|
||||||
(* [[file:../element.org::*Printers][Printers:1]] *)
|
(* [[file:~/QCaml/particles/element.org::*Printers][Printers:1]] *)
|
||||||
val pp : Format.formatter -> t -> unit
|
val pp : Format.formatter -> t -> unit
|
||||||
val pp_long : Format.formatter -> t -> unit
|
val pp_long : Format.formatter -> t -> unit
|
||||||
(* Printers:1 ends here *)
|
(* Printers:1 ends here *)
|
||||||
|
@ -52,6 +52,7 @@ let rec install_printers = function
|
|||||||
eval_exn cmd && install_printers printers
|
eval_exn cmd && install_printers printers
|
||||||
|
|
||||||
let () =
|
let () =
|
||||||
|
eval_exn "#require \"lacaml.top\";;";
|
||||||
if not (install_printers printers) then
|
if not (install_printers printers) then
|
||||||
Format.eprintf "Problem installing QCaml-printers@."
|
Format.eprintf "Problem installing QCaml-printers@."
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ let rec install_printers = function
|
|||||||
eval_exn cmd && install_printers printers
|
eval_exn cmd && install_printers printers
|
||||||
|
|
||||||
let () =
|
let () =
|
||||||
|
eval_exn "#require \"lacaml.top\";;";
|
||||||
if not (install_printers printers) then
|
if not (install_printers printers) then
|
||||||
Format.eprintf "Problem installing QCaml-printers@."
|
Format.eprintf "Problem installing QCaml-printers@."
|
||||||
(* Intall printers:2 ends here *)
|
(* Intall printers:2 ends here *)
|
||||||
|
Loading…
Reference in New Issue
Block a user