Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Related Pages

NoiseOccupancyTest.h

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         // Compression mode X1X
00039         APICALL(&api, modifyABCDVar(&st, ST_COMPRESSION, 1), "NoiseOccupancyTest::startTest")
00040 
00041         // Edge detect off
00042         APICALL(&api, modifyABCDVar(&st, ST_EDGE_DETECT, 0), "NoiseOccupancyTest::startTest")
00043 
00044         // No masked channels
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

Generated on Thu Jul 15 09:50:49 2004 for SCT DAQ/DCS Software - C++ by doxygen 1.3.5