File indexing completed on 2026-06-06 07:55:38
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029 #include "RunAction.hh"
0030
0031 #include "RunData.hh"
0032
0033 #include "G4AnalysisManager.hh"
0034 #include "G4Run.hh"
0035 #include "G4RunManager.hh"
0036 #include "G4SystemOfUnits.hh"
0037 #include "G4UnitsTable.hh"
0038 #include "globals.hh"
0039
0040 namespace B4b
0041 {
0042
0043
0044
0045 RunAction::RunAction()
0046 {
0047
0048 G4RunManager::GetRunManager()->SetPrintProgress(1);
0049
0050
0051
0052
0053 auto analysisManager = G4AnalysisManager::Instance();
0054
0055
0056
0057
0058 analysisManager->SetVerboseLevel(1);
0059 analysisManager->SetNtupleMerging(true);
0060
0061
0062
0063
0064
0065
0066 analysisManager->CreateH1("Eabs", "Edep in absorber", 110, 0., 330 * MeV);
0067 analysisManager->CreateH1("Egap", "Edep in gap", 100, 0., 30 * MeV);
0068 analysisManager->CreateH1("Labs", "trackL in absorber", 100, 0., 50 * cm);
0069 analysisManager->CreateH1("Lgap", "trackL in gap", 100, 0., 50 * cm);
0070
0071
0072
0073 analysisManager->CreateNtuple("B4", "Edep and TrackL");
0074 analysisManager->CreateNtupleDColumn("Eabs");
0075 analysisManager->CreateNtupleDColumn("Egap");
0076 analysisManager->CreateNtupleDColumn("Labs");
0077 analysisManager->CreateNtupleDColumn("Lgap");
0078 analysisManager->FinishNtuple();
0079 }
0080
0081
0082
0083 G4Run* RunAction::GenerateRun()
0084 {
0085 return (new RunData);
0086 }
0087
0088
0089
0090 void RunAction::BeginOfRunAction(const G4Run* run)
0091 {
0092 G4cout << "### Run " << run->GetRunID() << " start." << G4endl;
0093
0094
0095
0096
0097
0098 auto analysisManager = G4AnalysisManager::Instance();
0099
0100
0101
0102 G4String fileName = "B4.root";
0103
0104
0105
0106
0107 analysisManager->OpenFile(fileName);
0108 G4cout << "Using " << analysisManager->GetType() << G4endl;
0109 }
0110
0111
0112
0113 void RunAction::EndOfRunAction(const G4Run* )
0114 {
0115
0116
0117 auto analysisManager = G4AnalysisManager::Instance();
0118 if (analysisManager->GetH1(1)) {
0119 G4cout << G4endl << " ----> print histograms statistic ";
0120 if (isMaster) {
0121 G4cout << "for the entire run " << G4endl << G4endl;
0122 }
0123 else {
0124 G4cout << "for the local thread " << G4endl << G4endl;
0125 }
0126
0127 G4cout << " EAbs : mean = " << G4BestUnit(analysisManager->GetH1(0)->mean(), "Energy")
0128 << " rms = " << G4BestUnit(analysisManager->GetH1(0)->rms(), "Energy") << G4endl;
0129
0130 G4cout << " EGap : mean = " << G4BestUnit(analysisManager->GetH1(1)->mean(), "Energy")
0131 << " rms = " << G4BestUnit(analysisManager->GetH1(1)->rms(), "Energy") << G4endl;
0132
0133 G4cout << " LAbs : mean = " << G4BestUnit(analysisManager->GetH1(2)->mean(), "Length")
0134 << " rms = " << G4BestUnit(analysisManager->GetH1(2)->rms(), "Length") << G4endl;
0135
0136 G4cout << " LGap : mean = " << G4BestUnit(analysisManager->GetH1(3)->mean(), "Length")
0137 << " rms = " << G4BestUnit(analysisManager->GetH1(3)->rms(), "Length") << G4endl;
0138 }
0139
0140
0141
0142 analysisManager->Write();
0143 analysisManager->CloseFile();
0144 }
0145
0146
0147
0148 }