У этого термина существуют и другие значения, см. 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 включает в себя:
AC-анализ (анализ по переменному току)
DC-анализ (анализ по постоянному току) для слабых сигналов
Входные и выходные форматы: Netlist, schematic capture и plotting
SPICE2 принимает netlist в текстовом виде на вход и выдает line-printer listings как результат своей работы. Такая программа была типичной для 1975 года. Листинги представляют либо колонки с номерами, соответствующими рассчитанным выходным параметрам (чаще всего, токам и напряжениям), либо представляли собой рисунок из символов (ASCII art). SPICE3 оставил формат netlist для описания схем, но позволил контролировать анализ с помощью командного интерфейса (CLI). Также в SPICE3 появились базовые варианты отрисовки схемы в графической среде X Window, по мере того, как Unix и рабочие станции становились более популярными.
↑Ho, Ruehli, and Brennan (1974). "The Modified Nodal Approach to Network Analysis". Proc. 1974 Int. Symposium on Circuits and Systems, San Francisco. pp. 505–509. Архивировано 15 мая 2011. Дата обращения: 17 мая 2010. {{cite conference}}: Неизвестный параметр |month= игнорируется (справка)Википедия:Обслуживание CS1 (множественные имена: authors list) (ссылка)Источник (неопр.). Дата обращения: 14 июня 2023. Архивировано 15 мая 2011 года.
↑Quarles, Thomas L., Analysis of Performance and Convergence Issues for Circuit Simulation, Memorandum No. UCB/ERL M89/42, University of California, Berkeley, Apr. 1989.
↑Nagel, L., Is it Time for SPICE4?Архивировано 26 сентября 2006 года., 2004 Numerical Aspects of Device and Circuit Modeling Workshop, June 23-25, 2004, Santa Fe, New Mexico. Retrieved on 2007-11-10