OpticalFlow.h 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. /*
  2. This program is free software: you can redistribute it and/or modify
  3. it under the terms of the GNU General Public License as published by
  4. the Free Software Foundation, either version 3 of the License, or
  5. (at your option) any later version.
  6. This program is distributed in the hope that it will be useful,
  7. but WITHOUT ANY WARRANTY; without even the implied warranty of
  8. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  9. GNU General Public License for more details.
  10. You should have received a copy of the GNU General Public License
  11. along with this program. If not, see <http://www.gnu.org/licenses/>.
  12. */
  13. #pragma once
  14. class AP_HAL::OpticalFlow {
  15. public:
  16. class Data_Frame {
  17. public:
  18. float pixel_flow_x_integral;
  19. float pixel_flow_y_integral;
  20. float gyro_x_integral;
  21. float gyro_y_integral;
  22. uint32_t delta_time;
  23. uint8_t quality;
  24. };
  25. virtual void init() = 0;
  26. virtual bool read(Data_Frame& frame) = 0;
  27. virtual void push_gyro(float gyro_x, float gyro_y, float dt) = 0;
  28. virtual void push_gyro_bias(float gyro_bias_x, float gyro_bias_y) = 0;
  29. };