EinsteinSum.h 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /*
  2. Author: Juan Rada-Vilela, Ph.D.
  3. Copyright (C) 2010-2014 FuzzyLite Limited
  4. All rights reserved
  5. This file is part of fuzzylite.
  6. fuzzylite is free software: you can redistribute it and/or modify it under
  7. the terms of the GNU Lesser General Public License as published by the Free
  8. Software Foundation, either version 3 of the License, or (at your option)
  9. any later version.
  10. fuzzylite is distributed in the hope that it will be useful, but WITHOUT
  11. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  12. FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
  13. for more details.
  14. You should have received a copy of the GNU Lesser General Public License
  15. along with fuzzylite. If not, see <http://www.gnu.org/licenses/>.
  16. fuzzylite™ is a trademark of FuzzyLite Limited.
  17. */
  18. #ifndef FL_EINSTEINSUM_H
  19. #define FL_EINSTEINSUM_H
  20. #include "fl/norm/SNorm.h"
  21. namespace fl {
  22. class FL_API EinsteinSum : public SNorm {
  23. public:
  24. std::string className() const FL_IOVERRIDE;
  25. scalar compute(scalar a, scalar b) const FL_IOVERRIDE;
  26. EinsteinSum* clone() const FL_IOVERRIDE;
  27. static SNorm* constructor();
  28. };
  29. }
  30. #endif /* FL_EINSTEINSUM_H */