aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2014-07-18 07:28:49 +0200
committerLorenz Meier <lm@inf.ethz.ch>2014-07-18 07:28:49 +0200
commit6c50e510a5fcadab19a6d5ff709c0da473e4ace0 (patch)
tree93e9b8924bc396039fe9fb292e2f8d1c743c3afc /src
parentdc612d75c788bc8b2a90c200a13a5a5a0e3a68d9 (diff)
downloadpx4-firmware-6c50e510a5fcadab19a6d5ff709c0da473e4ace0.tar.gz
px4-firmware-6c50e510a5fcadab19a6d5ff709c0da473e4ace0.tar.bz2
px4-firmware-6c50e510a5fcadab19a6d5ff709c0da473e4ace0.zip
Derivative fix: Comments and code style
Diffstat (limited to 'src')
-rw-r--r--src/modules/controllib/blocks.cpp8
-rw-r--r--src/modules/controllib/blocks.hpp15
2 files changed, 22 insertions, 1 deletions
diff --git a/src/modules/controllib/blocks.cpp b/src/modules/controllib/blocks.cpp
index 04cb023a8..0175acda9 100644
--- a/src/modules/controllib/blocks.cpp
+++ b/src/modules/controllib/blocks.cpp
@@ -293,10 +293,16 @@ int blockIntegralTrapTest()
float BlockDerivative::update(float input)
{
- float output = 0.0f;
+ float output;
if (_initialized) {
output = _lowPass.update((input - getU()) / getDt());
} else {
+ // if this is the first call to update
+ // we have no valid derivative
+ // and so we use the assumption the
+ // input value is not changing much,
+ // which is the best we can do here.
+ output = 0.0f;
_initialized = true;
}
setU(input);
diff --git a/src/modules/controllib/blocks.hpp b/src/modules/controllib/blocks.hpp
index b0545b60a..37d7832b3 100644
--- a/src/modules/controllib/blocks.hpp
+++ b/src/modules/controllib/blocks.hpp
@@ -242,6 +242,21 @@ public:
_lowPass(this, "LP")
{};
virtual ~BlockDerivative() {};
+
+ /**
+ * Update the state and get current derivative
+ *
+ * This call updates the state and gets the current
+ * derivative. As the derivative is only valid
+ * on the second call to update, it will return
+ * no change (0) on the first. To get a closer
+ * estimate of the derivative on the first call,
+ * call setU() one time step before using the
+ * return value of update().
+ *
+ * @param input the variable to calculate the derivative of
+ * @return the current derivative
+ */
float update(float input);
// accessors
void setU(float u) {_u = u;}