File: defuzzify_output_sugeno.m

package info (click to toggle)
octave-fuzzy-logic-toolkit 0.6.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,024 kB
  • sloc: makefile: 147
file content (80 lines) | stat: -rw-r--r-- 3,048 bytes parent folder | download
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
68
69
70
71
72
73
74
75
76
77
78
79
80
## Copyright (C) 2011-2025 L. Markowsky <lmarkowsky@gmail.com>
##
## This file is part of the fuzzy-logic-toolkit.
##
## The fuzzy-logic-toolkit is free software; you can redistribute it
## and/or modify it under the terms of the GNU General Public License
## as published by the Free Software Foundation; either version 3 of
## the License, or (at your option) any later version.
##
## The fuzzy-logic-toolkit is distributed in the hope that it will be
## useful, but WITHOUT ANY WARRANTY; without even the implied warranty
## of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
## General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with the fuzzy-logic-toolkit; see the file COPYING.  If not,
## see <http://www.gnu.org/licenses/>.

## -*- texinfo -*-
## @deftypefn {Function File} {@var{output} =} defuzzify_output_sugeno (@var{fis}, @var{aggregated_output})
##
## Given the:
## @itemize @bullet
## @item @var{fis.defuzzMethod:}
## the defuzzification method for the given @var{fis}
## @item @var{aggregated_output:}
## a vector of structures containing the aggregated output for each FIS output variable
## @end itemize
##
## Return:
## @itemize @bullet
## @item @var{output:}
## a vector of crisp output values
## @end itemize
##
## The @var{aggregated_output} is a vector of M structures, where M is the
## number of FIS output variables. Each structure contains an index i and a
## matrix of singletons that form the aggregated output for the ith FIS output.
## For each FIS output variable, the matrix of singletons is a 2 x L matrix
## where L is the number of distinct singleton locations in the fuzzy output
## for that FIS output variable. The first row gives the (distinct) locations,
## and the second gives the (non-zero) heights:
##
## @verbatim
##                singleton_1  singleton_2 ... singleton_L
##     location [[                                        ]
##       height  [                                        ]]
## @end verbatim
##
## The crisp @var{output} values are computed from the corresponding fuzzy
## values using the FIS defuzzification method. The @var{output}
## vector has the form:
##
## @verbatim
##     output:  [output_1 output_2 ... output_M]
## @end verbatim
##
## Because defuzzify_output_sugeno is called only by the private
## function evalfis_private, it does no error checking of the argument values.
## @end deftypefn

## Author:        L. Markowsky
## Keywords:      fuzzy-logic-toolkit fuzzy inference system fis
## Directory:     fuzzy-logic-toolkit/inst/private/
## Filename:      defuzzify_output_sugeno.m
## Last-Modified: 26 Jul 2024

function output = defuzzify_output_sugeno (fis, aggregated_output)

  num_outputs = columns (fis.output);
  output = zeros (1, num_outputs);

  for i = 1 : num_outputs
    next_agg_output = aggregated_output(i).aggregated_output;
    x = next_agg_output(1, :);
    y = next_agg_output(2, :);
    output(i) = defuzz (x, y, fis.defuzzMethod);
  endfor

endfunction