File: defaultstrategytest.cpp

package info (click to toggle)
aoflagger 3.4.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 8,960 kB
  • sloc: cpp: 83,076; python: 10,187; sh: 260; makefile: 178
file content (104 lines) | stat: -rw-r--r-- 4,005 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104

#include <boost/test/unit_test.hpp>

#include "../../lua/default-strategy.h"
#include "../../lua/luastrategy.h"
#include "../../lua/scriptdata.h"

#include "../../algorithms/testsetgenerator.h"

#include <aocommon/polarization.h>

using aocommon::Polarization;
using aocommon::PolarizationEnum;

using algorithms::BackgroundTestSet;
using algorithms::RFITestSet;
using algorithms::TestSetGenerator;

BOOST_AUTO_TEST_SUITE(default_strategy, *boost::unit_test::label("lua"))

static void initStrategy(LuaStrategy& strategy) {
  strategy.Initialize();
  std::vector<char> str(data_strategies_generic_default_lua_len + 1, 0);
  std::copy_n(data_strategies_generic_default_lua,
              data_strategies_generic_default_lua_len, str.data());
  strategy.LoadText(std::string(str.data()));
}

static std::pair<double, double> checkResult(TimeFrequencyData& data,
                                             const Mask2D& groundTruth) {
  LuaStrategy strategy;
  initStrategy(strategy);
  ScriptData scriptData;
  TimeFrequencyMetaDataCPtr metaData(new TimeFrequencyMetaData());
  TimeFrequencyData result = data;
  result.SetNoMask();
  strategy.Execute(result, metaData, scriptData, "execute");

  BOOST_REQUIRE_GT(result.MaskCount(), 0);
  size_t width = groundTruth.Width(), height = groundTruth.Height();
  size_t posCount = result.GetSingleMask()->GetCount<true>();
  Mask2D intersect(groundTruth);
  intersect.Intersect(*result.GetSingleMask());

  size_t truePosCount = intersect.GetCount<true>();
  size_t falsePosCount = posCount - truePosCount;
  size_t falseNegCount =
      groundTruth.GetCount<true>() - intersect.GetCount<true>();
  double fpRatio = double(falsePosCount) / double(width * height);
  double fnRatio = double(falseNegCount) / double(width * height);
  return std::make_pair(fpRatio, fnRatio);
}

BOOST_AUTO_TEST_CASE(stokesi_complex) {
  size_t width = 200, height = 50;
  TimeFrequencyData data = TestSetGenerator::MakeTestSet(
      RFITestSet::FullBandBursts, BackgroundTestSet::Empty, width, height);

  auto fpfn = checkResult(data, *data.GetSingleMask());
  BOOST_CHECK_LT(fpfn.first, 5e-3);  // False positives-ratio should be < 0.5 %
  BOOST_CHECK_LT(fpfn.second,
                 0.015);  // False negatives-ratio should be < 1.5 %
}

BOOST_AUTO_TEST_CASE(stokesi_amplitude) {
  size_t width = 200, height = 50;
  Mask2D mask = Mask2D::MakeSetMask<false>(width, height);
  TimeFrequencyData data = TestSetGenerator::MakeTestSet(
      RFITestSet::FullBandBursts, BackgroundTestSet::Empty, width, height);
  Image2DCPtr amplitude = data.GetImage(0);

  TimeFrequencyData tfData(TimeFrequencyData::AmplitudePart,
                           Polarization::StokesI, amplitude);

  auto fpfn = checkResult(tfData, *data.GetSingleMask());
  BOOST_CHECK_LT(fpfn.first, 5e-3);   // False positives-ratio should be < 0.5 %
  BOOST_CHECK_LT(fpfn.second, 5e-3);  // False negatives-ratio should be < 0.5 %
}

BOOST_AUTO_TEST_CASE(full_polarization) {
  size_t width = 200, height = 50;
  TimeFrequencyData allData;
  PolarizationEnum pols[4] = {Polarization::XX, Polarization::XY,
                              Polarization::YX, Polarization::YY};
  for (size_t i = 0; i != 4; ++i) {
    TimeFrequencyData real = TestSetGenerator::MakeTestSet(
        RFITestSet::FullBandBursts, BackgroundTestSet::Empty, width, height);
    TimeFrequencyData imag = TestSetGenerator::MakeTestSet(
        RFITestSet::FullBandBursts, BackgroundTestSet::Empty, width, height);
    TimeFrequencyData tfData(pols[i], real.GetImage(0), imag.GetImage(0));
    tfData.SetGlobalMask(real.GetMask(0));
    if (i == 0)
      allData = tfData;
    else
      allData =
          TimeFrequencyData::MakeFromPolarizationCombination(allData, tfData);
  }

  auto fpfn = checkResult(allData, *allData.GetSingleMask());
  BOOST_CHECK_LT(fpfn.first, 2e-2);   // False positives-ratio should be < 2 %
  BOOST_CHECK_LT(fpfn.second, 2e-3);  // False negatives-ratio should be < 0.2 %
}

BOOST_AUTO_TEST_SUITE_END()