Qucs — open-source САПР для моделирования электронных схем
В настоящее время существует не так уж и много open-source САПР. Тем не менее, среди САПР для электроники (EDA) есть весьма достойные продукты. Этот пост будет посвящён моделировщику электронных схем с открытым исходным кодом Qucs. Qucs написан на С++ с использованием фреймворка Qt4. Qucs является кроссплатформенным и выпущен для ОС Linux, Windows и MacOS.
Разработку данной САПР начали в 2004 году немцы Michael Margraf и Stefan Jahn (в настоящее время не активны). Сейчас Qucs разрабатывается интернациональной командой, в которую вхожу и я. Руководителями проекта являются Frans Schreuder и Guilherme Torri. Под катом будет рассказано о ключевых возможностях нашего моделировщика схем, его преимуществах и недостатках по сравнению с аналогами.
Главное окно программы показано на скриншоте. Там смоделирован резонансный усилитель на полевом транзисторе и получены осциллограммы напряжения на входе и выходе и также АЧХ.
Как видно, интерфейс интуитивно понятен. Центральную часть окна занимает собственно моделируемая схема. Компоненты размещаются на схеме методом перетаскивания из левой части окна. Виды моделирования и уравнения также являются особыми компонентами. Более подробно принципы редактирования схем описаны в документации к программе.
Формат схемного файла Qucs основан на XML и к нему поставляется документация. Поэтому схема Qucs может быть легко сгенерирована сторонними программами. Это позволяет создавать ПО для синтеза схем, которое является расширением Qucs. Проприетарное ПО как правило использует бинарные форматы.
Перечислим основные компоненты, имеющиеся в Qucs:
- Пассивные RCL-компоненты
- Диоды
- Биполярные транзисторы
- Полевые транзисторы (JFET, MOSFET, MESFET и СВЧ-транзисторы)
- Идеальные ОУ
- Коаксиальные и микрополосковые линии
- Библиотечные компоненты: транзисторы, диоды и микросхемы
- Файловые компоненты: подсхемы, spice-подсхемы, компоненты Verilog
Библиотека компонентов использует собственный формат, основанный на XML. Но можно импортировать существующие библиотеки компонентов, основанные на Spice (приводятся в даташитах на электронные компоненты).
- Моделирование рабочей точки на постоянном токе
- Моделирование в частотной области на переменном токе
- Моделирование переходного процесса во временной области
- Моделирование S-параметров
- Параметрический анализ
Результаты моделирования можно экспортировать в Octave/Matlab и выполнить там постобработку данных.
Qucs основан на вновь разработанном движке схемотехнического моделирования. Отличительной особенностью этого движка является встроенная возможность моделирования S-параметров и КСВ, что важно для анализа ВЧ-схем. Qucs может пересчитывать S-параметры в Y- и Z-параметры.
На скриншотах показан пример моделирования S-параметров широкополосного усилителя высокой частоты.
Итак, отличительной особенностью Qucs является возможность анализа комплексных частотных характеристик (КЧХ), построение графиков на комплексной плоскости и диаграмм Смита, анализ комплексных сопротивлений и S-параметров. Эти возможности отсутствуют в проприетарных системах MicroCAP и MultiSim, и здесь Qucs даже превосходит коммерческое ПО и позволяет получить недостижимые для симуляторов электронных схем, основанных на Spice результаты.
Недостатком Qucs является малое количество библиотечных компонентов. Но этот недостаток не является препятствием к использованию, так как Qucs совместим с форматом Spice в котором приводятся модели электронных компонентов в даташитах. Также моделировщик работает медленнее, чем аналогичные Spice-совместимые моделировщики (например MicroCAP (проприетарный) или Ngspice (open-source)).
В настоящее время мы работаем над возможностью предоставления пользователю выбора движка для моделирования схемы. Можно будет использовать встроенный движок Qucs, Ngspice (spice-совместимый консольный моделировщик, похожий на PSpice) или Xyce (моделировщик с поддержкой параллельных вычислений через OpenMPI )
Теперь рассмотрим перечень нововведений в недавнем релизе Qucs 0.0.18 перспективных направлений в разработке Qucs:
- Улучшена совместимость с Verilog
- Продолжается портирование интерфейса на Qt4
- Реализован список недавних открытых документов в главном меню.
- Реализован экспорт графиков, схем в растровые и векторные форматы: PNG, JPEG, PDF, EPS, SVG, PDF+LaTeX. Эта функция полезна при подготовке статей и отчётов, содержащих результаты моделирования
- Возможность открытия документа схемы из будущей версии программы.
- Исправлены баги, связанные с зависанием моделировщика при определённых условиях.
- Ведётся разработка системы синтеза активных фильтров для Qucs (ожидается в версии 0.0.19)
- Ведётся разработка сопряжения с прочими open-source движками для моделирования электронных схем (Ngspice, Xyce, Gnucap). В последующих версиях будет добавлена возможность выбора движка для моделирования схемы.
Можно заключить, что несмотря на свои недостатки Qucs представляет собой весьма достойную альтернативу проприетарным САПР для моделирования электронных схем.
Qucs: моделируем и анализируем
В отличие от некоторых более «продвинутых» аналогов, в Qucs нет моделирования в реальном времени: система сначала проводит необходимые расчеты, а затем отображает результаты в виде графиков, диаграмм и таблиц. На мой взгляд, отсутствие симуляции в режиме «онлайн» не является большой проблемой, поскольку визуально отследить электрические процессы просто невозможно из-за их малой длительности (миллисекунды или даже меньше). Впрочем, подобное упущение позволит исправить разработка на Битрикс (http://digitalpromo.com.ua/sites/) соответствующего сетевого решения, включающего в себя все плюсы Qucs и не имеющего минусов!
Настройка диаграммы
Исследование того или иного аспекта функционирования схемы требует своего подхода к моделированию. В Qucs можно использовать следующие типы симуляции:
> Моделирование на постоянном токе. Используется для анализа цепей постоянного тока.
> Моделирование переходного процесса. Позволяет наблюдать, как, например, происходит заряд конденсатора или определить время срабатывания реле.
> Моделирование на переменном токе. Используется для построения частотных характеристик элементов и цепей.
> Развертка параметра. Позволяет определить, как будут меняться характеристики цепи при изменении заданного параметра какого-либо из ее элементов.
> Цифровое моделирование. Используется для анализа цифровых схем.
> Оптимизация. Позволяет оптимизировать цепь по заданным критериям.
> Моделирование S-параметров. Используется для «малосигнального» моделирования.
> Гармонический баланс. Позволяет провести спектральный анализ сигнала.
Для того, чтобы добавить в схему требуемый вид моделирования нужно перетащить его из окна навигатора (вкладка «Компоненты», раздел «Виды моделирования») в рабочую область. Непосредственно расчет модели осуществляется кнопкой «Моделировать» в панели симулятора, выбором одноименного пункта в меню «Моделирование» или нажатием клавиши . Для получения результатов симуляции предварительно нужно установить в цепь амперметры или вольтметры (раздел «Измерители», вкладка «Компоненты» окна навигатора) или метки проводника, измеряющие напряжение (кнопка «Метка проводника» в панели симу-лятора или комбинация клавиш + ).
Результаты моделирования отображаются с помощью объектов из раздела «Диаграммы», помещенных на схему. При этом в свойствах таблицы или диаграммы необходимо выбрать, какие из доступных параметров будут отображаться.
В Qucs доступны следующие виды диаграмм:
> Декартовы двухмерные и трехмерные графики.
> Графики в полярных координатах.
> Диаграммы Смита.
> Круговые диаграммы.
> Таблицы.
> Временные диаграммы.
> Таблицы истинности.
Интегрирующая RC-цепь в Qucs
В качестве примера на рис. выше показана реализация схемы интегрирующей RC-цепи, которую можно найти в любом учебнике по основам радиотехники. В отличие от книги, «сухую» теорию здесь можно проверить в эксперименте пусть и виртуальным путем перебора различных значений сопротивления резистора, емкости конденсатора и длительности импульса.
Создание частотных фильтров в Qucs
Быстрый старт в аналоговом моделировании¶
Qucs (произносится: kju:ks) — симулятор цепей с графическим пользовательским интерфейсом. Он способен выполнять различные виды моделирования (например, на постоянном токе, S-параметров и т.д.). Этот документ дает краткое описание того, как пользоваться Qucs.
При первом запуске Qucs создает папку ”.qucs” в Вашей домашней папке. Каждый файл сохраняется в этой папке или в одной из ее подпапок. После загрузки Qucs показывается главное окно, которое выглядит примерно как на рис.1. С правой стороны расположена рабочая область (6), в которой содержатся схемы, документы показа данных и т.д.. С помощью вкладок (5) над этой областью можно быстро переключиться на любой документ, открытый в данный момент. С левой стороны главного окна Qucs находится еще одна область (1), содержание которой зависит от состояния вкладок, расположенных над ней: “Проекты” (2), “Содержание” (3) и “Компоненты” (4). После запуска Qucs активируется вкладка “Проекты” (2). Так как Вы запустили программу в первый раз, эта область пустая, поскольку у Вас еще нет ни одного проекта. Нажмите кнопку “Создать” прямо над областью (1) и откроется диалоговое окно. Введите имя для Вашего первого проекта, например, “firstProject” и нажмите кнопку “Создать”. Qucs создает папку проекта в папке
/.qucs, для этого примера “firstProject_prj”. Каждый файл, принадлежащий этому новому проекту, будет сохранен в этой папке. Новый проект немедленно открывается (это можно прочитать в заголовке окна) и вкладки переключаются на “Содержание” (3), где показывается содержание открытого в данный момент проекта. У Вас еще нет ни одного документа, поэтому нажмите кнопку сохранения на панели инструментов (или используйте главное меню: Файл->Сохранить) чтобы сохранить документ без названия, который заполняет рабочую область (6). После этого появится диалоговое окно для ввода имени нового документа. Введите “firstSchematic” и нажмите кнопку “Сохранить”.
Рис. 1 — Главное окно Qucs
Теперь нам нужно сделать простое моделирование на постоянном токе, то есть мы хотим проанализировать схему на рис. 1. Выберите вкладку “Компоненты” ( (4) на рис. 1). Там Вы увидите выпадающий список, в котором можно выбрать группу компонентов и, ниже, компоненты выбранной группы. Выберите “дискретные компоненты” и нажмите на первый символ: “Резистор”. Перемещая курсор мыши в рабочую область (6), Вы переносите рисунок обозначения резистора. Нажатие правой кнопки мыши вращает обозначение, нажатие левой кнопки мыши помещает компонент на схему. Повторите этот процесс для всех компонентов, показанных на рис. 1. Источник напряжения может быть найден в классе компонентов “источники”, обозначение заземления может быть взято из класса “дискретные компоненты” или с панели инструментов, требуемое моделирование определяется с помощью больших блоков моделирования, находящихся в классе компонентов “виды моделирования”. Чтобы изменить параметры второго резистора, сделайте двойное нажатие левой кнопки мыши на нем. Откроется диалоговое окно, где можно изменить сопротивление. Введите “100 Ohm” в поле редактирования справа и нажмите Enter.
Чтобы соединить компоненты, нажмите кнопку с проводником на панели инструментов (или воспользуйтесь главным меню: Вставка->Проводник). Переместите курсор на незанятый вывод (помеченный маленьким красным кружком). Нажатие кнопки мыши на нем начинает проводник. Теперь передвиньте курсор к конечной точке и снова нажите кнопку мыши. Теперь компоненты соединены. Если Вы хотите изменить направление изгиба проводника, нажмите правую кнопку мыши, прежде чем делать конечную точку. Вы можете также закончить проводник, не нажимая ни на свободный вывод, ни на проводник: просто сделайте двойное нажатие левой кнопки мыши.
Наконец, очень важно пометить узел, в котором Вы хотите, чтобы Qucs рассчитал напряжение. Нажмите на панели инструментов кнопку для метки проводника (или воспользуйтесь меню: Вставка->Метка проводника). Теперь нажмите кнопку мыши на выбранном проводнике. Откроется диалоговое окно и можно ввести имя узла. Напишите “divide” и нажмите кнопку “Ok”. Теперь схема должна выглядеть как на рис. 1.
Для запуска моделирования нажмите кнопку моделирования на панели инструментов (или используйте меню: Моделирование->Моделировать). Откроется окно и покажет продвижение процесса. После успешного завершения моделирования открывается документ показа данных. Обычно все это происходит так быстро, что Вы увидите лишь быстрое мелькание. Теперь Вам нужно поместить диаграмму, чтобы увидеть результаты моделирования. Слева находится класс компонентов “диаграммы”, который выбирается автоматически. Нажмите на “Табличная”, перейдите в рабочую область и поместите ее, нажав левую кнопку мыши. Открывается диалоговое окно, где можно выбрать, что следует показать в новой диаграмме. В левой области видно имя узла, которое Вы задали: “divide”. Сделайте двойное нажатие кнопки мыши на нем, и оно будет перенесено в правую область. Выйдите из диалога нажатием кнопки “Ok”. Теперь виден результат моделирования: 0.666667 вольт. Замечательно, похлопайте себя по плечу!
Симулятор электронных схем с открытым исходным кодом Qucs: основные возможности и основы моделирования
На современных предприятиях все чаще используется свободное программное обеспечение (СПО) с открытым исходным кодом (open-source software — OSS). В основном это серверные операционные системы (ОС), серверное программное обеспечение, системы управления базами данных (СУБД) и тому подобное программное обеспечение (ПО). По качеству и уровню техподдержки СПО не уступает проприетарным аналогам. Его применение способствует получению значительного экономического эффекта за счет сокращения расходов при закупке лицензий. Также достигается независимость от транснациональных корпораций, поскольку исходный код СПО контролируется пользователями, что особенно актуально в условиях санкций.
Но переход на СПО возможен не для всех классов ПО. Среди систем автоматизированного проектирования (САПР), как правило, доминируют проприетарные программные продукты. Однако в последние годы у них появились альтернативы. В статье рассматривается open-source-симулятор электронных схем Qucs [1, 2], его ключевые возможности и методика применения. Последнюю полнофункциональную версию Qucs-0.0.18 для всех поддерживаемых ОС можно бесплатно загрузить на сайте разработчика [1].
В настоящее время существует не так уж много САПР open-source. Обычно по функциональным характеристикам они уступают проприетарным аналогам, тем не менее среди САПР для электроники (EDA) есть весьма достойные продукты. К ним относится и симулятор электронных схем Qucs. Название данной САПР — это сокращение от Quite Universal Circuit Simulator (почти универсальный симулятор электронных схем). Как правило, для моделирования электронных схем используется такое проприетарное ПО, как MicroCAP, MultiSim, OrCAD и т. п. Это сложные программные комплексы, стоимость которых превышает несколько тысяч долларов, а Qucs является доступной альтернативой данным программным продуктам. К ее аналогам среди СПО относятся консольные симуляторы электронных схем Ngspice [3], Xyce [4] и Gnucap.
В 2004 году сотрудники Берлинского института высокочастотной техники Michael Margraf и Stefan Jahn [5] начали разработку Qucs. Сейчас к проекту, которым в настоящее время руководят Frans Schreuder и Guilherme Torri [2], подключилась интернациональная команда специалистов. Qucs написан на С++ с использованием фреймворка Qt4, и поэтому является кроссплатформенным и выпущен для ОС Linux, Windows и MacOS. Для достижения наилучших результатов рекомендуется использовать ОС Linux. Текущей версией проекта является 0.0.18. Ведется подготовка к релизу версии 0.0.19. Все желающие могут предложить изменения для исходного кода программы, сообщить об ошибках, запросить реализацию новой функции [2].
Возможности Qucs
Qucs предназначен для моделирования цифровых и аналоговых схем во временной и частотной областях от постоянного тока до СВЧ-частот. В противоположность многим современным симуляторам схем, базирующимся на ядре моделирования SPICE, Qucs основан на ядре qucsator оригинальной разработки [5]. Недостатком этого ядра является то, что используется формат списка цепей (netlist), отличный от SPICE. Данный недостаток удается преодолеть при помощи встроенной утилиты конвертирования файлов списка цепей. Ну а преимущество в том, что предусмотрена встроенная возможность моделирования S-параметров и гармонического баланса.
Перечислим доступные виды моделирования:
- Моделирование рабочей точки на постоянном токе (DC analysis).
- Моделирование в частотной области на переменном токе (AC analysis) с возможностью расчета шумовых напряжений.
- Моделирование переходного процесса во временной области (Transient analysis).
- Моделирование S-, Z-, Y-, A-параметров (S-parameter analysis) и КСВ с возможностью расчета шумовых напряжений.
- Моделирование цифровых схем — временные диаграммы и таблицы истинности.
- Гармонический баланс.
- Спектральный анализ.
- Параметрический анализ (Parameter sweep).
Поддерживаются следующие классы электронных компонентов:
- Пассивные RCL-компоненты.
- Источники постоянного тока и напряжения, переменного синусоидального напряжения, импульсного напряжения, напряжения произвольной формы, шумового напряжения, управляемые источники напряжения и тока, модулированные источники.
- Диоды, диоды Зенера, тиристоры, туннельные диоды.
- Биполярные транзисторы.
- Полевые транзисторы (JFET, MOSFET, MESFET и СВЧ-транзисторы).
- Фотодиоды, фототранзисторы.
- Идеальные ОУ.
- СВЧ-компоненты: коаксиальные и микро-полосковые линии.
- Библиотечные компоненты: транзисторы, диоды и аналоговые микросхемы.
- Цифровые компоненты — логические элементы, триггеры, счетчики, регистры, сумматоры, шифраторы, дешифраторы, VHDL-компоненты.
- Файловые компоненты: подсхемы, spice-подсхемы, компоненты Verilog, файлы S-параметров.
- Виртуальные датчики тока и напряжения.
- Математические уравнения. Рассмотрим интерфейс программы.
Главное окно программы показано на рис. 1. В качестве примера смоделирован резонансный усилитель радиочастоты на полевом транзисторе с p-n-переходом (JFET).
Рис. 1. Главное окно Qucs и пример моделирования схемы
В программе применен графический интерфейс пользователя со вкладками. Центральную часть окна занимают вкладки, на которых отображаются моделируемые схемы. Возможно одновременно открывать несколько схем, каждая из которых будет расположена на своей вкладке. Компоненты размещаются на схеме методом перетаскивания из левой части окна. Математические уравнения и виды моделирования и уравнения также являются особыми компонентами. Более подробно принципы редактирования схем описаны в документации к программе.
Проприетарными аналогами Qucs являются такие широко известные САПР, как MicroCAP, MultiSim, LTSpice и Proteus. По количеству видов моделирования и возможностям постобработки результатов моделирования с применением математического ПО (Matlab, Octave, Python) Qucs не уступает проприетарным аналогам и даже по отельным характеристикам превосходит их, так как в нем реализована возможность моделирования S-параметров, недоступная аналогам. Для использования в академических целях имеется важная функция экспорта схемы и результатов моделирования в растровые и векторные графические форматы. Но в Qucs отсутствуют такие возможности проприетарных САПР, как моделирование микроконтроллеров и интерактивное моделирование схем в реальном времени. Лидерами в этих областях являются САПР MultiSim и Proteus. На наш взгляд, включение этих возможностей в Qucs не оправдано, поскольку приводит к бесполезному потреблению вычислительных ресурсов персонального компьютера. В настоящее время данные задачи можно решать при помощи внутрисхемных средств отладки без применения моделирования. Таким образом, отсутствующие функции не становятся препятствием к использованию Qucs.
Серьезным ограничением Qucs остается отсутствие возможности цифро-аналогового моделирования. Здесь Qucs уступает лидеру в этой области — MicroCAP. В настоящее время мы работаем над реализацией такой возможности.
Qucs имеет следующие возможности по визуализации данных:
- Декартовские диаграммы (2D и 3D).
- Диаграммы в полярных координатах.
- Диаграммы на комплексной плоскости.
- Диаграммы Смита для сопротивлений и проводимостей.
- Табличная форма.
Имеется возможность использования маркеров на диаграммах, чтобы получить значение параметра в конкретной точке. Результаты моделирования можно экспортировать в Matlab-совместимую систему численной математики и выполнить там постобработку данных. Рекомендуется применять открытую Matlab-совместимую среду Octave. Возможен экспорт данных в виде CSV (comma separated values).
Формат схемного файла, основанный на XML, позволяет легко создавать утилиты для синтеза схем. В комплекте с Qucs поставляются утилиты для синтеза пассивных фильтров, аттенюаторов, согласованных схем, расчета микрополосковых, коаксиальных линий и волноводов.
Рис. 2. Модель широкополосного усилителя высокой частоты в Qucs
Qucs основан на вновь разработанном движке схемотехнического моделирования, особенностью которого является встроенная возможность моделирования S-параметров и КСВ, что важно для анализа ВЧ-схем. Qucs может пересчитывать S-параметры в Y-и Z-параметры. На рис. 2 и 3 показан пример моделирования S-параметров широкополосного усилителя высокой частоты и построения диаграммы Смита. Использование диаграмм Смита позволяет анализировать параметры в частотной области, степень согласованности схем и устойчивость активных схем. Это особенно важно при проектировании СВЧ-устройств.
Рис. 3. Пример различных способов визуализации данных в Qucs: декартовская диаграмма и диаграмма Смита
Пример моделирования с помощью спектрального анализа показан на рис. 4. Смоделирован кольцевой диодный балансный смеситель.
Рис. 4. Моделирование спектра напряжения на выходе кольцевого диодного смесителя
Для этого вида моделирования приведем краткое пояснение. Qucs не имеет специального вида моделирования спектра (Fourier Analysis). Вместо этого следует сначала провести моделирование переходного процесса, а затем рассчитать спектр напряжения при помощи математической функции Time2Freq (компонент «Уравнение» на рис. 4). Данная функция выполняет преобразование Фурье и нормировку его результата.
К недостаткам Qucs следует отнести малое количество библиотечных компонентов. Но этот недостаток не становится препятствием к использованию, поскольку Qucs совместим с форматом Spice, в котором приводятся модели электронных компонентов в даташитах. К тому же ядро моделирования работает медленнее, чем аналогичные Spice-совместимые моделировщики — например, MicroCAP (проприетарный) или Ngspice (open-source). Для конвертирования из библиотек SPICE служит встроенная утилита qucsconv.
Основы моделирования в Qucs
Рассмотрим подробнее базовые принципы работы с программой и интерфейс. После загрузки Qucs показывается главное окно, которое выглядит примерно как показано на рис. 5.
Рис. 5. Главное окно Qucs:
1 — выпадающий список с типами компонентов, видами моделирования и диаграмм;
2 — вкладки с открытыми схемами;
3 — рабочая область;
4 — кнопка запуска моделирования;
5 — кнопка вставки уравнения;
6 — кнопка вставки имени узла;
7 — кнопка вставки проводов;
8 — область выбора компонентов;
9 — кнопка вставки маркера на график;
10 — кнопка перехода в режим выделения компонентов
С правой стороны расположена рабочая область (3), в которой содержатся схемы, документы показа данных и т. д. С помощью вкладок (2) над этой областью можно быстро переключиться на любой документ, открытый в данный момент. С левой стороны главного окна Qucs находится еще одна область (8), чье содержание зависит от состояния вкладок, расположенных слева от нее: «Проекты», «Содержание» и «Компоненты». С помощью выпадающего списка (1), расположенного над областью (8), можно выбирать группы компонентов, которые будут размещаться на схеме. Компоненты размещаются на схеме методом перетаскивания из области (8) на рабочую область (3). Типы моделирования помещаются на схеме, так же как и компоненты. В меню «Справка ->Technical Papers»; «Cnpaвкa->Technical reports» и «Справка->Tutorials» можно найти подробную техническую документацию к программе и документацию по используемым алгоритмам моделирования. Через меню «Файл->Открыть примеры» можно открыть примеры схем.
По щелчку правой кнопки мыши на любом компоненте открывается контекстное меню компонента. По двойному щелчку мыши открывается диалоговое окно свойств компонента, в котором можно задавать, например, сопротивление резисторов, емкость конденсаторов, параметры транзисторов и т. п. Параметры компонентов можно также изменить по щелчку левой кнопкой мыши на значении сопротивления, емкости и т. п. в рабочей области. При этом параметр подсвечивается и с клавиатуры можно напечатать новое значение параметра, а затем нажать клавишу Enter. Для видов моделирования задаются параметры моделирования, в частности отрезок времени для моделирования переходного процесса или диапазон частот при моделировании на переменном токе. Пример установки свойств для компонента и для моделирования показан на рис. 6 и 7.
Рис. 6. Установка параметров компонента
Рис. 7. Установка параметров моделирования
Наименования параметров модели в программе Qucs совпадают с наименованиями параметров в моделях Spice, так как и Spice и Qucs используют одинаковые алгоритмы моделирования транзисторов (модель Гуммеля — Пуна).
Компоненты соединяются с помощью проводов, добавляемых на схему нажатием на кнопку (7), как показано на рис. 5. Схема не будет работать без заземления (GND). Заземление — это особый компонент, который добавляется на схему при помощи кнопки с пиктограммой заземления на панели инструментов.
Выбрав пункт меню «Инструменты ->Библиотека компонентов», можно открыть библиотеку компонентов (рис. 8).
Рис. 8. Окно библиотеки компонентов
Библиотека содержит готовые модели для различных электронных компонентов (диоды, транзисторы, операционные усилители), которые из окна библиотеки можно перетаскивать на схему.
Рассмотрим подробнее способ запуска моделирования схемы и визуализации результатов. В качестве примера возьмем моделирование сигналов на входе и на выходе транзисторного усилительного каскада. Будем использовать моделирование переходного процесса. Смоделируем отклик транзисторного однокаскадного усилителя низкой частоты, если на его вход подано синусоидальное напряжение амплитудой 200 мВ и частотой 10 кГц.
Сначала собираем схему усилителя (рис. 9). Особенностью этой схемы является то, что двум узлам, соответствующим входу и выходу усилителя, заданы имена in и out соответственно при помощи кнопки (6) на рис. 5. Кроме моделирования переходного процесса для схем, содержащих активные компоненты, нужно обязательно проводить расчет рабочей точки. Для этого поместим на схеме компонент моделирования на постоянном токе.
Рис. 9. Пример моделирования однокаскадного транзисторного усилителя
После того как все компоненты размещены на рабочем поле схемы и соединены между собой проводами и перед тем как запустить моделирование, нужно задать параметры моделирования переходного процесса: длительность моделирования и число точек для расчета. Для этого дважды щелкнем на виртуальном компоненте TR1 и в открывшемся окне введем параметры для моделирования переходного процесса (рис. 7). Начало моделирования 0 мс, конец моделирования 1 мс (1 ms) и шаг моделирования 1 мкс. Установка таких параметров обеспечивает моделирование схемы на отрезке времени от включения (0 мс) до 1 мс. Рассчитываются напряжения и токи в компонентах схемы через каждую 1 мкс. Все буквы в обозначениях единиц измерений на рис. 9 строго латинские. Русские буквы не допускаются.
Для того чтобы запомнить параметры моделирования, необходимо в диалоговом окне нажать ОК. После того как мы установили все параметры моделирования, запускаем моделирование нажатием на F2 на клавиатуре или кнопкой моделирования на панели инструментов. Происходит расчет, и после его окончания создается пустая вкладка страницы просмотра (рис. 10). Чтобы посмотреть полученные временные диаграммы напряжений на входе и на выходе усилителя, нужно на этой странице сначала разместить график, а потом установить его параметры.
Рис. 10. Размещение на странице просмотра диаграммы
Для того чтобы поместить на странице просмотра график, нужно перетащить на страницу просмотра специальный компонент (рис. 10). После размещения график будет пустой. Можно размещать диаграмму не только на странице просмотра, но и непосредственно на схеме.
Результаты моделирования переходного процесса в Qucs можно наблюдать в виде привычной диаграммы, если выбрать в группе «Диаграммы» декартовский вид отображения данных. Сигналы соответствуют тому, что вы увидели бы на экране осциллографа, если бы проверяли работу схемы на макетной плате.
После того как на странице просмотра размещен график, нужно отобразить на графике нужные кривые. После моделирования создается служебный файл, называемый «Набор данных», где содержатся результаты расчетов. Чтобы добавить на график кривую, следует в свойствах графика выбрать необходимый нам результат из набора данных. Если дважды щелкнуть мышью по графику, помещенному на странице просмотра, откроется окно установки свойств графика (рис. 11).
Рис. 11. Установка параметров диаграммы и отображаемых кривых на диаграмме
В левой части открывшегося окна находятся результаты расчетов. Осциллограммы переходного процесса имеют следующее обозначение: имя_узлаVt (рис. 11). Результаты переходного процесса всегда имеют суффикс .Vt. Соответственно результаты моделирования на переменном токе имеют суффикс .v. Чтобы на графике разместить осциллограммы переходного процесса на входе и на выходе усилителя, нужно дважды щелкнуть по имени результата в левой части окна, и он переместится в правую часть окна. Для просмотра на графике осциллограммы напряжения на входе и на выходе усилителя нужно разместить на нем кривые in.Vt и out.Vt, отмеченные на рис. 11.
В результате на странице просмотра отобразятся осциллограммы напряжений на входе и на выходе усилителя (рис. 12). На графиках размещены маркеры. Маркеры вставляются на кривые на осциллограмме с помощью кнопки (9) в главном окне программы (рис. 5). Маркеры представляют собой аналог курсорных измерений в осциллографе. С их помощью можно узнать, например, напряжение в определенный момент времени.
Рис. 12. Результаты моделирования переходного процесса. Маркеры на осциллограммах
Итак, мы промоделировали работу одно-каскадного усилителя на биполярном транзисторе. Из осциллограмм напряжения на входе и на выходе усилителя видно, что выходной сигнал находится в противофазе к входному и значительно больше его по амплитуде.
Работа с уравнениями на схеме
Важной функцией в Qucs является работа с уравнениями. Применение уравнений позволяет проводить постобработку результатов моделирования встроенными средствами Qucs. В уравнениях можно использовать достаточно большой набор функций, полный список которых можно увидеть, просмотрев разделы встроенной справочной системы (ее вызывают нажатием клавиши F1). В частности, в Qucs встроены такие функции, как преобразования матрицы рассеивания многополюсника в матрицу A-, Y-, Z-параметров.
Рассмотрим использование уравнений на примере моделирования АЧХ усилительного транзисторного каскада. Чтобы промоделировать АЧХ, модифицируем схему, как показано на рис. 13. Добавляем компонент «Моделирование на переменном токе» (AC) и компонент «Уравнение».
Рис. 13. Схема усилителя для моделирования на переменном токе
Компонент «Уравнение» нужен для того, чтобы вычислить коэффициент усиления усилителя, зная напряжения на его выходе и входе, и затем построить график зависимости коэффициента усиления от частоты. Как известно, частотный коэффициент передачи K(f) определяется как отношение образов сигналов в частотной области по выходу и по входу. Модуль частотного коэффициента передачи называется АЧХ, а фазовый угол — ФЧХ.
Для того чтобы получить зависимость коэффициента усиления от частоты для нашего усилителя, нужно задать уравнение, по которому он будет рассчитываться. Для этого дважды щелкаем мышью по компоненту «Уравнение» и входим в окно редактирования уравнений (рис. 14). Мы пометили узел, являющийся входом схемы, как in, а являющийся выходом схемы, как out. Частотному образу (зависимости напряжения от частоты) напряжения на выходе будет соответствовать выражение out.v, а на входе in.v.
Рис. 14. Диалог ввода уравнений:
1 — поле ввода переменной;
2 — поле ввода выражения
Чтобы получить коэффициент усиления, нужно поделить напряжение на выходе на напряжение на входе. Для этого вводим в окне на рис. 14 в поле ввода 1 символ K, а в поле ввода 2 — выражение dB(out.v/in.v). Функция dB() пересчитывает значение коэффициента усиления в децибелах (дБ). Теперь, когда поля ввода заполнены, нажимаем кнопку «Добавить». Можно переходить к редактированию нового уравнения, по которому будет рассчитываться ФЧХ.
Снова заполняем поля ввода, чтобы задать уравнение для ФЧХ. В поле ввода 1 вводим Ph, а в поле ввода 2 — выражение phase(out.v/in.v). Функция phase() вычисляет аргумент (фазу) комплексного числа в градусах.
После того как уравнения и параметры моделирования заданы, запускаем моделирование нажатием на клавишу F2. Несколько секунд происходит моделирование, и по его окончании можно посмотреть результаты расчета АЧХ и ФЧХ усилителя (рис. 13). Чтобы разместить на диаграмме АЧХ или ФЧХ, нужно выбрать их в диалоге свойств диаграммы (рис. 11).
Использование Qucs в учебном и исследовательском процессе
Qucs успешно применяется в учебном процессе на кафедре «Радиоэлектроника и телекоммуникации» в НИУ «Высшая школа экономики» (бывший МИЭМ) и на кафедре «Конструирование и производство электронной аппаратуры» Калужского филиала МГТУ им. Н. Э. Баумана при проведении лабораторных работ для изучения схемотехники аналоговых устройств и в курсовом и дипломном проектировании. Курс лабораторных работ включает моделирование высокочастотных резонансных и широкополосных усилительных каскадов, моделирование схем смесителей и демодуляторов, моделирование S- и Z-параметров активных и пассивных схем, моделирование автогенераторов, моделирование КЧХ (комплексная частотная характеристика) усилительных схем с положительной обратной связью (ПОС).
Возможности Qucs достаточны не только для использования в учебном процессе, но и для проведения научных исследований [7], связанных с моделированием электронных схем. В работе [7] было проведено исследование воздействия ЭСР с печатной платой (Charged board model — CBM ЭСР) на МДП-транзисторы. Весь процесс моделирования выполнен при помощи свободного ПО. Была разработана методика, позволяющая определять порог отказа МДП-транзисторов при воздействии СВМ ЭСР.
В работе [8] было произведено моделирование частотной зависимости полного сопротивления керамических конденсаторов. Для этого использована функция моделирования Z-параметров. Результаты работы позволяют оптимизировать схемотехнику цепей питания цифровых микросхем с учетом частотных параметров развязывающих керамических конденсаторов.
Со списком прочих научных исследований, проведенных при помощи Qucs за рубежом, можно ознакомиться на сайте [1].
Перспективные направления в разработке Qucs
В настоящее время автором совместно с коллективом разработчиков проводится работа над возможностью предоставления пользователю выбора движка для моделирования схемы. Можно будет использовать встроенный движок Qucs, Ngspice (spice-совместимый консольный симулятор с открытым кодом) или Xyce (моделировщик с поддержкой параллельных вычислений через OpenMPI). Данная возможность отсутствует в популярном проприетарном ПО для моделирования электронных схем.
В заключение рассмотрим перечень нововведений в недавнем релизе Qucs 0.0.18 и перспективные направления в разработке Qucs:
- Реализован экспорт графиков, схем в растровые и векторные форматы: PNG, JPEG, PDF, EPS, SVG, PDF+LaTeX. Эта функция полезна при использовании программы в учебном процессе вузов и при подготовке статей и отчетов, содержащих результаты моделирования.
- Добавлена возможность открытия документа схемы из будущей версии программы.
- Добавлен встроенный справочник цветовых кодировок резисторов.
- Улучшена русская локализация.
- Закрыты отчеты об ошибках.
- Ведется разработка системы синтеза активных фильтров для Qucs (подготовлена стабильная версия, ожидается в релизе 0.0.19).
- Ведется разработка сопряжения с прочими open-source консольными симуляторами электронных схем (Ngspice [3], Xyce [4], Gnucap). В последующих версиях будет добавлена возможность выбора вычислительного ядра для моделирования схемы.
Особое внимание в настоящее время уделяется вопросам реализации сопряжения со Spice-совместимыми ядрами моделирования. Реализация данного направления разработки позволит использовать возможности Ngspice и Xyce для моделирования силовой электроники, схем с импульсной формой напряжений и токов, поскольку Ngspice и Xyce имеют оптимизацию для моделирования таких схем, а встроенное ядро моделирования Qucsator имеет низкую производительность при расчете схем с импульсными воздействиями. Текущий статус разработки можно отследить здесь: https://github.com/Qucs/qucs/issues/77.
Заключение
Из вышесказанного видно, что Qucs представляет собой бурно развивающееся программное средство для моделирования электронных схем, позволяющее получать результаты, сопоставимые с коммерческим ПО. Для ряда применений Qucs способен заменить коммерческие симуляторы электронных схем. Можно рекомендовать Qucs учебным заведениям, радиолюбителям, индивидуальным разработчикам РЭА. Важным преимуществом является то, что Qucs распространяется бесплатно. Открытый исходный код, открытая спецификация файлов схем и библиотек и легкая расширяемость делают Qucs наиболее подходящим решением для применения в академических и исследовательских целях. Наличие функции моделирования S-параметров, комплексных входных и выходных сопротивлений и проводимостей, компонентов с распределенными параметрами позволяет использовать Qucs для моделирования устройств ВЧ- и СВЧ-электроники.