SPICE (logiciel)

Un article de Wikipédia, l'encyclopédie libre.
SPICE

Informations
Développé par Laurence W. Nagel (d) et université de Californie à BerkeleyVoir et modifier les données sur Wikidata
Dernière version 3f.5 ()Voir et modifier les données sur Wikidata
Écrit en CVoir et modifier les données sur Wikidata
Système d'exploitation LinuxVoir et modifier les données sur Wikidata
Type Electronic circuit simulation (en)Voir et modifier les données sur Wikidata
Licence Licence BSDVoir et modifier les données sur Wikidata
Site web bwrcs.eecs.berkeley.edu/Classes/IcBook/SPICEVoir et modifier les données sur Wikidata

SPICE (Simulation Program with Integrated Circuit Emphasis) est un logiciel libre de simulation généraliste de circuits électroniques analogiques. Il permet la simulation au niveau du composant (résistances, condensateurs, transistors) en utilisant différents types d'analyses :

Les logiciels Easyspice, Gspiceui dans la suite gEDA, LTspice (en) ou PSpice (en) sont des interfaces graphiques généralistes pour l'utilisation de SPICE. Le logiciel Gwave se concentre sur la visualisation des courbes des signaux analogiques fournis par SPICE.

Il est également à noter l'évolution de Spice qu'est Ngspice (en), plus moderne, plus puissant et plus récent.

Introduction[modifier | modifier le code]

Contrairement aux conceptions au niveau de cartes électroniques intégrant des composants discrets, il n'est pas possible d'essayer un schéma de circuits intégrés sur breadboard en phase de conception avant leur fabrication. En outre, les coûts élevés des masques photolithographiques et d'autres conditions préalables à la fabrication font qu'il est essentiel de concevoir le circuit de manière à ce qu'il soit aussi parfait que possible avant que le circuit intégré ne soit lancé en fonderie pour la première fois.

La simulation du circuit avec SPICE est la méthode standard de l'industrie pour vérifier le fonctionnement d'une conception au niveau du transistor avant de s'engager dans la fabrication d'un circuit intégré. Les simulateurs SPICE aident à prédire le comportement du circuit intégré dans différentes conditions de fonctionnement, telles que différents niveaux de tension et de courant, des variations de température et du bruit[1].

Les conceptions de circuits au niveau de la carte peuvent souvent être montées sur une carte d'essai pour être testées. Même avec une carte d'essai, certaines propriétés du circuit peuvent ne pas être précises par rapport à la carte de circuit imprimée finale, comme les résistances et capacités parasite, dont les effets peuvent souvent être estimés avec plus de précision à l'aide de la simulation. Par ailleurs, les concepteurs peuvent souhaiter disposer de plus d'informations sur le circuit que celles disponibles à partir d'une maquette unique. Par exemple, les performances du circuit sont affectées par les tolérances de fabrication des composants. Dans ce cas, il est courant d'utiliser SPICE pour effectuer des simulations Monte Carlo de l'effet des variations des composants sur les performances, une tâche qui n'est pas réalisable en effectuant des calculs à la main pour un circuit d'une complexité appréciable.

Les programmes de simulation de circuits, dont SPICE et ses dérivés sont les plus importants, prennent un texte netlist décrivant les éléments du circuit (transistors, résistances, condensateurs, etc.) et leurs connexions, et traduisent[2] cette description en équations à résoudre. Les équations générales produites sont des systèmes d'équations algébriques différentielles (en) non linéaires qui sont résolues à l'aide de méthodes d'intégration implicite, de méthode de Newton et de techniques de matrice creuse.

Historique[modifier | modifier le code]

SPICE a été créé à l'université de Californie (Berkeley) au début des années 1970 par l'équipe de Ron Rohrer, dont en particulier Larry Nagel.

C'est devenu par la suite le standard des simulateurs analogiques. Trois versions se sont succédé dont la dernière, SPICE3, date de 1985[3].

Il est disponible sous licence BSD.

Différents avatars commerciaux existent depuis les années 1980. Parmi les plus célèbres, on peut citer IS_SPICE, PSpice, MICROCAP, HSpice, ELDO, etc.

Aujourd'hui le paysage de la simulation analogique tend à se modifier lentement avec le développement de langages de description matérielle évolués tels que le Verilog-A et le VHDL-AMS. Ceux-ci permettent une plus grande flexibilité de modélisation en facilitant la modélisation mixte analogique-numérique et en autorisant l'écriture d'un modèle sous la forme d'un système d'équations différentielles quelconques. On peut également signaler l'existence d'une extension AMS à SystemC qui a été spécifiée par l'Open SystemC Initiative (OSCI) et implémentée pour l'institut Fraunhofer pour les circuits intégrés.

Successeurs[modifier | modifier le code]

Successeurs open-source[modifier | modifier le code]

Aucune version plus récente de Berkeley SPICE n'a été publiée après la version 3f5 en 1993[4]. Depuis lors, les continuations open-source ou académiques de SPICE comprennent : XSPICE[5], développé au Georgia Tech, qui a ajouté des "modèles de code" mixtes analogiques/numériques pour la simulation comportementale ; CIDER[6] (précédemment CODECS), développé par UC Berkeley et Oregon State University, qui a ajouté la simulation de dispositifs à semi-conducteur (en) ; Ngspice (en)[7],[8], basé sur SPICE 3f5 ; WRspice[9], une réécriture en C++ du code original de spice3f5. D'autres simulateurs libres non développés par des universitaires sont QUCS, QUCS-S[10], Xyce[11], et Qucsator.

Versions commerciales et produits dérivés[modifier | modifier le code]

Berkeley SPICE a inspiré et servi de base à de nombreux autres programmes de simulation de circuits, dans les universités, dans l'industrie et dans les produits commerciaux. La première version commerciale de SPICE est ISPICE[12], une version interactive sur un service de multipropriété, National CSS (en). Les versions commerciales les plus connues de SPICE comprennent HSPICE (commercialisé à l'origine par Ashawna et Kim Hailey de Meta Software, mais appartenant maintenant à Synopsys) et PSPICE (en) (appartenant maintenant à Cadence Design Systems). L'industrie des circuits intégrés a rapidement adopté SPICE et, jusqu'à ce que les versions commerciales soient bien développées, de nombreuses sociétés de conception de circuits intégrés disposaient de versions propriétaires de SPICE[13].

Aujourd'hui, quelques fabricants de circuits intégrés, généralement les plus grandes entreprises, ont des groupes qui continuent à développer des programmes de simulation de circuits basés sur SPICE. Parmi ceux-ci figurent ADICE chez Analog Devices, LTspice (en) chez Analog Devices (disponible au public en tant que logiciel gratuit), MCSPICE, suivi de Mica chez Freescale Semiconductor, aujourd'hui NXP Semiconductors, et TINA-TI (en)[14] chez Texas Instruments. LTspice et TINA-TI sont tous deux fournis avec les modèles de leur société respective[15],[16]. D'autres entreprises disposent de simulateurs de circuits internes qui ne sont pas directement basés sur SPICE, notamment PowerSpice chez IBM, TITAN chez Infineon Technologies, Lynx chez Intel Corporation, et Pstar chez NXP Semiconductors également [17].

Fonctionnement[modifier | modifier le code]

SPICE utilise des composants élémentaires modélisés par un ensemble d'équations. Par exemple, pour une résistance, on a tout simplement la loi d'Ohm .

Le fait de relier ces composants entre eux permet de créer un système d'équations à l'aide des lois de Kirchhoff. Celui-ci est linéarisé localement autour du point de polarisation courant si besoin et résolu. En non-linéaire, il faut alors itérer jusqu'à convergence (point fixe) avant de passer au pas de temps suivant. Il arrive toutefois que le système ne converge pas, lorsqu'il est mal conditionné ce qui est souvent provoqué par des nœuds en haute impédance.

Caractéristiques et structure du programme[modifier | modifier le code]

SPICE est devenu populaire parce qu'il contenait les analyses et les modèles nécessaires à la conception des circuits intégrés de l'époque, et qu'il était suffisamment robuste et rapide pour être pratique à utiliser[18]. Les précurseurs de SPICE avaient souvent un seul objectif : le BIAS[19], par exemple, simulait les points de fonctionnement des circuits de transistors bipolaires ; le programme SLIC[20] programme ne faisait que des analyses de petits signaux (en). SPICE combinait des solutions de points de fonctionnement, des analyses transitoires et diverses analyses de petits signaux avec les éléments de circuit et les modèles de dispositifs nécessaires pour simuler avec succès de nombreux circuits.

Analyses[modifier | modifier le code]

SPICE2 comprend les analyses suivantes :

  • Analyse CA (analyse linéaire petits signaux (en) dans le domaine des fréquences)
  • Analyse DC (calcul non linéaire du point de repos) ;
  • Analyse de la courbe de transfert CC (une séquence de points de fonctionnement non linéaires calculés en balayant une tension ou un courant d'entrée, ou un paramètre de circuit) ;
  • Analyse de bruit (une analyse de petits signaux réalisée à l'aide d'une technique de matrice adjointe qui additionne des courants de bruit non corrélés à un point de sortie choisi) ;
  • Analyse de la fonction de transfert (calcul du gain et de l'impédance d'une entrée/sortie à petit signal) ;
  • Analyse transitoire (solution à grand signal dans le domaine temporel d'équations algébriques différentielles non linéaires).

Étant donné que SPICE est généralement utilisé pour modéliser des circuits non linéaires, les analyses de petits signaux sont nécessairement précédées d'un calcul du point de repos auquel le circuit est linéarisé. SPICE2 contient également du code pour d'autres analyses de petits signaux : analyse de sensibilité, analyse pôle-zéro (en) et analyse de distorsion à petit signal. L'analyse à différentes températures est réalisée en mettant automatiquement à jour les paramètres du modèle de semi-conducteur en fonction de la température, ce qui permet de simuler le circuit à des températures extrêmes.

D'autres simulateurs de circuits ont depuis ajouté de nombreuses analyses au-delà de celles de SPICE2 pour répondre à l'évolution des besoins de l'industrie. Des balayages paramétriques ont été ajoutés pour analyser les performances du circuit en cas de modification des tolérances de fabrication ou des conditions de fonctionnement. Des calculs de gain de boucle et de stabilité ont été ajoutés pour les circuits analogiques. Des analyses d'équilibre harmonique (en) (en anglais : Harmonic balance) ou de régime permanent dans le domaine temporel ont été ajoutées pour la conception de circuits RF et à condensateurs commutés. Toutefois, aucun simulateur de circuit du domaine public contenant les analyses et les fonctions modernes nécessaires pour succéder à SPICE en termes de popularité n'a encore vu le jour[18].

Il est très important d'utiliser des analyses appropriées avec des paramètres soigneusement choisis. Par exemple, l'application d'une analyse linéaire à des circuits non linéaires doit être justifiée séparément. De même, l'application de l'analyse transitoire avec des paramètres de simulation par défaut peut conduire à des conclusions qualitativement erronées sur la dynamique du circuit[21].

Modèles de dispositifs[modifier | modifier le code]

SPICE2 comprend de nombreux modèles compacts (en) de dispositifs semi-conducteurs : trois niveaux de modèle MOSFET, un modèle combiné Ebers-Moll et Gummel-Poon, un modèle JFET et un modèle pour une diode de jonction. En outre, il comportait de nombreux autres éléments : résistances, condensateurs, inductances (y compris couplage), tension et source de courant indépendantes, ligne de transmission idéale, composants actifs et sources contrôlées en tension et en courant.

SPICE3 a ajouté des modèles MOSFET plus sophistiqués, rendus nécessaires par les progrès de la technologie des semi-conducteurs. En particulier, la famille de modèles BSIM (en) a été ajoutée, qui a également été développée à l'UC Berkeley.

Les simulateurs commerciaux et industriels SPICE ont ajouté de nombreux autres modèles de dispositifs au fur et à mesure que la technologie progressait et que les modèles antérieurs devenaient inadéquats. Pour tenter de normaliser ces modèles afin qu'un ensemble de paramètres de modèle puisse être utilisé dans différents simulateurs, un groupe de travail industriel a été formé, le Compact Model Council (en)[22], pour choisir, maintenir et promouvoir l'utilisation de modèles normalisés. Les modèles standard actuels comprennent BSIM3, BSIM4, BSIMSOI, PSP, HICUM et MEXTRAM.

Entrée et sortie : Listes netlist, capture et traçage de schémas[modifier | modifier le code]

SPICE2 prend en entrée une netlist textuelle et produit en sortie des listings imprimés à la machine à écrire, ce qui correspond à l'environnement informatique de 1975. Ces listes sont soit des colonnes de nombres correspondant à des sorties calculées (typiquement des tensions ou des courants), soit des caractères "plots". SPICE3 conserve la liste des réseaux pour la description des circuits, mais permet de contrôler les analyses à partir d'une interface en ligne de commande similaire à l'interpréteur en C shell. SPICE3 a également ajouté un système de traçage de base X Window System, à mesure que les UNIX et les stations de travail d'ingénierie devenaient courants.

Les fournisseurs et divers projets de logiciels libres ont ajouté des frontals de capture de schémas (en) à SPICE, ce qui permet de dessiner un schéma du circuit et de générer automatiquement la liste netlist et de la transférer à divers backends SPICE. Des interfaces graphiques ont également été ajoutées pour sélectionner les simulations à effectuer et manipuler les vecteurs de sortie de tension et de courant. En outre, des utilitaires graphiques très performants ont été ajoutés pour visualiser les formes d'onde et les graphiques des dépendances paramétriques. Plusieurs versions gratuites de ces programmes étendus sont disponibles.

Netlists SPICE[modifier | modifier le code]

Les netlists SPICE sont les fichiers d'entrée du simulateur. Ils comportent la liste des composants avec (dans l'ordre) :

  1. leur type et référence (R3 est une résistance) ;
  2. les nœuds auxquels ils sont reliés (deux pour une résistance, trois pour un transistor bipolaire...) ;
  3. la valeur dans les cas simples ;
  4. éventuellement le modèle (jeu de paramètres utilisés) ;
  5. éventuellement une liste de paramètres permettant d'altérer le modèle utilisé.

Exemple de netlist SPICE[modifier | modifier le code]

* Ceci est un commentaire
C1 1 0 1n
* résistance utilisant un modèle modifié 
* et un paramètre (température)
R1 1 2 1k ResModel TEMP=27

* générateur sinusoïdal
VIN 2 0 SIN(0 1 1k)

On a ici un générateur sinusoïdal de 1 V à 1 kHz à l'entrée d'un circuit RC passe-bas.

Utilisation de SPICE au-delà de la simulation électronique[modifier | modifier le code]

Comme SPICE résout généralement des équations algébriques différentielles non linéaires, il peut être appliqué à la simulation au-delà du domaine électrique.

Les plus importantes sont les simulations thermiques, car les systèmes thermiques peuvent être décrits par des éléments de circuit forfaitaires correspondant aux éléments électroniques SPICE (capacité thermique → capacité, conductance/résistance thermique → conductance/résistance, température → tension, flux de chaleur ou chaleur générée → courant[23]). Les systèmes thermiques et électroniques étant étroitement liés par la dissipation de puissance et les systèmes de refroidissement, la simulation électrothermique est aujourd'hui prise en charge par les fabricants de dispositifs semi-conducteurs qui proposent des modèles (de transistors) avec des nœuds électriques et thermiques[24]. On peut donc obtenir la dissipation de puissance électrique, qui entraîne un auto-échauffement provoquant des variations de paramètres, et l'efficacité du système de refroidissement en une seule simulation.

SPICE peut très bien simuler la partie électronique d'une commande de moteur. Cependant, il décrira tout aussi bien le modèle électro-mécanique du moteur. Encore une fois, ceci est réalisé en faisant correspondre les éléments mécaniques aux éléments électriques (couple → tension, vitesse angulaire → courant, coefficient de frottement visqueux → résistance, moment d'inertie → inductance)[25]. Ainsi, le modèle final n'est constitué que d'éléments de circuits forfaitaires compatibles avec SPICE, mais on obtient des données mécaniques en même temps que des données électriques au cours de la simulation[26].

La modélisation électromagnétique est accessible à un simulateur SPICE via la méthode PEEC (circuit équivalent à éléments partiels)[27]. Les équations de Maxwell ont été cartographiées, le RLC, l'effet Skin, les matériaux diélectriques ou magnétiques et les champs incidents ou rayonnés ont été modélisés.

Cependant, en 2019, SPICE ne peut pas être utilisé pour "simuler la photonique et l'électronique ensemble dans un simulateur de circuit photonique"[28] et il n'est donc pas encore considéré comme un simulateur de test pour les circuits intégrés photoniques.

Les circuits microfluidiques ont été modélisés avec SPICE[29] en créant un FET pneumatique.

SPICE a été appliqué pour modéliser l'interface entre les systèmes biologiques et électroniques, par exemple comme outil de conception pour la biologie synthétique et pour le prototypage virtuel de biocapteurs et de laboratoires sur puce[30].

SPICE a été appliqué en recherche opérationnelle pour évaluer des chaînes d'approvisionnement perturbées[31].

Voir aussi[modifier | modifier le code]

Articles connexes[modifier | modifier le code]

Notes et références[modifier | modifier le code]

  1. (en) « SPICE Simulators », sur BTV (consulté le ).
  2. (en) Colin Warwick, « Everything you always wanted to know about SPICE* (*But were afraid to ask) », EMC Journal, no 82,‎ , p. 27-29 (lire en ligne [PDF]).
  3. (en) SPICE History
  4. (en) « The Spice Page », Berkeley University (consulté le ).
  5. F.L. Cox, W.B. Kuhn, J.P. Murray et S. D. Tynor, [Proceedings&#93 ; 1992 IEEE International Symposium on Circuits and Systems, vol. 2, , 871-874 p. (ISBN 0-7803-0593-0, DOI 10.1109/ISCAS.1992 .230083, S2CID 195705106), « Modélisation au niveau du code dans XSPICE »
  6. CODECS : A Mixed-Level Circuit and Device Simulator, K. Mayaram, Memorandum No. UCB/ERL M88/71, Berkeley, 1988, http://www.eecs.berkeley.edu/Pubs/TechRpts/1988/ERL-88-71.pdf
  7. "ngspice, current status and future developments", H. Vogt, FOSDEM, Bruxelles 2019
  8. « ngspice - an open source mixed signal circuit simulator », Free Silicon Foundation (F-Si) (consulté le )
  9. « WRspice », Whiteley Research (consulté le )
  10. QUCS-S software
  11. Xyce software, Sandia National Laboratories.
  12. (en) A. Vladimirescu, Proceedings on Bipolar Circuits and Technology Meeting, , 96-101 p. (DOI 10.1109/BIPOL.1990.171136, S2CID 62622975), « SPICE : The third decade »
  13. (en) K. S. Kundert, The Designer's Guide to SPICE and Spectre, Boston, Kluwer. Academic Publishers, .
  14. (en) « SPICE-Based Analog Simulation Program - TINA-TI - TI Software Folder » [archive du ], sur ti.com.
  15. (en) Art Kay, Operational Amplifier Noise : Techniques and Tips for Analyzing and Reducing Noise, Elsevier, (ISBN 978-0-08-094243-8, lire en ligne), p. 41.
  16. (en) Ron Mancini, Op Amps for Everyone, Newnes, (ISBN 978-0-12-394406-1, lire en ligne), p. 162.
  17. (en) PSPICE Circuit Simulation Overview : Part 1, Chris Iannello () NASA Engineering and Safety Center (NESC) Academy. Consulté le . La scène se produit à 2:39.
  18. a et b (en) L. Nagel, Is it Time for SPICE4 ?, Santa Fe, Nouveau Mexique, Numerical Aspects of Device and Circuit Modeling Workshop, 23-25 juin 2004, (lire en ligne [archive du ] [PDF]).
  19. (en) McCalla et Howard, « BIAS-3 : A program for nonlinear D.C. analysis of bipolar transistor circuits », IEEE Journal of Solid-State Circuits, vol. 6, no 1,‎ , p. 14-19 (DOI 10.1109/JSSC.1971 .1050153, Bibcode 1971IJSSC...6... 14M).
  20. (en) Idleman, Jenkins, McCalla et Pederson, « SLIC : A simulator for linear integrated circuits », IEEE Journal of Solid-State Circuits, vol. 6, no 4,‎ , p. 188-203 (DOI 10.1109/JSSC.1971 .1050168, Bibcode 1971IJSSC...6..188I).
  21. (en) Giovanni Bianchi, 2015 7th International Congress on Ultra Modern Telecommunications and Control Systems and Workshops (ICUMT), , 79-84 p. (ISBN 978-1-4673-9283-9, DOI 10.1109/ICUMT.2015 .7382409, arXiv 1506.02484, S2CID 7140415), « Limites de la simulation PLL : oscillations cachées dans l'analyse SPICE ».
  22. (en) « CMC - Compact Model Council » [archive du ], GEIA
  23. (en) « ngspice tutorial on electro-thermal simulation » (consulté le ).
  24. (en) M. Maerz et Paul Nance, « Thermal Modeling of Power-electronic Systems », Fraunhofer IISB (consulté le ).
  25. (en) « AB-025 : Using SPICE To Model DC Motors », Precision Microdrives, (consulté le ).
  26. (en) Pham et Nathan, « Circuit Modeling and SPICE Simulation of Mixed-Signal Microsystems », Sensors and Materials, vol. 10, no 7,‎ , p. 435-460 (lire en ligne [PDF]).
  27. (en) Albert E. Ruehli, Giulio Antonini et Lijun Jiang, Circuit Oriented Electromagnetic Modeling Using the PEEC Techniques, Wiley, (ISBN 978-1-11-843664-6, lire en ligne).
  28. (en) Wim Bogaerts et Lukas Chrostowski, « Silicon Photonics Circuit Design : Methods, Tools and Challenges », Laser & Photonics Reviews, vol. 12, no 4,‎ , p. 1700237 (DOI 10.1002/lpor.201700237 Accès libre, Bibcode 2018LPRv...1200237B, hdl 1854/LU-8578535 Accès libre).
  29. H. Takao e.a., Micro Fluidic Circuit Design with "SPICE" Simulation, IEEE, , 1154-1157 p. (DOI 10.1109/MEMSYS.2011.5734635, S2CID 24263237, lire en ligne).
  30. (en) Morgan Madec e.a., « Modélisation et simulation de systèmes biologiques à l'aide du langage SPICE », PLOS ONE, vol. 12, no 8,‎ , e0182385 (PMID 28787027, PMCID 5546598, DOI 10.1371/journal.pone.0182385 Accès libre, Bibcode 2017PLoSO..1282385M).
  31. (en) Francisco Campuzano-Bolarín e.a., « Méthode de simulation de réseau pour l'évaluation de chaînes d'approvisionnement perturbées sur un horizon fini », CEJOR, Cent. Eur. J. Oper. Res, vol. 29, no 3,‎ , p. 823-839 (DOI 10.1007/s10100-021-00748-3, S2CID 235523347, lire en ligne).

Littérature[modifier | modifier le code]

Liens externes[modifier | modifier le code]