Используйте H-мост для управления двумя коллекторными моторами, а точнее скоростью и направлением вращения вала. H-мост также сможет управлять одним биполярным шаговым двигателем.
В качестве мозга для управления моторами рассмотрим платформу из серии Arduino, например Arduino Uno.
Выберите один из вариантов коммуникации драйвера с внешним микроконтроллером:
Для начала покрутим каждый мотор в одну, а затем другую сторону. Прошейте платформу Arduino скетчем, приведённым ниже.
// Пины управления скоростью и направлением мотора constexpr auto pinM1Speed = 9; constexpr auto pinM1Direction = A1; constexpr auto pinM2Speed = 10; constexpr auto pinM2Direction = A0; int pins[] = {pinM1Speed, pinM1Direction, pinM2Speed, pinM2Direction}; void setup() { // Настраиваем все пины управление моторами в режим выхода for (int i = 0; i < 4; i++) { pinMode(pins[i], OUTPUT); } } void loop() { // Крутим мотор M1 в одну сторону в течении 1 секунды motorsDrive(255, 0); delay(1000); // Крутим мотор M1 в другую сторону в течении 1 секунды motorsDrive(-255, 0); delay(1000); // Крутим мотор M2 в одну сторону в течении 1 секунды motorsDrive(0, 255); delay(1000); // Крутим мотор M2 в другую сторону в течении 1 секунды motorsDrive(0, -255); delay(1000); // Стоим на месте motorsDrive(0, 0); delay(1000); } // Функция управления моторами void motorsDrive(int M1Speed, int M2Speed) { if (M1Speed > 0) { digitalWrite(pinM1Direction, HIGH); } else { digitalWrite(pinM1Direction, LOW); } if (M2Speed > 0) { digitalWrite(pinM2Direction, HIGH); } else { digitalWrite(pinM2Direction, LOW); } analogWrite(pinM1Speed, abs(M1Speed)); analogWrite(pinM2Speed, abs(M2Speed)); }
Усовершенствуем эксперимент: заставим каждый мотор по очереди плавно разгоняться и останавливаться в разных направлениях.
// Пины управления скоростью и направлением мотора constexpr auto pinM1Speed = 9; constexpr auto pinM1Direction = A1; constexpr auto pinM2Speed = 10; constexpr auto pinM2Direction = A0; int pins[] = {pinM1Speed, pinM1Direction, pinM2Speed, pinM2Direction}; void setup() { // Настраиваем все пины управление моторами в режим выхода for (int i = 0; i < 4; i++) { pinMode(pins[i], OUTPUT); } } void loop() { // Медленно разгоняем M1 в одну сторону for (int i = 0; i <= 255; i++) { motorsDrive(i, 0); delay(10); } // Медленно тормозим мотор for (int i = 255; i >= 0; i--) { motorsDrive(i, 0); delay(10); } // Медленно разгоняем M1 в другую сторону for (int i = 0; i <= 255; i++) { motorsDrive(-i, 0); delay(10); } // Медленно тормозим мотор for (int i = 255; i >= 0; i--) { motorsDrive(-i, 0); delay(10); } // медленно разгоняем M2 в одну сторону for (int i = 0; i <= 255; i++) { motorsDrive(0, i); delay(10); } // медленно тормозим мотор for (int i = 255; i >= 0; i--) { motorsDrive(0, i); delay(10); } // медленно разгоняем M2 в другую сторону for (int i = 0; i <= 255; i++) { motorsDrive(0, -i); delay(10); } // медленно тормозим мотор for (int i = 255; i >= 0; i--) { motorsDrive(0, -i); delay(10); } } // Функция управления моторами void motorsDrive(int M1Speed, int M2Speed) { if (M1Speed > 0) { digitalWrite(pinM1Direction, HIGH); } else { digitalWrite(pinM1Direction, LOW); } if (M2Speed > 0) { digitalWrite(pinM2Direction, HIGH); } else { digitalWrite(pinM2Direction, LOW); } analogWrite(pinM1Speed, abs(M1Speed)); analogWrite(pinM2Speed, abs(M2Speed)); }
Для лёгкого и быстрого управления шаговым двигателем мы написали библиотеку AmperkaStepper, которая скрывает в себе все тонкости работы с мотором и предоставляет удобные методы.
// Библиотека для работы с шаговым двигателем #include <AmperkaStepper.h> // Создаём объект для работы с шаговым двигателем // и передаём фиксированное количество шагов за полный оборот. // Подробности в характеристиках двигателя AmperkaStepper motor(200, A0, A1, 9, 10); void setup() { // Устанавливаем скорость вращения 30 оборотов в минуту. motor.setSpeed(30); } void loop() { // 180° по часовой стрелке в двухфазном режиме motor.step(100, FULL_STEP); delay(1000); // 180° против часовой стрелки в однофазном режиме motor.step(-100, WAVE_DRIVE); delay(1000); // 180° по часовой стрелке в полушаговом режиме motor.step(200, HALF_STEP); delay(1000); // 180° против часовой стрелки в двухфазном режиме // этот режим используется по умолчанию, если не передан // второй аргумент motor.step(-100); delay(1000); }
В качестве мозга для управления моторами рассмотрим платформу из серии Espruino, например, Iskra JS.
Выберите один из вариантов коммуникации драйвера с внешним микроконтроллером:
Покрутим каждый мотор в одну, а затем другую сторону. Прошейте платформу Espruino скриптом, приведённым ниже.
// Подключаем библиотеку «motor» var Motor = require('@amperka/motor'); // Пины управления скоростью и направлением мотора var motorOne = Motor.connect({phasePin: A1, pwmPin: P9, freq: 100}); var motorTwo = Motor.connect({phasePin: A0, pwmPin: P10, freq: 100}); // Интервал времени var time = 1000; // Счётчик var state = 0; // Каждую секунду меняем режим работы setInterval(() => { motorOne.write(0); motorTwo.write(0); state++; if (state === 1) { motorOne.write(1); } else if (state === 2) { motorOne.write(-1); } else if (state === 3) { motorTwo.write(1); } else if (state === 4) { motorTwo.write(-1); } else { state = 0; } }, time);
Для лёгкого и быстрого управления шаговым двигателем, используйте библиотеку StepperMotor, которая скрывает в себе все тонкости работы с шаговиком и предоставляет удобные методы.
// Подключаем библиотеку «motor» var StepperMotor = require("StepperMotor"); // Создаём объект для работы с шаговым двигателем // передаём пины управления var motor = new StepperMotor({ pins:[A0, A1, P9, P10], pattern:[0b0001,0b0011,0b0010,0b0110,0b0100,0b1100,0b1000,0b1001], }); // Крутим вал на 100 шагов по часовой стрелке motor.moveTo(100, 5000, function() { // Крутим вал на 100 шагов против часовой стрелке motor.moveTo(-100, 5000, function() { // Приехали console.log("Done!"); }, true); });
В качестве мозга для управления моторами рассмотрим одноплатные компьютеры Raspberry Pi, например, Raspberry Pi 4.
В компьютере Raspberry Pi присутствует только два канала с ШИМ-сигналом, и то которые используются для аналогового звукового выхода. В итоге для регулировки скоростью моторов придется жертвовать звуком. Используйте плату расширения Troyka Cap, которая добавит малине 9 пинов с поддержкой ШИМ.
Подключите драйвер к компьютеру Raspberry Pi через Troyka Cap. Для коммуникации используйте трёхпроводные шлейфы «мама-мама», который идут в комплекте с модулем.
Для начала покрутим каждый мотор в одну, а затем другую сторону. Запустите скрипт на малине, приведённый ниже.
# библиотека для работы с пинами GPIO import RPi.GPIO as GPIO # библиотека для работі с временем import time # выбираем имена пинов BCM GPIO.setmode(GPIO.BCM) # устанавливаем светодиод в режим выхода GPIO.setup(24, GPIO.OUT) try: while True: # ждём одну секунду time.sleep(1) # зажигаем светодиод GPIO.output(24, GPIO.HIGH) # ждём одну секунду time.sleep(1) # гасим светодиод GPIO.output(24, GPIO.LOW) except KeyboardInterrupt: print('The program was stopped by keyboard.') finally: GPIO.cleanup() print('GPIO cleanup completed.')
H-мост может управлять двумя отдельными коллекторными моторами или одним биполярным шаговым двигателем.
P
.Значение входного силового напряжения зависит от номинального напряжения подключаемых моторов и ограничено диапазоном от 3,3 до 12 вольт.
P
.Значение входного силового напряжения зависит от номинального напряжения шагового двигателя и ограничено диапазоном от 3,3 до 12 вольт.
Сердце и мускулы платы — микросхема двухканального H-моста TB6612FNG, которая позволяет управлять двумя коллекторными моторами или одним биполярным шаговым двигателем с помощью внешнего микроконтроллера.
Термин «H-мост» появился благодаря графическому изображению схемы, напоминающему букву «H». Рассмотрим подробнее принцип работы H-моста.
В зависимости от текущего состояние переключателей возможно разное состояние мотора.
S1 | S2 | S3 | S4 | Результат |
---|---|---|---|---|
1 | 0 | 0 | 1 | Мотор крутится вправо |
0 | 1 | 1 | 0 | Мотор крутится влево |
0 | 0 | 0 | 0 | Свободное вращение мотора |
0 | 1 | 0 | 1 | Мотор тормозит |
1 | 0 | 1 | 0 | Мотор тормозит |
1 | 1 | 0 | 0 | Короткое замыкание источника питания |
0 | 0 | 1 | 1 | Короткое замыкание источника питания |
Ключи меняем на MOSFET-транзисторы, а для плавной регулировки скорости вращения вала мотора используем ШИМ-сигнал.
На плате драйвера моторов присутствует два контура питания: силовое и логическое.
P
c входным диапазоном напряжения от 5 до 12 вольт. V
. Диапазон входного напряжения от 3,3 до 5 вольт. Если отсутствует хотя бы один из контуров питания — драйвер H-мост работать не будет.
При подключении питания соблюдайте полярность. Неправильное подключение может привести к непредсказуемому поведению или выходу из строя платы или источника питания.
Нагрузка разделена на два независимых канала. Первый канал на плате обозначен шёлком M1
, а второй канал — M2
. К каждому каналу можно подключить по одному коллекторному мотору или объединить каналы для подключения биполярного шагового двигателя.
Обозначения «+» и «−» показывают воображаемые начало и конец обмотки. Если подключить два коллекторных двигателя, чтобы их одноимённые контакты щёточного узла соответствовали одному и тому же обозначению на плате, то при подаче на H-Bridge одинаковых управляющих импульсов, моторы будут вращаться в одну и ту же сторону.
Имя светодиода | Назначение |
---|---|
DIR1/EN1 | Индикация состояния направления и скорости первого канала M1 . При высоком логическом уровне светится зелёным светом, при низком — красным. Яркость светодиода пропорциональна скорости вращения двигателя. |
DIR2/EN2 | Индикация состояния направления и скорости первого канала M2 . При высоком логическом уровне светится зелёным светом, при низком — красным. Яркость светодиода пропорциональна скорости вращения двигателя. |