10
1
mirror of https://gitlab.com/scemama/qmcchem.git synced 2025-01-05 02:48:36 +01:00

Removing core

This commit is contained in:
Anthony Scemama 2019-07-19 11:46:29 +02:00
parent 4c870cb62b
commit a719c694ce
3 changed files with 70 additions and 30 deletions

View File

@ -147,11 +147,12 @@ let raw_data ?(locked=true) () =
module StringSet = Set.Make(String)
let properties = lazy ( let properties = lazy (
List.fold_left (fun s x -> StringSet.add (Property.to_string x.property) s) StringSet.empty (raw_data ()) let h = Hashtbl.create 63 in
|> StringSet.elements List.iter (fun x ->
Hashtbl.add h (Property.to_string x.property) x.property)
(raw_data ());
Hashtbl.fold (fun k v a -> v :: a) h []
) )

View File

@ -565,7 +565,7 @@ let compress =
(** Last value on each compute node (for wall_time) *) (** Last value on each compute node (for wall_time) *)
let max_value_per_compute_node t = let max_value_per_compute_node t =
let table = String.Table.create () let table = Hashtbl.create 63
in in
let create_key block = let create_key block =
Printf.sprintf "%s %10.10d" Printf.sprintf "%s %10.10d"
@ -603,8 +603,8 @@ let max_value_per_compute_node t =
(** String representation *) (** String representation *)
let to_string p = let to_string p =
match p.property with match p.property with
| Property.Cpu -> Printf.sprintf "%s" (Time.Span.to_string (Time.Span.of_sec (sum p))) | Property.Cpu -> Printf.sprintf "%s" (Time.string_of_sec (sum p))
| Property.Wall -> Printf.sprintf "%s" (Time.Span.to_string (Time.Span.of_sec (sum (max_value_per_compute_node p)))) | Property.Wall -> Printf.sprintf "%s" (Time.string_of_sec (sum (max_value_per_compute_node p)))
| Property.Accep -> Printf.sprintf "%16.10f" (average p |> Average.to_float) | Property.Accep -> Printf.sprintf "%16.10f" (average p |> Average.to_float)
| _ -> | _ ->
begin begin
@ -667,17 +667,28 @@ let compress_files () =
Lazy.force dir_name Lazy.force dir_name
in in
let files = let files =
Sys.ls_dir dir_name Sys.readdir dir_name
|> Array.to_list
|> List.filter (fun x -> |> List.filter (fun x ->
match String.substr_index ~pattern:"locked" x with try
| Some x -> false Str.search_backward (Str.regexp "locked") x (String.length x) >= 0
| None -> true with
| Not_found -> true
) )
|> List.map (fun x -> dir_name^x) |> List.map (fun x -> dir_name^x)
in in
let out_channel_dir = let out_channel_dir =
Filename.temp_dir ~in_dir:(!Ezfio.ezfio_filename ^ "/blocks/") "qmc" "" let rand_num = Random.int 1000000 |> string_of_int in
let tmp_dir =
Filename.concat "!Ezfio.ezfio_filename" @@
Filename.concat "blocks" @@
Filename.concat "qmc" rand_num
in
try
Unix.mkdir tmp_dir 0o600;
tmp_dir
with _ -> raise (Sys_error "Cannot create temp dir")
in in
let out_channel_name = let out_channel_name =
@ -687,11 +698,12 @@ let compress_files () =
Unix.getpid () Unix.getpid ()
|> string_of_int |> string_of_int
in in
String.concat [ hostname ; "." ; suffix ] String.concat "." [ hostname ; suffix ]
in in
let block_channel = let block_channel =
Out_channel.create (out_channel_dir ^ out_channel_name) Filename.concat out_channel_dir out_channel_name
|> open_out
in in
List.iter (fun p -> List.iter (fun p ->
@ -709,14 +721,15 @@ let compress_files () =
|> merge_per_compute_node_and_block_id |> merge_per_compute_node_and_block_id
in in
List.iter (fun x -> List.iter (fun x ->
Out_channel.output_string block_channel (Block.to_string x); output_string block_channel (Block.to_string x);
Out_channel.output_char block_channel '\n'; output_char block_channel '\n';
) l.data ) l.data
) properties ; ) properties ;
Out_channel.close block_channel; close_out block_channel;
List.iter Unix.remove files ; List.iter Unix.unlink files ;
Unix.rename ~src:(out_channel_dir^out_channel_name) ~dst:(dir_name^out_channel_name); Unix.rename (Filename.concat out_channel_dir out_channel_name)
(Filename.concat dir_name out_channel_name);
Unix.rmdir out_channel_dir Unix.rmdir out_channel_dir
@ -738,7 +751,7 @@ let autocovariance { property ; data } =
if (i > 1) then (float_of_int i) else 1. if (i > 1) then (float_of_int i) else 1.
in in
let r = let r =
Array.sub 0 i x_t Array.sub x_t 0 i
|> Array.fold_left (fun accu x -> |> Array.fold_left (fun accu x ->
accu +. x *. x_t.(i)) 0. accu +. x *. x_t.(i)) 0.
in in
@ -756,7 +769,7 @@ let centered_cumulants { property ; data } =
|> Average.to_float |> Average.to_float
in in
let centered_data = let centered_data =
List.map ~f:(fun x -> List.map (fun x ->
( (Weight.to_float x.Block.weight), ( (Weight.to_float x.Block.weight),
(Sample.to_float x.Block.value) -. ave ) (Sample.to_float x.Block.value) -. ave )
) )
@ -764,20 +777,20 @@ let centered_cumulants { property ; data } =
in in
let var = let var =
let (num, denom) = let (num, denom) =
List.fold_left ~init:(0., 0.) ~f:(fun (a2, ad) (w,x) -> List.fold_left (fun (a2, ad) (w,x) ->
let x2 = x *. x let x2 = x *. x
in in
let var = w *. x2 let var = w *. x2
and den = w and den = w
in (a2 +. var, ad +. den) in (a2 +. var, ad +. den)
) centered_data ) (0., 0.) centered_data
in num /. denom in num /. denom
in in
let centered_data = let centered_data =
let sigma_inv = let sigma_inv =
1. /. (sqrt var) 1. /. (sqrt var)
in in
List.map ~f:(fun x -> List.map (fun x ->
( (Weight.to_float x.Block.weight), ( (Weight.to_float x.Block.weight),
( (Sample.to_float x.Block.value) -. ave ) *. sigma_inv ) ( (Sample.to_float x.Block.value) -. ave ) *. sigma_inv )
) )
@ -785,14 +798,14 @@ let centered_cumulants { property ; data } =
in in
let (cum3,cum4) = let (cum3,cum4) =
let (cum3, cum4, denom) = let (cum3, cum4, denom) =
List.fold_left ~init:(0., 0., 0.) ~f:(fun (a3, a4, ad) (w,x) -> List.fold_left (fun (a3, a4, ad) (w,x) ->
let x2 = x *. x let x2 = x *. x
in in
let cum3 = w *. x2 *. x let cum3 = w *. x2 *. x
and cum4 = w *. x2 *. x2 and cum4 = w *. x2 *. x2
and den = w and den = w
in (a3 +. cum3, a4 +. cum4, ad +. den) in (a3 +. cum3, a4 +. cum4, ad +. den)
) centered_data ) (0., 0., 0.) centered_data
in in
( cum3 /. denom, cum4 /. denom -. 3. ) ( cum3 /. denom, cum4 /. denom -. 3. )
in in
@ -817,9 +830,9 @@ let histogram { property ; data } =
let delta_x = let delta_x =
length /. (n-.1.) length /. (n-.1.)
and result = and result =
Array.init ~f:(fun _ -> 0.) (int_of_float (n +. 1.)) Array.init (int_of_float n + 1) (fun _ -> 0.)
in in
List.iter ~f:(fun x -> List.iter (fun x ->
let w = let w =
(Weight.to_float x.Block.weight) (Weight.to_float x.Block.weight)
and x = and x =
@ -834,10 +847,10 @@ let histogram { property ; data } =
; ;
let norm = let norm =
1. /. ( delta_x *. ( 1. /. ( delta_x *. (
Array.fold_left ~init:0. ~f:(fun accu x -> accu +. x) result Array.fold_left (fun accu x -> accu +. x) 0. result
) ) ) )
in in
Array.mapi ~f:(fun i x -> (min +. (float_of_int i)*.delta_x, x *. norm) ) result Array.mapi (fun i x -> (min +. (float_of_int i)*.delta_x, x *. norm) ) result
|> Array.to_list |> Array.to_list

26
ocaml/Time.ml Normal file
View File

@ -0,0 +1,26 @@
let of_sec s =
Unix.gmtime s
let to_sec t =
let sec = t.Unix.tm_sec
and min = t.Unix.tm_min
and hour = t.Unix.tm_hour
and mday = t.Unix.tm_mday
in
sec +
min * 60 +
hour * 60 * 60 +
mday * 60 * 60 * 24
let string_of_t t =
let mday = t.Unix.tm_mday in
let sec = t.Unix.tm_sec
and min = t.Unix.tm_min
and hour = t.Unix.tm_hour + 24*mday
in
Printf.sprintf "%2d:%2d:%2d" hour min sec
let string_of_sec s =
of_sec s
|> string_of_t