Changeset 9325 for trunk/MagicSoft/Mars


Ignore:
Timestamp:
02/12/09 00:47:43 (16 years ago)
Author:
tbretz
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/Changelog

    r9324 r9325  
    3636     - added some getter
    3737
    38    * mhist/MHEvent.cc:
     38   * mhist/MHEvent.[h,cc]:
    3939     - some improvements to output
     40     - implemented display for trigger pattern
     41
     42   * mtrigger/MTriggerPattern.[h,cc]:
     43     - added Copy-function
     44
     45   * mhist/Makefile:
     46     - added -I../mtrigger
    4047
    4148   * mmc/MMcEvtBasic.[h,cc]:
  • trunk/MagicSoft/Mars/NEWS

    r9317 r9325  
    1616
    1717   * added support for Arehucas Version >= 200812140
     18
     19 ;mars
     20
     21   * The display now also displays the trigger pattern
    1822
    1923 ;ceres
  • trunk/MagicSoft/Mars/mhist/MHEvent.cc

    r9313 r9325  
    4848#include <TStyle.h>
    4949#include <TCanvas.h>
     50#include <TPaveText.h>
    5051
    5152#include "MLog.h"
     
    5960#include "MTaskList.h"
    6061#include "MParList.h"
     62#include "MGeomCam.h"
    6163#include "MSignalCam.h"
    6264#include "MRawEvtHeader.h"
     
    6466#include "MRawEvtData.h"
    6567#include "MImgCleanStd.h"
     68#include "MTriggerPattern.h"
    6669
    6770ClassImp(MHEvent);
     
    7780    fTitle = "Single Event display task";
    7881
    79     fClone = new MRawEvtData("MHEventData");
     82    fClone   = new MRawEvtData("MHEventData");
     83    fTrigCpy = new MTriggerPattern;
    8084}
    8185
     
    8892
    8993    delete fClone;
     94    delete fTrigCpy;
    9095}
    9196
     
    97102    fMcEvt       = (MMcEvt*)plist->FindObject("MMcEvt");
    98103    fTime        = (MTime*)plist->FindObject("MTime");
     104    fTrigger     = (MTriggerPattern*)plist->FindObject("MTriggerPattern");
    99105
    100106    fRawEvtData = (MRawEvtData*)plist->FindObject("MRawEvtData");
     
    228234        return kERROR;
    229235    }
     236
     237    if (fTrigger)
     238        fTrigger->Copy(*fTrigCpy);
    230239
    231240    if (fRawEvtData)
     
    312321}
    313322
    314 void MHEvent::Paint(Option_t *)
     323void MHEvent::Paint(Option_t *o)
    315324{
    316325    TVirtualPad *pad = gPad;
    317326
    318     pad->GetPad(2)->cd(1);
    319     if (gPad->FindObject("Proj"))
    320     {
    321         TH1 *h=fHist->Projection("Proj");
    322         if (h->GetMaximum()>0)
    323             gPad->SetLogy();
    324     }
    325 
    326     pad->GetPad(2)->cd(2);
    327     if (gPad->FindObject("ProfRad"))
    328         fHist->RadialProfile("ProfRad");
    329 
    330     pad->GetPad(2)->cd(3);
    331     if (gPad->FindObject("ProfAz"))
    332         fHist->AzimuthProfile("ProfAz");
     327    if (TString(o).IsNull())
     328    {
     329        pad->GetPad(2)->cd(1);
     330        if (gPad->FindObject("Proj"))
     331        {
     332            TH1 *h=fHist->Projection("Proj");
     333            if (h->GetMaximum()>0)
     334                gPad->SetLogy();
     335        }
     336
     337        pad->GetPad(2)->cd(2);
     338        if (gPad->FindObject("ProfRad"))
     339            fHist->RadialProfile("ProfRad");
     340
     341        pad->GetPad(2)->cd(3);
     342        if (gPad->FindObject("ProfAz"))
     343            fHist->AzimuthProfile("ProfAz");
     344    }
     345
     346    if (TString(o)=="1")
     347    {
     348        const Double_t r = fHist->GetGeometry()->GetMaxRadius();
     349        TPaveText s4(0.82*r, -r, 0.90*r, -0.92*r, "br");
     350        TPaveText s3(0.74*r, -r, 0.82*r, -0.92*r, "br");
     351        TPaveText s2(0.66*r, -r, 0.74*r, -0.92*r, "br");
     352        TPaveText s1(0.58*r, -r, 0.66*r, -0.92*r, "br");
     353        TPaveText s0(0.50*r, -r, 0.58*r, -0.92*r, "br");
     354        s0.SetBorderSize(1);
     355        s1.SetBorderSize(1);
     356        s2.SetBorderSize(1);
     357        s3.SetBorderSize(1);
     358        s4.SetBorderSize(1);
     359        s0.AddText("P");
     360        s1.AddText("C");
     361        s2.AddText("1");
     362        s3.AddText("2");
     363        s4.AddText("S");
     364
     365        const Byte_t pat = fTrigCpy->GetUnprescaled();
     366
     367        s0.SetFillColor(pat&MTriggerPattern::kPedestal    ? kBlue : kWhite);
     368        s1.SetFillColor(pat&MTriggerPattern::kCalibration ? kBlue : kWhite);
     369        s2.SetFillColor(pat&MTriggerPattern::kTriggerLvl1 ? kBlue : kWhite);
     370        s3.SetFillColor(pat&MTriggerPattern::kTriggerLvl2 ? kBlue : kWhite);
     371        s4.SetFillColor(pat&MTriggerPattern::kSumTrigger  ? kBlue : kWhite);
     372
     373        s0.Paint();
     374        s1.Paint();
     375        s2.Paint();
     376        s3.Paint();
     377        s4.Paint();
     378    }
    333379}
    334380
     
    352398    gPad->SetBorderMode(0);
    353399    fHist->Draw();
     400
     401    AppendPad("1");
    354402
    355403    pad->cd(2);
     
    383431    h->Draw();
    384432}
     433
  • trunk/MagicSoft/Mars/mhist/MHEvent.h

    r9224 r9325  
    1616class MSignalCam;
    1717class MImgCleanStd;
     18class MTriggerPattern;
    1819
    1920class MHEvent : public MH
     
    3031
    3132private:
    32     MRawEvtData   *fRawEvtData;    //!
    33     MRawRunHeader *fRawRunHeader;  //!
    34     MRawEvtHeader *fRawEvtHeader;  //!
     33    MRawEvtData      *fRawEvtData;    //!
     34    MRawRunHeader    *fRawRunHeader;  //!
     35    MRawEvtHeader    *fRawEvtHeader;  //!
    3536
    36     MTime         *fTime;          //!
    37     MMcEvt        *fMcEvt;         //!
    38     MMcTrig       *fMcTrig;        //!
    39     MSignalCam    *fCerPhotEvt;    //!
    40     MImgCleanStd  *fImgCleanStd;   //!
     37    MTime            *fTime;          //!
     38    MMcEvt           *fMcEvt;         //!
     39    MMcTrig          *fMcTrig;        //!
     40    MSignalCam       *fCerPhotEvt;    //!
     41    MImgCleanStd     *fImgCleanStd;   //!
     42    MTriggerPattern  *fTrigger;       //!
    4143
    42     MRawEvtData   *fClone;         //->
     44    MRawEvtData      *fClone;         //->
     45    MTriggerPattern  *fTrigCpy;       //->
    4346
    4447    MHCamera *fHist;
     
    6669    void Draw(Option_t *o="");
    6770    void Paint(Option_t *o="");
    68  
     71
    6972    ClassDef(MHEvent, 1)
    7073};
  • trunk/MagicSoft/Mars/mhist/Makefile

    r8614 r9325  
    2222           -I../mgui -I../mgeom -I../mdata -I../mfilter -I../mimage \
    2323           -I../mpointing -I../mmc  -I../mastro -I../msignal        \
    24            -I../mbadpixels -I../mcalib -I../mreport
     24           -I../mbadpixels -I../mcalib -I../mreport -I../mtrigger
    2525
    2626SRCFILES = MHEvent.cc \
     
    3232           MHCamera.cc \
    3333           MHRate.cc \
    34            MHWeather.cc
     34           MHWeather.cc \
     35           MHQuality.cc
    3536
    3637#           MHFadcPix.cc \
  • trunk/MagicSoft/Mars/mtrigger/MTriggerPattern.cc

    r9157 r9325  
    151151}
    152152
     153void MTriggerPattern::Copy(TObject &obj) const
     154{
     155    static_cast<MTriggerPattern&>(obj).fPrescaled=fPrescaled;
     156    static_cast<MTriggerPattern&>(obj).fUnprescaled=fUnprescaled;
     157}
     158
    153159void MTriggerPattern::Print(Option_t *) const
    154160{
  • trunk/MagicSoft/Mars/mtrigger/MTriggerPattern.h

    r9158 r9325  
    3030
    3131    void Print(Option_t *) const;
     32    void Copy(TObject &obj) const { static_cast<MTriggerPattern&>(obj).fPrescaled=fPrescaled; static_cast<MTriggerPattern&>(obj).fUnprescaled=fUnprescaled; }
    3233
    3334    void Reset() { fPrescaled=0; fUnprescaled=0; }
Note: See TracChangeset for help on using the changeset viewer.