PX4 Firmware
PX4 Autopilot Software http://px4.io
BlockDerivative.hpp
Go to the documentation of this file.
1
/****************************************************************************
2
*
3
* Copyright (C) 2012 PX4 Development Team. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
7
* are met:
8
*
9
* 1. Redistributions of source code must retain the above copyright
10
* notice, this list of conditions and the following disclaimer.
11
* 2. Redistributions in binary form must reproduce the above copyright
12
* notice, this list of conditions and the following disclaimer in
13
* the documentation and/or other materials provided with the
14
* distribution.
15
* 3. Neither the name PX4 nor the names of its contributors may be
16
* used to endorse or promote products derived from this software
17
* without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
26
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30
* POSSIBILITY OF SUCH DAMAGE.
31
*
32
****************************************************************************/
33
34
/**
35
* @file blocks.h
36
*
37
* Controller library code
38
*/
39
40
#pragma once
41
42
#include "
BlockLowPass.hpp
"
43
44
#include <px4_platform_common/defines.h>
45
#include <math.h>
46
47
#include "
block/Block.hpp
"
48
#include "
block/BlockParam.hpp
"
49
50
#include "
matrix/math.hpp
"
51
52
namespace
control
53
{
54
55
/**
56
* A simple derivative approximation.
57
* This uses the previous and current input.
58
* This has a built in low pass filter.
59
* @see LowPass
60
*/
61
class
__EXPORT
BlockDerivative
:
public
SuperBlock
62
{
63
public
:
64
// methods
65
BlockDerivative
(
SuperBlock
*parent,
const
char
*
name
) :
66
SuperBlock
(parent, name),
67
_u(0),
68
_initialized(false),
69
_lowPass(this,
"LP"
)
70
{}
71
virtual
~
BlockDerivative
() =
default
;
72
73
/**
74
* Update the state and get current derivative
75
*
76
* This call updates the state and gets the current
77
* derivative. As the derivative is only valid
78
* on the second call to update, it will return
79
* no change (0) on the first. To get a closer
80
* estimate of the derivative on the first call,
81
* call setU() one time step before using the
82
* return value of update().
83
*
84
* @param input the variable to calculate the derivative of
85
* @return the current derivative
86
*/
87
float
update(
float
input);
88
// accessors
89
void
setU
(
float
u) {_u = u;}
90
void
reset
() { _initialized =
false
; };
91
float
getU
() {
return
_u;}
92
float
getLP
() {
return
_lowPass.getFCut();}
93
float
getO
() {
return
_lowPass.getState(); }
94
protected
:
95
// attributes
96
float
_u
;
/**< previous input */
97
bool
_initialized
;
98
BlockLowPass
_lowPass
;
/**< low pass filter */
99
};
100
101
}
// namespace control
control::BlockDerivative::_initialized
bool _initialized
Definition:
BlockDerivative.hpp:97
control::BlockDerivative::getO
float getO()
Definition:
BlockDerivative.hpp:93
__EXPORT
Definition:
I2C.hpp:51
control::BlockDerivative::BlockDerivative
BlockDerivative(SuperBlock *parent, const char *name)
Definition:
BlockDerivative.hpp:65
control::BlockDerivative::_u
float _u
previous input
Definition:
BlockDerivative.hpp:96
control::BlockLowPass
A low pass filter as described here: http://en.wikipedia.org/wiki/Low-pass_filter.
Definition:
BlockLowPass.hpp:63
Block.hpp
Controller library code.
control::BlockDerivative::setU
void setU(float u)
Definition:
BlockDerivative.hpp:89
control::SuperBlock
Definition:
Block.hpp:94
math.hpp
control
Definition:
Block.cpp:45
BlockParam.hpp
Controller library code.
control::BlockDerivative::getLP
float getLP()
Definition:
BlockDerivative.hpp:92
name
const char * name
Definition:
tests_main.c:58
control::BlockDerivative::_lowPass
BlockLowPass _lowPass
low pass filter
Definition:
BlockDerivative.hpp:98
control::BlockDerivative
A simple derivative approximation.
Definition:
BlockDerivative.hpp:61
control::BlockDerivative::reset
void reset()
Definition:
BlockDerivative.hpp:90
control::BlockDerivative::getU
float getU()
Definition:
BlockDerivative.hpp:91
BlockLowPass.hpp
src
lib
controllib
BlockDerivative.hpp
Generated by
1.8.13