/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- #include #include "OpticalFlow.h" const AP_Param::GroupInfo OpticalFlow::var_info[] PROGMEM = { // @Param: ENABLE // @DisplayName: Optical flow enable/disable // @Description: Setting this to Enabled(1) will enable optical flow. Setting this to Disabled(0) will disable optical flow // @Values: 0:Disabled, 1:Enabled // @User: Standard AP_GROUPINFO("_ENABLE", 0, OpticalFlow, _enabled, 0), // @Param: FXSCALER // @DisplayName: X axis optical flow scale factor correction // @Description: This sets the parts per thousand scale factor correction applied to the flow sensor X axis optical rate. It can be used to correct for variations in effective focal length. Each positive increment of 1 increases the scale factor applied to the X axis optical flow reading by 0.1%. Negative values reduce the scale factor. // @Range: -200 +200 // @Increment: 1 // @User: Standard AP_GROUPINFO("_FXSCALER", 1, OpticalFlow, _flowScalerX, 0), // @Param: FYSCALER // @DisplayName: Y axis optical flow scale factor correction // @Description: This sets the parts per thousand scale factor correction applied to the flow sensor Y axis optical rate. It can be used to correct for variations in effective focal length. Each positive increment of 1 increases the scale factor applied to the Y axis optical flow reading by 0.1%. Negative values reduce the scale factor. // @Range: -200 +200 // @Increment: 1 // @User: Standard AP_GROUPINFO("_FYSCALER", 2, OpticalFlow, _flowScalerY, 0), AP_GROUPEND }; // default constructor OpticalFlow::OpticalFlow(const AP_AHRS &ahrs) : _ahrs(ahrs), _device_id(0), _surface_quality(0), _last_update(0) { AP_Param::setup_object_defaults(this, var_info); // healthy flag will be overwritten when init is called _flags.healthy = false; };