summaryrefslogtreecommitdiff
path: root/fuzzylite/fl/defuzzifier/SmallestOfMaximum.h
blob: 94f8a7ae3674623d98f0e1fbb40b4119346c9398 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
 fuzzylite (R), a fuzzy logic control library in C++.
 Copyright (C) 2010-2017 FuzzyLite Limited. All rights reserved.
 Author: Juan Rada-Vilela, Ph.D. <jcrada@fuzzylite.com>

 This file is part of fuzzylite.

 fuzzylite is free software: you can redistribute it and/or modify it under
 the terms of the FuzzyLite License included with the software.

 You should have received a copy of the FuzzyLite License along with
 fuzzylite. If not, see <http://www.fuzzylite.com/license/>.

 fuzzylite is a registered trademark of FuzzyLite Limited.
 */

#ifndef FL_SMALLESTOFMAXIMUM_H
#define FL_SMALLESTOFMAXIMUM_H

#include "fl/defuzzifier/IntegralDefuzzifier.h"

namespace fl {

    /**
      The SmallestOfMaximum class is an IntegralDefuzzifier that computes the
      smallest value of the maximum membership function of a fuzzy set
      represented in a Term.

      @author Juan Rada-Vilela, Ph.D.
      @see LargestOfMaximum
      @see MeanOfMaximum
      @see IntegralDefuzzifier
      @see Defuzzifier
      @since 4.0
     */
    class FL_API SmallestOfMaximum : public IntegralDefuzzifier {
    public:
        explicit SmallestOfMaximum(int resolution = defaultResolution());
        virtual ~SmallestOfMaximum() FL_IOVERRIDE;
        FL_DEFAULT_COPY_AND_MOVE(SmallestOfMaximum)

        virtual std::string className() const FL_IOVERRIDE;

        virtual Complexity complexity(const Term* term) const FL_IOVERRIDE;

        /**
          Computes the smallest value of the maximum membership function in the
          fuzzy set. The smallest value is computed while integrating over the
          fuzzy set. The integration algorithm is the midpoint rectangle method
          (https://en.wikipedia.org/wiki/Rectangle_method).

          @param term is the fuzzy set
          @param minimum is the minimum value of the fuzzy set
          @param maximum is the maximum value of the fuzzy set
          @return the smallest @f$x@f$-coordinate of the maximum membership
          function value in the fuzzy set
         */
        virtual scalar defuzzify(const Term* term,
                scalar minimum, scalar maximum) const FL_IOVERRIDE;
        virtual SmallestOfMaximum* clone() const FL_IOVERRIDE;

        static Defuzzifier* constructor();
    };
}

#endif  /* FL_SMALLESTOFMAXIMUM_H */