![]() |
PID output to a variable
I am trying to use a PID loop from the WPI library to control my robot drive in the autonomous mode. I don't know how to make the PID loop output to a variable that I can set to the drive speed. I tried making a bogus victor and setting a float variable equal to that value, but I got an error when I built the code saying "cannot convert `Victor*' to `float' in assignment". Any ideas out there?
Thanks in advance, will |
Re: PID output to a variable
The way the PID controller in WPI lib works is that you inherit the PIDOutput class and provide a PIDWrite callback function. The PID controller will call the PIDOutput:: PIDWrite function to run your motors. In essence, do something similar to this:
Code:
class MyRobot: public SimpleRobot, public PIDOutput |
Re: PID output to a variable
Thanks mikets. That looks very helpful, but I don't know a whole lot of C++ and I'm not exactly sure about what I am supposed to do with that code that you gave me. Do I need to make a subclass? Do I put the code that controls the motors in the subclass?
So far what I have been trying is: ---------------------------------- class IterativeDemo : public IterativeRobot { RobotDrive *myRobot; PIDEncoder *leftencoder; PIDEncoder *rightencoder; float leftAutoDrive; float rightAutoDrive; public: myRobot = new RobotDrive(1, 3, 2, 4); leftencoder = new PIDEncoder(7,8,true,Encoder::k4X); leftencoder->SetDistancePerPulse(0.04318); //inches leftencoder->Start(); rightencoder = new PIDEncoder(9,10,true,Encoder::k4X); rightencoder->SetDistancePerPulse(0.04318); //inches rightencoder->Start(); leftAutoControl = new PIDController(0.1, 0.01, 0.001, leftencoder, bogusLeft); rightAutoControl = new PIDController(0.1, 0.01, 0.001, rightencoder, bogusRight); } void AutonomousInit(void) { auto_periodic_loops = 0; // Reset the loop counter for autonomous mode disabled_periodic_loops = 0; tele_periodic_loops = 0; leftAutoControl->Enable(); rightAutoControl->Enable(); //Initialization LoopsPerSec = 50; } void AutonomousPeriodic(void) { // feed the user watchdog at every period when in autonomous GetWatchdog().Feed(); auto_periodic_loops++; dash_periodic_loops++; leftAutoControl->SetSetpoint(18); rightAutoControl->SetSetpoint(18); leftAutoDrive = bogusLeft; rightAutoDrive = bogusRight; myRobot->TankDrive(rightAutoDrive, leftAutoDrive); // drive with tank style } --------------------------- The error is in the "leftAutoDrive = bogusLeft" and "rightAutoDrive = bogusRight" parts. |
Re: PID output to a variable
Are you going to use the encoders to drive straight or do you also want to use the encoders to turn a certain angle? Your code suggested you have 4-motor drive system. Are you doing mecanum or just normal wheels? Where are the encoders mounted? These questions are important to determine how the code is written.
|
Re: PID output to a variable
We are just trying to go straight for now. We are planning on using a 4-motor drive on our final robot, but the prototype chassis we have to play with our programming on only has two motors. We are just doing normal wheels. Thank you for taking time to give me such a specific answer.
|
Re: PID output to a variable
The PID controller in WPIlib has the following constructor:
Code:
PIDController(float p, float i, float d, PIDSource *source, PIDOutput output, float period = 0.05);This means you need to provide the PIDSource and PIDOutput objects when creating the PIDController object. The easiest way to do it is to have your IterativeDemo class inheriting both PIDSource and PIDOutput. Essentially, you are saying IterativeDemo is both PIDSource and PIDOutput as well. Then in the IterativeDemo class, you need to implement PIDGet() and PIDWrite(). If you just need to go straight, you need only one PID controller. Something similiar to the following: Code:
class IterativeDemo : public IterativeRobot, public PIDSource, public PIDOutputYou then need two PID controllers and they are not independent of each other. |
| All times are GMT -5. The time now is 14:06. |
Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi