custom-board-bundle-sample-.../firmware/controllers/system/dc_motor.h

68 lines
1.8 KiB
C
Raw Normal View History

/**
2019-03-29 06:11:13 -07:00
* @file dc_motor.h
*
* @date Dec 22, 2018
* @author Matthew Kennedy, (c) 2018
*/
#pragma once
#include "pwm_generator_logic.h"
/**
* @brief Brushed or brushless DC motor interface
*
* Represents a DC motor (brushed or brushless) that provides simple
* torque/power/current/duty cycle control, but not accurate absolute position control.
*/
class DcMotor
{
public:
/**
* @brief Sets the motor duty cycle.
* @param duty +1.0f represents full power forward, and -1.0f represents full power backward.
* @return True if any fault was detected driving the motor, and false if successful.
*/
virtual bool Set(float duty) = 0;
};
/**
* @brief Represents a DC motor controller (H bridge) with one pin for enable (PWM),
* and two pins for direction control.
*
* The enable pin is used for PWM and disable, and the two direction pins are used
* to set the polarity of each half of the H bridge. setting {dir1,dir2} = 10 should,
* turn the motor one direction (positive duty), and = 01 should turn the other way (negative
* duty).
*/
class TwoPinDcMotor : public DcMotor
{
2019-05-04 21:42:50 -07:00
public:
enum class ControlType
{
2019-05-04 21:53:24 -07:00
PwmDirectionPins,
PwmEnablePin,
2019-05-04 21:42:50 -07:00
};
private:
2019-05-04 21:42:50 -07:00
SimplePwm* const m_enable;
SimplePwm* const m_dir1;
SimplePwm* const m_dir2;
float m_value = 0;
ControlType m_type;
public:
/**
2019-05-04 21:42:50 -07:00
* @param enable SimplePwm driver for enable pin, for PWM speed control.
* @param dir1 Enable 1 or direction 1 pin. Gets set high to rotate forward.
* @param dir2 Enable 2 or direction 2 pin. Gets set high to rotate backward.
*/
2019-05-04 21:42:50 -07:00
TwoPinDcMotor(SimplePwm* enable, SimplePwm* dir1, SimplePwm* dir2);
virtual bool Set(float duty) override;
2019-03-01 20:09:33 -08:00
float Get();
bool isOpenDirection();
2019-05-04 21:42:50 -07:00
void SetType(ControlType type) { m_type = type; }
};