Automatisme : norme 1131-3 et GRAFCET/Retour sur le graphe d'état – Langage LD de la norme 1131-3
Contacts et bobines
[modifier | modifier le wikicode]Le langage LD est composé de contacts (ou interrupteurs) qui doivent être considérées comme des entrées. Il est composé aussi de bobines qui sont elles des sorties (voir l’article correspondant dans wikipédia).
Le langage LD (Ladder Diagram ou langage Ladder) est plus connu chez nous comme langage à contacts. Comment implanter une fonction booléenne ? Les opérateurs de base étant le ET et le OU nous adopterons le principe suivant :
- interrupteurs en série = ET
- interrupteurs en parallèle = OU.
C'est la seule règle à connaître lorsqu'on programme en langage ladder. Il nous faut avouer quand même que les choses se compliquent un peu avec les équations de récurrences.
Bien distinguer les contacs qui sont des entrées et les bobines qui sont des sorties.
Il existe un certain nombre de modificateurs qu’il faut connaître :
- / = NOT, N=Negative pulse, P=Positive Pulse sont des modificateurs pour les contacts d'entrées.
- / = NOT N=Negative pulse, P=Positive Pulse, S=Set, R=Reset sont des modificateurs pour les bobines de sorties
L'exemple ci-contre est complet. Il utilise des blocs fonctionnels présentés au chapitre précédent. Cet aspect du langage sera seulement survolé dans ce chapitre.
Graphe d'états
[modifier | modifier le wikicode]Lire le chapitre graphe d'états du projet Logique séquentielle. On y présente toutes les définitions pour comprendre ce qu'est un graphe d'états.
Nous sommes dans un livre d'automatisme et peut être des lecteurs savent ce qu'est un GRAFCET à ce point du cours (sinon il sera présenté plus loin, et pour vous, allez à la section suivante). Un graphe d'états est un GRAFCET pour lequel on a remplacé les étapes (rectangulaires) par des états (ronds) et pour lequel un jeton circule. Mais il ne peut y avoir qu'un seul jeton !
Équations de récurrence
[modifier | modifier le wikicode]Lire le chapitre équations de récurrence du projet logique séquentielle.
Nous ne donnons que le résultat correspondant aux équations de récurrences de l'exemple ci-contre.
Équations de sorties
[modifier | modifier le wikicode]Lire le chapitre Équations de sorties du projet logique séquentielle.
Les équations de sortie de l'exemple ci-dessus sont ainsi :
Implantation des équations du graphe d'états en langage Ladder
[modifier | modifier le wikicode]Nous allons nous intéresser maintenant à l'écriture des équations de récurrence en langage Ladder. La méthode est différente suivant que les bobines sont normales ou de type R (Reset) et S (set).
L'entrée "Init" est un problème en soi. Elle n’est pas adaptée à l’utilisation des Automates Programmable Industriel. Une petite explication peut-être.
Il est normal d’utiliser une entrée spécifique appelée "Init" quand notre objectif est de réaliser une synthèse matérielle avec des circuits logiques (comme présenté dans un autre projet). Pour un automate programmable on utilisera jamais une entrée spécifique pour l'initialisation. En général il existe un mécanisme particulier pour gérer cette initialisation. Cela peut se faire à l'aide d'un bit interne ou d'une autre façon. Pour rester indépendant des fabricants d'automates, on utilisera bien dans la suite un interrupteur appelé "Init" sans se préoccuper de la façon dont on le réalise en pratique.
Implantation des équations de récurrence avec bobines normales
[modifier | modifier le wikicode]Pour cette implantation on distingue arbitrairement les équations séquentielles (ou équations de récurrences) et les équations de sorties. Pourquoi ? Tout simplement parce que les équations de sorties seront utilisées sans aucun changement dans la section suivante.
Les variables associées aux états (notées ) sont présentes sur les contacts d'entrées et sur les bobines de sortie. C'est une caractéristique des équations de récurrences.
Remarquez aussi la présence du Init dont on a déjà discuté dans la section précédente.
Implantation des équations de récurrence avec bobines mémorisées
[modifier | modifier le wikicode]Nous présentons la façon de faire sans gérer l'initialisation pour le moment.
La programmation des sorties se fait exactement de la même manière qu’à la section précédente.
Pour poursuivre plus loin, il nous faut gérer l'initialisation. Le principe est tout simple :
- pour l'état initial ajouter un OU "Init" sur la bobine SET
- pour tous les états normaux ajouter un OU "Init" sur la bobine RESET
Pour ne pas alourdir le texte de cette section, nous laissons de côté le problème du "Init" pour le moment.
En résumé
[modifier | modifier le wikicode]Rien n'est plus parlant qu'une figure explicative. Voici en résumé les deux techniques pour implanter des équations de récurrences en langage Ladder.
Bien sûr une implémentation pratique nécessitera d'écrire les et les en langage ladder.
Notez que les sont complémentés dans l'implantation avec bobine normale tandis qu’ils ne le sont pas dans l'implantation avec bobine mémorisée. Ce n’est pas une erreur. La compréhension du pourquoi vous ouvrira les portes de la compréhension des équations de récurrences.