You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CustomFunction.h 3.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. #pragma once
  2. /* -------------------------------------------------------------------------- *
  3. * Lepton *
  4. * -------------------------------------------------------------------------- *
  5. * This is part of the Lepton expression parser originating from *
  6. * Simbios, the NIH National Center for Physics-Based Simulation of *
  7. * Biological Structures at Stanford, funded under the NIH Roadmap for *
  8. * Medical Research, grant U54 GM072970. See https://simtk.org. *
  9. * *
  10. * Portions copyright (c) 2009 Stanford University and the Authors. *
  11. * Authors: Peter Eastman *
  12. * Contributors: *
  13. * *
  14. * Permission is hereby granted, free of charge, to any person obtaining a *
  15. * copy of this software and associated documentation files (the "Software"), *
  16. * to deal in the Software without restriction, including without limitation *
  17. * the rights to use, copy, modify, merge, publish, distribute, sublicense, *
  18. * and/or sell copies of the Software, and to permit persons to whom the *
  19. * Software is furnished to do so, subject to the following conditions: *
  20. * *
  21. * The above copyright notice and this permission notice shall be included in *
  22. * all copies or substantial portions of the Software. *
  23. * *
  24. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
  25. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
  26. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *
  27. * THE AUTHORS, CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
  28. * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
  29. * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE *
  30. * USE OR OTHER DEALINGS IN THE SOFTWARE. *
  31. * -------------------------------------------------------------------------- */
  32. #include "windowsIncludes.h"
  33. namespace Lepton
  34. {
  35. /**
  36. * This class is the interface for defining your own function that may be included in expressions.
  37. * To use it, create a concrete subclass that implements all of the virtual methods for each new function
  38. * you want to define. Then when you call Parser::parse() to parse an expression, pass a map of
  39. * function names to CustomFunction objects.
  40. */
  41. class LEPTON_EXPORT CustomFunction
  42. {
  43. public:
  44. virtual ~CustomFunction() { }
  45. /**
  46. * Get the number of arguments this function exprects.
  47. */
  48. virtual int getNumArguments() const = 0;
  49. /**
  50. * Evaluate the function.
  51. *
  52. * @param arguments the array of argument values
  53. */
  54. virtual double evaluate(const double* arguments) const = 0;
  55. /**
  56. * Evaluate a derivative of the function.
  57. *
  58. * @param arguments the array of argument values
  59. * @param derivOrder an array specifying the number of times the function has been differentiated
  60. * with respect to each of its arguments. For example, the array {0, 2} indicates
  61. * a second derivative with respect to the second argument.
  62. */
  63. virtual double evaluateDerivative(const double* arguments, const int* derivOrder) const = 0;
  64. /**
  65. * Create a new duplicate of this object on the heap using the "new" operator.
  66. */
  67. virtual CustomFunction* clone() const = 0;
  68. };
  69. } // namespace Lepton