Astrée est un analyseur statique pour les logiciels critiques écrits ou générés en C ou C++.
Astrée est sûr — c’est-à-dire que si aucune erreur n’est signalée, l’absence d’erreurs a été formellement prouvée. En 2020, le National Institute of Standards and Technology des États-Unis a établi qu’Astrée répondait à ses critères pour l’analyse statique de code sûre.
Astrée a été utilisé pour vérifier l’absence d’erreurs à l’exécution dans le logiciel de commande de vol électrique primaire de plusieurs types d’avion Airbus.
Astrée est déployé par l’équipementier automobile Robert Bosch, après une expérimentation intensive d’un an dans sa Division « Automotive Steering ».
Leader mondial dans les moteurs et les ventilateurs pour les systèmes de climatisation et de réfrigération, ebm-papst utilise Astrée pour la vérification entièrement automatique continue de logiciels de contrôle critique pilotés par interruption pour la commutation de moteurs EC à haut rendement pour des systèmes de ventilateurs.
En Avril 2008, Astrée pouvait prouver l’absence de tout erreur d’exécution dans une version C des logiciels d’accostage automatique du Véhicule automatique de transfert européen (ATV) Jules Verne développé pour ravitailler la Station spatiale internationale (ISS). L’analyse était effectuée de façon complètement automatique.
Le fournisseur automobile global Helbako utilise Astrée dans le processus de développement pour démontrer la conformité du code avec MISRA et pour vérifier qu’aucune erreur à l’exécution ne peut arriver dans les logiciels de contròle électronique.
MTU Friedrichshafen utilise Astrée pour démontrer la justesse du logiciel de contrôle pour les générateurs de secours dans les centrales électriques. Les outils combinés avec leurs kits de qualification (QSK et QSLCD) font partie du processus de certification selon l’IEC60880.
Les erreurs trouvées par Astrée sont :
Astrée traite précisément et sûrement les calculs de virgule flottante.
Toute erreur d’arrondi possible ainsi que leurs effets cumulatifs sont prit
en compte. Le même s’applique pour des valeurs −∞, +∞ et NaN
dans tous des calculs et des comparaisons.
Astrée est basé sur l’interprétation abstraite de la sémantique des programmes analysés et calcule donc une sur-approximation de l’ensemble des comportements possibles du code à l’exécution. Astrée est donc correct et ne peut jamais omettre de signaler une erreur à l’exécution.
Par contre, Astrée est incomplet à cause de la sur-approximation qui peut introduire des comportements et donc des erreurs fictives impossibles dans toutes les exécutions réelles. On parle alors de fausses alarmes. L’objectif est donc de calculer des approximations suffisamment précises pour éviter toute fausse alarme (les vraies alarmes devant conduire à une correction du code).
Astrée est paramétrable et dispose de directives d’analyses pour s’adapter aux besoins spécifiques des utilisateurs. Il peut être également facilement étendu pour inclure de nouvelles abstractions permettant d’atteindre l’objectif de précision, sans aucune fausse alarme, sur des familles précises de programmes.
Un exemple de famille de programmes pour lequel Astrée est très précis est celui des codes de contrôle commande temps réel engendrés automatiquement à partir d’une spécification synchrone de haut niveau (comme SCADE).
Nous offrons des kits de qualification speciales pour Astrée, qui simplifient votre processus de certification DO-178B/C, ISO 26262 ou IEC 61508.
Commandez votre version d’évaluation gratuite aujourd’hui ou bien contactez nos distributeurs officiels :