Усовершенствование моделирования работы электрических схем в gschem

Обоснование

Начинающим не так-то просто использовать gschem как оболочку для схемотехнического моделирования (для ngspice или gnucap). Вот что новому пользователю хотелось бы делать в gschem:

Запуск моделирования и постобработка могут быть во внешней программе, вызываемой посредством IPC.

Существует несколько графических оболочек, но они не решают всех вышеуказанных проблем:

Все оболочки имеют одну проблему — в них нельзя указать соединение, данные которого хотелось бы увидеть. Нужно знать имя соединения для узла.

Набросок проекта

Допустим, нам хотелось бы совсем немного изменить gschem и libgeda, чтобы иметь возможность по крайней мере установить несколько измерительных приборов и запустить моделирование.

Измерительные приборы

Измерителями тока могут быть обычные источники постоянного напряжения 0 В. Легче всего в качестве такого прибора использовать символ с двумя выводами, подобный обычному амперметру. Если нам захотелось бы подключить измеритель тока к выводу, то нужно, чтобы генератор списка соединений распознал его и заместил нашим “амперметром”. Если в качестве амперметра использовать источник напряжения, генератору не нужно будет знать имён соединений внутри схемы. Все источники напряжения 0 В со специальным именем устройства являлись бы измерителями тока.

Измерителями напряжения могут быть источники тока 0 А. Второй вывод источника тока присоединяется к GND атрибутом net. Поэтому снова генератору списка соединений не нужно будет знать имён соединений, так как он сможет использовать соединение, подключенное к этому специальному источнику тока. Подобно вышеописанному источнику напряжения мог бы быть специальный (графический) символ, который распознавался бы генератором списка соединений.

Источники тока и напряжения

Определить параметры источников не так просто. В настоящее время они хранятся внутри атрибутов value символа, например value=pulse 0 1 10n 10n 100n 1u 2u. Эти настройки должны соответствовать атрибутам SPICE pulse(V1 V2 TD TR TF PW PER).

Было бы здорово иметь диалоговое окно, предлагающее пользователям имена атрибутов, а не только строку значения.

Настройкой источников напряжения или тока могла бы заниматься модифицированная команда редактирования атрибутов (ee), которая вызывала бы для этих источников специальные диалоговые окна их свойств. В настоящее время эта команда вызывает диалоговое окно редактирования всех атрибутов символа.

Моделирование

Как сохранять параметры моделирования внутри gschem.

Для хранения параметров одного моделирования можно использовать символ с названием устройства SIMULATION. Все параметры, определяющие один вид моделирования сохраняются как атрибуты, прикреплённые к данному объекту:

v 20061020 1
C 41500 49200 1 0 0 spice-directive-1.sym
{
device=spice_simulation_block
refdes=A1
simulation_name=random name
simulation_active=1
simulation_type=DC 0V 1V 0.1V
parametric_simulation1=V1 lin 0 5 0.1
parametric_simulation2=R1.value lin 10k 100k 10k
option_TNOM=100 Deg
option_ABSTOL=1e-3
global_param1=???
global_param2=???
}

Таких объектов моделирования в одной схеме могло бы быть много.

Для хранения дополнительных библиотек можно использовать либо директиву вложения (include), либо символ LIBRARY, содержащий все библиотеки в одном из двух видов:

Между глобальными, пользовательскими и локальными библиотеками должно быть различие. Глобальные и пользовательские библиотеки могут определяться в gafrc или в новом конфигурационном файле spicerc.

Создание диалогового окна для моделирования внутри gschem

Допустим, всё что нам нужно, чтобы добавить поддержку моделирования в gschem, это одно диалоговое окно.

При создании такого диалогового окна все объекты моделирования собираются в перечень видов моделирования (в виде списка с кнопками разрешения/запрета).

При изменении настроек меняются атрибуты соответствующего объекта моделирования.

Диалоговое окно параметров

Какие параметры нужны для этого диалогового окна? И почему?

Расставленные нами измерители можно использовать, чтобы сообщать программе моделирования о том, какие нам хотелось бы сохранять переменные, или программе построения графиков о том, какие хотелось бы увидеть графики. Это вещи совершенно различные, и нам нужна возможность выбирать следующее:

Запуск моделирования

Кнопка моделирования в диалоговом окне должна вызывать следующие действия:

Этот скрипт мог бы вызывать даже диспетчер, который бы занимался множеством крупномасштабных моделирований.

Приложение

Символ измерителя тока (эскиз)

v 20061020 1
P 0 0 200 200 1 0 0
{
T 100 0 5 10 0 1 0 0 1
pintype=pas
T 0 100 5 10 0 1 0 0 1
pinseq=1
T 0 100 5 10 0 1 0 0 1
pinnumber=1
T 0 100 5 10 0 1 0 0 1
pinlabel=1
}
V 300 300 150 3 10 0 0 -1 -1 0 -1 -1 -1 -1 -1
L 300 200 240 360 3 10 0 0 -1 -1
L 300 200 360 360 3 10 0 0 -1 -1
T 0 500 9 10 0 0 0 0 1
device=VOLTAGE_PROBE
T 200 50 9 6 1 1 0 0 1
refdes=I_VP?
T 0 700 9 10 0 0 0 0 1
net=GND:2
T 0 900 9 10 0 0 0 0 1
value=DC 0A

Символ измерителя напряжения (эскиз)

v 20061020 1
P 0 200 150 200 1 0 0
{
T -150 50 5 10 0 1 0 0 1
pintype=pas
T 50 250 5 10 0 1 0 0 1
pinseq=1
T 50 250 5 10 0 1 0 0 1
pinnumber=1
T 50 250 5 10 0 1 0 0 1
pinlabel=1
}
V 300 200 150 3 10 0 0 -1 -1 0 -1 -1 -1 -1 -1
L 300 300 380 140 3 10 0 0 -1 -1
L 300 300 220 140 3 10 0 0 -1 -1
T 0 500 9 10 0 0 0 0 1
device=CURRENT_PROBE
T 200 370 9 6 1 1 0 0 1
refdes=V_IP?
P 600 200 450 200 1 0 0
{
T 500 50 5 10 0 1 0 0 1
pintype=pas
T 500 250 5 10 0 1 0 0 1
pinseq=2
T 500 250 5 10 0 1 0 0 1
pinnumber=2
T 500 250 5 10 0 1 0 0 1
pinlabel=2
}
L 240 180 360 180 3 10 0 0 -1 -1
T 0 700 9 10 0 0 0 0 1
value=DC 0V

Ещё один символ измерителя тока (эскиз), который использует Kurt Peters

v 20061020 1
T 700 650 8 10 1 1 0 0 1
refdes=VAM?
T 700 850 5 10 1 1 0 0 1
device=Ammeter
T 700 1050 5 10 0 0 0 0 1
footprint=none
T 700 1250 5 10 0 0 0 0 1
numslots=0
T 700 1450 5 10 0 0 0 0 1
description=ammeter for spice
P 300 1200 300 900 1 0 0
{
T 350 1000 5 8 1 1 0 0 1
pinnumber=1
T 350 1000 5 8 0 1 0 2 1
pinseq=1
T 400 850 9 8 1 1 0 5 1
pinlabel=+
T 300 700 5 8 0 1 0 5 1
pintype=pwr
}
P 300 0 300 300 1 0 0
{
T 350 100 5 8 1 1 0 0 1
pinnumber=2
T 350 100 5 8 0 1 0 2 1
pinseq=2
T 300 500 5 8 0 1 0 3 1
pintype=pwr
T 300 300 5 10 1 1 0 0 1
pinlabel=-
}
L 300 400 400 500 3 0 0 0 -1 -1
L 200 500 300 400 3 0 0 0 -1 -1
T 700 450 5 10 0 1 0 0 1
value=DC 0V
L 300 400 300 800 3 0 0 0 -1 -1
L 100 800 500 400 3 0 0 0 -1 -1
B 0 300 600 600 3 0 0 0 -1 -1 0 -1 -1 -1 -1 -1
L 200 800 100 800 3 0 0 0 -1 -1
L 100 700 100 800 3 0 0 0 -1 -1