Как стать автором
Обновить

Создание регулятора на базе нечеткой логики с многоканальной настройкой

Анализ и проектирование систем *Алгоритмы *Математика *Matlab *
«Зато мы делаем ракеты!»

В предыдущей статье я проверил, можно ли автоматически настраивать нечеткий регулятор, «стандартными методами» оптимизации. Оказалось можно и результат автоматической настройки вполне удовлетворительный. По крайней мере для ракеты, модель которой была использована.

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

Проверим возможно ли настроить такой регулятор стандартными методами оптимизации.
Рассмотрим синтез нечеткого регулятора с многоканальной настройкой для стабилизации баллистической ракеты по углу тангажа. Как подсказали в комментариях ракета будет ФАУ-2. Используем пример из той же книге Гостева В.В. «Нечеткие регуляторы в системах автоматического регулирования».

Все термины использованные в данном тексте взяты из этой книги и могут не соответствовать строгой терминологии теории автоматического управления.

Постановка задачи


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

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

Приняв за выходную координату ракеты угол тангажа , за входную координату – угол поворота руля , определим передаточную функцию в виде:


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











В задаче принимается, что время начала полета соответствует 6 секунде. Значения полином принимаются со сдвигом на 6 секунда.
Математическая модель нестационарного колебательного звена описывается дифференциальным уравнением:



Математическая модель нестационарного форсирующего звена описывается дифференциальным уравнением:



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

Структурная схема модели представлена на рисунке 1. Чтобы был понятен принцип формирования модели, на линиях связи указаны переменные Х1, Х и их производные (Х1’’, Х1'', X') согласно уравнениям звеньев. Зеленым прямоугольником обозначена часть схемы модели, соответствующая колебательному звену, желтым – форсирующему.

Параметры a(t),b(t),c(t),r(t) задаются в виде коэффициентов усиления, в блоках типа «усилитель». Параметр задается в коэффициенте усиления интегрирующего звена.


Рисунок 1. Структурная схема модели.

Программная траектория, заданный угол тангажа u(t) = 1+0.5sin(πt/30).
Графики изменения параметров ракеты в процессе полета представлены на рисунке 2.
В качестве начала полета принимается значение t = 6, в функции полиномов для расчета параметров используется значение (time+6), где time – текущее время моделирования.


Рисунок 2. Графики изменения параметров ракеты.

Регулятор на базе нечеткой логики


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

Блок задержка на шаг квантования обеспечивает дискретизацию преобразования непрерывного сигнала в дискретный с шагом дискретизации 0.01 сек.

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

Блоки фазификации осуществляют расчет значений термов для отклонения, скорости изменения и ускорения. (Более подробно об этом см. предыдущей текст). На выходе из каждого блока фазифкации мы получаем вектор термов для лингвистических переменных. (см. таблицу 1)
Лингвистическая переменная Термы
Отклонение Больше
Норма
Меньше
Скорость изменения Растет
Не изменяется
Падает
Ускорение изменения Увеличивается
Постоянна
Уменьшается
Блоки демультиплексоры разбирают вектора на отдельные термы, которые передаются в блоки логической обработки согласно правил нечеткого вывода.
Результат работы нечеткого вывода тоже имеет три лингвистические переменные: «уменьшать», «не изменять», «увеличивать». В виде схемы записаны следующие правила логического вывода.

  • Если Больше и Растет и скорость роста увеличивается => уменьшаем.
  • Если норма, и не изменяется и постоянна => не изменяем.
  • Если Меньше и Падает и скорость падения увеличивается => увеличиваем.


Рисунок 3. Схема реуглятора на базе нечеткой логики.

В качестве функции принадлежности при денацификации используются треугольные функции с общим основанием (см. рис. 4)

Рисунок 4. Треугольные функции фазификации с общим основанием.

Принимается, что функции симметричны относительно 0, в этом случае для описания трех треугольных функций достаточно одного значения Мах. Для приведенных на рисунке Мaх = 30.

Для вывода используются такие же функции принадлежности.

Для полного определения регулятора необходимо задать максимальные значения для блоков фазификации переменных:

— deltaMax – максимальное отклонение;
— divMax – максимальна производная отклонения;
— div2Max – максимальная вторая производная отклонения;
— uMaх – максимальное управляющее воздействие.

Оптимизация по полному процессу


Максимальное управляющее воздействие принимаем равным uMaх — 70.
Таким образом, нам остается подобрать 3 параметра для функции фазифкации.
В данной задаче у нас рассогласование подается ступенькой в нулевой момент модельного времени, u(t) = 1+0.5.sin(πt/30).

Программная траектория, заданный угол тангажа u(t) = 1+0.5sin(πt/30), вызывает ступенчатое воздействие на первой секунде переходного процесса, как выяснилось при опытах с предыдущей задачей, регуляторы, настроенные на плавных процесс управления, при ступенчатом воздействии могут не обеспечивать требуемое качество переходного процесса.

Поэтому для оптимизации мы формируем 3 критерия:

  1. Время переходного процесса – мы должны как можно быстрее выйти на заданную программную траекторию.
  2. Среднеквадратичное отклонение.
  3. Количество переключений – в экспериментах с предыдущей задачей мы получили вариант, когда в системе управления на выходе были высокочастотные колебания управляющего воздействия.

Общая схема блока оптимизации представлена на рисунке 5.

Рисунок 5. Схема блока оптимизации.

Входные параметры блока оптимзации:

— отклонение от заданного угла тангажа.
— регулирующего воздействия.

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

В качестве переключения используется модуль отклонения. Если модуль отклонения больше заданного значения переключения (0.02) то на выходе из блока подается текущее время, если модуль меньше заданного значения то на выход передается время запомненное, когда отклонение было больше. Если далее отклонение снова превысит предел, мы снова получим время. Таким образом, на выходе у нас всегда последнее время, когда отклонение превышало заданное.
В качестве единицы переключения принято изменения знака управляющего воздействия с + на -. Для вычисления количества переключений используем блок «импульс по фронту» который при изменении входа с 0 до 1 выдает импульс длительностью в шаг интегрирования, подсчет импульсов выполняется интегратором. На выходе из блока — количество переключений.

— Блок оптимизации подбирает значения оптимизируемых параметров таким образом, что бы минимизировать все три параметра:
— deltaMax – максимальное отклонение;
— divMax – максимальна производная отклонения;
— div2Max – максимальная вторая производная отклонения.

Результат оптимизация по полному переходному процессу.


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

— deltaMax = 0.185– максимальное отклонение;
— divMax = 0.278 – максимальна производная отклонения;
— div2Max = 1.291 – максимальная вторая производная отклонения.

Результаты оптимизированного процесса приведены на рисунке 6.

Рисунок 6а. Переходной процесс.

Рисунок 6б. Параметры управления.

Видно, что оптимизация, в целом, удалась, но отклонения от заданного угла тангажа есть практически на всем протяжении процесса. Укрупненный график отклонения показывает, что отклонения после оптимизации и завершения переходного процесса находятся в передела 0.015 — 0.02. (см. рис. 7)

Рисунок 7. Отклонение в процессе управления.

Оптимизация по участкам полета.


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

Первый участок – это время со старта до выхода на заданную траекторию. Исходя из графика отклонения, переходной процесс, связанный с начальным ступенчатым воздействием, заканчивается где-то при 20 сек. (см. рис. 7). На этом участке происходит оптимизация по времени переходного процесса.

Установим время окончания расчета 20 сек. И выполним оптимизации, убрав из критериев среднеквадратичное отклонение. Оптимизировать будем по времени переходного процесса и количества переключений. Схема блока оптимизации приведена на рисунке 8.


Рисунок 8. Схема оптимизация на первом участке полета.

Автоматическая оптимизация для первого участка полета до 20 секунд выдала такие параметры для нечеткого регулирования:

— deltaMax = 0.056– максимальное отклонение;
— divMax = 0.0968 – максимальна производная отклонения;
— div2Max = 0.987 – максимальная вторая производная отклонения.

Переходной процесс после оптимизации представлен на рисунке 9.

Отклонение в увеличенном масштабе представлены на рисунке 10

Рисунок 9а. Переходной процесс.

Рисунок 9б. Параметры управления.


Рисунок 10. Отклонение в увеличенном масштабе первого участка полета.

На графиках видно, что уменьшилась величина перерегулирования и отклонение после завершения переходного процесса стало меньше 0.005.

Для оптимизации на следующем участке полета мы выполним моделирование с сохраненным состоянием, полученным на первом участке.

Моделирование происходит с 20 по 40 секунду полета баллистической ракеты, оптимизация происходит по всему процессу.

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


Рисунок 11. Схема оптимизации на втором участке полета.

Автоматическая оптимизация для второго участка полета от 20 до 40 секунд выдала такие параметры для нечеткого регулирования:

— deltaMax = 0.056– максимальное отклонение;
— divMax = 0.0974 – максимальна производная отклонения;
— div2Max = 0.980 – максимальная вторая производная отклонения.

При заданных параметрах отклонение угла тангажа от заданного уменьшается на всем втором временном участке полета. Но если использовать полученные оптимизацией на втором участке полета параметры для управления до 66 секунды, то видно, что точность начинает снижется и отклонение начинает расти после 40 секунды (см. рис. 12).


Рисунок 12. Процесс управления баллистической ракетой с настройками, оптимизированными на 20-40 секунду полета.

Повторим оптимизацию для третьего участка полета. Сохраним результаты 40 секунды.

Используем их для старта и оптимизации на участке от 40 до 66 секунды.

Автоматическая оптимизация для последнего участка полета от 40 до 66 секунд выдала такие параметры для нечеткого регулирования:

— deltaMax = 0.0146– максимальное отклонение;
— divMax = 0.0157– максимальна производная отклонения;
— div2Max = 0.555 – максимальная вторая производная отклонения.

График процесса управления на последнем участке полета баллистической ракеты после оптимизации представлен на рисунке 13.

Рисунок 13. Процесс управления баллистической ракетой на последнем участке полета.

Из рисунка 13 видно, что при новых настройках отклонение на временном отрезке полета 40-66 секунд не увеличивается, в отличие от настроек оптимизированных на второй участок полета (см. рис.12).

Таким образом, мы получили настройки нечеткого регулятора для трех участков полета. Давайте создадим переключатель режимов, который будет переключать настройки регулятора в процессе полета. Схема переключателя режимов изображена на рисунке 14


Рисунок 14. Переключатель режимов нечеткого регулятора баллистической ракеты.

Переключение режимов у нас будет происходить по времени, в верхней части простая логическая схема осуществляет сравнение текущего модельного времени с точками переключения. В результате в мултиплексоре формируется управляющий вектор из трех значений. В данном векторе значение 1 находится на позиции текущего временного интервала.

Рассчитанные ранее методами оптимизации параметры нечеткого регулятора упакованы в вектора из трех значений.

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

Для наглядности значения, передаваемые по линии связи, отображены на схеме. Рисунок соответствует последнему участку полета баллистической ракеты. Время больше 40 сек. Вектор управления (0,0,1) в регулятор подается последний параметр из набора.

Результат моделирования управления углом тангажа ракеты с переключением параметров регулятора представлен на рисунке 15.

Рисунок 15а. Переходной процесс.

Рисунок 15б. Параметры управления.

Выводы:
Регулятор на базе нечеткой логики может быть настроен методом оптимизации на работу в режим переключения параметров.

Отклонение при работе с переменными параметрами в приведённом примере уменьшились в 3 – 5 раз по сравнению с работой регулятора с постоянными параметрами.

Архив с проектами для самостоятельного изучения можено скачать здесь...
Теги: SimInTechfuzzy logicsimulinkТАУматематическое моделированиесистемы автоматического управления
Хабы: Анализ и проектирование систем Алгоритмы Математика Matlab
Всего голосов 6: ↑6 и ↓0 +6
Комментарии 35
Комментарии Комментарии 35

Похожие публикации

Лучшие публикации за сутки