annotate tests/evaltest.c @ 669:440b77b635a5

Add -f option to evaltest.
author Matti Hamalainen <ccr@tnsp.org>
date Tue, 16 Apr 2013 09:46:25 +0300
parents 69337f2fc4a4
children 776c22f83726
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
668
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
1 #include "dmlib.h"
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
2 #include "dmeval.h"
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
3 #include "dmargs.h"
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
4
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
5
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
6 BOOL optBenchmark = FALSE;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
7 char * optFormula = "";
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
8
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
9
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
10 DMOptArg optList[] =
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
11 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
12 { 0, '?', "help", "Show this help", OPT_NONE },
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
13 { 1, 'v', "verbose", "Be more verbose", OPT_NONE },
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
14 { 2, 'b', "benchmark", "Run in benchmark mode", OPT_NONE },
669
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
15 { 3, 'f', "formula", "Next argument is the formula", OPT_ARGREQ },
668
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
16 };
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
17
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
18 const int optListN = sizeof(optList) / sizeof(optList[0]);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
19
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
20
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
21 void argShowHelp()
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
22 {
669
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
23 dmPrintBanner(stdout, dmProgName, "[options] [-f] '<formula>'");
668
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
24 dmArgsPrintHelp(stdout, optList, optListN);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
25 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
26
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
27
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
28 BOOL argHandleOpt(const int optN, char *optArg, char *currArg)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
29 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
30 switch (optN)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
31 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
32 case 0:
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
33 argShowHelp();
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
34 exit(0);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
35 break;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
36
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
37 case 1:
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
38 dmVerbosity++;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
39 break;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
40
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
41 case 2:
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
42 optBenchmark = TRUE;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
43 break;
669
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
44
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
45 case 3:
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
46 optFormula = optArg;
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
47 break;
440b77b635a5 Add -f option to evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents: 668
diff changeset
48
668
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
49 default:
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
50 dmError("Unknown option '%s'.\n", currArg);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
51 return FALSE;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
52 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
53
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
54 return TRUE;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
55 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
56
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
57
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
58 BOOL argHandleNonOpt(char *currArg)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
59 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
60 optFormula = currArg;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
61 return TRUE;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
62 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
63
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
64
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
65 int main(int argc, char *argv[])
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
66 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
67 DMEvalContext *ev = dm_eval_new();
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
68 DMEvalNode *parsed = NULL, *ordered = NULL;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
69 DMValue result, t, f = 44100.0f;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
70 int ret;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
71
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
72 dmInitProg("evaltest", "evaltest", "0.1", NULL, NULL);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
73
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
74 // Parse arguments
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
75 if (!dmArgsProcess(argc, argv, optList, optListN,
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
76 argHandleOpt, argHandleNonOpt, FALSE))
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
77 exit(1);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
78
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
79
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
80 dm_eval_add_var(ev, "t", &t);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
81 dm_eval_add_var(ev, "f", &f);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
82
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
83 ret = dm_eval_parse_expr(ev, optFormula, &parsed);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
84 dmMsg(1, "parse ret=%d\n", ret);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
85 if (ev->err)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
86 dmError("%s\n", ev->errStr);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
87
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
88 if (dmVerbosity > 0)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
89 dm_print_optree(ev, parsed);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
90
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
91 if (ret != 0)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
92 return -1;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
93
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
94 dm_eval_clear_err(ev);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
95
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
96 ret = dm_eval_reorder(ev, parsed, &ordered);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
97 dmMsg(1, "reorder ret=%d\n", ret);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
98 if (ev->err)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
99 dmError("%s\n", ev->errStr);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
100
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
101 if (dmVerbosity > 0)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
102 dm_print_optree(ev, ordered);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
103
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
104 if (ret != 0)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
105 return -2;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
106
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
107 if (optBenchmark)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
108 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
109 dmMsg(0, "Benchmarking ...\n");
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
110 for (t = 0; t < 2500000; t++)
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
111 ret = dm_eval_exec(ev, ordered, &result);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
112 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
113 else
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
114 {
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
115 ret = dm_eval_exec(ev, ordered, &result);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
116 printf("%1.5f\n", result);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
117 }
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
118
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
119 dmMsg(1, "eval ret=%d\n", ret);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
120
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
121 dm_eval_close(ev);
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
122
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
123 return 0;
69337f2fc4a4 Add evaltest.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
124 }