2014-04-01 08:57:03 -03:00
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
/// @file AP_Parachute.h
/// @brief Parachute release library
# ifndef AP_PARACHUTE_H
# define AP_PARACHUTE_H
2015-08-11 03:28:45 -03:00
# include <AP_Param/AP_Param.h>
# include <AP_Common/AP_Common.h>
# include <AP_Relay/AP_Relay.h>
2014-04-01 08:57:03 -03:00
# define AP_PARACHUTE_TRIGGER_TYPE_RELAY_0 0
# define AP_PARACHUTE_TRIGGER_TYPE_RELAY_1 1
# define AP_PARACHUTE_TRIGGER_TYPE_RELAY_2 2
# define AP_PARACHUTE_TRIGGER_TYPE_RELAY_3 3
# define AP_PARACHUTE_TRIGGER_TYPE_SERVO 10
2014-04-03 11:05:41 -03:00
# define AP_PARACHUTE_RELEASE_DELAY_MS 500 // delay in milliseconds between call to release() and when servo or relay actually moves. Allows for warning to user
2015-05-12 10:08:00 -03:00
# define AP_PARACHUTE_RELEASE_DURATION_MS 2000 // when parachute is released, servo or relay stay at their released position/value for 2000ms (2seconds)
2014-04-01 08:57:03 -03:00
# define AP_PARACHUTE_SERVO_ON_PWM_DEFAULT 1300 // default PWM value to move servo to when shutter is activated
# define AP_PARACHUTE_SERVO_OFF_PWM_DEFAULT 1100 // default PWM value to move servo to when shutter is deactivated
2014-04-06 23:17:07 -03:00
# define AP_PARACHUTE_ALT_MIN_DEFAULT 10 // default min altitude the vehicle should have before parachute is released
2014-04-01 08:57:03 -03:00
/// @class AP_Parachute
/// @brief Class managing the release of a parachute
class AP_Parachute {
public :
/// Constructor
AP_Parachute ( AP_Relay & relay ) :
_relay ( relay ) ,
2014-04-06 23:04:41 -03:00
_release_time ( 0 ) ,
_released ( false )
2014-04-01 08:57:03 -03:00
{
// setup parameter defaults
AP_Param : : setup_object_defaults ( this , var_info ) ;
}
/// enabled - enable or disable parachute release
2014-04-03 11:05:41 -03:00
void enabled ( bool on_off ) ;
2014-04-01 08:57:03 -03:00
/// enabled - returns true if parachute release is enabled
bool enabled ( ) const { return _enabled ; }
/// release - release parachute
void release ( ) ;
/// update - shuts off the trigger should be called at about 10hz
void update ( ) ;
2014-04-06 23:17:07 -03:00
/// alt_min - returns the min altitude above home the vehicle should have before parachute is released
2014-04-03 05:53:45 -03:00
/// 0 = altitude check disabled
2014-04-06 23:17:07 -03:00
int16_t alt_min ( ) const { return _alt_min ; }
2014-04-01 08:57:03 -03:00
static const struct AP_Param : : GroupInfo var_info [ ] ;
private :
// Parameters
AP_Int8 _enabled ; // 1 if parachute release is enabled
AP_Int8 _release_type ; // 0:Servo,1:Relay
AP_Int16 _servo_on_pwm ; // PWM value to move servo to when shutter is activated
AP_Int16 _servo_off_pwm ; // PWM value to move servo to when shutter is deactivated
2014-04-06 23:17:07 -03:00
AP_Int16 _alt_min ; // min altitude the vehicle should have before parachute is released
2014-04-01 08:57:03 -03:00
// internal variables
2014-04-06 23:22:48 -03:00
AP_Relay & _relay ; // pointer to relay object from the base class Relay. The subclasses could be AP_Relay_APM1 or AP_Relay_APM2
2014-04-03 11:05:41 -03:00
uint32_t _release_time ; // system time that parachute is ordered to be released (actual release will happen 0.5 seconds later)
bool _released ; // true if the parachute has been released
2014-04-01 08:57:03 -03:00
} ;
# endif /* AP_PARACHUTE_H */