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


C++ Flavour::IsGluon方法代码示例

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


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

示例1: FinalColours

void Colour_Generator::FinalColours() {
  //   msg_Out()<<METHOD<<":\n";
  size_t flow(0),col(0);
  Particle * part;
  Flavour flav;
  for (size_t beam=0;beam<2;beam++) {
    size_t length(m_hadrons[1-beam]->Size());
    
    /*      msg_Out()<<"   Trips["<<beam<<"]:";
        for (set<int>::iterator cit=m_col[beam][0].begin();
        cit!=m_col[beam][0].end();cit++) msg_Out()<<" "<<(*cit);
        msg_Out()<<"\n";
        msg_Out()<<"   Antis["<<beam<<"]:";
        for (set<int>::iterator cit=m_col[beam][1].begin();
        cit!=m_col[beam][1].end();cit++) msg_Out()<<" "<<(*cit);
        msg_Out()<<"\n";*/
    
    for (size_t i=length-2;i<length;i++) {
      part = m_hadrons[1-beam]->GetParticle(i);
      flav = part->Flav();
      if (flav.IsQuark() || flav.IsDiQuark()) {
    if ((flav.IsQuark()   && !flav.IsAnti()) ||
        (flav.IsDiQuark() && flav.IsAnti()))    flow=0;
    if ((flav.IsQuark()   && flav.IsAnti()) ||
        (flav.IsDiQuark() && !flav.IsAnti()))   flow=1;
    if (m_col[beam][flow].size()>0) {
      col = (*m_col[beam][flow].begin());
      part->SetFlow(flow+1,col);
      m_col[beam][flow].erase(m_col[beam][flow].begin());
    }
    else {
      part->SetFlow(flow+1,-1);
      m_col[beam][1-flow].insert(part->GetFlow(flow+1));	  
    }
      }
      else if (flav.IsGluon()) {
    for (flow=0;flow<2;flow++) {
      if (m_col[beam][flow].size()>0) {
        col = (*m_col[beam][flow].begin());
        part->SetFlow(flow+1,col);
        m_col[beam][flow].erase(m_col[beam][flow].begin());
      }
      else {
        part->SetFlow(flow+1,-1);
        m_col[beam][1-flow].insert(part->GetFlow(flow+1));	  
      }
    }
      }
      //       msg_Out()<<(*part)<<"\n";
    }
  }
}
开发者ID:alisw,项目名称:SHERPA,代码行数:52,代码来源:Colour_Generator.C

示例2: abort

Proto_Particle::
Proto_Particle(Flavour flav,Vec4D mom,char info) :
  m_flav(flav), m_mom(mom), m_info(info), 
  m_mass(hadpars->GetConstituents()->Mass(flav)), m_kt2max(0.), 
  p_partner(NULL)
{ 
  if (!flav.IsGluon() && !flav.IsDiQuark()) {
    if (flav.IsQuark() && flav.Kfcode()>5) {
      std::cerr<<"Error in Proto_Particle::Proto_Particle():\n"
           <<"   Tried to form a cluster particle from a "<<flav<<".\n"
           <<"   Please make sure that heavy coloured objects decay "
           <<"before they enter hadronization.\n"
           <<"   Will exit the run.\n";
      abort();
    }
  }
  control::s_AHAprotoparticles++; 
  s_actives.push_back(this);
}
开发者ID:alisw,项目名称:SHERPA,代码行数:19,代码来源:Proto_Particle.C


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