Simulate Fuzzy Inference Systems in Simulink
You can simulate a fuzzy inference system (FIS) in Simulink® using one of the following blocks:
Fuzzy Logic Controller — Simulate a traditional type-1 FIS (
mamfis
andsugfis
) or type-2 FIS (mamfistype2
andsugfistype2
).Fuzzy Logic Controller with Ruleviewer — Simulate a type-1 FIS while displaying the rule inference process.
FIS Tree — Simulate a tree of interconnected fuzzy systems (
fistree
. (since R2024a)
For more information on creating fuzzy inference systems, see:
Simulate Fuzzy Inference System
Once you have implemented a fuzzy inference system using Fuzzy Logic Designer, using Neuro-Fuzzy Designer, or at the command line, you can simulate the system in Simulink.
For this example, you control the level of water in a tank using a fuzzy inference system implemented using a Fuzzy Logic Controller block. Open the sltank
model.
open_system('sltank')
For this system, you control the water that flows into the tank using a valve. The outflow rate depends on the diameter of the output pipe, which is constant, and the pressure in the tank, which varies with water level. Therefore, the system has nonlinear characteristics.
The two inputs to the fuzzy system are the water level error, level
, and the rate of change of the water level, rate
. The output of the fuzzy system is the rate at which the control valve is opening or closing, valve
.
To implement a fuzzy inference system, specify the FIS name parameter of the Fuzzy Logic Controller block as the name of a FIS object in the MATLAB® workspace. In this example, the block uses the mamfis
object tank
.
For more information on this system, see Water Level Control in a Tank.
As a first attempt to control the water level, set the following rules in the FIS. These rules adjust the valve based on only the water level error.
If the water level is okay, then do not adjust the valve.
If the water level is low, then open the valve quickly.
If the water level is high, then close the valve quickly.
Specify the rules by creating a vector of fisrule
objects and assigning it to the Rules
property of the tank
FIS object.
rule1 = "If level is okay then valve is no_change"; rule2 = "If level is low then valve is open_fast"; rule3 = "If level is high then valve is close_fast"; rules = [rule1 rule2 rule3]; tank.Rules = fisrule(rules);
Simulate the model, and view the water level.
open_system('sltank/Comparison') sim('sltank',100)
These rules are insufficient for controlling the system, since the water level oscillates around the setpoint.
To reduce the oscillations, add two more rules to the system. These rules adjust the valve based on the rate of change of the water level when the water level is near the setpoint.
If the water level is okay and increasing, then close the valve slowly.
If the water level is okay and decreasing, then open the valve slowly.
To add these rules, use the addRule
function.
rule4 = "If level is okay and rate is positive then valve is close_slow"; rule5 = "If level is okay and rate is negative then valve is open_slow"; newRules = [rule4 rule5]; tank = addRule(tank,newRules);
Simulate the model.
sim('sltank',100)
The water level now tracks the setpoint without oscillating.
You can also simulate fuzzy systems using the Fuzzy Logic Controller with Ruleviewer block. The sltankrule
model is the same as the sltank
model, except that it uses the Fuzzy Logic Controller with Ruleviewer block.
open_system('sltankrule')
During simulation, this block displays the Rule Viewer from the Fuzzy Logic Designer app.
sim('sltankrule',100)
If you pause the simulation, you can examine the FIS behavior by manually adjusting the input variable values in the Rule Viewer, and observing the inference process and output.
You can also access the Fuzzy Logic Designer editors from the Rule Viewer. From the Rule Viewer, you can then adjust the parameters of your fuzzy system using these editors, and export the updated system to the MATLAB workspace. To simulate the updated FIS, restart the simulation. For more information on using these editors, see Build Fuzzy Systems Using Fuzzy Logic Designer.
Simulation Modes
The Fuzzy Logic Controller and FIS Tree blocks have the following two simulation modes:
Interpreted execution
— Simulate fuzzy systems using precompiled MEX files. Using this option reduces the initial compilation time of the model.Code generation
— Simulate fuzzy system without precompiled MEX files. Use this option when simulating fuzzy systems for code generation applications. Doing so simulates your system using the same code path used for generated code.
To select a simulation mode, set the Simulate using parameter of
the block. By default, the block uses Interpreted execution
mode
for simulation.
Access Intermediate Inference Results for Fuzzy Logic Controller block
You can access intermediate fuzzy inference results when simulating a system using the Fuzzy Logic Controller block. You can use this data to visualize the fuzzy inference process or troubleshoot the performance of your FIS. To access this data, enable the corresponding parameters in the block, and connect signals to the corresponding output ports. For more information, see Fuzzy Logic Controller.
Block Parameter | Description | Output Port |
---|---|---|
Fuzzified Inputs | Fuzzified input values, obtained by evaluating the input membership functions of each rule at the current input values. | fi |
Rule firing strengths | Rule firing strengths, obtained by evaluating the antecedent of each rule. | rfs |
Rule outputs | Rule outputs, obtained by evaluating the consequent of each rule. | ro |
Aggregated outputs | Aggregate output for each output variable, obtained by combining the corresponding outputs from all the rules. | ao |
Map Command-Line Functionality to Block Configuration
The parameters and ports of the Fuzzy Logic Controller and FIS
Tree blocks map to the input and output arguments of evalfis
or the properties of evalfisOptions
.
The following table shows the Fuzzy Logic Controller block parameters and
ports that map to evalfis
arguments.
evalfis Argument | Description | Block Parameter or Port |
---|---|---|
fis | Fuzzy inference system | FIS name |
input , when a single row | Input variable values | in |
output , when a single row | Output variable values | out |
fuzzifiedIn | Fuzzified inputs | fi |
ruleOut | Rule outputs | ro |
aggregateOut | Aggregated outputs | ao |
ruleFiring | Rule firing strengths | rfs |
The following table shows the FIS Tree block parameters and ports that
map to evalfis
arguments.
evalfis Argument | Description | Block Parameter or Port |
---|---|---|
fis | Fuzzy inference system | FIS name |
input , when a single row | Input variable values | in |
output , when a single row | Output variable values | out |
The following table shows the Fuzzy Logic Controller and FIS
Tree block parameters that map to evalfisOptions
properties.
evalfisOptions Property | Description | Block Parameter |
---|---|---|
NumSamplePoints | Number of points in output fuzzy sets | Number of samples for output discretization |
OutOfRangeInputValueMessage | Diagnostic message behavior when an input is out of range | Out of range input value |
NoRuleFiredMessage | Diagnostic message behavior when no rules fire | No rule fired |
EmptyOutputFuzzySetMessage | Diagnostic message behavior when an output fuzzy set is empty | Empty output fuzzy set |
The remaining block parameters of the block do not map to arguments of
evalfis
. Also, unlike the Fuzzy Logic Controller and
FIS Tree blocks, evalfis
does not support fixed-point
data for simulation or code generation.