Stepper Driver configuration
data:image/s3,"s3://crabby-images/93496/93496f1f8c6d750ef37fbeca73d9ec7c9b7a5073" alt=""
data:image/s3,"s3://crabby-images/73901/7390146417daf687a179cfe1a90fc5816a6aff0a" alt=""
data:image/s3,"s3://crabby-images/0e41f/0e41fc3423b33521d67fdd015c98f8ace95c85e2" alt=""
Arduino SimpleFOClibrary implements support for two types of Stepper driver control interfaces:
Classes StepperDriver2PWM
and StepperDriver4PWM
provide an abstraction layer of all the hardware/platform specific code for all the supported platforms: ATMega328, ESP32, STM32, SAM, SAMD and Teensy. They implement:
- PWM configuration
- PWM frequency
- PWM center-alignment
- Direction channel handling (2 PWM)
- Complementary direction channel (2 PWM)
- PWM duty cycle setting
- Voltage limiting
These classes can be used as stand-alone classes and they can be used to set certain PWM value to the stepper driver outputs, see example codes in utils > driver_standalone_test
. In order for FOC algorithm to work the StepperDriverxPWM
classes are linked to a StepperMotor
class which uses the driver to set the appropriate phase voltages.
The driver code is written in a way to support as many different drivers out there as possible and in a way to be fully interchangeable.
Digging deeper
For more theoretical explanations and source code implementations of the FOC algorithm and the motion control approaches check out the digging deeper section.