AP_NavEKF_core_common.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. /*
  2. NavEKF_core_common holds scratch data shared by EKF2 and EKF3
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 3 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. #include "AP_NavEKF_core_common.h"
  15. NavEKF_core_common::Matrix24 NavEKF_core_common::KH;
  16. NavEKF_core_common::Matrix24 NavEKF_core_common::KHP;
  17. NavEKF_core_common::Matrix24 NavEKF_core_common::nextP;
  18. NavEKF_core_common::Vector28 NavEKF_core_common::Kfusion;
  19. /*
  20. fill common scratch variables, for detecting re-use of variables between loops in SITL
  21. */
  22. void NavEKF_core_common::fill_scratch_variables(void)
  23. {
  24. #if CONFIG_HAL_BOARD == HAL_BOARD_SITL
  25. // fill the common variables with NaN, so we catch any cases in
  26. // SITL where they are used without initialisation. These are all
  27. // supposed to be scratch variables that are not used between
  28. // iterations
  29. fill_nanf(&KH[0][0], sizeof(KH)/sizeof(float));
  30. fill_nanf(&KHP[0][0], sizeof(KHP)/sizeof(float));
  31. fill_nanf(&nextP[0][0], sizeof(nextP)/sizeof(float));
  32. fill_nanf(&Kfusion[0], sizeof(Kfusion)/sizeof(float));
  33. #endif
  34. }