GY-63_MS5611/libraries/AS5600/AS5600.h
2022-06-26 13:58:33 +02:00

136 lines
3.1 KiB
C++

#pragma once
//
// FILE: AS5600.h
// AUTHOR: Rob Tillaart
// VERSION: 0.1.3
// PURPOSE: Arduino library for AS5600 magnetic rotation meter
// DATE: 2022-05-28
// URL: https://github.com/RobTillaart/AS5600
#include "Arduino.h"
#include "Wire.h"
#define AS5600_LIB_VERSION (F("0.1.3"))
#define AS5600_CLOCK_WISE 0 // LOW
#define AS5600_COUNTERCLOCK_WISE 1 // HIGH
#define AS5600_RAW_TO_DEGREES (0.0879120879120879121)
#define AS5600_RAW_TO_RADIANS (0.00153435538636864138630654133494)
class AS5600
{
public:
AS5600(TwoWire *wire = &Wire);
#if defined (ESP8266) || defined(ESP32)
bool begin(int sda, int scl, int directionPin = AS5600_CLOCK_WISE);
#endif
bool begin(int directionPin = AS5600_CLOCK_WISE);
bool isConnected();
uint8_t getAddress() { return _address; }; // 0x36
// SET CONFIGURE REGISTERS
// read datasheet first
void setDirection(uint8_t direction = AS5600_CLOCK_WISE);
uint8_t getDirection();
uint8_t getZMCO();
void setZPosition(uint16_t value);
uint16_t getZPosition();
void setMPosition(uint16_t value);
uint16_t getMPosition();
void setMaxAngle(uint16_t value);
uint16_t getMaxAngle();
// access the whole configuration register
void setConfigure(uint16_t value);
uint16_t getConfigure();
// access details of the configuration register
// 0 = Normal
// 1,2,3 are low power mode - check datasheet
void setPowerMode(uint8_t powerMode); // 0..3
uint8_t getPowerMode();
// hysteresis = nr of LSB
void setHysteresis(uint8_t hysteresis); // 0..3
uint8_t getHysteresis();
// 0 = analog 0-100%
// 1 = analog 10-90%
// 2 = PWM
void setOutputMode(uint8_t outputMode); // 0..2
uint8_t getOutputMode();
// 0 = 115 1 = 230 2 = 460 3 = 920 (Hz)
void setPWMFrequency(uint8_t pwmFreq); // 0..3
uint8_t getPWMFrequency();
void setSlowFilter(uint8_t mask); // 0..3
uint8_t getSlowFilter();
void setFastFilter(uint8_t mask); // 0..7
uint8_t getFastFilter();
// 0 = OFF
// 1 = ON (auto low power mode)
void setWatchDog(uint8_t mask); // 0..1
uint8_t getWatchDog();
// READ OUTPUT REGISTERS
uint16_t rawAngle();
uint16_t readAngle();
// READ STATUS REGISTERS
uint8_t readStatus();
uint8_t readAGC();
uint16_t readMagnitude();
// access detail status register
bool detectMagnet();
// BURN COMMANDS
// DO NOT UNCOMMENT - USE AT OWN RISK - READ DATASHEET
// void burnAngle();
// void burnSetting();
// experimental 0.1.2 - to be tested.
// approximation of the angular speed in rotations per second.
// mode == 1: radians /second
// mode == 0: degrees /second (default)
float getAngularSpeed(uint8_t mode = 0);
private:
uint8_t readReg(uint8_t reg);
uint16_t readReg2(uint8_t reg);
uint8_t writeReg(uint8_t reg, uint8_t value);
const uint8_t _address = 0x36;
uint8_t _directionPin;
uint8_t _error = 0;
TwoWire* _wire;
uint32_t _lastMeasurement = 0;
uint16_t _lastAngle = 0;
};
// -- END OF FILE --