Julian Oes
12 years ago
7 changed files with 237 additions and 109 deletions
@ -0,0 +1,116 @@
@@ -0,0 +1,116 @@
|
||||
/****************************************************************************
|
||||
* |
||||
* Copyright (C) 2013 PX4 Development Team. All rights reserved. |
||||
* Author: Julian Oes <joes@student.ethz.ch> |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions |
||||
* are met: |
||||
* |
||||
* 1. Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* 2. Redistributions in binary form must reproduce the above copyright |
||||
* notice, this list of conditions and the following disclaimer in |
||||
* the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* 3. Neither the name PX4 nor the names of its contributors may be |
||||
* used to endorse or promote products derived from this software |
||||
* without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS |
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
||||
* POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
****************************************************************************/ |
||||
|
||||
/**
|
||||
* @file pwm_limit.c |
||||
* |
||||
* Lib to limit PWM output |
||||
* |
||||
* @author Julian Oes <joes@student.ethz.ch> |
||||
*/ |
||||
|
||||
#include "pwm_limit.h" |
||||
#include <math.h> |
||||
#include <stdbool.h> |
||||
#include <drivers/drv_hrt.h> |
||||
|
||||
__EXPORT pwm_limit_init(pwm_limit_t *limit) |
||||
{ |
||||
limit->nchannels = 0; |
||||
limit->state = LIMIT_STATE_OFF; |
||||
limit->time_armed = 0; |
||||
return; |
||||
} |
||||
|
||||
__EXPORT void pwm_limit_calc(const bool armed, const uint16_t *disarmed_pwm, const uint16_t *min_pwm, const uint16_t *max_pwm, const float *output_requested, uint16_t *effective_pwm, pwm_limit_t *limit) |
||||
{ |
||||
/* first evaluate state changes */ |
||||
switch (limit->state) { |
||||
case LIMIT_STATE_OFF: |
||||
if (armed) |
||||
limit->state = LIMIT_STATE_RAMP; |
||||
limit->time_armed = hrt_absolute_time(); |
||||
break; |
||||
case LIMIT_STATE_INIT: |
||||
if (!armed) |
||||
limit->state = LIMIT_STATE_OFF; |
||||
else if (hrt_absolute_time() - limit->time_armed >= INIT_TIME_US) |
||||
limit->state = LIMIT_STATE_RAMP; |
||||
break; |
||||
case LIMIT_STATE_RAMP: |
||||
if (!armed) |
||||
limit->state = LIMIT_STATE_OFF; |
||||
else if (hrt_absolute_time() - limit->time_armed >= INIT_TIME_US + RAMP_TIME_US) |
||||
limit->state = LIMIT_STATE_ON; |
||||
break; |
||||
case LIMIT_STATE_ON: |
||||
if (!armed) |
||||
limit->state = LIMIT_STATE_OFF; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
|
||||
unsigned progress; |
||||
uint16_t temp_pwm; |
||||
|
||||
/* then set effective_pwm based on state */ |
||||
switch (limit->state) { |
||||
case LIMIT_STATE_OFF: |
||||
case LIMIT_STATE_INIT: |
||||
for (unsigned i=0; i<limit->nchannels; i++) { |
||||
effective_pwm[i] = disarmed_pwm[i]; |
||||
} |
||||
break; |
||||
case LIMIT_STATE_RAMP: |
||||
|
||||
progress = (hrt_absolute_time() - INIT_TIME_US - limit->time_armed)*10000 / RAMP_TIME_US; |
||||
for (unsigned i=0; i<limit->nchannels; i++) { |
||||
|
||||
temp_pwm = output_requested[i] * (max_pwm[i] - min_pwm[i])/2 + (max_pwm[i] + min_pwm[i])/2; |
||||
/* already follow user/controller input if higher than min_pwm */ |
||||
effective_pwm[i] = (disarmed_pwm[i]*(10000-progress) + (temp_pwm > min_pwm[i] ? temp_pwm : min_pwm[i])*progress)/10000; |
||||
|
||||
} |
||||
break; |
||||
case LIMIT_STATE_ON: |
||||
for (unsigned i=0; i<limit->nchannels; i++) { |
||||
effective_pwm[i] = output_requested[i] * (max_pwm[i] - min_pwm[i])/2 + (max_pwm[i] + min_pwm[i])/2; |
||||
} |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
return; |
||||
} |
@ -0,0 +1,79 @@
@@ -0,0 +1,79 @@
|
||||
/****************************************************************************
|
||||
* |
||||
* Copyright (C) 2013 PX4 Development Team. All rights reserved. |
||||
* Author: Julian Oes <joes@student.ethz.ch> |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions |
||||
* are met: |
||||
* |
||||
* 1. Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* 2. Redistributions in binary form must reproduce the above copyright |
||||
* notice, this list of conditions and the following disclaimer in |
||||
* the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* 3. Neither the name PX4 nor the names of its contributors may be |
||||
* used to endorse or promote products derived from this software |
||||
* without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS |
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
||||
* POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
****************************************************************************/ |
||||
|
||||
/**
|
||||
* @file pwm_limit.h |
||||
* |
||||
* Lib to limit PWM output |
||||
* |
||||
* @author Julian Oes <joes@student.ethz.ch> |
||||
*/ |
||||
|
||||
#ifndef PWM_LIMIT_H_ |
||||
#define PWM_LIMIT_H_ |
||||
|
||||
#include <stdint.h> |
||||
#include <stdbool.h> |
||||
|
||||
__BEGIN_DECLS |
||||
|
||||
/*
|
||||
* time for the ESCs to initialize |
||||
* (this is not actually needed if PWM is sent right after boot) |
||||
*/ |
||||
#define INIT_TIME_US 500000 |
||||
/*
|
||||
* time to slowly ramp up the ESCs |
||||
*/ |
||||
#define RAMP_TIME_US 2500000 |
||||
|
||||
typedef struct { |
||||
enum { |
||||
LIMIT_STATE_OFF = 0, |
||||
LIMIT_STATE_INIT, |
||||
LIMIT_STATE_RAMP, |
||||
LIMIT_STATE_ON |
||||
} state; |
||||
uint64_t time_armed; |
||||
unsigned nchannels; |
||||
} pwm_limit_t; |
||||
|
||||
__EXPORT void pwm_limit_init(pwm_limit_t *limit); |
||||
|
||||
__EXPORT void pwm_limit_calc(const bool armed, const uint16_t *disarmed_pwm, const uint16_t *min_pwm, const uint16_t *max_pwm, const float *output_requested, uint16_t *effective_pwm, pwm_limit_t *limit); |
||||
|
||||
|
||||
__END_DECLS |
||||
|
||||
#endif /* PWM_LIMIT_H_ */ |
Loading…
Reference in new issue