Moved ControlledMotor to branch
This commit is contained in:
		
							parent
							
								
									f4b0eb1743
								
							
						
					
					
						commit
						1b36f97e18
					
				| @ -1,44 +0,0 @@ | |||||||
| #include "ControlledMotor.h" |  | ||||||
| #include <Arduino.h> |  | ||||||
| ControlledMotor::ControlledMotor() { |  | ||||||
|   this->type = Thing::ControlledMotorType; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| ControlledMotor::ControlledMotor(Motor* motor, Encoder* encoder) |  | ||||||
|     : ControlledMotor() { |  | ||||||
|   this->motor = motor; |  | ||||||
|   this->encoder = encoder; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void ControlledMotor::SetTargetSpeed(float velocity) { |  | ||||||
|   this->targetVelocity = velocity; |  | ||||||
|   this->rotationDirection = |  | ||||||
|       (targetVelocity < 0) ? Direction::Reverse : Direction::Forward; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void ControlledMotor::Update(float currentTimeMs) { |  | ||||||
|   actualVelocity = |  | ||||||
|       (int)rotationDirection * encoder->GetRevolutionsPerSecond(currentTimeMs); |  | ||||||
|   float error = targetVelocity - velocity; |  | ||||||
| 
 |  | ||||||
|   float timeStep = currentTimeMs - lastUpdateTime; |  | ||||||
|   float acceleration = |  | ||||||
|       error * timeStep * pidP;  // Just P is used at this moment
 |  | ||||||
|   motor->SetSpeed(targetVelocity + acceleration);  // or something like that
 |  | ||||||
|   this->lastUpdateTime = currentTimeMs; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| float ControlledMotor::GetActualSpeed() { |  | ||||||
|   return actualVelocity; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool ControlledMotor::Drive(float distance) { |  | ||||||
|   if (!driving) { |  | ||||||
|     targetDistance = distance; |  | ||||||
|     startDistance = encoder->GetDistance(); |  | ||||||
|     driving = true; |  | ||||||
|   } |  | ||||||
|   float totalDistance = encoder->GetDistance() - startDistance; |  | ||||||
|   bool completed = totalDistance > targetDistance; |  | ||||||
|   return completed; |  | ||||||
| } |  | ||||||
| @ -1,59 +0,0 @@ | |||||||
| #pragma once |  | ||||||
| 
 |  | ||||||
| #include "Encoder.h" |  | ||||||
| #include "Motor.h" |  | ||||||
| 
 |  | ||||||
| namespace Passer { |  | ||||||
| namespace RoboidControl { |  | ||||||
| 
 |  | ||||||
| /// @brief A motor with speed control
 |  | ||||||
| /// It uses a feedback loop from an encoder to regulate the speed
 |  | ||||||
| /// The speed is measured in revolutions per second.
 |  | ||||||
| class ControlledMotor : public Thing { |  | ||||||
|  public: |  | ||||||
|   ControlledMotor(); |  | ||||||
|   ControlledMotor(Motor* motor, Encoder* encoder); |  | ||||||
| 
 |  | ||||||
|   inline static bool CheckType(Thing* thing) { |  | ||||||
|     return (thing->type & (int)Thing::Type::ControlledMotor) != 0; |  | ||||||
|   } |  | ||||||
|   float velocity; |  | ||||||
| 
 |  | ||||||
|   float pidP = 1; |  | ||||||
|   float pidD = 0; |  | ||||||
|   float pidI = 0; |  | ||||||
| 
 |  | ||||||
|   void Update(float currentTimeMs); |  | ||||||
| 
 |  | ||||||
|   /// @brief Set the target speed for the motor controller
 |  | ||||||
|   /// @param speed the target in revolutions per second.
 |  | ||||||
|   void SetTargetSpeed(float speed); |  | ||||||
| 
 |  | ||||||
|   /// @brief Get the actual speed from the encoder
 |  | ||||||
|   /// @return The speed in revolutions per second
 |  | ||||||
|   float GetActualSpeed(); |  | ||||||
| 
 |  | ||||||
|   bool Drive(float distance); |  | ||||||
| 
 |  | ||||||
|   Motor* motor; |  | ||||||
|   Encoder* encoder; |  | ||||||
| 
 |  | ||||||
|  protected: |  | ||||||
|   float lastUpdateTime; |  | ||||||
|   float targetVelocity; |  | ||||||
|   float actualVelocity; |  | ||||||
|   float netDistance = 0; |  | ||||||
|   float startDistance = 0; |  | ||||||
| 
 |  | ||||||
|   enum Direction { Forward = 1, Reverse = -1 }; |  | ||||||
| 
 |  | ||||||
|   Direction rotationDirection; |  | ||||||
| 
 |  | ||||||
|   bool driving = false; |  | ||||||
|   float targetDistance = 0; |  | ||||||
|   float lastEncoderPosition = 0; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| }  // namespace RoboidControl
 |  | ||||||
| }  // namespace Passer
 |  | ||||||
| using namespace Passer::RoboidControl; |  | ||||||
							
								
								
									
										10
									
								
								Motor.cpp
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Motor.cpp
									
									
									
									
									
								
							| @ -1,9 +1,13 @@ | |||||||
| #include "Motor.h" | #include "Motor.h" | ||||||
| #include <time.h> | #include <time.h> | ||||||
| 
 | 
 | ||||||
| Motor::Motor() { type = (int)Thing::UncontrolledMotorType; } | Motor::Motor() { | ||||||
|  |   type = (int)Thing::UncontrolledMotorType; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| float Motor::GetSpeed() { return this->currentTargetSpeed; } | float Motor::GetSpeed() { | ||||||
|  |   return this->currentTargetSpeed; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| void Motor::SetSpeed(float targetSpeed) { | void Motor::SetSpeed(float targetSpeed) { | ||||||
|   this->currentTargetSpeed = targetSpeed; |   this->currentTargetSpeed = targetSpeed; | ||||||
| @ -21,6 +25,6 @@ bool Motor::Drive(float distance) { | |||||||
|     return true; |     return true; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   SetSpeed(distance < 0 ? -1 : 1); // max speed
 |   SetSpeed(distance < 0 ? -1 : 1);  // max speed
 | ||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user