libdsp/lib_observer.c: remove dir argument from speed observers

We can automatically detect the direction of movement from angle diff
This commit is contained in:
raiden00pl 2022-02-13 13:57:42 +01:00 committed by Xiang Xiao
parent 01cbe9133e
commit 31ffa6d576
2 changed files with 11 additions and 29 deletions

View File

@ -551,8 +551,7 @@ void motor_aobserver_smo(FAR struct motor_aobserver_f32_s *o,
void motor_sobserver_div_init(FAR struct motor_sobserver_div_f32_s *so, void motor_sobserver_div_init(FAR struct motor_sobserver_div_f32_s *so,
uint8_t samples, float filer, float per); uint8_t samples, float filer, float per);
void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o, void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o, float angle);
float angle, float dir);
void motor_aobserver_nfo_init(FAR struct motor_aobserver_nfo_f32_s *nfo); void motor_aobserver_nfo_init(FAR struct motor_aobserver_nfo_f32_s *nfo);
void motor_aobserver_nfo(FAR struct motor_aobserver_f32_s *o, void motor_aobserver_nfo(FAR struct motor_aobserver_f32_s *o,
@ -561,8 +560,7 @@ void motor_aobserver_nfo(FAR struct motor_aobserver_f32_s *o,
void motor_sobserver_pll_init(FAR struct motor_sobserver_pll_f32_s *so, void motor_sobserver_pll_init(FAR struct motor_sobserver_pll_f32_s *so,
float pll_kp, float pll_ki); float pll_kp, float pll_ki);
void motor_sobserver_pll(FAR struct motor_sobserver_f32_s *o, void motor_sobserver_pll(FAR struct motor_sobserver_f32_s *o, float angle);
float angle, float dir);
/* Motor openloop control */ /* Motor openloop control */

View File

@ -458,12 +458,10 @@ void motor_sobserver_div_init(FAR struct motor_sobserver_div_f32_s *so,
* *
****************************************************************************/ ****************************************************************************/
void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o, void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o, float angle)
float angle, float dir)
{ {
LIBDSP_DEBUGASSERT(o != NULL); LIBDSP_DEBUGASSERT(o != NULL);
LIBDSP_DEBUGASSERT(angle >= 0.0f && angle <= 2*M_PI_F); LIBDSP_DEBUGASSERT(angle >= 0.0f && angle <= 2*M_PI_F);
LIBDSP_DEBUGASSERT(dir == DIR_CW || dir == DIR_CCW);
FAR struct motor_sobserver_div_f32_s *so = FAR struct motor_sobserver_div_f32_s *so =
(FAR struct motor_sobserver_div_f32_s *)o->so; (FAR struct motor_sobserver_div_f32_s *)o->so;
@ -471,28 +469,17 @@ void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o,
LIBDSP_DEBUGASSERT(so != NULL); LIBDSP_DEBUGASSERT(so != NULL);
/* Normalize angle to range <-PI, PI> */
angle_norm_2pi(&angle, -M_PI_F, M_PI_F);
/* Get angle diff */ /* Get angle diff */
so->angle_diff = angle - so->angle_prev; so->angle_diff = angle - so->angle_prev;
/* Correct angle if we crossed angle boundary /* Normalize angle to range <-PI, PI> */
* REVISIT:
*/
if ((dir == DIR_CW && so->angle_diff < -ANGLE_DIFF_THR) || angle_norm_2pi(&so->angle_diff, -M_PI_F, M_PI_F);
(dir == DIR_CCW && so->angle_diff > ANGLE_DIFF_THR))
{
/* Correction sign depends on rotation direction */
so->angle_diff += dir * 2 * M_PI_F;
}
/* Get absolute value */
if (so->angle_diff < 0.0f)
{
so->angle_diff = -so->angle_diff;
}
/* Accumulate angle only if sample is valid */ /* Accumulate angle only if sample is valid */
@ -525,7 +512,7 @@ void motor_sobserver_div(FAR struct motor_sobserver_f32_s *o,
* *
* where: * where:
* omega0 - minimum angular speed * omega0 - minimum angular speed
* T - speed estimation period (samples*one_by_dt) * T - speed estimation period (samples*per)
*/ */
LP_FILTER(o->speed, omega, so->filter); LP_FILTER(o->speed, omega, so->filter);
@ -690,13 +677,10 @@ void motor_sobserver_pll_init(FAR struct motor_sobserver_pll_f32_s *so,
* Input Parameters: * Input Parameters:
* o - (in/out) pointer to the speed observer data * o - (in/out) pointer to the speed observer data
* angle - (in) electrical angle normalized to <0.0, 2PI> * angle - (in) electrical angle normalized to <0.0, 2PI>
* dir - (in) electrical rotation direction. Valid values:
* DIR_CW (1.0f) or DIR_CCW(-1.0f)
* *
****************************************************************************/ ****************************************************************************/
void motor_sobserver_pll(FAR struct motor_sobserver_f32_s *o, void motor_sobserver_pll(FAR struct motor_sobserver_f32_s *o, float angle)
float angle, float dir)
{ {
FAR struct motor_sobserver_pll_f32_s *so = FAR struct motor_sobserver_pll_f32_s *so =
(FAR struct motor_sobserver_pll_f32_s *)o->so; (FAR struct motor_sobserver_pll_f32_s *)o->so;