Жесткая задача с экспоненциальной нелинейностью для тестирования программ математического и схемотехнического моделирования
Представлена тестовая задача для оценки эффективности методов численного решения обыкновенных дифференциальных уравнений и методов численного анализа переходных процессов в электронных цепях и системах. Задачи моделирования сложных радиотехнических цепей.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | статья |
Язык | русский |
Дата добавления | 29.07.2017 |
Размер файла | 988,5 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Жесткая задача с экспоненциальной нелинейностью для тестирования программ математического и схемотехнического моделирования
А.М. Пилипенко
Южный федеральный университет, Таганрог
Аннотация: Представлена оригинальная тестовая задача для оценки эффективности методов численного решения обыкновенных дифференциальных уравнений и методов численного анализа переходных процессов в электронных цепях и системах. Тестовая задача описана как в виде математической модели, так и в виде модели электрической цепи. Предложенные в работе тестовая задача и методика оценки точности численного решения могут использоваться в программах математического и схемотехнического моделирования для тестирования как известных, так и новых методов численного моделирования электронных цепей и систем с различной динамикой, в том числе описывающихся жесткими и/или нелинейными дифференциальными уравнениями.
Ключевые слова: численные методы, электронные цепи, анализ переходных процессов, обыкновенные дифференциальные уравнения, жесткие системы.
Для разработки высокотехнологичной радиоэлектронной аппаратуры в настоящее время важнейшее значение приобретают современные системы автоматизированного проектирования (САПР), позволяющие обеспечить высокую точность моделирования различных электронных устройств [1]. В связи с постоянным совершенствованием методов моделирования электронных устройств актуальной задачей является разработка тестов, позволяющих оценить эффективность указанных методов [2].
Моделирование динамики различных электронных устройств, например, радиотехнических цепей, как правило, состоит в решении системы обыкновенных дифференциальных уравнений (ОДУ), описывающей рассматриваемое устройство во временной области. В качестве среды для анализа радиотехнических цепей во временной области можно использовать как программы математического моделирования (Mathcad, MATLAB), так и программы схемотехнического моделирования (SPICE, Microcap, NI Multisim). В указанные программы включено большое количество методов предназначенных для численного решения различных типов ОДУ [3, 4].
Задачи моделирования сложных радиотехнических цепей относятся к жестким задачам, которые достаточно трудны для численного решения [5]. Решение жесткой задачи (жесткой системы ОДУ) содержит как быстрые, так и медленные компоненты, скорости изменения которых отличаются на порядок и более. Жесткость системы можно оценить отношением максимальной и минимальной постоянных времени системы.
В настоящее время для тестирования программ математического моделирования широко применяются уравнение Далквиста и уравнение Ван дер Поля [3 - 5]. Указанные задачи так же можно использовать и для тестирования программ схемотехнического моделирования, так как уравнению Далквиста соответствует линейная RC-цепь, а уравнению Ван дер Поля - нелинейный осциллятор. Основной недостаток задачи Далквиста заключается, в том, что ее решение дает только приближенные сведения о погрешности численных методов на комплексной плоскости [6], кроме того уравнение Далквиста линейное и не является жестким, т.е. не позволяет учесть основные трудности, возникающие при анализе радиотехнических цепей. Уравнение Ван дер Поля является нелинейным и позволяет моделировать как жесткие, так и колебательные цепи, но данное уравнение, как и ряд других тестов, основанных на прикладных задачах, имеет существенный недостаток - не известно явное выражение для его точного решения [7].
Цель настоящей статьи - разработать тестовую задачу в виде ОДУ и схемной модели с произвольной жесткостью и нелинейностью для исследования эффективности методов численного анализа переходных процессов в программах математического и схемотехнического моделирования. Кроме нелинейности, жесткости и возможности схемного описания, важнейшим требованием, предъявляемым к разрабатываемой тестовой задаче, является наличие точного решения в явном виде.
Наиболее распространенная в математике задача для тестирования методов численного интегрирования ОДУ представляет собой линейное дифференциальное уравнение первого порядка, также называемое уравнением Далквиста [8]:
. (1)
Решение уравнения (1) описывается следующим выражением
. (2)
Нетрудно показать, что уравнение Далквиста описывает линейную RC-цепь, схема которой приведена на рис. 1, а. Постоянная времени RC-цепи фC и параметр л, входящий в уравнение (1), связаны следующим соотношением фC = RC = ?1 / л, где R и С - параметры элементов RC-цепи.
Рис. 1. - Известная (а) и предлагаемая (б) схемы тестовых цепей
Для получения нелинейной тестовой цепи (рис. 1, б) заменим в схеме RC-цепи линейное сопротивление R нелинейным элементом VD. Будем полагать, что в качестве нелинейного элемента VD используется диод, вольт-амперная характеристика (ВАХ) которого описывается моделью Шокли [9]:
, (3)
где uD - напряжение на диоде; IS и ц - основные параметры диода.
Кроме того, будем полагать, что напряжение источника имеет вид:
(4)
где E -постоянная величина; t - время.
С учетом выражений (3) и (4) запишем систему уравнений электрического равновесия нелинейной тестовой цепи при t ? 0:
(5)
Из системы (5) нетрудно получить ОДУ относительно напряжения на емкости для тестовой цепи с экспоненциальной нелинейностью:
(6)
К сожалению, получить из уравнения (6) явное выражение для u(t) не удается, поэтому далее рассмотрим ОДУ нелинейной цепи относительно тока. Из формулы (3) выразим напряжение на диоде через ток
. (7)
Напряжение на емкости связано с током следующим образом:
. (8)
Подставив (7) и (8) в первое уравнения системы (5) получаем
. (9)
Продифференцировав обе части уравнения (9) по t, получаем ОДУ заданной цепи относительно тока
. (10)
Разделяя переменные в уравнении (10), получаем
. (11)
Интегрируя обе части уравнения (11), определяем
, (12)
где ; ; ? значение тока цепи при t = 0.
Из выражения (12) нетрудно определить ток:
. (13)
Подставляя выражение (13) в (7) и учитывая, что u = E ? uD, получаем решение ОДУ нелинейной цепи в явном виде:
. (14)
Значение t0 можно определить из выражения (12), полагая t = 0 и учитывая, что , (cм. формулу (3)):
Для нелинейных цепей, как и для нелинейных ОДУ, вместо понятия «постоянная времени» используют термин «переменная временная постоянная» , которая для ОДУ первого порядка du/dt = f(u) определяется следующим образом [10]
. (15)
Учитывая, что правая часть тестового ОДУ (6) получаем с помощью формулы (15) «переменную временную постоянную» нелинейной тестовой цепи
(16)
Жесткость нелинейной тестовой цепи можно оценить отношением максимального и минимального значений [10]:
, (17)
; .
Для изменения жесткости нелинейной цепи можно варьировать начального напряжения на емкости u0. На рис. 2, а показано напряжение на выходе нелинейной тестовой цепи, рассчитанное по формуле (14) при различных значениях u0 (кривая 1 соответствует u0 = 0,9 В, кривая 2 - u0 = 0,96 В, кривая 3 - u0 = 0,99 В), штриховая линия на этом же рисунке - напряжение на выходе линейной RC-цепи описывающееся следующим выражением .
Зависимость жесткости нелинейной тестовой цепи от начального напряжения на емкости приведена на рис. 2, б, из которого следует, что при приближении u0 к нулю значение жесткости может достигать 1016. При проведении расчетов были выбраны следующие параметры тестовых цепей: C = 1 Ф; E = 1 В; R = 1 Ом (для линейной цепи); IS = 0,027 А, ц = 0,027 В (для нелинейной цепи). При этом фС = фmax = ф = 1 с.
Рис. 2. - Временные диаграммы напряжений на выходе тестовых цепей (а) и оценка жесткости нелинейной тестовой цепи (б)
Важнейшим критерием эффективности численного метода является его точность. Таким образом, для оценки эффективности методов численного анализа цепей во временной области (численных методов решения ОДУ) рассчитывают текущую относительную погрешность численного решения, которая имеет следующий вид
, (18)
где uk -значение отклика цепи, полученное с помощью численного метода; u(tk) - точное значение отклика; umax - максимальное значение отклика.
Для проверки работоспособности предлагаемого в данной работе теста было проведено исследование точности следующих методов численного анализа переходных процессов, использующихся в пактетах математического и схемотехнического моделирования: метод трапеций (TR); методы Гира (Gear) и BDF, основанные на формулах дифференцирования назад; метод Radau [4 - 6]. Следует отметить, что метод Гира используется по умолчанию для анализа переходных процессов в большинстве программ схемотехнического моделирования. Методы BDF отличается от метода Гира только процедурой автоматического выбора шага интегрирования и реализован в программах компьютерной математики.
В данной работе тестирование методов TR и Gear проводилось в пакете NI Multisim, методов BDF и Radau - в программе Mathcad. На рис. 3 приведены текущие погрешности анализа переходных процессов в линейной и нелинейной тестовых цепях, параметры которых были указаны выше. Результаты на рис. 3 были получены при использовании установленных по умолчанию опций численного анализа: предельно допустимая относительная ошибка моделирования RELTOL = 10 - 3; временной шаг выбирается программой автоматически.
Из рис. 3 видно, что текущая погрешность моделирования для метода трапеций существенно возрастает при решении жесткой нелинейной задачи по сравнению с аналогичной погрешностью для линейной задачи. Данный факт подтверждает корректную работу предлагаемого теста, поскольку известно, что метод трапеций теряет свою эффективность при решении жестких задач [5, 10].
Рис. 3. - Текущие погрешности моделирования линейной (а) и нелинейной (б) тестовых цепей
Погрешности методов Gear и BDF существенно отличатся друг от друга для задач различной жесткости, что очевидно связано с различной процедурой автоматического выбора шага в методах Gear и BDF. Таким образом, предлагаемая тестовая задача позволяет сравнивать как точность разностных схем численных методов, так и эффективность алгоритмов автоматического выбора шага в программах численного анализа. При решении жесткой задачи на интервале t > ф текущая погрешность моделирования для метода Radau, как и для метода трапеций, существенно возрастает по сравнению с аналогичной погрешностью для линейной задачи. По-видимому, данное свойство, а также низкая точность метода Radau при решении колебательных задач [6] препятствуют его применению в пакетах схемотехнического моделирования.
Таким образом, представленная тестовая задача и методика тестирования позволяют оценить как достоверность численного анализа, так и его точность. Предлагаемая тестовая задача также позволяет оценить влияние характеристик исследуемой цепи или системы (нелинейность, жесткость, скорость затухания переходных процессов) на свойства численного метода и установить предельную точность численных методов при решении практических задач.
Исследование выполнено при финансовой поддержке РФФИ в рамках научного проекта № 16-07-00631a.
математический программа моделирование тестирование
Литература
1. Бегляров В.В., Берёза А.Н. Гибридный эволюционный алгоритм решения систем линейных алгебраических уравнений, описывающих электрические цепи // Инженерный вестник Дона, 2013, № 1. URL: ivdon.ru/ru/magazine/archive/n1y2013/1540.
2. Маничев В.Б., Жук Д.М., Витюков Ф.А. Метод математического тестирования программ анализа переходных процессов в САПР электронных схем // Проблемы разработки перспективных микро- и наноэлектронных систем (МЭС). 2014. № 1. С. 83-88.
3. Душенин Д.Ю. Численное моделирование функционирования ансамбля нейронов коры головного мозга // Инженерный вестник Дона, 2011, № 4. URL: ivdon.ru/ru/magazine/archive/n4y2011/533.
4. Hairer E., Wanner G. Solving Ordinary Differential Equations II: Stiff and Differential-Algebraic Problems. 2nd rev. ed. Springer-Verlag, Heidelberg, 1996. 614 p.
5. Калиткин Н.Н., Численные методы решения жестких систем // Математическое моделирование. 1995. Т. 7, № 5. С. 8-11.
6. Бирюков В.Н., Пилипенко А.М. Анализ погрешности численного моделирования автогенераторов во временной области // Известия ЮФУ. Технические науки. 2014. № 11 (160). С. 119-127.
7. Гужев Д.С., Калиткин Н.Н., Уравнение Бюргерса - тест для численных методов // Математическое моделирование. 1995. Т. 7, № 4. С. 99-127.
8. Dahlquist G.G. A special stability problem for linear multistep methods // BIT Numerical Mathematics. 1963, Vol. 3, № 1. pp. 27-43.
9. Jaeger R.C., Blalock T.N. Microelectronic circuit design. Fourth Edition. McGraw-Hill, New York, 2011. 1365 p.
10. Modern Numerical Methods for Ordinary Differential Equations / edited by G. Hall, J. M. Watt, Clarendon Press, Oxford, 1976. 336 p.
Размещено на Allbest.ru
Подобные документы
Вывод системы дифференциальных уравнений. Описание методов численного решения задачи Коши. Моделирование переходных процессов в электрической цепи. Решение задачи аппроксимации. Расчет количества теплоты, выделившейся на резисторе, реализация в MathCAD.
курсовая работа [202,5 K], добавлен 11.11.2013Основные этапы математического моделирования. Метод Эйлера как наиболее простой численный метод решения обыкновенных дифференциальных уравнений. Написание компьютерной программы, которая позволит изучать графики системы дифференциальных уравнений.
курсовая работа [1,9 M], добавлен 05.01.2013Исследование конечно-разностных методов решения краевых задач путем моделирования в среде пакета Micro-Cap V. Оценка эффективности и сравнительной точности этапов получения решений методом математического, аналогового моделирования и численными расчетами.
курсовая работа [324,3 K], добавлен 23.06.2009Задача о ранце как задача комбинаторной оптимизации. Задача о загрузке, рюкзаке, ранце. Постановка и NP-полнота задачи. Классификация методов решения задачи о рюкзаке. Динамическое программирование. Метод ветвей и границ. Сравнительный анализ методов.
курсовая работа [1,7 M], добавлен 18.01.2011Опытное исследование свойств методов Рунге-Кутты. Реализация численных методов приближенного интегрирования обыкновенных дифференциальных уравнений, наиболее часто применяющихся в практике моделирования и проектирования систем автоматизации и управления.
курсовая работа [311,5 K], добавлен 05.03.2009Особенности метода численного интегрирования обыкновенных дифференциальных уравнений. Расчет переходного процесса в нелинейной электрической цепи, вызванного ее включением или отключением. Метод численного интегрирования Рунге-Кутта с переменным шагом.
отчет по практике [740,1 K], добавлен 10.10.2011Решение дифференциальных уравнений первого порядка. Варианты методов Рунге-Кутта различных порядков. Основные методы численного решения задачи Коши. Повышение точности вычислений и итерационный метод уточнения. Дискретная числовая последовательность.
лабораторная работа [33,3 K], добавлен 14.05.2012Разработка быстрого и эффективного алгоритма для решения задачи оценки параметров обыкновенных дифференциальных уравнений с запаздывающими аргументами, не разрешаемых аналитически. Реализация алгоритма в виде библиотеки на языке программирования MATLAB.
дипломная работа [1,6 M], добавлен 19.06.2012Структурно-информационный анализ методов моделирования динамических систем. Математическое моделирование. Численные методы решения систем дифференциальных уравнений. Разработка структуры програмного комплекса для анализа динамики механических систем.
дипломная работа [1,1 M], добавлен 14.05.2010Характеристика основных методов и средств моделирования мультиагентных систем. Ознакомление с результатами экспериментального тестирования и отладки программного комплекса. Рассмотрение методов оценки качества разработанного программного продукта.
дипломная работа [3,1 M], добавлен 27.10.2017