mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-13 03:18:29 -04:00
Debugging controller.
git-svn-id: https://arducopter.googlecode.com/svn/trunk@1658 f9c3cf11-9bcb-44bc-f272-b75c42450872
This commit is contained in:
parent
e2d4c9e901
commit
6788def679
@ -52,7 +52,7 @@ protected:
|
|||||||
class ToServo: public Block
|
class ToServo: public Block
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ToServo(AP_RcChannel & ch) : _ch(ch)
|
ToServo(AP_RcChannel * ch) : _ch(ch)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
virtual void connect(Block * block)
|
virtual void connect(Block * block)
|
||||||
@ -63,11 +63,11 @@ public:
|
|||||||
virtual void update(const float & dt = 0)
|
virtual void update(const float & dt = 0)
|
||||||
{
|
{
|
||||||
if (_input.getSize() > 0)
|
if (_input.getSize() > 0)
|
||||||
_ch.setPosition(APVarPtr2Float(_output[0]));
|
_ch->setNormalized(APVarPtr2Float(_input[0]));
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
float _position;
|
float _position;
|
||||||
AP_RcChannel & _ch;
|
AP_RcChannel * _ch;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// SumGain
|
/// SumGain
|
||||||
@ -94,17 +94,15 @@ public:
|
|||||||
if ( (&var6 == &AP_Float_zero) || (&gain6 == &AP_Float_zero) ) add(var6,gain6);
|
if ( (&var6 == &AP_Float_zero) || (&gain6 == &AP_Float_zero) ) add(var6,gain6);
|
||||||
if ( (&var7 == &AP_Float_zero) || (&gain7 == &AP_Float_zero) ) add(var7,gain7);
|
if ( (&var7 == &AP_Float_zero) || (&gain7 == &AP_Float_zero) ) add(var7,gain7);
|
||||||
if ( (&var8 == &AP_Float_zero) || (&gain8 == &AP_Float_zero) ) add(var8,gain8);
|
if ( (&var8 == &AP_Float_zero) || (&gain8 == &AP_Float_zero) ) add(var8,gain8);
|
||||||
|
|
||||||
|
// create output
|
||||||
|
_output.push_back(new AP_Float(0));
|
||||||
}
|
}
|
||||||
void add(AP_Var & var, AP_Var & gain)
|
void add(AP_Var & var, AP_Var & gain)
|
||||||
{
|
{
|
||||||
_input.push_back(&var);
|
_input.push_back(&var);
|
||||||
_gain.push_back(&gain);
|
_gain.push_back(&gain);
|
||||||
}
|
}
|
||||||
virtual void connect(Block * block)
|
|
||||||
{
|
|
||||||
if (block->getOutput().getSize() > 0)
|
|
||||||
_input.push_back(block->getOutput()[0]);
|
|
||||||
}
|
|
||||||
virtual void update(const float & dt = 0)
|
virtual void update(const float & dt = 0)
|
||||||
{
|
{
|
||||||
if (_output.getSize() < 1) return;
|
if (_output.getSize() < 1) return;
|
||||||
@ -140,12 +138,13 @@ public:
|
|||||||
}
|
}
|
||||||
virtual void connect(Block * block)
|
virtual void connect(Block * block)
|
||||||
{
|
{
|
||||||
|
if (!block) return;
|
||||||
if (block->getOutput().getSize() > 0)
|
if (block->getOutput().getSize() > 0)
|
||||||
_input.push_back(block->getOutput()[0]);
|
_input.push_back(block->getOutput()[0]);
|
||||||
}
|
}
|
||||||
virtual void update(const float & dt = 0)
|
virtual void update(const float & dt = 0)
|
||||||
{
|
{
|
||||||
if (_output.getSize() < 1) return;
|
if (_output.getSize() < 1 || !_input[0] || !_output[0]) return;
|
||||||
|
|
||||||
// derivative
|
// derivative
|
||||||
float RC = 1/(2*M_PI*_fCut); // low pass filter
|
float RC = 1/(2*M_PI*_fCut); // low pass filter
|
||||||
@ -160,6 +159,18 @@ public:
|
|||||||
|
|
||||||
// pid sum
|
// pid sum
|
||||||
*_output[0] = _kP*_e + _kI*_eI + _kD*_eD;
|
*_output[0] = _kP*_e + _kI*_eI + _kD*_eD;
|
||||||
|
|
||||||
|
|
||||||
|
Serial.println("debug");
|
||||||
|
Serial.println(_kP);
|
||||||
|
Serial.println(_kI);
|
||||||
|
Serial.println(_kD);
|
||||||
|
Serial.println(_e);
|
||||||
|
Serial.println(_eI);
|
||||||
|
Serial.println(_eD);
|
||||||
|
Serial.println(APVarPtr2Float(_output[0]));
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
float _e; /// input
|
float _e; /// input
|
||||||
@ -179,25 +190,19 @@ public:
|
|||||||
void addBlock(Block * block)
|
void addBlock(Block * block)
|
||||||
{
|
{
|
||||||
if (_blocks.getSize() > 0)
|
if (_blocks.getSize() > 0)
|
||||||
_blocks[_blocks.getSize()]->connect(block);
|
_blocks[_blocks.getSize()-1]->connect(block);
|
||||||
_blocks.push_back(block);
|
_blocks.push_back(block);
|
||||||
}
|
}
|
||||||
void addCh(AP_RcChannel * ch)
|
void update(const double dt=0)
|
||||||
{
|
|
||||||
_rc.push_back(ch);
|
|
||||||
}
|
|
||||||
AP_RcChannel & getRc(int i)
|
|
||||||
{
|
|
||||||
return *(_rc[i]);
|
|
||||||
}
|
|
||||||
void update()
|
|
||||||
{
|
{
|
||||||
for (int i=0;i<_blocks.getSize();i++)
|
for (int i=0;i<_blocks.getSize();i++)
|
||||||
_blocks[i]->update();
|
{
|
||||||
|
if (!_blocks[i]) continue;
|
||||||
|
_blocks[i]->update(dt);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
Vector<Block * > _blocks;
|
Vector<Block * > _blocks;
|
||||||
Vector<AP_RcChannel * > _rc;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // AP_Controller_H
|
#endif // AP_Controller_H
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
#include <FastSerial.h>
|
#include <FastSerial.h>
|
||||||
#include <AP_Controller.h>
|
#include <AP_Controller.h>
|
||||||
#include <AP_Var.h>
|
#include <AP_Var.h>
|
||||||
#include <AP_EEProm.h>
|
|
||||||
#include <AP_RcChannel.h>
|
#include <AP_RcChannel.h>
|
||||||
#include <APM_RC.h>
|
#include <APM_RC.h>
|
||||||
|
|
||||||
@ -11,53 +10,82 @@ class CarController : public AP_Controller
|
|||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
// state
|
// state
|
||||||
AP_Float * roll;
|
AP_Var & velocity;
|
||||||
AP_Float * airspeed;
|
AP_Var & heading;
|
||||||
AP_Float * velocity;
|
|
||||||
AP_Float * heading;
|
|
||||||
|
|
||||||
// servo positions
|
|
||||||
AP_Float * steering;
|
|
||||||
AP_Float * throttle;
|
|
||||||
|
|
||||||
// control variables
|
// control variables
|
||||||
AP_Float * headingCommand;
|
AP_Var & headingCommand;
|
||||||
AP_Float * velocityCommand;
|
AP_Var & velocityCommand;
|
||||||
|
|
||||||
// channels
|
// channels
|
||||||
uint8_t chStr;
|
AP_RcChannel * steeringCh;
|
||||||
uint8_t chThr;
|
AP_RcChannel * throttleCh;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CarController() :
|
CarController(AP_Var::Key pidStrKey, AP_Var::Key pidThrKey,
|
||||||
chStr(0), chThr(1)
|
AP_Var & heading, AP_Var & velocity,
|
||||||
|
AP_Var & headingCommand, AP_Var & velocityCommand,
|
||||||
|
AP_RcChannel * steeringCh, AP_RcChannel * throttleCh) :
|
||||||
|
heading(heading), velocity(velocity),
|
||||||
|
headingCommand(headingCommand), velocityCommand(velocityCommand),
|
||||||
|
steeringCh(steeringCh), throttleCh(throttleCh)
|
||||||
{
|
{
|
||||||
// rc channels
|
|
||||||
addCh(new AP_RcChannel("STR",APM_RC,chStr,45));
|
|
||||||
addCh(new AP_RcChannel("THR",APM_RC,chThr,100));
|
|
||||||
|
|
||||||
// steering control loop
|
// steering control loop
|
||||||
addBlock(new SumGain(headingCommand,&AP_unity,heading,&AP_negativeUnity));
|
addBlock(new SumGain(headingCommand,AP_Float_unity,heading,AP_Float_negative_unity));
|
||||||
addBlock(new Pid("HDNG",0.1,0,0,1,20));
|
addBlock(new Pid(pidStrKey,PSTR("STR"),0.1,0,0,1,20));
|
||||||
addBlock(new ToServo(getRc(chStr)));
|
addBlock(new ToServo(steeringCh));
|
||||||
|
|
||||||
// throttle control loop
|
// throttle control loop
|
||||||
addBlock(new SumGain(velocityCommand,&AP_unity,velocity,&AP_negativeUnity));
|
addBlock(new SumGain(velocityCommand,AP_Float_unity,velocity,AP_Float_negative_unity));
|
||||||
addBlock(new Pid("THR",0.1,0,0,1,20));
|
addBlock(new Pid(pidThrKey,PSTR("THR"),0.1,0,0,1,20));
|
||||||
addBlock(new ToServo(getRc(chThr)));
|
addBlock(new ToServo(throttleCh));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
AP_Controller * controller;
|
AP_Controller * controller;
|
||||||
|
Vector<AP_RcChannel * > ch;
|
||||||
|
|
||||||
|
AP_Float heading, velocity; // measurements
|
||||||
|
AP_Float headingCommand, velocityCommand; // guidance data
|
||||||
|
|
||||||
|
enum keys
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
chStrKey,
|
||||||
|
chThrKey,
|
||||||
|
pidStrKey,
|
||||||
|
pidThrKey
|
||||||
|
};
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
//controller = new CarController;
|
|
||||||
|
// variables
|
||||||
|
heading = 0;
|
||||||
|
velocity = 0;
|
||||||
|
headingCommand = 1;
|
||||||
|
velocityCommand = 1;
|
||||||
|
|
||||||
|
// rc channels
|
||||||
|
APM_RC.Init();
|
||||||
|
ch.push_back(new AP_RcChannel(chStrKey,PSTR("STR"),APM_RC,1,45));
|
||||||
|
ch.push_back(new AP_RcChannel(chThrKey,PSTR("THR"),APM_RC,2,100));
|
||||||
|
|
||||||
|
// controller
|
||||||
|
controller = new CarController(pidStrKey,pidThrKey,heading,velocity,headingCommand,velocityCommand,ch[0],ch[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
Serial.println("Looping");
|
Serial.println("Looping");
|
||||||
|
heading += 0.1;
|
||||||
|
velocity += 0.1;
|
||||||
delay(1000);
|
delay(1000);
|
||||||
//controller->update();
|
controller->update(.1);
|
||||||
|
Serial.printf("heading:\t%f\tcommand(%f)\tservo(%f)\n", (float)heading,(float) headingCommand, ch[0]->getNormalized());
|
||||||
|
Serial.printf("velocity:\t%f\tcommand(%f)\tservo(%f)\n", (float)velocity, (float) velocityCommand, ch[1]->getNormalized());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// vim:ts=4:sw=4:expandtab
|
||||||
|
@ -109,3 +109,5 @@ void loop()
|
|||||||
{
|
{
|
||||||
test->update();
|
test->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// vim:ts=4:sw=4:expandtab
|
||||||
|
Loading…
Reference in New Issue
Block a user