Geant4不完全学习--/examples/extended/persistency/gdml/G01/main函数注释

#include <vector>

#include "G4Types.hh"

#include "G4RunManagerFactory.hh"

#include "G4UImanager.hh"

#include "G4LogicalVolumeStore.hh"
#include "G4TransportationManager.hh"

#include "G01PrimaryGeneratorAction.hh"
#include "G01DetectorConstruction.hh"
#include "G01ActionInitialization.hh"

#include "FTFP_BERT.hh"

#include "G4VisExecutive.hh"
#include "G4UIExecutive.hh"

#include "G4GDMLParser.hh"
//该程序的运行分为以下几种情况
//当输入参数数量等于1时候会报错出现"Error! Mandatory input file is not specified!"
//当输入参数数量等于2时就会直接调用可视化并不会调用print_aux函数
//当输入参数数量等于3时调用para.write,将输入的gdml文件输出到新的gdml文件
//当输入参数数量等于4时会直接执行后面的宏文件进行粒子的入射
//当输入参数数量大于4时会报错出现"Error! Too many arguments!"


//输出GDML信息的辅助类,输出type,value,unit
void print_aux(const G4GDMLAuxListType* auxInfoList, G4String prepend="|")
{
  for(std::vector<G4GDMLAuxStructType>::const_iterator
      iaux = auxInfoList->begin(); iaux != auxInfoList->end(); iaux++ )
    {
      G4String str=iaux->type;
      G4String val=iaux->value;
      G4String unit=iaux->unit;

      G4cout << prepend << str << " : " << val  << " " << unit << G4endl;

      if (iaux->auxList) print_aux(iaux->auxList, prepend + "|");
    }
  return;
}

// --------------------------------------------------------------

int main(int argc,char **argv)
{
   G4cout << G4endl;
   G4cout << "Usage: load_gdml <intput_gdml_file:mandatory>"
          << " <output_gdml_file:optional>" << G4endl;
   G4cout << G4endl;

   if (argc<2)
   {
      G4cout << "Error! Mandatory input file is not specified!" << G4endl;
      G4cout << G4endl;
      return -1;
   }

   G4GDMLParser parser;

// Uncomment the following if wish to avoid names stripping
// 如果希望避免名称剥离,请取消对以下内容的注释
// parser.SetStripFlag(false);

   parser.SetOverlapCheck(true);//检查是否重复
   parser.Read(argv[1]);//读取gdml文件

   if (argc>4)
   {
      G4cout << "Error! Too many arguments!" << G4endl;
      G4cout << G4endl;
      return -1;
   }

   auto* runManager = G4RunManagerFactory::CreateRunManager();

   runManager->SetUserInitialization(new G01DetectorConstruction(
                                     parser.GetWorldVolume()));
   runManager->SetUserInitialization(new FTFP_BERT);
   runManager->SetUserInitialization(new G01ActionInitialization());

   runManager->Initialize();

   // Initialize visualization
   G4VisManager* visManager = new G4VisExecutive;
   visManager->Initialize();

   // Get the pointer to the User Interface manager
   G4UImanager* UImanager = G4UImanager::GetUIpointer();

   ///
   //
   // Example how to retrieve Auxiliary Information
   //如何检索辅助信息的例子

   G4cout << std::endl;

   const G4LogicalVolumeStore* lvs = G4LogicalVolumeStore::GetInstance();
   std::vector<G4LogicalVolume*>::const_iterator lvciter;
   for( lvciter = lvs->begin(); lvciter != lvs->end(); lvciter++ )
   {
     G4GDMLAuxListType auxInfo = parser.GetVolumeAuxiliaryInformation(*lvciter);

     if (auxInfo.size()>0)
       G4cout << "Auxiliary Information is found for Logical Volume :  "
              << (*lvciter)->GetName() << G4endl;

     print_aux(&auxInfo);
   }

   // now the 'global' auxiliary info
   G4cout << std::endl;
   G4cout << "Global auxiliary info:" << std::endl;
   G4cout << std::endl;

   print_aux(parser.GetAuxList());

   G4cout << std::endl;

   //
   // End of Auxiliary Information block
   //
   


   runManager->BeamOn(0);

   // example of writing out

   if (argc>=3)
   {
/*
     G4GDMLAuxStructType mysubaux = {"mysubtype", "mysubvalue", "mysubunit", 0};
     G4GDMLAuxListType* myauxlist = new G4GDMLAuxListType();
     myauxlist->push_back(mysubaux);

     G4GDMLAuxStructType myaux = {"mytype", "myvalue", "myunit", myauxlist};
     parser.AddAuxiliary(myaux);


     // example of setting auxiliary info for world volume
     // (can be set for any volume)

     G4GDMLAuxStructType mylocalaux = {"sometype", "somevalue", "someunit", 0};

     parser.AddVolumeAuxiliary(mylocalaux,
       G4TransportationManager::GetTransportationManager()
       ->GetNavigatorForTracking()->GetWorldVolume()->GetLogicalVolume());
*/

     parser.SetRegionExport(true);
     //     parser.SetEnergyCutsExport(true);
     //     parser.SetOutputFileOverwrite(true);
     parser.Write(argv[2], G4TransportationManager::GetTransportationManager()
      ->GetNavigatorForTracking()->GetWorldVolume()->GetLogicalVolume());
   }

//对于参数的数量等于4的情况不会调用可视化的进行,对于参数小于等于3 的情况就会调用可视化界面
   if (argc==4)   // batch mode
   {
     G4String command = "/control/execute ";
     G4String fileName = argv[3];
     UImanager->ApplyCommand(command+fileName);
   }
   else           // interactive mode
   {
     G4UIExecutive* ui = new G4UIExecutive(argc, argv);
     UImanager->ApplyCommand("/control/execute vis.mac");
     ui->SessionStart();
     delete ui;
   }

   delete visManager;
   delete runManager;

   return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这是一个Geant4命令,其中/run/beamOn是命令的关键字,100是命令的参数。该命令用于启动一次模拟运行并指定要模拟的粒子数为100个。在Geant4中,/run/beamOn命令用于启动模拟运行,并且在每次模拟运行结束后都需要重新输入该命令进行下一次模拟运行。在这个例子中,该命令将启动模拟运行并模拟100个粒子。 ### 回答2: "Geant4 /run/beamOn 100"是一条Geant4命令,用于在模拟程序中运行100个粒子的束流。 Geant4是一款用于高能物理和核物理实验模拟的软件工具包。它可以模拟粒子在物质中传输和相互作用的过程,从而帮助研究人员理解实验中观测到的现象。 /run/beamOn是Geant4命令的一部分,用于设置并运行粒子的束流。在这条命令中,100是指要运行的粒子数。 当执行这条命令时,Geant4会生成一束包含100个粒子的束流,并将它们注入模拟中。每个粒子都被赋予起始位置、动量和能量,并模拟其在探测器或目标物质中的运动和相互作用。 这样一来,研究人员可以通过运行多个粒子来获取更多统计数据,从而更准确地验证实验结果和理论模型。同时,可以通过改变命令中的数字来模拟不同数量的粒子束流,以满足实际研究的需求。 总之,"Geant4 /run/beamOn 100"是一条Geant4命令,用于在模拟程序中生成并运行100个粒子的束流,帮助研究人员模拟和研究高能物理和核物理实验中的现象和结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值