Библиотека для удобного управления коллекторными моторами через драйвер
- Контроль скорости и направления вращения
- Работа с ШИМ любого разрешения
- Плавный пуск и изменение скорости
- Порог минимального ШИМ
- Программный deadtime
- Поддержка 6 типов драйверов
Warning
Библиотека "состоит" из двух библиотек: GyverMotor
и GyverMotor2
. Вторая версия новее, легче, удобнее и лучше оптимизирована! Первая устарела и не рекомендуется к использованию
Совместима со всеми Arduino платформами (используются Arduino-функции)
- Для esp8266 (до SDK v3) не забудь переключить библиотеку в 10 бит или установить ШИМ в 8 бит на самой еспшке!
Константа | Описание | Пины | Сигнал вперёд | Сигнал назад |
---|---|---|---|---|
DRIVER2WIRE |
двухпроводной драйвер с инверсией шим | GPIO, PWM | 0, PWM | 1, ~PWM |
DRIVER2WIRE_NO_INVERT |
двухпроводной драйвер без инверсии ШИМ | GPIO, PWM | 0, PWM | 1, PWM |
DRIVER2WIRE_PWM_SPEED |
двухпроводной с двумя ШИМ (скорость) | PWM, PWM | 0, PWM | PWM, 0 |
DRIVER2WIRE_PWM_POWER |
двухпроводной с двумя ШИМ (момент) | PWM, PWM | ~PWM, 1 | 1, ~PWM |
DRIVER3WIRE |
трёхпроводной драйвер | GPIO, GPIO, PWM | 0, 1, PWM | 1, 0, PWM |
RELAY2WIRE |
реле в качестве драйвера | GPIO, GPIO | 0, 1 | 1, 0 |
- Для двухпроводных мостовых драйверов стоит отдавать предпочтение типу
DRIVER2WIRE_PWM_POWER
. Он требует два ШИМ пина, но драйвер работает более правильно и меньше нагружается, а также скорость будет одинаковая в обе стороны, в отличие от простогоDRIVER2WIRE
DRIVER2WIRE_PWM_SPEED
даёт мотору более высокую скорость, аDRIVER2WIRE_PWM_POWER
- более высокий крутящий момент и стабильное вращение
GMotor2<тип> motor(пин1, пин2, пин3); // разрядность ШИМ 8 бит (0.. 255)
GMotor2<тип, разрядность> motor(пин1, пин2, пин3); // общий случай, разрядность ШИМ в битах (умолч. 8 бит)
// инициализация с указанием пинов
GMotor2(uint8_t a, uint8_t b, uint8_t c = 0xff);
// установить минимальный ШИМ (умолч. 0)
void setMinDuty(uint16_t mduty);
// установить минимальный ШИМ в % (умолч. 0)
void setMinDutyPerc(uint8_t p);
// реверс направления (умолч. false)
void reverse(bool rev);
// остановка. Если включено ускорение, то плавная
void stop();
// активный тормоз
void brake();
// установить скорость (-макс.. макс)
void setSpeed(int16_t speed);
// установить скорость в процентах (-100.. 100%)
void setSpeedPerc(int16_t spd);
// установить deadtime в микросекундах (умолч. 0)
void setDeadtime(uint16_t us);
// плавное изменение к указанной скорости с ускорением setAccel, вызывать в loop
void tick();
// установить ускорение в единицах ШИМ в секунду. 0 чтобы отключить
void setAccel(uint32_t s);
// установить ускорение в процентах в секунду. 0 чтобы отключить
void setAccelPerc(uint8_t p);
// получить статус: мотор крутится (1 и -1), мотор остановлен (0)
int8_t getState();
// получить текущую скорость мотора в единицах ШИМ
int16_t getSpeed();
Настройки компиляции (объявляются до подключения библиотеки):
#define GMOTOR2_NO_ACCEL // отключить поддержку плавного режима
#define GMOTOR2_DT 50 // период таймера ускорения, мс
Скорость задаётся в setSpeed(-макс ШИМ.. макс ШИМ)
в величине ШИМ сигнала, либо в setSpeedPerc(-100.. 100)
в процентах. Скорость может быть отрицательной, тогда мотор будет крутиться в обратную сторону. При значении 0
мотор остановится и драйвер будет отключен.
- Вызов
stop()
равносиленsetSpeed(0)
. При прямом управлении мотор будет сразу остановлен, при плавном - остановится плавно. Драйвер отключится, вал мотора будет освобождён - Вызов
brake()
остановит мотор и переключит драйвер в режим активного торможения (замкнёт мотор через себя). Вал мотора будет сопротивляться вращению - Вызов
reverse(true)
инвертирует направление вращения мотора
В setMinDuty(-макс ШИМ.. макс ШИМ)
можно установить минимальное значение ШИМ (при которой мотор начинает вращение, подбирается экспериментально), это удобно в большинстве применений: установленная в setSpeed()
скорость будет автоматически масштабироваться с учётом минимального ШИМ. Также можно задать минимальную скорость в процентах setMinDutyPerc(-100.. 100)
.
В плавном режиме установленная в setSpeed()
скорость применяется не сразу, а плавно в течением времени с заданным ускорением. Для включения
плавного режима нужно указать ускорение в setAccel(uint32_t s)
в единицах ШИМ в секунду и поместить в основном цикле программы функцию-тикер tick()
. Скорость изменения скорости можно задать и в процентах в секунду через setAccelPerc(uint8_t p)
. Для отключения режима нужно установить ускорение равным 0
.
Остальные примеры смотри в examples!
#include <GyverMotor2.h>
GMotor2<DRIVER2WIRE> motor(5, 6);
void setup() {
motor.setMinDuty(70); // мин. ШИМ
//motor.reverse(1); // реверс
//motor.setDeadtime(5); // deadtime
}
void loop() {
motor.setSpeed(10);
delay(1000);
motor.setSpeed(-100);
delay(1000);
motor.setSpeed(50);
delay(1000);
motor.setSpeed(255);
delay(1000);
motor.brake();
delay(3000);
}
- v1.1 - убраны дефайны
- v1.2 - возвращены дефайны
- v2.0:
- Программный deadtime
- Отрицательные скорости
- Поддержка двух типов драйверов и реле
- Плавный пуск и изменение скорости
- v2.1: небольшие фиксы и добавления
- v2.2: оптимизация
- v2.3: добавлена поддержка esp (исправлены ошибки)
- v2.4: совместимость с другими библами
- v2.5: добавлен тип DRIVER2WIRE_NO_INVERT
- v3.0: переделана логика minDuty, добавлен режим для ШИМ любой битности
- v3.1: мелкие исправления
- v3.2: улучшена стабильность плавного режима
- v3.2.1: вернул run() в public
- v4.0: исправлен баг в GyverMotor. Добавлен GyverMotor2
- Библиотеку можно найти по названию GyverMotor и установить через менеджер библиотек в:
- Arduino IDE
- Arduino IDE v2
- PlatformIO
- Скачать библиотеку .zip архивом для ручной установки:
- Распаковать и положить в C:\Program Files (x86)\Arduino\libraries (Windows x64)
- Распаковать и положить в C:\Program Files\Arduino\libraries (Windows x32)
- Распаковать и положить в Документы/Arduino/libraries/
- (Arduino IDE) автоматическая установка из .zip: Скетч/Подключить библиотеку/Добавить .ZIP библиотеку… и указать скачанный архив
- Читай более подробную инструкцию по установке библиотек здесь
- Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
- Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
- Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
При нахождении багов создавайте Issue, а лучше сразу пишите на почту [email protected]
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:
- Версия библиотеки
- Какой используется МК
- Версия SDK (для ESP)
- Версия Arduino IDE
- Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
- Какой код загружался, какая работа от него ожидалась и как он работает в реальности
- В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код