33 const std::string wave_program =
36 " for (var i := 0; i < 1000; i += 1) "
38 " r += (1 / (2i + 1)) * sin((4i + 2) * pi * f * t); "
41 " r *= a * (4 / pi); ";
43 static const T
pi = T(3.141592653589793238462643383279502);
49 symbol_table_t symbol_table;
50 symbol_table.add_variable(
"f",f);
51 symbol_table.add_variable(
"t",t);
52 symbol_table.add_variable(
"a",a);
53 symbol_table.add_constants();
55 expression_t expression;
56 expression.register_symbol_table(symbol_table);
59 parser.compile(wave_program,expression);
61 const T
delta = (T(4) *
pi) / T(1000);
63 for (t = (T(-2) *
pi); t <= (T(+2) *
pi); t +=
delta)
65 const T result = expression.value();
66 printf(
"%19.15f\t%19.15f\n", t, result);