From 70c2682c281fef032387350be406818729f1fa45 Mon Sep 17 00:00:00 2001 From: Andrew Chapman Date: Mon, 3 Mar 2014 18:55:48 +0100 Subject: [PATCH] LogAnalyzer: detect all zeros in MAG X/Y/Z data --- Tools/LogAnalyzer/tests/TestCompass.py | 29 +++++++++++++++++--------- 1 file changed, 19 insertions(+), 10 deletions(-) diff --git a/Tools/LogAnalyzer/tests/TestCompass.py b/Tools/LogAnalyzer/tests/TestCompass.py index fca688e008..b1c4156479 100644 --- a/Tools/LogAnalyzer/tests/TestCompass.py +++ b/Tools/LogAnalyzer/tests/TestCompass.py @@ -61,20 +61,24 @@ class TestCompass(Test): magField = [] (minMagField, maxMagField) = (None,None) (minMagFieldLine, maxMagFieldLine) = (None,None) + zerosFound = False while indexmaxMagField: - maxMagField = mf - maxMagFieldLine = logdata.channels["MAG"]["MagX"].listData[index][0] - if index == 0: - (minMagField, maxMagField) = (mf,mf) + if ((mx==0) and (my==0) and (mz==0)): # sometimes they're zero, not sure why, same reason as why we get NaNs as offsets? + zerosFound = True + else: + mf = math.sqrt(mx*mx + my*my + mz*mz) + magField.append(mf) + if mfmaxMagField: + maxMagField = mf + maxMagFieldLine = logdata.channels["MAG"]["MagX"].listData[index][0] + if index == 0: + (minMagField, maxMagField) = (mf,mf) index += 1 percentDiff = (maxMagField-minMagField) / minMagField if percentDiff > percentDiffThresholdFAIL: @@ -90,9 +94,14 @@ class TestCompass(Test): self.result.statusMessage = self.result.statusMessage + "Min mag field length (%.2f) < recommended (%.2f)\n" % (minMagField,minMagFieldThreshold) if maxMagField > maxMagFieldThreshold: self.result.statusMessage = self.result.statusMessage + "Max mag field length (%.2f) > recommended (%.2f)\n" % (maxMagField,maxMagFieldThreshold) + if zerosFound: + if self.result.status != TestResult.StatusType.FAIL: + self.result.status = TestResult.StatusType.WARN + self.result.statusMessage = self.result.statusMessage + "All zeros found in MAG X/Y/Z log data\n" if verbose: self.result.statusMessage = self.result.statusMessage + "Min mag_field of %.2f on line %d\n" % (minMagField,minMagFieldLine) self.result.statusMessage = self.result.statusMessage + "Max mag_field of %.2f on line %d\n" % (maxMagField,maxMagFieldLine) + else: self.result.statusMessage = self.result.statusMessage + "No MAG data, unable to test mag_field interference\n"