Le langage des modules
Structure, dégradation et modes de défaillance des puces et modules de puissance
Historique Les composants de puissance à semi-conducteur sont les composants actifs permettant au sein des convertisseurs statiques d’énergie d’assurer la conversion et le contrôle de l’énergie électrique. Les premiers composants de puissance à semi-conducteur développés furent les redresseurs en germanium (1952) puis en silicium (1955). Les premiers thyristors sont apparus en 1957. Le transistor bipolaire de puissance est apparu au début des années 1960, puis suivirent des composants dérivés du thyristor tels que le triac, le thyristor asymétrique rapide, le thyristor à déclenchement optique, et le GTO (thyristors Gate Turn Off) dans les années 1980.
Les transistors MOS de puissance (transistor à effet de champs Métal Oxyde Semi-conducteur) développés dans les années 1980 également présentent de nombreux avantages par rapport au transistor bipolaire mais restent confinés pour les composants silicium aux applications de relativement faible tension.
Le développement du transistor IGBT a permis de complètement révolutionner l’électronique de puissance, il assure la commutation de puissances élevées (jusqu’à environ 5MVA), il est robuste (tenue de courant de court-circuit supérieure à 10µs) sa commande est relativement simple à mettre en œuvre et le compromis entre chute de tension à l’état passant et pertes par commutation autorise des fréquence de commutation élevées pour des composants faible puissance (de l’ordre de 100kHz pour des composants 600V-20A) et de l’ordre de 1kHz pour les composants les plus conséquents en puissance, (figure 1.1) [LETURCQ_99], [KAUSHIK_01]. (a)
Figure 1.1 (b) Applications de l’électronique de puissance (a), classement de composant de puissance à semi-conducteur (b) [BALIGA_08] 1. Matériaux semi-conducteurs pour composants de puissance L’élément actif d’un composant ou module de puissance est la puce à semi-conducteur. Actuellement, le matériau utilisé pour la fabrication de puces est le silicium même si apparaissent des composants à base de matériaux grand gap tels le SiC ou le GaN.
On constate également une forte volonté d’augmenter la température maximale admissible par les puces. Cette tendance forte est motivée par le développement de certaines applications plaçant les composants de puissance dans un environnement « haute température ». On peut penser aux 29 Matériaux semi-conducteurs pour composants de puissance applications automobiles hybrides avec une température ambiante pouvant atteindre 90 à 120°C ou plus critiques, les applications aéronautiques (200°C au voisinage du réacteur) et pétrolières.
La montée en température est également liée à l’intégration de plus en plus compacte des convertisseurs d’énergie. Dans le même temps, une montée en température des puces permet de réduire le volume des refroidisseurs d’où un gain de volume et de masse conséquent sur les convertisseurs. Dans des conditions sévères à haute température, le silicium atteint rapidement ses limites lorsque par exemple la concentration intrinsèque de porteurs générés devient du même ordre de grandeur que le dopage de la région N- assurant la tenue en tension (il devient alors difficile de différencier un semi conducteur de type N d’un semi-conducteur de type P).
A titre d’exemple, la limite pour le silicium est de l’ordre de seulement 175°C pour un composant de tension de claquage 1200V alors qu’elle est de l’ordre de 250°C pour une tension de claquage d’environ 100V (cf. figure 1.2). Figure 1.2 Température théorique maximal d’utilisation des différents matériaux [WONDRAK_99] Ainsi pour les applications de puissance à haute température, les matériaux à grand gap sont extrêmement intéressants car ils repoussent les limites en températures rencontrées avec le silicium.
Ces matériaux modifient également complètement les domaines d’utilisation potentiels des composants unipolaires et bipolaires. Pour le silicium, les composants unipolaires possèdent de meilleurs performances que les bipolaires tant que la tension de claquage reste inférieure à environ 400V. Ce chiffre ne concerne pas les composants à base de super-jonction dont nous parlerons ultérieurement.
Pour les composants SiC cette limite est largement repoussée Description des modules en OCaml Dans cette section, nous rappelons brièvement les caractéristiques du système de modules d’OCaml pour le lecteur à qui cela n’est pas familier. Il s’agit d’un langage à part entière au dessus du langage de base d’OCaml (il est en réalité indépendant du langage de base [177]), remplissant uniquement des fonctions de génie logiciel : compilation séparée, structuration de l’espace de noms, encapsulation et généricité du code.
Définition des structures
Le langage des modules est un langage fonctionnel d’ordre supérieur fortement typé, dont les termes sont appelés modules. Les «briques» de base sont les structures, unités regroupant entre eux des types, des valeurs, des exceptions ou des définitions de modules. Par exemple, une implantation naïve des ensembles sous la forme de listes ordonnées pourrait être la suivante :
module Set = struct type α set = α list (∗ empty: α list ∗) let empty = [] (∗ comp: α →α →int ∗) let comp = compare (∗ add: α →α list→α list ∗) let rec add e s = match s with [] →[e] | hd::tl →match (comp e hd) with 0 →s(∗eest déjà dans s ∗) | x when x<0 →e:: s (∗ e est plus petit qu’un élément de l’ ensemble s ∗) | x when x>0 →hd :: add e tl (∗ member: α →α list→bool ∗) let rec member e s = match s with [] →false | hd::tl →match (comp e hd) with 0 →true (∗ x est inclu dans s ∗) | x when x<0 →false (∗ x est plus petit qu’un élément de l’ ensemble s ∗) | x when x>0 →member e tl end