exprtk_simple_example_11.cpp 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. **************************************************************
  3. * C++ Mathematical Expression Toolkit Library *
  4. * *
  5. * Simple Example 11 *
  6. * Author: Arash Partow (1999-2020) *
  7. * URL: http://www.partow.net/programming/exprtk/index.html *
  8. * *
  9. * Copyright notice: *
  10. * Free use of the Mathematical Expression Toolkit Library is *
  11. * permitted under the guidelines and in accordance with the *
  12. * most current version of the MIT License. *
  13. * http://www.opensource.org/licenses/MIT *
  14. * *
  15. **************************************************************
  16. */
  17. #include <cstdio>
  18. #include <string>
  19. #include "exprtk.hpp"
  20. template <typename T>
  21. void square_wave2()
  22. {
  23. typedef exprtk::symbol_table<T> symbol_table_t;
  24. typedef exprtk::expression<T> expression_t;
  25. typedef exprtk::parser<T> parser_t;
  26. const std::string wave_program =
  27. " var r := 0; "
  28. " for (var i := 0; i < 1000; i += 1) "
  29. " { "
  30. " r += (1 / (2i + 1)) * sin((4i + 2) * pi * f * t); "
  31. " }; "
  32. " r *= a * (4 / pi); ";
  33. static const T pi = T(3.141592653589793238462643383279502);
  34. T f = pi / T(10);
  35. T t = T(0);
  36. T a = T(10);
  37. symbol_table_t symbol_table;
  38. symbol_table.add_variable("f",f);
  39. symbol_table.add_variable("t",t);
  40. symbol_table.add_variable("a",a);
  41. symbol_table.add_constants();
  42. expression_t expression;
  43. expression.register_symbol_table(symbol_table);
  44. parser_t parser;
  45. parser.compile(wave_program,expression);
  46. const T delta = (T(4) * pi) / T(1000);
  47. for (t = (T(-2) * pi); t <= (T(+2) * pi); t += delta)
  48. {
  49. const T result = expression.value();
  50. printf("%19.15f\t%19.15f\n", t, result);
  51. }
  52. }
  53. int main()
  54. {
  55. square_wave2<double>();
  56. return 0;
  57. }