2014-01-27 02:38:57 -04:00
from LogAnalyzer import Test , TestResult
import DataflashLog
class TestGPSGlitch ( Test ) :
''' test for bad GPS data (satellite count, hdop), and later for sudden repositioning beyond what the drone could do '''
def __init__ ( self ) :
self . name = " GPS "
def run ( self , logdata ) :
self . result = TestResult ( )
2014-01-30 05:33:25 -04:00
self . result . status = TestResult . StatusType . PASS
if " GPS " not in logdata . channels :
2014-02-22 15:36:30 -04:00
self . result . status = TestResult . StatusType . UNKNOWN
2014-01-30 05:33:25 -04:00
self . result . statusMessage = " No GPS log data "
return
2014-01-27 02:38:57 -04:00
# define and check different thresholds for WARN level and FAIL level
minSatsWARN = 6
minSatsFAIL = 5
maxHDopWARN = 3.0
maxHDopFAIL = 10.0
foundBadSatsWarn = logdata . channels [ " GPS " ] [ " NSats " ] . min ( ) < minSatsWARN
foundBadHDopWarn = logdata . channels [ " GPS " ] [ " HDop " ] . max ( ) > maxHDopWARN
foundBadSatsFail = logdata . channels [ " GPS " ] [ " NSats " ] . min ( ) < minSatsFAIL
foundBadHDopFail = logdata . channels [ " GPS " ] [ " HDop " ] . max ( ) > maxHDopFAIL
if foundBadSatsFail or foundBadHDopFail :
self . result . status = TestResult . StatusType . FAIL
self . result . statusMessage = " Min satellites: %s , Max HDop: %s " % ( logdata . channels [ " GPS " ] [ " NSats " ] . min ( ) , logdata . channels [ " GPS " ] [ " HDop " ] . max ( ) )
elif foundBadSatsWarn or foundBadHDopWarn :
self . result . status = TestResult . StatusType . WARN
2014-01-30 05:33:25 -04:00
self . result . statusMessage = " Min satellites: %s , Max HDop: %s " % ( logdata . channels [ " GPS " ] [ " NSats " ] . min ( ) , logdata . channels [ " GPS " ] [ " HDop " ] . max ( ) )
2014-01-27 02:38:57 -04:00
2014-01-30 05:33:25 -04:00
# TODO: also test for sudden repositioning beyond what the drone could reasonably achieve, like is done with glitch protection - or is that logged when it happens?
2014-01-27 02:38:57 -04:00
# ...