Skip to content

simplefoc/Arduino-FOC-drivers

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SimpleFOC Driver and Support Library

Library Compile License: MIT Release

This library contains an assortment of drivers and supporting code for SimpleFOC.

The intent is to keep the core of SimpleFOC clean, and thus easy to maintain, understand and port to different platforms. In addition to this core, there are various drivers and supporting code which has grown around SimpleFOC, and which we would like to make available to the community.

New Release

v1.0.7 - Released 29 March 2024, for Simple FOC 2.3.2 or later

What's changed since 1.0.6?

  • Improvements to LinearHall driver, thanks to dekutree
  • Fix for ESP32 compiler warning, thanks to Yannik Stradmann
  • Added STM32 LPTIM encoder driver
  • Refactored communications code
  • Working telemetry abstraction
  • Working streams communications, ASCII based
  • Refactored settings storage code
  • Refactored I2CCommander
  • New utility class for simple trapezoidal motion profiles
  • Bugfixes included

What is included

What is here? See the sections below. Each driver or function should come with its own more detailed README.

Motor/Gate driver ICs

Software to control gate driver ICs or integrated driver ICs which have advanced configuration and status interfaces, e.g. via I2C or SPI.

Encoders

Drivers for various position sensor ICs. In many cases these hardware-specific drivers often support more functionality than the generic SimpleFOC sensor drivers, including reading status registers, setting configurations and more.

  • AS5048A SPI driver - SPI driver for the AMS AS5048A absolute position magnetic rotary encoder IC.
  • AS5047 SPI driver - SPI driver for the AMS AS5047P and AS5047D absolute position magnetic rotary encoder ICs.
  • AS5047U SPI driver - SPI driver for the AMS AS5047U absolute position magnetic rotary encoder ICs.
  • AS5600 I2C driver - I2C driver for the AMS AS5600 and AS5600L absolute position magnetic rotary encoder ICs.
  • MA730 SPI driver - SPI driver for the MPS MagAlpha MA730 absolute position magnetic rotary encoder IC.
  • MA730 SSI driver - SSI driver for the MPS MagAlpha MA730 absolute position magnetic rotary encoder IC.
  • AS5145 SSI driver - SSI driver for the AMS AS5145 and AS5045 absolute position magnetic rotary encoder ICs.
  • TLE5012B SPI driver - SPI (half duplex) driver for TLE5012B absolute position magnetic rotary encoder IC.
  • STM32 Hardware Encoder - Hardware timer based encoder driver for ABI type quadrature encoders.
  • SC60228 SPI driver - SPI driver for SemiMent SC60288 magnetic encoder IC.
  • MA330 SPI driver - SPI driver for the MPS MagAlpha MA330 absolute position magnetic rotary encoder IC.
  • MT6816 SPI driver - SPI driver for the MagnTek MT6816 absolute position magnetic rotary encoder IC.
  • MT6701 SSI driver - SSI driver for the MagnTek MT6701 absolute position magnetic rotary encoder IC.
  • MT6835 SPI driver - SPI driver for the MagnTek MT6835 21 bit magnetic rotary encoder IC.
  • STM32 PWM sensor driver - STM32 native timer-based driver for PWM angle sensors.
  • CalibratedSensor - A sensor which can calibrate for eccentricity on the magnet placement.
  • SmoothingSensor - A SimpleFOC Sensor wrapper implementation which adds angle extrapolation.

Communications

Extended communications classes for SimpleFOC. In particular the Telemetry and PacketCommander classes, which implement ASCII or Binary communications and allow monitoring and control of multiple motors, via an easy to use "Registers" abstraction. The Binary and ASCII packet based protocols are directly supported in PySimpleFOC.

  • PacketCommander - Serial communications with binary protocol, based on register abstraction - get or set any value in SimpleFOC
  • Telemetry - Telemetry based on registers - monitor any value in SimpleFOC, and log in either ASCII or Binary, compatible with PacketCommander
  • SimpleTelemetry - Register telemetry for use with Arduino Serial Plotter tool
  • TeleplotTelemetry - Register telemetry for use with VSCode Teleplot extension
  • I2CCommander I2C driver - I2C communications based on register abstraction
  • STM32 SpeedDir Input - Control target velocity with PWM speed and direction inputs

Settings

Load and store SimpleFOC motor settings, based on register abstraction. Storing the motor calibration allows you to skip the calibration phase during setup.

Motor classes

Drive different kinds of motors, or use alternate algorithms to SimpleFOC's default BLDCMotor and StepperMotor classes.

Utilities

Other support code not fitting in the above categories.

How to use

Arduino Library Manager

The simplest way to get hold of the library is directly by using Arduino IDE and its integrated Library Manager.

  • Open Arduino IDE and start Arduino Library Manager by clicking: Tools > Manage Libraries....
  • Search for Simple FOC drivers library and install the latest version.
  • Reopen Arduino IDE and you should have the library examples in File > Examples > Simple FOC drivers.

Using Github website

  • Go to the github repository
  • Click first on Clone or Download > Download ZIP.
  • Unzip it and place it in Arduino Libraries folder. Windows: Documents > Arduino > libraries.
  • Reopen Arduino IDE and you should have the library examples in File > Examples > Simple FOC drivers.

Using parts

You can copy parts of the library, for example to minimize your code size, or make it easier to add adaptations of your own. If you do so, please be sure to adhere to and include the LICENSE.

Further Documentation

Find out more information about the Arduino SimpleFOC project on the docs website

Release History

What's changed since 1.0.5?

  • Added STSPIN32G4 driver
  • Added STM32G4 CORDIC code, for greatly accellerated trig functions on supported MCUs
  • Added STM32FlashSettingsStorage driver, supporting STM32G4 MCUs
  • Improvements in the MT6835 sensor driver
  • Bugfixes included

What's changed since 1.0.4?

  • Added smoothing sensor by @dekutree64
  • Added TMD6200 SPI driver by @YaseenTwati
  • Added HybridStepperMotor by @VIPQualityPost
  • New Settings abstraction to load and save SimpleFOC settings and calibration
  • New Settings driver: SAMDNVMSettingsStorage
  • SimpleFOCRegisters abstraction, mapping SimpleFOC parameters to virtual "Registers"
  • Updated I2CCommander to use the new registers abstraction
  • Bugfixes included

What's changed since 1.0.3?

  • New Comms/Input: STM32SpeedDirCommander
  • New Utility: STM32PWMInput
  • Fixed MT6835 driver bugs
  • Improved AS5047 driver, fixed bugs
  • Improved AS5047U driver, fixed bugs

What's changed since 1.0.2?

  • New Sensor: MT6835
  • Fixed bugs

What's changed since 1.0.1?

  • Calibrated sensor by @MarethyuPrefect
  • New Sensors: MT6701, MA330, MT6816
  • Fixed bugs