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

Система противораскачивания груза (Anti-Sway Control)

Уровень сложностиСредний
Время на прочтение10 мин
Количество просмотров4.8K

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

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

Схема тележки с грузом
Схема тележки с грузом
Обозначения

M = 30 кг – масса тележки

m = 10 кг  – масса груза

f – сила, прикладываемая к тележке

x(t) – значение горизонтального перемещения тележки

α – угол поворота маятника, учитывается в положительном направлении от строго вертикального положения вниз

l = 1.2 м – расстояние от точки крепления до
центра масс маятника

Дифференциальные уравнения

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

Начнем с дифференциальных уравнений. Чтобы представить модель в таком виде мы воспользуемся методом Лагранжа.

Метод Лагранжа

Данный метод позволяет написать дифференциальные уравнения движения второго порядка. Суть метода заключается в том, что динамика механической системы рассматривается в целом и внутренние силы реакции связей исключаются из уравнений модели. Чтобы записать модель, нужно выбрать обобщенные координаты и обобщенные скорости. Что это такое? Обобщенные координаты – это независимые друг от друга параметры, которые определяют положение системы в пространстве, а обобщенные скорости это их производные. В нашей модели это позиция тележки x_c(t)и угол поворота маятника α(t)и, соответственно, их производные это скорости.

После того, как мы определились с нужными параметрами, можем перейти к уравнениям.

Уравнение Лагранжа имеет вид:

Обозначения

Функция Лагранжа или Лагранжиан вычисляется как:

L=T-U
Обозначения

Т - кинетическая энергия

U - потенциальная энергия

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

Потенциальная энергия этой системы определяется только потенциальной энергией отклонённого на угол αмаятника. Тележка находится на поверхности, которая является нулевым уровнем относительно нее, поэтому высота равняется нулю и, соответственно, потенциальная энергия тоже равна нулю.

U=mgh= mgl(1-cos⁡α)
Вывод уравнения кинетической энергии системы

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

T=\frac{1}{2} Mv^2+\frac{1}{2} mv^2=\frac{1}{2} M\dot{x}^2_c+\frac{1}{2} m(\dot{x}^2_p+\dot{y}^2_p)

Необходимо выразить координаты центра масс маятника(x_p,y_p)через координаты тележки:

x_p= x_c+ l sin⁡αy_p= -l cos⁡α

Нужны скорости, поэтому продифференцируем эти два уравнения:

\dot{x_p}=\dot{x}_c+l\dot{α}cosα\dot{y}_p=l\dotαsinα

Подставляем в формулу кинетической энергии:

T=\frac{1}{2} M\dot{x}^2_c+\frac{1}{2} m(\dot{x}^2_c+2\dot{x}_cl\dot{α}cosα+l^2\dot{α}^2)

Полная кинетическая энергия системы:

T=\frac{1}{2} M\dot{x}^2_c+\frac{1}{2} m(\dot{x}^2_c+2\dot{x}_cl\dot{α}cosα+l^2\dot{α}^2)

Все найденное подставляем в формулу Лагранжиана и получаем:

L=\frac{1}{2} M\dot{x}^2_c+\frac{1}{2} m(\dot{x}^2_c+2\dot{x}_cl\dot{α}cosα+l^2\dot{α}^2)-mgl(1-cos⁡α)

Теперь можно составить систему уравнений Лагранжа нашей системы. Первое уравнение будет описывать движение тележки. Так как это движение линейное, воздействием является сила. Второе уравнение – движение маятника, воздействием является момент. Маятник совершает свободные колебания и не управляется никаким приводом, поэтому момент равен нулю:

Подставив все, продифференцируем и получим систему уравнений:

Линеаризация

Система нелинейная и надо это исправить, потому что иначе не выйдет далее перейти к нормальной форме Коши. При достаточно малых значениях  можно заменить нелинейные функции, как первые члены ряда Тейлора:sin⁡α  ≈ α ,cos⁡α  ≈1, \dot{α}^2≈0.

Тогда упрощённая система будет выглядеть так:

Итоговые уравнения

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

Последним шагом является ввод вектора состояния:

где x_c(t)- позиция тележки, α(t)- угол поворота маятника, \dot{x}(t)- скорость тележки, \dot{α}(t)- скорость угла поворота маятника. Такой вектор выбран относительно составляющих уравнений и будущих желаемых результатов.

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

Пространство состояний

Пространство состояний – n-мерное пространство, которое состоит из элементов, каждый из которых полностью определяет состояние рассматриваемой системы.

Описывается система двумя векторно-матричными уравнениями.

1. Дифференциальное уравнение состояния:

\dot{x}=Ax(t)+Bu(t)
Обозначения

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

2. Дифференциальное уравнение выходов:

y=Cx(t)+Du(t)
Обозначения

Это уравнение связывает переменные состояния и управляющие воздействия с выходными измеряемыми переменными.

Модель в пространстве состояний будет выглядеть так:

A =\begin{bmatrix} 0&0&1&0\\0&0&0&1\\0&\frac{gm}{M}&0&0\\0&-\frac{g(M+m)}{Ml}&0&0\end{bmatrix}; B=\begin{bmatrix} 0\\0\\\frac{1}{M}\\-\frac{1}{Ml}\end{bmatrix};C=\begin{bmatrix} 1&0&0&0 \\0&1&0&0\\0&0&1&0\\0&0&0&1\end{bmatrix}; D=\begin{bmatrix} 0 \\ 0\\0\\0 \end{bmatrix};

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

Модель тележки с грузом с управлением по скорости

Так как нет конкретного способа преобразовать силу в скорость, были выполнены преобразования.

Преобразования силы в скорость

Если представить модель упрощённо, то система выглядит таким образом:

F – заданная сила (входное воздействие)

G – объект моделирования

V – скорость тележки (выходное состояние)

Обратившись ко второму закону Ньютона и представив формулу в виде структурной схемы, в которой выход будет скорость.

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

Записав передаточную функцию системы получим:

W_{зам}=\frac{K_1}{s+K_1}

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

V*– заданная скорость (входное воздействие)

K1 – коэффициент усиления

G – объект моделирования

V- фактическая скорость (выходное состояние)

Коэффициент K1 отображает скорость отработки тележкой заданной скорости. Для будущих расчетов примем примерно K1 =500.

Из полученной модели выразим силу, для того, чтобы заменить ее в дифференциальных уравнениях.

F=K_1 V^*-K_1 V=K_1 (V^*-V)

Так у нас получилось вывести нужные дифференциальные уравнения и матрицы пространства состояний.

Дифференциальные уравнения

Матрицы пространства состояния

A =\begin{bmatrix} 0&0&1&0\\0&0&0&1\\0&\frac{gm}{M}&-\frac{K_1}{M}&0\\0&-\frac{g(M+m)}{Ml}&\frac{K_1}{Ml}&0\end{bmatrix}; B=\begin{bmatrix} 0\\0\\\frac{K_1}{M}\\-\frac{K_1}{Ml}\end{bmatrix};C=\begin{bmatrix} 1&0&0&0 \\0&1&0&0\\0&0&1&0\\0&0&0&1\end{bmatrix}; D=\begin{bmatrix} 0 \\ 0\\0\\0 \end{bmatrix};

Выбор регулятора

Теперь перейдем к главному вопросу – как задать нужное управление. Для этого нам понадобится регулятор. Определить вид регулятора нужно исходя из требований и формы представления математической модели. Наша модель представлена в виде пространства состояний, поэтому, чтобы влиять на все состояния по отдельности, необходимо найти матрицу, с помощью которой будет обеспечиваться устойчивый процесс управления. Таким образом формируется многомерная система управления, реализующая принцип обратной связи. У нас частный случай и управляющее воздействие одно.

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

Ввод регулятора K в систему преобразует управляющее воздействие к виду: u=-Kx. Подставив управляющее воздействие в уравнение состояния получим: \dot{x}=(A-BK)x. Таким образом регулятор K будет напрямую влиять на расположение полюсов матрицы состояния и тем самым влиять на поведение системы.

Синтез регулятора

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

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

Для нашего случая ручные вычисления очень трудоёмкие, поэтому расчет проведен в среде Matlab при помощи команды ctrb(A,B), которая рассчитывает матрицу управляемости. Система полностью управляема. Значит можно начать синтез регулятора.

Алгоритм расчета параметров модального регулятора

Существует алгоритм расчета коэффициентов для модального регулятора. Он был взят из источника.

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

Команда K = acker (A, B, P) вычисляет такую матрицу K, что полюса системы A-BK равны значениям, заданным вектором желаемых полюсов P.

Теперь стоит вопрос в том, какие задавать желаемые полюса (корни).

Выбор корней

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

Подбор корней для решения задачи движения по положению

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

В данной схеме входными воздействиями являются заданные состояния системы в таком порядке: позиция тележки, угол маятника, скорость тележки, скорость угла поворота маятника. В примере на первый вход (позиция тележки) задается 2 м, а на остальные входы подаются 0.

Расчет коэффициентов регулятора, как и было сказано, будет в Matlab.

Для примера выберем вектор полюсов [-1 -1 -1 -1].

Коэффициенты регулятора: K=[0.0073 0.3616 -0.9706 -0.2528]
Коэффициенты регулятора: K=[0.0073 0.3616 -0.9706 -0.2528]

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

Пример с корнями [-3 -3 -3 -3]
Коэффициенты регулятора: К = [0.5945 -2.3898 -0.2073 0.0872]
Коэффициенты регулятора: К = [0.5945 -2.3898 -0.2073 0.0872]

При векторе желаемых корней [-3 -3 -3 -3] переходная характеристика скорости тележки имеет сильные колебания, что неудовлетворительно для работы в реальной жизни.

Но у нас стоит задача задавать скорость и позицию тележки.

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

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

Внутри устанавливается позиция, скорость и время разгона.

Добавим новый блок Speed generator в нашу схему.

Необходимо выбрать требования, которые могут показать наиболее приближенный результат к реальным условиям. Мы будем проверять результаты при входных значениях: позиция 1 м и скорость тележки 0,28 м/с (номинальная скорость для стенда).

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

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

Алгоритм расчета корней

1. Определить порядок системы, следовательно степень характеристического полинома.

2. Выбрать стандартный полином для последующих расчетов: полином Ньютона или полином Баттерворта. Выбор исходит от требований к показателям качества будущей переходной характеристики. Если требуется, чтобы не было перерегулирования, то выбирается полином Ньютона, т.к. корни его полиномов вещественные и не имеют мнимой части, которая влияет на перерегулирование. Если перерегулирование больше 1%, то выбирается полином Баттерворта, т.к. корни его полинома имеют мнимые части. Значения перерегулирования и времени регулирования можно посмотреть в таблице 1 и 2.

3. Выбрав из таблицы 1 или 2 значение времени регулирования по номеру порядка системы и желаемое время регулирования, данные подставляются в формулу для вычисления ω0 – радиуса окружности, на котором лежат полюса.

ω_0=\frac{t_п^1}{t_п}

t1п - время регулирования стандартного полинома 

tп - желаемое время регулирования

ω0 - радиус окружности

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

Таблица 1 - Показатели качества полинома Ньютона

Порядок полинома

1

2

3

4

5

6

Время регулирования t1п, с

3,0

4,8

6,3

7,8

9,2

10,5

Перерегулирование σ, %

0

0

0

0

0

0

Таблица 2 -Показатели качества полинома Баттерворта

Порядок полинома

1

2

3

4

5

6

Время регулирования t1п, с

3,0

2,9

6,0

6,8

7,7

10,8

Перерегулирование σ, %

0

4,5

8,0

11,0

13,5

14,3

Зададим динамические показатели качества: перерегулирование σ = 0% и время переходного процесса будем подбирать вручную, подставляя в формулу.  Для дальнейшего расчета выберем характеристический полином Ньютона, т.к. он соответствует перерегулированию равному 0 %. Объект управления обладает четвертым порядком. Выберем полином 4 порядка.

p_n=λ^4+4ω_0 λ^3+6ω_0^2 λ^2+4ω_0^3 λ+ω_0^4

Как сказано в алгоритме, для расчета корней необходимо задаться временем переходного процесса, который значительно влияет на поведение системы. Методом подбора выбрали время равное 2 с. Если брать значение больше или меньше, характеристики переходных процессов не удовлетворяют поставленным требованиям. Для разных параметров системы это время будет свое.

ω_0=\frac{7.8}{2}=3.9

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

Коэффициенты регулятора: K=[1.6979 -3.7484 0.7415 0.9666]
Коэффициенты регулятора: K=[1.6979 -3.7484 0.7415 0.9666]

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

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

Светлана Верятинская

 Инженер-разработчик ООО "Троицкий крановый завод"

Статья написана в соавторстве с @ivpo6 (инженер-программист Иван Попков)

Теги:
Хабы:
+32
Комментарии86

Публикации

Изменить настройки темы

Истории

Ближайшие события