SPICE (симулятор электронных схем)

Материал из Википедии — свободной энциклопедии
Перейти к: навигация, поиск

SPICE (Simulation Program with Integrated Circuit Emphasis) — симулятор электронных схем общего назначения с открытым исходным кодом. Является мощной программой, используемой в разработке как интегральных схем, так и печатных плат для проверки целостности схемы и для анализа ее поведения.

Введение[править | править исходный текст]

Интегральные схемы, в отличие от печатных плат, практически не поддаются макетированию перед производством. Кроме того, высокая стоимость создания фотолитографических масок и других этапов полупроводникового производства приводят к необходимости очень тщательной разработки и верификации. Симуляция схемы при помощи SPICE является общепринятым в полупроводниковой промышленности способом верификации работы схемы на транзисторном уровне (перед её реализацией в кремнии).

Для печатных плат, особенно небольшой сложности, возможно проводить макетирование. Но на макетной плате некоторые свойства схем могут быть неточны по сравнению с итоговой платой. Например, на макетной плате у печатных дорожек будут иные паразитные сопротивления и ёмкости. Подобные паразитные элементы часто можно оценить при помощи симуляции на SPICE.


История[править | править исходный текст]

SPICE был разработан в Electronics Research Laboratory в Калифорнийском университете в Беркли Лоуренсом Нагелем (Laurence Nagel) и его научным руководителем профессором Дональдом Педерсоном (Donald Pederson). SPICE1 был в значительной степени основан на более ранней программе CANCER,[1] написанной Лоуренсом с другим научным руководителем, профессором Рональдом Рохрером (Ronald Rohrer). Название программы расшифровывалось как «Computer Analysis of Nonlinear Circuits, Excluding Radiation» (Компьютерный анализ нелинейных схем, исключая радиацию), что было отсылкой к относительной свободе в Университете Беркли в 1960-х годах[2]. В то время большая часть симуляторов электронных схем разрабатывалась по грантам и контрактам министерства обороны США, одним из требований которых была возможность оценки влияния радиации на работу схем (См. Radiation hardening). После смены научного руководителя, Нагелю пришлось переписать проприетарный CANCER так, чтобы новую программу можно было опубликовать в открытом доступе, таким образом передав в общественное достояние.[3]


Впервые SPICE1 был представлен на конференции в 1973.[4] Программа была написана на языке FORTRAN и использовала анализ цепи методом узловых потенциалов для построения уравнений схемы. Метод узловых потенциалов имел ограничения в работе с индуктивностями, источниками переменного напряжения и с различными вариантами управляемых генераторов тока и напряжения. В SPICE1 было доступно небольшое количество элементов, программа использовала анализ переходных процессов (transient analysis) с фиксированным шагом по времени. Популярность пришла ко второй версии программы, SPICE2[5], в 1975 году. Она тоже была написана на FORTRAN, но имела больше элементов, позволяла изменять шаг по времени при анализе переходных процессов, уравнения цепей формулировались при помощи модифицированного метода узловых потенциалов (modified nodal analysis)[6], устраняя тем самым ограничения метода узловых потенциалов. Последняя версия SPICE, написанная на языке FORTRAN, — 2G.6 (1983 год). Следующую версию, SPICE3[7] разработал Томас Кворлс (Thomas Quarles) в 1989. Она написана на языке Си, использует тот же формат данных об электрических цепях (netlist) и поддерживает визуализацию в среде X Window System.

С ранних версий SPICE являлась программным обеспечением с открытыми исходными кодами, что способствовало ее широкому распространению и применению. SPICE стала индустриальным стандартом симуляции электрических схем[8]. Исходные коды SPICE распространялись университетом по номинальной стоимости (по цене магнитной ленты). Лицензия изначально включала в себя условия, ограничивающие передачу кода в некоторые недружественные США страны, но в настоящее время программа распространяется по условиям лицензии BSD.

SPICE послужил основой для разработки множества других программ симуляции схем, как в академической, так и в промышленной среде. Первая коммерческая версия - ISPICE,[9] (National CSS). Наиболее выдающиеся коммерческие версии SPICE: HSPICE (изначально Meta Software, ныне Synopsys) и PSPICE (ныне Cadence Design Systems). Академические версии программы: XSPICE (Georgia Tech, с поддержкой смешанных аналого-цифровых моделей) и Cider (ранее CODECS, UC Berkeley и Oregon State Univ.; с поддержкой полупроводниковых устройств). Индустрия проектирования интегральных схем достаточно рано начала пользоваться SPICE, и, до развития коммерческих реализаций, многие компании-разработчики микросхем имели собственные проприетарные версии SPICE.[10] В настоящее время крупные производители микросхем развивают собственные программы симулирования на базе SPICE. Например, ADICE у компании Analog Devices, LTspice у Linear Technology, Mica у Freescale Semiconductor, TISPICE у Texas Instruments.

В 2011 году появление SPICE было отнесено к IEEE Milestone,[11] было отмечено, что SPICE и его производные стали неотъемлемой частью разработки практически любой интегральной схемы.

Особенности и структура программы[править | править исходный текст]

SPICE стал популярен, поскольку поддерживал анализ и содержал модели, необходимые для разработки интегральных схем того времени, и при этом был достаточно быстрым для практического использования.[12] Предшественники SPICE часто имели лишь одно предназначение, например BIAS[13] позволял рассчитывать режимы биполярных транзисторов; SLIC[14] производил анализ малых сигналов. SPICE комбинировал в себе несколько режимов анализа и достаточно обширную библиотеку моделей устройств.

Виды анализа[править | править исходный текст]

SPICE2 включает в себя:


Модели элементов[править | править исходный текст]

Входные и выходные форматы: Netlist, schematic capture и plotting[править | править исходный текст]

SPICE2 принимает netlist в текстовом виде на вход и выдает line-printer listings как результат своей работы. Такая программа была типичной для 1975 года. Листинги представляют либо колонки с номерами, соответствующими рассчитанным выходным параметрам (чаще всего, токам и напряжением), либо представляли собой рисунок из символов (ASCII art). SPICE3 оставил формат netlist для описания схем, но позволил контролировать анализ с помощью командного интерфейса (CLI). Также в SPICE3 появились базовые варианты отрисовки схемы в графической среде X Window, по мере того, как Unix и рабочие станции становились более популярными.


См. также[править | править исходный текст]

Примечания[править | править исходный текст]

  1. Nagel, L. W., and Rohrer, R. A. (August 1971). «Computer Analysis of Nonlinear Circuits, Excluding Radiation». IEEE Journal of Solid State Circuits SC-6: 166–182. DOI:10.1109/JSSC.1971.1050166.
  2. Life of SPICE
  3. Perry, T. (June 1998). «Donald O. Pederson». IEEE Spectrum 35: 22–27. DOI:10.1109/6.681968.
  4. SPICE (Simulation Program with Integrated Circuit Emphasis), Technical Report No. UCB/ERL M382, April 1973, Laurence W. Nagel and D.O. Pederson
  5. SPICE2: A Computer Program to Simulate Semiconductor Circuits, Laurence W. Nagel, Berkeley Technical Report No. UCB/ERL M520 1975
  6. Ho, Ruehli, and Brennan (April 1974). "The Modified Nodal Approach to Network Analysis". Proc. 1974 Int. Symposium on Circuits and Systems, San Francisco: 505–509. 
  7. Quarles, Thomas L., Analysis of Performance and Convergence Issues for Circuit Simulation, Memorandum No. UCB/ERL M89/42, University of California, Berkeley, Apr. 1989.
  8. Pescovitz, David. 1972: The release of SPICE, still the industry standard tool for integrated circuit design, Lab Notes: Research from the Berkeley College of Engineering (2 мая 2002). Проверено 10 марта 2007.
  9. Vladimirescu, Andrei, SPICE -- The Third Decade, Proc. 1990 IEEE Bipolar Circuits and Technology Meeting, Minneapolis, Sept. 1990, pp. 96–101
  10. K. S. Kundert, The Designer’s Guide to SPICE and SPECTRE, Kluwer. Academic Publishers, Boston , 1998
  11. List of IEEE Milestones. IEEE Global History Network. IEEE. Проверено 1 января 2013. Архивировано из первоисточника 6 января 2013.
  12. Nagel, L., Is it Time for SPICE4?, 2004 Numerical Aspects of Device and Circuit Modeling Workshop, June 23-25, 2004, Santa Fe, New Mexico. Retrieved on 2007-11-10
  13. McCalla and Howard (February 1971). «BIAS-3 – A program for nonlinear D.C. analysis of bipolar transistor circuits». IEEE J. of Solid State Circuits 6: 14–19. DOI:10.1109/JSSC.1971.1050153.
  14. Idleman, Jenkins, McCalla and Pederson (August 1971). «SLIC—a simulator for linear integrated circuits». IEEE J. of Solid State Circuits 6: 188–203. DOI:10.1109/JSSC.1971.1050168.

Ссылки[править | править исходный текст]


Оригинальные работы о SPICE[править | править исходный текст]

Версии SPICE с исходными кодами[править | править исходный текст]

Руководства, информация для пользователей[править | править исходный текст]

Applications[править | править исходный текст]