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


C++ Analysis::loop方法代码示例

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


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

示例1: main

int main(int argc, char ** argv) {

  if (argc != 2+1) {
    cout << "wrong number of arguments - usage :" << endl;
    cout << argv[0] << " <input txt file> <output file name>" << endl;
    return 1;
  }

  TString txtFile(argv[1]);
  TString outputFileName(argv[2]);
  cout << "input txt file   = " << txtFile << endl;
  cout << "output file name = " << outputFileName << endl;

  Analysis analysis;

  ifstream in;
  in.open(txtFile);
  while (true) {
    TString fileName;
    in >> fileName;
    if (!in.good()) break;

    TFile * f = TFile::Open(fileName);
    if(!f->IsOpen()) {
      printf("ERROR file %s not found\n", fileName.Data());
      return 1;
    }
    f->Close();

    analysis.add(fileName);
  }
  in.close();

  analysis.init();
  analysis.loop(outputFileName);

  return 0;
}
开发者ID:johanneserdmann,项目名称:AllhadronicAnalysis,代码行数:38,代码来源:run.C

示例2: main

int main(int argc, char* argv[]) 
{
  cout <<"#------------------------------------------------------------------------------#" << endl;
  cout <<"#------------------------------------------------------------------------------#" << endl;
  cout <<"#                WCAlgo, Analysis weigth convolution algorithm                 #" << endl;
  cout <<"#------------------------------------------------------------------------------#" << endl;
  if (argc == 1) {
    cout << "#------------------------------------------------------------------------------#" << endl;
    cout << "# OPTIONS:                                                                      " << endl;
    cout << "# --weight          Start weight calculation                                    " << endl;
    cout << "# --outTree=[name]  Choose name of tree for output file                         " << endl;
    cout << "#------------------------------------------------------------------------------#" << endl;
    cout << "# Analysis data (default):                                                      " << endl;
    cout << "# Example: ./wcAlgo weight.root DRSfile output.root                             " << endl;
    cout << " -ch=[value] -fE=[value] -lE=[value] -fG=[value] -lG=[value]                    " << endl;
    cout << "# -ch=[value] Choose number of channel for analysis from DRS file               " << endl;
    cout << "# -fE=[value] Choose first event for read                                       " << endl;
    cout << "# -lE=[value] Choose last event for read                                        " << endl;
    cout << "# -fG=[value] Choose firs value (time form wight function) for gate [ns]        " << endl;
    cout << "# -lG=[value] Choose last value (time form wight function) for gate [ns]        " << endl;
    cout << "#------------------------------------------------------------------------------#" << endl;
    cout << "# Weight calculation (--weight):                                                " << endl;
    cout << "# Example: ./wcAlgo DRSfile weight.root --weight                                " << endl;
    cout << " -ch=[value] -fE=[value] -lE=[value] -[type]                                    " << endl;
    cout << "# --w=[name]  Choose name for weights data (default name = weights)             " << endl;
    cout << "# -ch=[value]  Choose number of channel from DRS file                           " << endl;
    cout << "# -fE=[value]  Choose first event for read                                      " << endl;
    cout << "# -lE=[value]  Choose last event for read                                       " << endl;
    cout << "# -[type]      Choose type of weight function type:                             " << endl;
    cout << "                                                   pf - power function          " << endl;
    cout << "# --deg=[value] Choose degree for power function                                " << endl;
    cout << "#------------------------------------------------------------------------------#" << endl;

    return 0;
  }
  char inputFileName[128] = "none";
  char weightFileName[128] = "none";
  char weightDataName[128] = "none";
  char outputFileName[128] = "none";
  char outputTreeName[128] = "default";

  int ch = 0;
  unsigned long int firstNumEvent = 0;
  unsigned long int lastNumEvent = 0;
  float firstGate = 0;
  float lastGate = 0;

  bool isWeight = false;
  float degree = 1;
  int type = 0;

  for(int i = 1; i < argc; i++) {
    if(strncmp(argv[i],"--weight", 6) == 0)
      isWeight = true;
  }
  if(!isWeight) {
  strcpy(weightFileName, argv[1]);
  strcpy(inputFileName, argv[2]);
  strcpy(outputFileName, argv[3]);
  for(int i = 1; i < argc; i++) {  
    if(strncmp(argv[i],"--outTree=", 7) == 0)
      sscanf(argv[i], "--outTree=%s", outputTreeName);
    if(strncmp(argv[i], "-fE=", 4) == 0)
      sscanf(argv[i], "-fE=%lu", &firstNumEvent);
    if(strncmp(argv[i], "-lE=", 4) == 0)
      sscanf(argv[i], "-lE=%lu", &lastNumEvent);
    if(strncmp(argv[i], "-fG=", 4) == 0)
      sscanf(argv[i], "-fG=%f", &firstGate);
    if(strncmp(argv[i], "-lG=", 4) == 0)
      sscanf(argv[i], "-lG=%f", &lastGate);
    if(strncmp(argv[i], "-ch=", 4) == 0)
      sscanf(argv[i], "-ch=%d", &ch);
  }
    cout << "#------------------------------------------------------------------------------#" << endl;
    cout << "# Analysis data:                                                                " << endl;
    cout << "#------------------------------------------------------------------------------#" << endl;
    cout << "# InputFile: " << inputFileName << endl;
    cout << "# firstEvent=" << firstNumEvent << " lastEvent=" << lastNumEvent << endl;
    cout << "# GateFile: " << inputFileName << endl;
    cout << "# OutputFile: " << outputFileName << endl;
    cout << "# OutputTree: " << outputTreeName << endl;
    cout << "# firstGate=" << firstGate << " [ns]" << " lastGate=" << lastGate << " [ns]" << endl;

    Analysis analysis;
    analysis.setInputFile(inputFileName);
    analysis.setOutputFile(outputFileName, outputTreeName);
    if(firstNumEvent >= 0 && lastNumEvent > 0)
      analysis.loop(ch, firstNumEvent, lastNumEvent, firstGate, lastGate, weightFileName);
    else
      cout << "# Can't run loop function, for help execute ./wcAlgo" << endl;
  }
  else {
    strcpy(inputFileName, argv[1]);
    strcpy(outputFileName, argv[2]);
    for(int i = 1; i < argc; i++) {
      if(strncmp(argv[i],"--outTree=", 7) == 0)
        sscanf(argv[i], "--outTree=%s", outputTreeName);
      if(strncmp(argv[i],"--w=", 4) == 0)
        sscanf(argv[i], "--w=%s", weightDataName);
      if(strncmp(argv[i], "-fE=", 4) == 0)
//.........这里部分代码省略.........
开发者ID:shchablo,项目名称:WCAlgo,代码行数:101,代码来源:main.C


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