00001 #ifndef NOISEOCCUPANCY_H
00002 #define NOISEOCCUPANCY_H
00003
00004 #include "../ipc/TestRequest.h"
00005 #include "../ipc/CalibrationController.h"
00006 #include "../ipc/ScanLibrary.h"
00007 #include "../ipc/Sct_CalibrationController.hh"
00008 #include "../CalibrationControllerImpl.h"
00009
00010 #include "../SctApiAccessException.h"
00011 #include "Sct/LogicErrors.h"
00012 #include "../SctApiCall.h"
00013
00014 #include "NoiseOccupancyScan.h"
00015
00016 #include <CommonWithDsp/ABCD/ABCDscans.h>
00017 #include <iostream>
00018 #include <vector>
00019
00020 using namespace Sct;
00021 using namespace std;
00022 using namespace SctCalibrationController::Ipc;
00023 using namespace SctCalibrationController;
00024
00025 namespace SctCalibrationController {
00026 namespace Scripts {
00027
00028 class NoiseOccupancyTest : public TestRequestImpl {
00029 public:
00030 static NoiseOccupancyTest& instance() {
00031 static NoiseOccupancyTest no;
00032 return no;
00033 }
00034
00035 virtual void startTest(Sct_SctApi_T_SctApi& api, string& name, unsigned short& testVariable, unsigned long& nScans, vector<double>& testPoints) {
00036 this->api = &api;
00037
00038
00039 APICALL(&api, modifyABCDVar(&st, ST_COMPRESSION, 1), "NoiseOccupancyTest::startTest")
00040
00041
00042 APICALL(&api, modifyABCDVar(&st, ST_EDGE_DETECT, 0), "NoiseOccupancyTest::startTest")
00043
00044
00045 APICALL(&api, modifyABCDVar(&st, ST_SEND_MASK, 0), "NoiseOccupancyTest::startTest")
00046
00047 name = "NoiseOccupancyTest";
00048 testVariable = ST_ELAPSED;
00049 nScans = 1;
00050 testPoints.push_back(0.);
00051 }
00052
00053 virtual ScanRequest* getNextScan(unsigned long index) {
00054 ScanLibrary& sl = CalibrationControllerImpl::instance().getScanLibrary();
00055
00056 APICALL(api, modifyABCDVar(&st, ST_QCAL, 0.), "NoiseOccupancyTest::getNextScan")
00057
00058 return &sl.noiseOccupancyScan();
00059 }
00060
00061 virtual bool canFeedback() {
00062 return false;
00063 }
00064
00065 virtual void endTest() {
00066 api = 0;
00067 }
00068
00069
00070 private:
00071 NoiseOccupancyTest() {}
00072 Sct_SctApi_T_SctApi* api;
00073 };
00074 }
00075 }
00076 #endif //RESPONSECURVE_H