Skip to content
Snippets Groups Projects
Select Git revision
  • fcc4e1761a38d7bd49c7f724155fb861d41bdedb
  • master default protected
  • L2SS-1914-fix_job_dispatch
  • TMSS-3170
  • TMSS-3167
  • TMSS-3161
  • TMSS-3158-Front-End-Only-Allow-Changing-Again
  • TMSS-3133
  • TMSS-3319-Fix-Templates
  • test-fix-deploy
  • TMSS-3134
  • TMSS-2872
  • defer-state
  • add-custom-monitoring-points
  • TMSS-3101-Front-End-Only
  • TMSS-984-choices
  • SDC-1400-Front-End-Only
  • TMSS-3079-PII
  • TMSS-2936
  • check-for-max-244-subbands
  • TMSS-2927---Front-End-Only-PXII
  • Before-Remove-TMSS
  • LOFAR-Release-4_4_318 protected
  • LOFAR-Release-4_4_317 protected
  • LOFAR-Release-4_4_316 protected
  • LOFAR-Release-4_4_315 protected
  • LOFAR-Release-4_4_314 protected
  • LOFAR-Release-4_4_313 protected
  • LOFAR-Release-4_4_312 protected
  • LOFAR-Release-4_4_311 protected
  • LOFAR-Release-4_4_310 protected
  • LOFAR-Release-4_4_309 protected
  • LOFAR-Release-4_4_308 protected
  • LOFAR-Release-4_4_307 protected
  • LOFAR-Release-4_4_306 protected
  • LOFAR-Release-4_4_304 protected
  • LOFAR-Release-4_4_303 protected
  • LOFAR-Release-4_4_302 protected
  • LOFAR-Release-4_4_301 protected
  • LOFAR-Release-4_4_300 protected
  • LOFAR-Release-4_4_299 protected
41 results

UnitTest.cc

Blame
  • user avatar
    Alexander van Amesfoort authored
    fcc4e176
    History
    Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    UnitTest.cc 1.93 KiB
    //# UnitTest.cc
    //# Copyright (C) 2012-2013  ASTRON (Netherlands Institute for Radio Astronomy)
    //# P.O. Box 2, 7990 AA Dwingeloo, The Netherlands
    //#
    //# This file is part of the LOFAR software suite.
    //# The LOFAR software suite is free software: you can redistribute it and/or
    //# modify it under the terms of the GNU General Public License as published
    //# by the Free Software Foundation, either version 3 of the License, or
    //# (at your option) any later version.
    //#
    //# The LOFAR software suite is distributed in the hope that it will be useful,
    //# but WITHOUT ANY WARRANTY; without even the implied warranty of
    //# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    //# GNU General Public License for more details.
    //#
    //# You should have received a copy of the GNU General Public License along
    //# with the LOFAR software suite. If not, see <http://www.gnu.org/licenses/>.
    //#
    //# $Id$
    
    #include <lofar_config.h>
    
    #include "UnitTest.h"
    
    #include <GPUProc/global_defines.h>
    #include <GPUProc/OpenCL_Support.h>
    #include <GPUProc/createProgram.h>
    
    namespace LOFAR
    {
      namespace Cobalt
      {
    
        UnitTest::UnitTest(const Parset &ps, const char *programName)
          :
          counter(programName != 0 ? programName : "test", profiling)
        {
          createContext(context, devices);
          queue = cl::CommandQueue(context, devices[0], CL_QUEUE_PROFILING_ENABLE);
    
          if (programName != 0)
            program = createProgram(ps, context, devices, programName);
        }
    
    
        bool UnitTest::fpEquals(double val, double ref, double epsilon) const
        {
          double err = std::abs(val - ref);
          if (ref >= 1.0e-1) {
            err /= ref;         // prefer relative error cmp iff away from 0.0
          }
          return err < epsilon;
        }
    
        bool UnitTest::cfpEquals(std::complex<double> val, std::complex<double> ref, double epsilon) const
        {
          return fpEquals(val.real(), ref.real(), epsilon) &&
                 fpEquals(val.imag(), ref.imag(), epsilon);
        }
      }
    }