当前位置: 首页>>代码示例>>C++>>正文


C++ Trigger::Mask方法代码示例

本文整理汇总了C++中Trigger::Mask方法的典型用法代码示例。如果您正苦于以下问题:C++ Trigger::Mask方法的具体用法?C++ Trigger::Mask怎么用?C++ Trigger::Mask使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Trigger的用法示例。


在下文中一共展示了Trigger::Mask方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: HotTowerSearch

void HotTowerSearch(char * var="Eta")
{
  const Int_t N_BINS=100;
  gSystem->Load("src/RunData.so");
  RunData * RD = new RunData();
  Trigger * T = new Trigger();
  Environ * env = new Environ();
  EventClass * ev = new EventClass();

  Int_t N_CLASS_tmp = ev->N;
  const Int_t N_CLASS = N_CLASS_tmp;

  TChain * tc = new TChain("str");
  tc->Add("redset/Red*.root");
  //tc->Add("redset/RedOutputset080s1.root");

  Float_t E12,Pt,Eta,Phi,M12,Z,N12;
  Int_t runnum;
  UInt_t L2sum[2];
  tc->SetBranchAddress("runnum",&runnum);
  tc->SetBranchAddress("E12",&E12);
  tc->SetBranchAddress("Pt",&Pt);
  tc->SetBranchAddress("Eta",&Eta);
  tc->SetBranchAddress("Phi",&Phi);
  tc->SetBranchAddress("M12",&M12);
  tc->SetBranchAddress("Z",&Z);
  tc->SetBranchAddress("N12",&N12);
  tc->SetBranchAddress("L2sum",L2sum);


  Float_t bin_low,bin_high;
  Float_t * kinvar;

  if(!strcmp(var,"Eta"))
  {
    bin_low = env->EtaLow;
    bin_high = env->EtaHigh;
    kinvar = Η
  }
  else if(!strcmp(var,"Phi"))
  {
    bin_low = env->PhiLow;
    bin_high = env->PhiHigh;
    kinvar = Φ
  }
  else if(!strcmp(var,"Pt"))
  {
    bin_low = env->PtLow;
    bin_high = env->PtHigh;
    kinvar = &Pt;
  }
  else if(!strcmp(var,"E12"))
  {
    bin_low = env->EnLow;
    bin_high = env->EnHigh;
    kinvar = &E12;
  }

  Int_t count=0;
  Int_t runnum_tmp=0;

  TH1D * h[N_CLASS][2000]; // assumes max number of runs
  char h_name[N_CLASS][2000][32];
  for(Int_t i=0; i<tc->GetEntries(); i++)
  {
    tc->GetEntry(i);
    ev->SetKinematics(runnum,E12,Pt,Eta,Phi,M12,Z,N12);
    if(runnum!=runnum_tmp)
    {
      if(runnum_tmp!=0) count++;
      for(Int_t c=0; c<N_CLASS; c++)
      {
        sprintf(h_name[c][count],"h_%d_%s",runnum,ev->Name(c));
        h[c][count] = new TH1D(h_name[c][count],h_name[c][count],N_BINS,bin_low,bin_high);
      };
      printf("%d %d\n",count,runnum);
      runnum_tmp = runnum;
    };
    for(Int_t c=0; c<N_CLASS; c++)
    {
      if(ev->Valid(c) && L2sum[1]&T->Mask(runnum,"All",1))
        h[c][count]->Fill(*kinvar);
    };
  };

  char h2_t[N_CLASS][64];
  char h2_n[N_CLASS][32];
  TH2D * h2[N_CLASS];
  for(Int_t c=0; c<N_CLASS; c++)
  {
    sprintf(h2_t[c],"%s %s vs. run index",ev->Title(c),var);
    sprintf(h2_n[c],"h2_%s",ev->Name(c));
    h2[c] = new TH2D(h2_n[c],h2_t[c],count+1,0,count+1,N_BINS,bin_low,bin_high);
    Float_t binpos;
    Int_t binn;
    for(Int_t k=0; k<count+1; k++)
    {
      h[c][k]->Scale(1/h[c][k]->Integral());
      for(Int_t b=0; b<h[c][k]->GetNbinsX(); b++)
      {
//.........这里部分代码省略.........
开发者ID:c-dilks,项目名称:spin15pAu,代码行数:101,代码来源:HotTowerSearch.C


注:本文中的Trigger::Mask方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。