27
Commande à logique floue Mounir Boukadoum

ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

  • Upload
    others

  • View
    8

  • Download
    0

Embed Size (px)

Citation preview

Page 1: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Commande à logique floue

Mounir Boukadoum

Page 2: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Et si Bouddha avait raison ?…

« Tout doit toujours être ou ne pas être »Aristote

« Le monde n’est ni éternel ni éphémère, ni fini ni infini »Bouddha

Corollaire : « Rien dans le monde, objet ou événement, ne serait vrai ou faux s’il n’existait pas de créatures pensantes »

Donald Davidson

Page 3: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Flou, mais pas imprécis ou inconnu

X est inconnu si X(t) = 1 pour tout t

X est précis Si X(t)=1 pour t unique, 0 ailleurs 

X est imprécis si X(t) = 1 pour t dans [t0, t1], 0 ailleurs

X est flou si X(t) dans  [0,  1] pour tout t

Exemple : X      :  fait exprimant la taille d’untel avec une mesure tX(t) : vraisemblance de l’appartenance de t à X

X(t)

Page 4: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Flou mais logique !

Logique floue :

Ensemble de principes mathématiques  pour la représentation et la manipulation des connaissances en se basant sur des degrés d’appartenance compris dans [0,1]

Après fuzzy sets, Lotfi Zadeh publie, en 1973 , un autre article qui montre comment capturer la connaissance humaine à l’aide de règles floues.

(a) Boolean Logic. (b) Multi-valued Logic.0 1 10 0.2 0.4 0.6 0.8 100 1 10

Page 5: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Que vaut une affirmation floue ?« Aujourd’hui il fait chaud »

Chaud = ?  C’est une question d’appréciation :

T=50oC : Vous aimez les euphémismes ! T=40oC : un peu trop à mon goût ! T=30oC : oui T=20oC : un peu T=10oC : Ouin ! T=  0oC : Pour un canadien, peut‐être ! T=‐10oC : Vous voulez rire !

On peut trancher en associant un degré de vérité à chaque valeur de Trelativement  à « chaud »

Page 6: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Degré de vérité d’une affirmation En logique binaire, une affirmation est vraie ou fausse ; son 

degré de vérité vaut 1 ou 0.Valeur Signification1 Absolument vrai0 Absolument faux

En logique floue, une affirmation est plus ou moins vraie (donc, plus ou moins fausse); son degré de vérité varie entre 0 et 1. Degré de vérité Signification0.0 Absolument faux0.2 Plutôt faux0.4 Quelque peu faux0.6 Quelque peu vrai0.8 Plutôt vrai1.0 Absolument vrai

Page 7: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Exemple Température T Degré de vérité pour CHAUD : Chaud(T)

<‐10oC 0.0‐5oC 0.10oC 0.25oC 0.310oC 0.415oC 0.520oC 0.625oC 0.730oC 0.835oC 0.9>40oC 1.0

Page 8: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Exemple continué On peut résumer le tableau par le tracé d’une fonction d’appartenance :

La fonction d’appartenance formalise la relation entre les valeurs précises (mesurées, calculées, etc.) d’une variable d’entrée/sortie et un label flou(dit aussi valeur symbolique ou linguistique ; e.g. CHAUD)

Une variable d’e/s peut être associée à plusieurs labels ; L’ensemble des labels définit alors les valeurs floues (linguistiques) de la variable.

Pour chaque label, la fonction d’appartenance représente le degré de vérité des valeurs précises d’une variable d’e/s par rapport au label. 

-10 -5 0 5 10 15 20 25 30 35 40

0.5

1.0

0.0

Température (T)

mCHAUD(T)

Page 9: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Éléments d’un ensemble flou Un système à logique floue comprend :

Des variables d’e/s, Des labels qui représentent les valeurs floues de chaque variable, Des fonctions qui définissent le degré d’appartenance des valeurs des 

variables aux labels.

Une valeur mesurée peut appartenir à plusieurs labels, avec des degrés divers. Par exemple, pour T=6 oC et T=30 oC on a :

FROID(6)  =.6, TIÈDE(6)  =.05, CHAUD(6)=0 FROID(30)= 0, TIÈDE(30)=.3, CHAUD(30)=.8

-10 -5 0 5 10 15 20 25 30 35 40

0.5

1.0

0.0

Température

v()FROID TIÈDE CHAUD

Page 10: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Un ensemble flou A sur un univers de discours X est un ensemble de paires ordonnées :

A x x x XA {( , ( ))| }

Univers dediscours

Ensemble flouFonction d’appartenance

(FA)

A est tel que tout x en est membre à un degré 0  d  1 A est entièrement caractérisé par sa fonction d’appartenance

Concrètement,  A est un attribut qualitatif (valeur floue ou linguistique) que l’on associe avec les valeurs précises d’une variable numérique x

Petit détour formel

Page 11: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Une variable floue (dite aussi linguistique) est un quintuplet

{ x, T(x), X, G, M } où x est le nom de la variable :   ex. âge T(x) est l’ensemble de ses valeurs :

ex. T(âge) = {jeune, moins jeune, très jeune, ...} X est l’univers de discours : ex. X = [0‐100] G est une règle syntaxique qui définit l’ensemble T(x)  M est une règle sémantique qui associe  un ensemble flou 

avec chaque élément de T(x) ex. : M(jeune), M(vieux)…)

Petit détour formel II

Page 12: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Une relation floue R est un ensemble flou défini sur le produit cartésien de deux univers de discours X et Y :

Permet d’exprimer une relation qualitative entre deux variables numériques :  x est près de y (nombres) x dépend de y (évènements) x et y se ressemblent (personnes ou objets)

R x y x y x y X YR {(( , ), ( , ))|( , ) }

Petit détour formel III

Page 13: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Petit détour formel (le dernier, promis ! )

Répartition floue : distribution des ensembles flous sur l’univers de discours

Exemple : Répartition floue des valeurs linguistiques“jeune”, “ni jeune ni vieux”, et “vieux”:

Page 14: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Opérations en logique floue  Le langage humain comprend aussi bien des affirmations 

simples (« Le taux de chômage est élévé ») que composées (« La crise économique est sévère et ET les différentes communautés en souffrent pareillement »)

Comment évaluer le degré de vérité d’une affirmation composée ?Affirmation Degré de vérité

(fonction d’appartenance)X (X)Y (Y)X ET Y min((X), (Y))X OU Y max((X), (Y))non‐X 1‐ (X)

Page 15: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Exemples d’opérations floues X= « La température est élevée » Y= « La couche de glace est faible »

Logique binaire

Logique floue

X Y XY X+Y XY X+Y

1 1 1 1 1 1

1 0 0 1 0 1

0 1 0 1 0 1

0 0 0 0 0 0

0.70.70.70.5

10.800.5

????

????

0.70.700.5

10.80.70.5

Page 16: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Règles d’inférence floues

Syntaxe identique à celle de la logique binaire :SI <condition> ALORS <conséquence>

<condition> est une affirmation simple ou composée.

Ex. :Régulateur de température dont les variables sont : temp = la température ambiante vac = vitesse de rotation d’un ventilateur d’air chaud vaf = vitesse de rotation d’un ventilateur d’air frais

Les règles d’inférence peuvent être : Si temp est haute alors vac est nulle Si temp est haute alors vaf est grande Si temp est basse alors vac est grande Si temp est basse alors vaf est nulle

Page 17: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Propriétés des règles floues L’évaluation des règles se fait sur les valeurs des () et non pas sur les 

valeurs précises des variables d’e/s.

Lorsqu’on a des conditions composées, on peut regrouper les règles dans une table, la matrice cognitive floue (« Fuzzy Cognitive Matrix » ou FCM).

La variable conditionnelle sert à prendre une décision (commander un actuateur, tirer une conclusion, classer une entrée, etc.) et les variables indépendantes sont obtenues à partir de valeurs mesurées (valeurs de () correspondantes).

Valeurs de la variable indépendante 1

valeurs

de la valeur indépendante 2

Valeurs de la variable conditionnelle

Page 18: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Étapes de conception d’un systèmed’inférence/commande à logique floue

1. Identifier les variables significatives d’entrée et de sortie

2. Définir les valeurs linguistiques de chacune  

3. Pour chaque variable d’entrée, définir une fonction d’appartenance pour chacune de ses valeurs linguistiques  

4. Concevoir une collection de règles floues « si‐alors »permettant d’évaluer les  valeurs linguistiques des variables de sortie

5. Choisir une méthode de conversion des valeurs linguistiques de sortie obtenues en valeurs précises.

Page 19: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Exemple d’application : Système de commande d’un pendule inversé

2

ml mgl mlx

f t Mx mddt

x l M m x lm

2

2

22

sin cos

( ) ( sin ) ( ) ( cos sin )

l

m

mx

f(t)

x

mg

Il s’agit de déplacer le chariot de manière à maintenir le pendule àla verticale (θ=0). L’approche classique n’est pas évidente !

La solution exacte :Résoudre le système d’équadiffscouplées – Good luck !

La solution floue :Pousser le chariot à gauche ou à droite en sens inverse du signe de « proportionnellement »

Page 20: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

1. Choix des variables d=e/s

Système decommande Chariot

Tension de commande du moteur

v

Donc, deux variables d’entrée, θ et ω, et une variable de sortie  v ; les variables floues correspondantes portent les mêmes noms.

Page 21: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

2 Choix des valeurs linguistiques Il s’agit de regrouper des règles de la forme « Si θ est X1 et ω

est X2, alors v est Y » en une matrice cognitive floue.

Exemple de définition des valeurs  X1 ,X2 et Y :Nom Signification

TN Très négatif 

MN Moyennement négatif

PN Peu négatif 

PP Peu Positif

MP Moyennement positif

TP Très positif

Page 22: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

4. Choix des fonctions d’appartenance

En général, on choisit des fonctions d’appartenance de forme triangulaire ou trapézoïdale. Cela simplifie les calculs.

0.5

1.0

0.0Valeur mesurée

v()TN MN PN PP MP TP

Page 23: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

3. définition des règles d’inférence On pourrait alors définir la matrice cognitive suivante :

Les intersections des valeurs linguistiques de θ et de ω définissent les valeurs linguistiques de sortie correspondantes (en termes de )

Pour chaque valeur linguistiques de sortie, on retient le max correspondant

θ

ωTN MN PN PP MP TP

TN TN TN TN TN MN PN

MN TN TN TN MN PN PP

PN TN TN MN PN PP MP

PP MN PN PP MP TP TP

MP PN PP MP TP TP TP

TP PP MP TP TP TP TP

Page 24: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

5. Détermination des valeurs de sortie précises correspondant à On détermine le degré de vérité de chaque valeur 

linguistique de sortie possible; on prend ensuite la valeur pondérée des résultats (inférence de Sugeno).

Pour chaque valeur mesurée de θ et de ω :1. On détermine ses degrés d’appartenance à TN, MN, PN, PP, MP 

et TP

2. On applique les règles d’inférence floues aux résultats afin d’obtenir les degrés d’appartenance correspondants pour les différentes valeurs linguistiques de v (on prend max pour chacune)

3. On calcule la moyenne pondérée des résultats

Page 25: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Exemple de valeur « déflouïfiée » Ex. Deux valeurs mesurées de θ et de ω donnent :Valeur de sortie  (max)TN 0MN 0PN 0.5PP 1MP 1TP 0.5

On obtient par la méthode du centre de gravité (en supposant que chaque  valeur en abscisse correspond à une valeur précise) :

v = [(0x0)+(0x64)+(0.5X112)+(1X132)+(1X196)+(0.5X255)]/6 = 164

0 64 112 132 196 2550

0.5

1

Page 26: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Logique Floue et Probabilité

Les bouteilles d’eau de Bezdek

P={liquides potables}

=0.91 signifie que la bouteille contient vraisemblablement de l’eau, et cela même après avoir ouvert la bouteille. 

p=0.91  signifie dit que  la bouteille contient de l’eau dans 91% des cas ; on peut trouver un liquide totalement différent en ouvrant la bouteille.

est le même a priori et a posteriori ; P vaut 0 ou 1 à l’observation

Page 27: ch8a commande floue - UQAMboukadoum_m/MIC4235/Notes/ch8a... · 2009. 12. 9. · Flou mais logique ! Logique floue : Ensemble de principes mathématiques pour la représentation et

Règle compositionnelle d’inférencefloue

y = f(x) => y = b si x = a, 

a et b: points

y = f(x) : une courbe

a

b

y

xx

y

a et b: intervalles

y = f(x) : une fonctiond’intervalles de valeurs

a

b

y = f(x) y = f(x)