Управление движением самолёта по тангажу¶
В данном примере демонстрируется моделирование системы управления продольным движением самолета. Модели динамики самолёта и исполнительных механизмов описываются линейными аппроксимациями первого порядка и соединеняются с аналоговой системой управления. Подсистема Controller (Регулятор):
Использует сигнал тангажа от ручки управления самолётом в качестве уставки для угла тангажа самолета.
Использует угол тангажа самолета и скорость изменения этого угла для формирования управляющих воздействий.
Для возмущения системы в модели реализована упрощенная подсистема Dryden Wind Gust Models (Модели порывов Драйдена).
Схема модели:¶
Определение функции для загрузки и запуска модели:¶
In [ ]:
function start_model_engee()
try
engee.close("pitch_control", force=true) # закрытие модели
catch err # в случае, если нет модели, которую нужно закрыть и engee.close() не выполняется, то будет выполнена её загрузка после catch
m = engee.load("$(@__DIR__)/pitch_control.engee") # загрузка модели
end;
try
engee.run(m) # запуск модели
catch err # в случае, если модель не загружена и engee.run() не выполняется, то будут выполнены две нижние строки после catch
m = engee.load("$(@__DIR__)/pitch_control.engee") # загрузка модели
engee.run(m) # запуск модели
end
end
Out[0]:
Запуск симуляции¶
In [ ]:
start_model_engee();
Выделение из переменной simout сигналов угла тангажа и уставки:
In [ ]:
result = simout;
res = collect(result)
Out[0]:
Запись сигналов в переменные:
In [ ]:
alpha = collect(res[1])
stick = collect(res[2]);
Визуализация результатов моделирования¶
График угла тангажа самолёта и сигнал уставки:
In [ ]:
using Plots
gr()
plot(alpha[:,1], alpha[:,2], label="Угол тангажа самолёта, град.", linewidth=3)
plot!(stick[:,1], stick[:,2], label="Уставка, град.", linewidth=3)
Out[0]: