Présentation

Article

1 - PARADIGMES DE CONCEPTION DES ARCHITECTURES DE CONTRÔLE

2 - DESCRIPTION DE QUELQUES ARCHITECTURES DE CONTRÔLE

3 - DÉVELOPPEMENT DES ARCHITECTURES DE CONTRÔLE

4 - CONCLUSION

Article de référence | Réf : S7791 v1

Description de quelques architectures de contrôle
Architectures de contrôle pour la robotique - Approches et tendances

Auteur(s) : Robin PASSAMA, David ANDREU, Didier CRESTANI, Karen GODARY-DEJEAN

Date de publication : 10 sept. 2014

Pour explorer cet article
Télécharger l'extrait gratuit

Vous êtes déjà abonné ?Connectez-vous !

Sommaire

Présentation

Version en anglais English

RÉSUMÉ

Longtemps la face cachée de la robotique, l’intégration logicielle des fonctionnalités du robot devient une problématique centrale pour la future industrie de la robotique de service (médicale, d'assistance, etc.). Celle-ci s'organise autour de l'architecture logicielle de contrôle du robot. L'état des lieux, exposé dans cet article, témoigne d’une grande diversité d’approches pour concevoir et développer de telles architectures. Néanmoins, la tendance actuelle privilégie les approches basées sur les composants logiciels et l'utilisation, pour leur programmation, de middleware dédiés au domaine. L'article présente donc des middleware de référence ou au contraire originaux, compare globalement leurs propriétés et en évoque les limites en présentant les solutions émergentes basées sur la montée en abstraction via l'utilisation de l'ingénierie dirigée par les modèles et des langages dédiés. Cette analyse nous permettra d'identifier les caractéristiques exigées pour amener l’intégration logicielle en robotique à une maturité comparable à celle de l'électronique.

Lire cet article issu d'une ressource documentaire complète, actualisée et validée par des comités scientifiques.

Lire l’article

Auteur(s)

  • Robin PASSAMA : Ingénieur de recherche CNRS - Laboratoire d’informatique, de robotique et de microélectronique de Montpellier (LIRMM)

  • David ANDREU : Maître de conférences - LIRMM, université Montpellier 2

  • Didier CRESTANI : Professeur - LIRMM, université Montpellier 2

  • Karen GODARY-DEJEAN : Maître de conférences - LIRMM, université Montpellier 2

INTRODUCTION

La robotique est par essence multidisciplinaire, traitant dès leur origine des problèmes couplant mécanique, automatique, électronique, informatique, etc. sans omettre ceux relatifs au domaine d’application lui-même. Elle doit ses progrès aux avancées réalisées dans chaque discipline ainsi qu’à leur croisée. Les robots sont des entités technologiques de plus en plus complexes auxquelles sont confiées des missions toujours plus compliquées, relevant d’une multitude de domaines applicatifs. Les spécificités des divers domaines d’application et des grandes catégories de robots (robotique terrestre, sous-marine, aérienne) sont souvent à l’origine de solutions différentes. Certaines applications vont requérir une réactivité importante et des capacités décisionnelles moindres, d’autres auront des besoins de planification importants, etc.

Cette complexité induit de nombreuses exigences, notamment sur l’informatique censée gérer le fonctionnement du robot et supporter ses capacités d’action, d’adaptation, de décision, etc., cette « intelligence » que lui confère son contrôle. C’est donc de l’architecture logicielle de contrôle, c'est-à-dire la manière dont est conçu et développé le logiciel chargé du contrôle du robot, dont nous allons discuter dans cet article.

Ces architectures logicielles se distinguent par le besoin de prendre en compte tout un spectre de fonctions allant de calculs délibératifs, très gourmands en temps et en espace, jusqu’au contrôle en temps réel de dispositifs physiques. Organiser ces « fonctions », les mettre en relation requiert un niveau d'expertise élevé. C'est pourquoi des solutions générales ont initialement été proposées sous la forme de « modèles architecturaux ». Les modèles architecturaux classiquement admis seront présentés, sachant qu’ils sont encore soumis à évolution pour intégrer la variété de schémas relationnels qui donnent une dimension unique à ces architectures. En effet, le robot immergé dans son environnement est aussi sujet à des relations homme-robot (autonomie décisionnelle partagée), robot-robot (flottille) ou encore robot-environnement actif (capteurs de l’habitat et routes intelligentes par exemple) qui, déclinées sur le plan des architectures de contrôle, nécessitent de considérer les relations dynamiques qui peuvent s’instaurer.

Si le modèle architectural guide dans la manière de structurer une architecture, il reste à définir comment la décrire et la mettre en œuvre. Avec la croissance de la complexité des architectures logicielles robotiques et l’explosion de la diversité toujours plus grande des applications et des missions, la conception et le développement d’architectures logicielles performantes et correctes devient un enjeu majeur. Il n’y a à ce jour aucune approche communément admise pour capitaliser et mutualiser les connaissances et les bonnes pratiques et pour réutiliser les briques logicielles développées. L’état des lieux que nous allons dresser témoigne de la diversité des propositions, révélant l’influence des cultures initiales des concepteurs, plus robotique, automatique ou informatique. Dans tous les cas, ces propositions visent, avec plus ou moins de succès, à définir comment décrire et encapsuler les diverses fonctions que le robot doit assurer sous la forme d'un ensemble d'entités logicielles en interaction. Ce faisant, l'objectif est de conférer à la solution des propriétés de modularité, de portabilité, de réutilisabilité, etc.

Décrire l’architecture logicielle n’est pas suffisant car il faut ensuite l'implémenter, la déployer et l’exécuter. Implémenter l’architecture logicielle et la déployer sur une cible d’exécution, tout en maîtrisant les contraintes logiques et temporelles de l’exécution typiques des systèmes réactifs, conduisent à considérer les contraintes provenant de la plate-forme (matérielle, système d'exploitation, langages de programmation) sous-jacente. Construire des architectures pérennes, réutilisables et adaptables pour une grande variété de plates-formes et de composants physiques (capteurs, actionneurs, mais aussi processeurs, réseaux, et autres matériels parfois spécifiques à la robotique) constitue un défi important. Nous évoquerons dès lors, à travers la présentation des approches récentes, les intergiciels (appelés « middleware ») pour les architectures de contrôle robotiques tant leur rôle peut être primordial à ces égards.

Cet article est réservé aux abonnés.
Il vous reste 93% à découvrir.

Pour explorer cet article
Téléchargez l'extrait gratuit

Vous êtes déjà abonné ?Connectez-vous !


L'expertise technique et scientifique de référence

La plus importante ressource documentaire technique et scientifique en langue française, avec + de 1 200 auteurs et 100 conseillers scientifiques.
+ de 10 000 articles et 1 000 fiches pratiques opérationnelles, + de 800 articles nouveaux ou mis à jours chaque année.
De la conception au prototypage, jusqu'à l'industrialisation, la référence pour sécuriser le développement de vos projets industriels.

DOI (Digital Object Identifier)

https://doi.org/10.51257/a-v1-s7791


Cet article fait partie de l’offre

Robotique

(60 articles en ce moment)

Cette offre vous donne accès à :

Une base complète d’articles

Actualisée et enrichie d’articles validés par nos comités scientifiques

Des services

Un ensemble d'outils exclusifs en complément des ressources

Un Parcours Pratique

Opérationnel et didactique, pour garantir l'acquisition des compétences transverses

Doc & Quiz

Des articles interactifs avec des quiz, pour une lecture constructive

ABONNEZ-VOUS

Version en anglais English

2. Description de quelques architectures de contrôle

Si le modèle d’organisation architecturale retenu est le plus souvent l’architecture hybride, les approches de mise en œuvre sont quasiment toutes différentes. Cette différence de mise en œuvre, de la modélisation à l’implémentation, se reflète entre autres par les entités logicielles avec lesquelles est décrite et composée l’architecture.

La notion d’entité logicielle, au sens général, est centrale dans le développement d’architectures, dont celles de contrôle en robotique. Cette notion se décline néanmoins de manières bien différentes selon les approches considérées. À la base de la structuration, elle peut par exemple être définie par une fonction, un objet, un module, un agent ou encore un composant. Dans tous les cas, l’élément central du développement est la fonction qui encapsule l’algorithme (loi de commande, traitement d’image, etc.), mais le point de vue adopté ici est l’entité informatique à partir de laquelle sont articulées les architectures logicielles de contrôle correspondantes. Sans être exhaustifs ni détaillés, car le lecteur trouvera le complément d’informations nécessaire dans les références, nous allons mentionner différentes propositions, en mettant en exergue l’architecture résultante. Le regard que nous proposons est d’une part : « comment est construite l’architecture de contrôle à partir de ces entités ? » et d’autre part : « quelles sont les préoccupations initiales ? », sachant que nous évoquerons les apports récents du génie logiciel à la conception d’architectures de contrôle dans un prochain paragraphe.

Fonctions, objets, modules, agents et composants sont les briques de base d’architectures aux structurations et propriétés différentes que nous avons choisies d’exposer. Cette variété d’approches révèle en fait des pratiques de développement différentes, selon des orientations, des préoccupations et des cultures plus robotique, informatique ou automatique selon les cas.

2.1 Approches basées fonctions

Structurer une application de contrôle via des entités de base que sont les fonctions est une approche classique de structuration du code en informatique. La proposition ProCoSA (programmation et contrôle des systèmes à forte autonomie) développée par l’ONERA ...

Cet article est réservé aux abonnés.
Il vous reste 93% à découvrir.

Pour explorer cet article
Téléchargez l'extrait gratuit

Vous êtes déjà abonné ?Connectez-vous !


L'expertise technique et scientifique de référence

La plus importante ressource documentaire technique et scientifique en langue française, avec + de 1 200 auteurs et 100 conseillers scientifiques.
+ de 10 000 articles et 1 000 fiches pratiques opérationnelles, + de 800 articles nouveaux ou mis à jours chaque année.
De la conception au prototypage, jusqu'à l'industrialisation, la référence pour sécuriser le développement de vos projets industriels.

Cet article fait partie de l’offre

Robotique

(60 articles en ce moment)

Cette offre vous donne accès à :

Une base complète d’articles

Actualisée et enrichie d’articles validés par nos comités scientifiques

Des services

Un ensemble d'outils exclusifs en complément des ressources

Un Parcours Pratique

Opérationnel et didactique, pour garantir l'acquisition des compétences transverses

Doc & Quiz

Des articles interactifs avec des quiz, pour une lecture constructive

ABONNEZ-VOUS

Lecture en cours
Description de quelques architectures de contrôle
Sommaire
Sommaire

BIBLIOGRAPHIE

  • (1) - NILSON (N.J.) -   A mobile automaton : An application of AI techniques  -  Proceedings of the First International Joint Conference on Artificial Intelligence (Morgan Kaufmann publishers, San Francisco 1969), pp. 509-520 (1969).

  • (2) - ALBUS (J.S.), LUMIA (R.), FIALA (J.), WAVERING (A.) -   NASREM : the NASA/NBS standard reference model for telerobot control system architecture  -  Technical report, Robot Systems Division, National Institute of Standards and Technology (1987).

  • (3) - BROOKS (R.A.) -   A robust layered control system for a mobile robot  -  Robotics and Automation, vol. RA-2, pp. 14-23 (Apr. 1986).

  • (4) - ROSENBLATT (J.K.) -   DAMN : a distributed architecture for mobile navigation  -  Journal of Experimental and Theoretical Artificial Intelligence, 9(2/3), pp. 339-360 (1997).

  • (5) - ARKIN (R.C.), BALCH (T.) -   AuRA : principles and practice in review  -  Journal of Experimental & Theoretical Artificial Intelligence 9 (2-3) : 175-189 (1997).

  • ...

Cet article est réservé aux abonnés.
Il vous reste 95% à découvrir.

Pour explorer cet article
Téléchargez l'extrait gratuit

Vous êtes déjà abonné ?Connectez-vous !


L'expertise technique et scientifique de référence

La plus importante ressource documentaire technique et scientifique en langue française, avec + de 1 200 auteurs et 100 conseillers scientifiques.
+ de 10 000 articles et 1 000 fiches pratiques opérationnelles, + de 800 articles nouveaux ou mis à jours chaque année.
De la conception au prototypage, jusqu'à l'industrialisation, la référence pour sécuriser le développement de vos projets industriels.

Cet article fait partie de l’offre

Robotique

(60 articles en ce moment)

Cette offre vous donne accès à :

Une base complète d’articles

Actualisée et enrichie d’articles validés par nos comités scientifiques

Des services

Un ensemble d'outils exclusifs en complément des ressources

Un Parcours Pratique

Opérationnel et didactique, pour garantir l'acquisition des compétences transverses

Doc & Quiz

Des articles interactifs avec des quiz, pour une lecture constructive

ABONNEZ-VOUS