-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtexb2bs.ml
114 lines (91 loc) · 3.86 KB
/
texb2bs.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
open Common
open Getopt
open TeX
(* tabulate a b2b data as 4 tables *)
let takeDays' = ref (Some 33)
let dropDays' = ref (Some 7)
let latex' = ref false
let tableDoc' = ref false
let matrix' = ref true
let matrixDoc' = ref false
let summary' = ref true
let showTables'= ref true
let absNorm' = ref false
let rogue' = ref true
let outDir' = ref ""
let inputPath' = ref None (* input path to encode in the matrix' input statements *)
let masterLine'= ref true
let drop' = ref (Some "rbucks-aranks-caps-")
let scientific'= ref false (* stoggle cientific notation %e vs. %f *)
let precise' = ref false
let verbose' = ref false
let specs =
[
(noshort,"takedays",None,Some (fun x -> takeDays' := Some (int_of_string x)));
(noshort,"notakedays",(set takeDays' None),None);
(noshort,"dropdays",None,Some (fun x -> dropDays' := Some (int_of_string x)));
(noshort,"nodropdays",(set dropDays' None),None);
('t',"tex", (set latex' true), None);
('T',"tdoc", (set tableDoc' true), None);
('m',"matrix", (set matrix' true), None);
(noshort,"nomatrix",(set matrix' false), None);
('d',"mdoc", (set matrixDoc' true), None);
('s',"summary", (set summary' (not !summary')), None);
('S',"showTables",(set showTables' (not !showTables')), None);
('a',"absNorm", (set absNorm' true), None);
(noshort,"rogue", (set rogue' true), None);
(noshort,"norogue", (set rogue' false), None);
('o',"outdir", None, Some (fun x -> outDir' := x));
('i',"inputpath", None, Some (fun x -> inputPath' := Some x));
('L',"masterline",(set masterLine' (not !masterLine')),None);
('x',"drop", None, Some (fun x -> drop' := Some x));
('e',"scientific",(set scientific' (not !scientific')),None);
(noshort,"precise", (set precise' (not !precise')), None);
('v',"verbose", (set verbose' true), None)
]
let _ =
let args = getOptArgs specs in
let latex, tableDoc, matrix, matrixDoc, absNorm =
!latex', !tableDoc', !matrix', !matrixDoc', !absNorm' in
let outDir, inputPath, masterLine, drop, verbose =
!outDir', !inputPath', !masterLine', !drop', !verbose' in
let takeDays, dropDays, scientific, precise, rogue =
!takeDays', !dropDays', !scientific', !precise', !rogue' in
let summary, showTables =
!summary', !showTables' in
let tex,suffix,asWhat = texParams latex tableDoc in
let outDir = if String.is_empty outDir then suffix else outDir in
let mark = if absNorm then Some "abs" else Some "rel" in
let b2bName =
match args with
| x::[] -> x
| _ -> failwith "usage: texvols [-tTmd] b2bName"
in
let saveInfix, saveSuffix = saveBase ~mark ~drop suffix b2bName in
let roguePrefix =
if rogue
then
if absNorm then "srel"
else "sabs"
else "srev" in
let prefixes = ["befr";"self";"aftr";roguePrefix] in
let tableNames = listNames saveSuffix prefixes in
reportTableNames b2bName asWhat outDir tableNames;
let b2bs: day_b2b = loadData b2bName in
let before,self,after,rogue =
Bucket_power.b2b_ratios absNorm b2bs in
let tables: rates list = [before;self;after;rogue] in
let startRow,tables = dayRanges ~takeDays ~dropDays tables in
let floatPrint = pickFloatPrint scientific precise in
(* ~drop unnecessary as we do it right in saveInfix! *)
if showTables then printShowTables tex ~verbose floatPrint tables ~startRow outDir tableNames;
if summary then tableSummaries tex ~verbose ~outDir floatPrint tables tableNames else ();
if matrix then begin
let includeNames = listNames saveInfix prefixes in
let matrixName = sprintf "4x4%s" saveSuffix in
printShowMatrix matrixDoc ~verbose outDir ~inputPath matrixName includeNames;
if masterLine then
printShowMasterLine ~verbose outDir ~inputPath matrixName
else ()
end
else ()