diff --git a/NPLib/Physics/NPFissionDecay.cxx b/NPLib/Physics/NPFissionDecay.cxx index ff47f954de0c2970f9ee2ff1255f766c18530853..9083a63ac3f95d90fee31e8387e50a1b3c572da7 100644 --- a/NPLib/Physics/NPFissionDecay.cxx +++ b/NPLib/Physics/NPFissionDecay.cxx @@ -125,6 +125,7 @@ bool NPL::FissionDecay::GenerateEvent(string CompoundName, double MEx,double MEK FFl.SetKineticEnergy(KEl); FFh.SetKineticEnergy(KEh); } + FissionFragments.push_back(FFl); FissionFragments.push_back(FFh); Ex.push_back(0); @@ -145,6 +146,11 @@ bool NPL::FissionDecay::GenerateEvent(string CompoundName, double MEx,double MEK double Phil = m_FissionModel->GetPhffl(); double Phih = m_FissionModel->GetPhffh(); + if(Thetal != Thetal) + worked=false; + if(Thetah != Thetah) + worked=false; + TVector3 uxy = TVector3(cos(TMath::Pi()/2-PhiCN), sin(TMath::Pi()/2-PhiCN), 0); TVector3 Momentuml = Pl * TVector3(sin(Thetal)*cos(Phil), sin(Thetal)*sin(Phil), @@ -155,7 +161,7 @@ bool NPL::FissionDecay::GenerateEvent(string CompoundName, double MEx,double MEK sin(Thetah)*sin(Phih), cos(Thetah)); Momentumh.Rotate(-ThetaCN, uxy); - + DPx.push_back(Momentuml.X()); DPx.push_back(Momentumh.X()); DPy.push_back(Momentuml.Y()); @@ -168,19 +174,23 @@ bool NPL::FissionDecay::GenerateEvent(string CompoundName, double MEx,double MEK KE2 = m_FissionModel->GetKE2(); // Neutron and gamma emission - float* En1; - float* Eg1; - En1 = m_FissionModel->GetNeutronEnergyFrag1(); - //cout << "----- Neutron energy: " << endl; - //for(int i=0; i<51; i++) { - // cout << "En= " << En1[i] << endl; - //} - - Eg1 = m_FissionModel->GetGammaEnergyFrag1(); - //cout << "----- Gamma energy: " << endl; - //for(int i=0; i<101; i++){ - // cout << "Eg= " << Eg1[i] << endl; - //} + if(m_shoot_neutron){ + float* En1; + En1 = m_FissionModel->GetNeutronEnergyFrag1(); + //cout << "----- Neutron energy: " << endl; + //for(int i=0; i<51; i++) { + // cout << "En= " << En1[i] << endl; + //} + } + + if(m_shoot_gamma){ + float* Eg1; + Eg1 = m_FissionModel->GetGammaEnergyFrag1(); + //cout << "----- Gamma energy: " << endl; + //for(int i=0; i<101; i++){ + // cout << "Eg= " << Eg1[i] << endl; + //} + } } } return worked; diff --git a/NPSimulation/Process/FissionDecay.cc b/NPSimulation/Process/FissionDecay.cc index a3e8a1509369e2d7e669f7b87cb6d0135dd9b8c0..45cd4a22d6bdf39fe9fa6a58a9acb1a187d62f10 100644 --- a/NPSimulation/Process/FissionDecay.cc +++ b/NPSimulation/Process/FissionDecay.cc @@ -107,13 +107,13 @@ G4bool FissionDecay::ModelTrigger(const G4FastTrack& fastTrack) { const G4Track* PrimaryTrack = fastTrack.GetPrimaryTrack(); int Parent_ID = PrimaryTrack->GetParentID(); + m_PreviousEnergy = PrimaryTrack->GetKineticEnergy(); m_FissionConditions->Clear(); if(Parent_ID>=0){ Trigger = true; - - m_PreviousEnergy=fastTrack.GetPrimaryTrack()->GetKineticEnergy(); } + return Trigger; } @@ -150,11 +150,11 @@ void FissionDecay::DoIt(const G4FastTrack& fastTrack,G4FastStep& fastStep){ std::vector<double> DPz; double TKE, KE1, KE2; - G4bool IsFissionDecay = m_FissionDecay.GenerateEvent(NPL::ChangeNameFromG4Standard(m_CurrentName),m_ExcitationEnergy,energy, pdirection.x(),pdirection.y(),pdirection.z(), FissionFragment, Ex,DEK,DPx,DPy,DPz, TKE, KE1, KE2); + if(IsFissionDecay){ ///////////////////////////////////////////////// // Fillion the attached Fission condition Tree // @@ -187,7 +187,7 @@ void FissionDecay::DoIt(const G4FastTrack& fastTrack,G4FastStep& fastStep){ int FFZ = FissionFragment[i].GetZ(); int FFA = FissionFragment[i].GetA(); FissionFragmentDef=NULL; - + // Set the momentum direction G4ThreeVector Momentum (DPx[i],DPy[i],DPz[i]); Momentum=Momentum.unit(); @@ -197,7 +197,6 @@ void FissionDecay::DoIt(const G4FastTrack& fastTrack,G4FastStep& fastStep){ m_FissionConditions->SetFragmentZ(FFZ); m_FissionConditions->SetFragmentA(FFA); - //m_FissionConditions->SetFragmentKineticEnergy(DEK[i]); m_FissionConditions->SetFragmentKineticEnergy(KineticEnergy); m_FissionConditions->SetFragmentBrho(Brho); m_FissionConditions->SetFragmentTheta(Momentum.theta()/deg); @@ -222,13 +221,11 @@ void FissionDecay::DoIt(const G4FastTrack& fastTrack,G4FastStep& fastStep){ // the rest else FissionFragmentDef=G4ParticleTable::GetParticleTable()->GetIonTable()->GetIon(FFZ, FFA, Ex[i]); - - G4DynamicParticle DynamicFissionFragment(FissionFragmentDef,Momentum,DEK[i]); fastStep.CreateSecondaryTrack(DynamicFissionFragment, localPosition, time); } - if(size){ + if(size>0){ // Set the end of the step conditions fastStep.SetPrimaryTrackFinalKineticEnergyAndDirection(0,pdirection); fastStep.SetPrimaryTrackFinalPosition(worldPosition); diff --git a/Projects/Sofia/sofia.detector b/Projects/Sofia/sofia.detector index 80ae67ba7cf207f40388763e72de87e3f21fb44e..a10a046b1bbefd7fc7b675e1bcf62c7ea557ccbb 100644 --- a/Projects/Sofia/sofia.detector +++ b/Projects/Sofia/sofia.detector @@ -15,7 +15,7 @@ SofTofW Build_GLAD= 0 GLAD_TiltAngle= 14 deg GLAD_DistanceFromTarget= 3.05 m - Build_MagneticField= 0 + Build_MagneticField= 1 GLAD_MagField= 1.70 T Build_VacuumPipe= 1 VacuumPipeX= 0 cm diff --git a/Projects/e793s/macro/CS2.h b/Projects/e793s/macro/CS2.h index 6a429bb2052dcd3373e1a7f1e01396cfa8880f72..89cc9dffb3f025d9c57ea7cc3d40708517ac0422 100644 --- a/Projects/e793s/macro/CS2.h +++ b/Projects/e793s/macro/CS2.h @@ -1,6 +1,7 @@ /* Predefine functions */ vector<vector<double>> GetExpDiffCross(double Energy); TH1F* PullThetaLabHist(int i, double minTheta, double gatesize); +TH1F* PullPhaseSpaceHist(int i, double minTheta, double gatesize); void Scale(TGraph* g , TGraphErrors* ex); TGraph* TWOFNR(double E, double J0, double J, double n, double l, double j); double ToMininize(const double* parameter); @@ -13,7 +14,10 @@ TGraphErrors* staticExp; int indexE; /* Output volume toggle */ -bool loud = 1; +bool loud = 0; + +/* Scale method toggle */ +bool scaleTogether = 1; //////////////////////////////////////////////////////////////////////////////// void CS(){ @@ -113,6 +117,14 @@ void CS(double Energy, double Spin, double spdf, double angmom){ anglecentres.push_back(((areaArray[i][4]-areaArray[i][3])/2.)+areaArray[i][3]); anglewidth.push_back(areaArray[i][4]-areaArray[i][3]); + double tempsum=0, tempsumerr=0; + for(int x=binmin;x<binmax+1;x++){ + tempsum += SolidAngle->GetBinContent(x); + tempsumerr += SolidAngle->GetBinError(x); + if(loud){cout << x << endl;} + } + if(loud){cout << "TEST CHECK " << tempsum << " +- " << tempsumerr << endl;} + double SAerr; double SA = SolidAngle->IntegralAndError(binmin,binmax,SAerr); SA = SA*1000.; //sr->msr @@ -162,20 +174,20 @@ void CS(double Energy, double Spin, double spdf, double angmom){ 0, &(expDCSerr[0]) ); gdSdO->SetTitle("Differential Cross Section"); gdSdO->GetXaxis()->SetTitle("ThetaLab [deg]"); - gdSdO->GetYaxis()->SetTitle("d#sigma/d#Theta [mb/msr]"); + gdSdO->GetYaxis()->SetTitle("d#sigma/d#Omega [mb/msr]"); gdSdO->Draw(); /* TWOFNR diff. cross section, in mb/msr */ TCanvas* c_TWOFNR = new TCanvas("c_TWOFNR","c_TWOFNR",1000,1000); c_TWOFNR->SetLogy(); TGraph* TheoryDiffCross = TWOFNR(means[indexE], J0, Spin, nodes, spdf, angmom); - TheoryDiffCross->GetYaxis()->SetTitle("d#sigma/d#Theta [mb/msr]"); //msr set in func above + TheoryDiffCross->GetYaxis()->SetTitle("d#sigma/d#Omega [mb/msr]"); //msr set in func above TheoryDiffCross->GetXaxis()->SetTitle("ThetaLab [deg]"); TheoryDiffCross->Draw(); /* Convert AoSA into Differential Cross Section */ //cout << " SCALING BY NORMALIZATION = " << ElasticNorm << endl; - //gAoSA->GetYaxis()->SetTitle("d#sigma/d#Theta [mb/msr]"); + //gAoSA->GetYaxis()->SetTitle("d#sigma/d#Omega [mb/msr]"); /* Scaled and compared on same plot */ @@ -211,6 +223,32 @@ vector<vector<double>> GetExpDiffCross(double Energy){ vector<vector<double>> OnePeak_AllGates; int numbins = 10; double x[numbins], y[numbins]; + TList* list = new TList(); + + /* Determine scaling factor for PhaseSpace */ + double trackScale = 0.0; + if(scaleTogether){ + TH1F* baseEx = PullThetaLabHist(0,105.,5.); + TH1F* basePS = PullPhaseSpaceHist(0,105.,5.); + for(int i=1; i<numbins;i++){ + TH1F* addEx = PullThetaLabHist(i,105.,5.); baseEx->Add(addEx,1.); + TH1F* addPS = PullPhaseSpaceHist(i,105.,5.); basePS->Add(addPS,1.); + } + basePS->Scale(0.01); + trackScale = 0.01; + int numbinsScale = baseEx->GetNbinsX(); + for(int b=0; b<numbinsScale; b++){ + while(basePS->GetBinContent(b) > baseEx->GetBinContent(b)){ + basePS->Scale(0.99999); + trackScale *= 0.99999; + } + } + baseEx->Add(basePS,-1.); + baseEx->SetName("AllAngles"); + list->Add(baseEx); + cout << " !!!!!!!!!!!!!!!FINAL SCALING = " << trackScale << endl; + } + for(int i=0; i<numbins;i++){ double bin = 5.; double min = 105. + (i*bin); @@ -221,12 +259,41 @@ vector<vector<double>> GetExpDiffCross(double Energy){ /* Retrieve theta-gated Ex TH1F from file GateThetaLabHistograms.root */ /* To change angle gates, run GateThetaLab_MultiWrite() */ TH1F* gate = PullThetaLabHist(i,105.,5.); + TH1F* pspace = PullPhaseSpaceHist(i,105.,5.); + + /* Scale Phase Space... */ + /* ... for all angles together */ + if(scaleTogether){ + gate->Add(pspace,-trackScale); + } + /* ... or seperately for each angular bin */ + else { + if(pspace->Integral() > 50.){ // Non-garbage histogram + pspace->Scale(0.01); + int numbins = gate->GetNbinsX(); + for(int b=0; b<numbins; b++){ + if(loud){cout << " FROM " << pspace->GetBinContent(b) << + " > " << gate->GetBinContent(b); + } + while(pspace->GetBinContent(b) > gate->GetBinContent(b)){ + pspace->Scale(0.9999); + } + if(loud){cout << " TO " << pspace->GetBinContent(b) << + " > " << gate->GetBinContent(b) << endl; + } + } + gate->Add(pspace,-1); + } + } /* Retrieve array containing all fits, for one angle gate. * * Specific peak of interest selected from the vector by * * global variable indexE */ AllPeaks_OneGate = FitKnownPeaks_RtrnArry(gate); + /* Write PS-subtracted spectrum to list */ + list->Add(gate); + /* Check correct OneGate vector is selected */ cout << "area of " << means[indexE] << " = " << AllPeaks_OneGate[indexE][1] @@ -240,17 +307,37 @@ vector<vector<double>> GetExpDiffCross(double Energy){ /* Push relevant OneGate vector to end of AllGates vector */ OnePeak_AllGates.push_back(AllPeaks_OneGate[indexE]); } + + /* Write PS-subtracted spectrum to file */ + TFile* outfile = new TFile("GateThetaLab_ExMinusGatePhaseSpace.root","RECREATE"); + list->Write("GateThetaLab_ExMinusPhaseSpace",TObject::kSingleKey); + return OnePeak_AllGates; } //////////////////////////////////////////////////////////////////////////////// TH1F* PullThetaLabHist(int i, double minTheta, double gatesize){ - TFile* file = new TFile("GateThetaLabHistograms.root","READ"); + TFile* file = new TFile("GateThetaLabHistograms_ReadMe.root","READ"); string histname = "cThetaLabGate_" - + to_string(minTheta+(i*gatesize)) + "-" - + to_string(minTheta+((i+1)*gatesize)); + + to_string((int) (minTheta+(i*gatesize))) + "-" + + to_string((int) (minTheta+((i+1)*gatesize))); + cout << "Loading " << histname << endl; TList *list = (TList*)file->Get("GateThetaLabHistograms"); TH1F* hist = (TH1F*)list->FindObject(histname.c_str()); +// file->Close(); + return hist; +} + +//////////////////////////////////////////////////////////////////////////////// +TH1F* PullPhaseSpaceHist(int i, double minTheta, double gatesize){ + TFile* file = new TFile("GatePhaseSpaceThetaLabHistograms_ReadMe.root","READ"); + string histname = "cPSpaceThetaLabGate_" + + to_string((int) (minTheta+(i*gatesize))) + "-" + + to_string((int) (minTheta+((i+1)*gatesize))); + cout << "Loading " << histname << endl; + TList *list = (TList*)file->Get("GatePhaseSpaceThetaLabHistograms"); + TH1F* hist = (TH1F*)list->FindObject(histname.c_str()); + file->Close(); return hist; } @@ -389,7 +476,7 @@ TGraph* TWOFNR(double E, double J0, double J, double n, double l, double j){ } //////////////////////////////////////////////////////////////////////////////// -double Chi2(TGraph* theory , TGraphErrors* exper){ +double Chi2(TGraph* theory, TGraphErrors* exper){ double Chi2 = 0 ; double chi; //for(int i = 1 ; i < exper->GetN() ; i++){ @@ -403,7 +490,6 @@ double Chi2(TGraph* theory , TGraphErrors* exper){ return Chi2; } - //////////////////////////////////////////////////////////////////////////////// double ToMininize(const double* parameter){ static int f = 0 ; diff --git a/Projects/e793s/macro/DrawPlots.C b/Projects/e793s/macro/DrawPlots.C index 290f6a48b998a9f389e95aea98ecff8d2392b94a..a7d5258fd3971e624b963a07a451ed37e3ea7d93 100755 --- a/Projects/e793s/macro/DrawPlots.C +++ b/Projects/e793s/macro/DrawPlots.C @@ -4,6 +4,7 @@ #include "CS2.h" #include "ThreeBodyBreakup.h" +#include "ThreeBodyBreakup_FitPhaseSpace.h" /* USE THIS SPACE TO TEST NEW FEATURES */ void thickness(){ @@ -523,10 +524,12 @@ void DrawPlots(){ cout << "========== AVAILABLE FUNCTIONS ===========" << endl; cout << " 2D Matrices " << endl; cout << "\t- Draw_2DParticleGamma() "<< endl; + cout << "\t- Load_2DParticleGamma() "<< endl; cout << "\t- Draw_2DGammaGamma() "<< endl; cout << ""<< endl; cout << " Ungated histograms " << endl; cout << "\t- Draw_1DParticle() "<< endl; + cout << "\t- Load_1DParticle() "<< endl; cout << "\t- Draw_1DParticle_MUST2() "<< endl; cout << "\t- Draw_1DGamma() "<< endl; cout << "\t- Draw_1DGamma_MG() "<< endl; diff --git a/Projects/e793s/macro/DrawPlots.h b/Projects/e793s/macro/DrawPlots.h index 55122547f19667b1ee35a2117aa8cd710b569ea2..3e7ee21499cb88287dc4e92b08d8007981bc4543 100755 --- a/Projects/e793s/macro/DrawPlots.h +++ b/Projects/e793s/macro/DrawPlots.h @@ -40,22 +40,13 @@ TChain* Chain(std::string TreeName, std::vector<std::string>& file, bool EventLi void LoadChainNP(){ vector<string> files; - //files.push_back("../../../Outputs/Analysis/OriginalValues_ptI.root"); - //files.push_back("../../../Outputs/Analysis/OriginalValues_ptII.root"); - //files.push_back("../../../Outputs/Analysis/OriginalValues_ptIII.root"); - - //files.push_back("../../../Outputs/Analysis/47K_Full_07Sep_PartI.root"); - //files.push_back("../../../Outputs/Analysis/47K_Full_07Sep_PartII.root"); - - //files.push_back("../../../Outputs/Analysis/47Kdp_11Oct_PartI.root"); - //files.push_back("../../../Outputs/Analysis/47Kdp_11Oct_PartII.root"); - - //files.push_back("../../../Outputs/Analysis/47Kdp_13Oct_wildTry_PartI.root"); - //files.push_back("../../../Outputs/Analysis/47Kdp_13Oct_wildTry_PartII.root"); - files.push_back("../../../Outputs/Analysis/47Kdp_08Nov_PartI.root"); files.push_back("../../../Outputs/Analysis/47Kdp_08Nov_PartII.root"); +// files.push_back("../../../Outputs/Analysis/47Kdp_17Feb_AGATA_RotateBYpi.root"); + +// files.push_back("../../../Outputs/Analysis/47Kdp_19Feb_AGATA_RotateBXYZ.root"); + chain = Chain("PhysicsTree",files,true); } @@ -183,9 +174,16 @@ void Draw_1DGamma_MM(){ Eg->GetYaxis()->SetTitle("Counts / 0.001 MeV"); } +void Load_1DParticle(){ + TH1F *hEx = new TH1F("hEx","Loaded 1D Particle Spectrum",200,-1,9); + TFile *file = new TFile("LoadHistograms/Load_1DParticle.root","READ"); + hEx = (TH1F*)file->Get("Ep"); + hEx->Draw(); +} + void Draw_1DParticle(){ TCanvas *cEx = new TCanvas("cEx","cEx",1000,1000); - chain->Draw("Ex>>Ep(160,-1,7)", + chain->Draw("Ex>>Ep(200,-1,9)", "abs(T_MUGAST_VAMOS-2777)<600 && Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8", ""); TH1F* Ep = (TH1F*) gDirectory->Get("Ep"); @@ -198,7 +196,7 @@ void Draw_1DParticle(){ void Draw_1DParticleMUST2(){ TCanvas *cEx = new TCanvas("cEx","cEx",1000,1000); - chain->Draw("Ex>>Ep(160,-1,7)", + chain->Draw("Ex>>Ep(200,-1,9)", "abs(T_MUGAST_VAMOS-2777)<600 && MUST2.TelescopeNumber>0 && MUST2.TelescopeNumber<4", ""); TH1F* Ep = (TH1F*) gDirectory->Get("Ep"); @@ -207,9 +205,16 @@ void Draw_1DParticleMUST2(){ Ep->GetYaxis()->SetTitle("Counts / 0.05 MeV"); } +void Load_2DParticleGamma(){ + TH2F *hExEg = new TH2F("hExEg","Loaded 2D Particle-Gamma",200,-1,9,2500,0,5); + TFile *file = new TFile("LoadHistograms/Load_2DParticleGamma.root","READ"); + hExEg = (TH2F*)file->Get("ExEg"); + hExEg->Draw(); +} + void Draw_2DParticleGamma(){ TCanvas *cExEg = new TCanvas("cExEg","cExEg",1000,1000); - chain->Draw("AddBack_EDC:Ex>>ExEg(140,-1,7,2500,0,5)", + chain->Draw("AddBack_EDC:Ex>>ExEg(200,-1,9,2500,0,5)", "abs(T_MUGAST_VAMOS-2777)<600 && Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8", "colz"); TH1F* ExEg = (TH1F*) gDirectory->Get("ExEg"); @@ -287,7 +292,7 @@ cout << " NO MG3 IN THIS ONE!!!!!!!!!!!!!!!!!!!!!!!!!" << endl; string title = to_string(gamma-width)+" < Eg < "+to_string(gamma+width); string ytitle = "Counts / " + to_string(binsize) + " MeV"; - string draw = "Ex>>ExGate(" + to_string(8.0/binsize) + ",-1,7)"; + string draw = "Ex>>ExGate(" + to_string(10.0/binsize) + ",-1,9)"; TCanvas *cEx_Gate = new TCanvas("cEx_Gate","cEx_Gate",1000,1000); //chain->Draw("Ex>>ExGate(60,-1,5)",gating.c_str(),"colz"); @@ -314,7 +319,7 @@ void GateGamma_SeeParticle_WithBG(double gamma, double width, double bg){ + " BG: "+to_string(bg-width)+" to "+to_string(bg+width)+"."; TCanvas *cEx_Gate = new TCanvas("cEx_Gate","cEx_Gate",1000,1000); - chain->Draw("Ex>>ExGate(80,-1,7)",gating.c_str(),""); + chain->Draw("Ex>>ExGate(100,-1,9)",gating.c_str(),""); //chain->Draw("Ex>>ExGate(120,-1,5)",gating.c_str(),""); TH1F* ExGate = (TH1F*) gDirectory->Get("ExGate"); ExGate->GetXaxis()->SetTitle("Ex [MeV]"); @@ -325,7 +330,7 @@ void GateGamma_SeeParticle_WithBG(double gamma, double width, double bg){ ExGate->SetFillStyle(3154); ExGate->SetTitle(title.c_str()); - chain->Draw("Ex>>ExBG(80,-1,7)",bggate.c_str(),"same"); + chain->Draw("Ex>>ExBG(100,-1,9)",bggate.c_str(),"same"); //chain->Draw("Ex>>ExBG(120,-1,5)",bggate.c_str(),"same"); TH1F* ExBG = (TH1F*) gDirectory->Get("ExBG"); ExBG->SetLineColor(kRed); @@ -351,7 +356,7 @@ void GateGamma_SeeParticle_WithBG(double gamma, double width, double bg, double + " BG: "+to_string(bg-width)+" to "+to_string(bg+width)+"."; TCanvas *cEx_Gate = new TCanvas("cEx_Gate","cEx_Gate",1000,1000); - chain->Draw("Ex>>ExGate(80,-1,7)",gating.c_str(),""); + chain->Draw("Ex>>ExGate(100,-1,9)",gating.c_str(),""); //chain->Draw("Ex>>ExGate(120,-1,5)",gating.c_str(),""); TH1F* ExGate = (TH1F*) gDirectory->Get("ExGate"); ExGate->GetXaxis()->SetTitle("Ex [MeV]"); @@ -362,7 +367,7 @@ void GateGamma_SeeParticle_WithBG(double gamma, double width, double bg, double ExGate->SetFillStyle(3154); ExGate->SetTitle(title.c_str()); - chain->Draw("Ex>>ExBG(80,-1,7)",bggate.c_str(),"same"); + chain->Draw("Ex>>ExBG(100,-1,9)",bggate.c_str(),"same"); //chain->Draw("Ex>>ExBG(120,-1,5)",bggate.c_str(),"same"); TH1F* ExBG = (TH1F*) gDirectory->Get("ExBG"); ExBG->Scale(ratio); @@ -621,7 +626,7 @@ void CompareSimExp(){ TCanvas *cSimExp = new TCanvas("cSimExp","cSimExp",1000,1000); gStyle->SetOptStat(0); - chain->Draw("Ex>>hexp(70,-1,6)","abs(T_MUGAST_VAMOS-2777)<600",""); + chain->Draw("Ex>>hexp(100,-1,9)","abs(T_MUGAST_VAMOS-2777)<600",""); TH1F* hexp = (TH1F*) gDirectory->Get("hexp"); hexp->SetTitle("Comparing Simulation to Experiment"); hexp->GetXaxis()->SetTitle("Ex [MeV]"); @@ -632,7 +637,7 @@ void CompareSimExp(){ //TFile* simfile = new TFile("../../../Outputs/Analysis/SimTest_Jun22_TWOFNR_p32.root", "READ"); TTree* simtree = (TTree*) simfile->FindObjectAny("PhysicsTree"); - simtree->Draw("Ex>>hsimMGp32(70,-1,6)", + simtree->Draw("Ex>>hsimMGp32(100,-1,9)", "Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8","same"); TH1F* hsimMGp32 = (TH1F*) gDirectory->Get("hsimMGp32"); hsimMGp32->SetLineColor(kBlue); @@ -890,7 +895,7 @@ void ExPhiLab_ForPoster(){ void ExThetaLab(){ TCanvas *diagnoseTheta = new TCanvas("diagnoseTheta","diagnoseTheta",1000,1000); chain->Draw( - "Ex:ThetaLab>>thetaHist(60,100,160,120,-1,5)", + "Ex:ThetaLab>>thetaHist(60,100,160,100,-1,9)", "abs(T_MUGAST_VAMOS-2777)<600 && Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8", "colz"); TH1F* thetaHist = (TH1F*) gDirectory->Get("thetaHist"); @@ -939,7 +944,7 @@ void ExThetaLab(double gamma, double width){ string gating = "abs(T_MUGAST_VAMOS-2777)<600 && Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8 && abs(AddBack_EDC-" + to_string(gamma) + ") < " + to_string(width); - chain->Draw("Ex:ThetaLab>>thetaHist(60,100,160,60,-1,5)", gating.c_str(), "colz"); + chain->Draw("Ex:ThetaLab>>thetaHist(60,100,160,100,-1,9)", gating.c_str(), "colz"); TH1F* thetaHist = (TH1F*) gDirectory->Get("thetaHist"); thetaHist->GetXaxis()->SetTitle("Theta (degrees)"); thetaHist->GetYaxis()->SetTitle("Ex [MeV]"); @@ -1181,7 +1186,7 @@ void GateThetaCM(double minTheta, double maxTheta, double binsize){ string title = to_string(minTheta)+" < ThetaCM < "+to_string(maxTheta); string ytitle = "Counts / " + to_string(binsize) + " MeV"; - string draw = "Ex>>Ex_ThetaCMGate(" + to_string(8.0/binsize) + ",-1,7)"; + string draw = "Ex>>Ex_ThetaCMGate(" + to_string(10.0/binsize) + ",-1,9)"; TCanvas *cEx_ThetaCMGate = new TCanvas("cEx_ThetaCMGate","cEx_ThetaCMGate",1000,1000); chain->Draw(draw.c_str(),gating.c_str(),"colz"); @@ -1201,7 +1206,7 @@ void GateThetaLab(double minTheta, double maxTheta, double binsize){ string title = to_string(minTheta)+" < ThetaLab < "+to_string(maxTheta); string ytitle = "Counts / " + to_string(binsize) + " MeV"; - string draw = "Ex>>Ex_ThetaLabGate(" + to_string(8.0/binsize) + ",-1,7)"; + string draw = "Ex>>Ex_ThetaLabGate(" + to_string(10.0/binsize) + ",-1,9)"; TCanvas *cEx_ThetaLabGate = new TCanvas("cEx_ThetaLabGate","cEx_ThetaLabGate",1000,1000); chain->Draw(draw.c_str(),gating.c_str(),"colz"); @@ -1221,19 +1226,20 @@ void GateThetaLab_MultiWrite(double startTheta, double finishTheta, int numGates for (int i=0; i<numGates; i++){ double minTheta = startTheta + (i * gatesize); - string title = to_string(minTheta)+" < ThetaLab < "+to_string(minTheta+gatesize); + string title = to_string((int) minTheta)+" < ThetaLab < "+to_string((int) (minTheta+gatesize)); string gating = core + to_string(minTheta) + " && ThetaLab < " + to_string(minTheta+gatesize); - string histname = "cThetaLabGate_" + to_string(minTheta) + "-" + to_string(minTheta+gatesize); - string draw = "Ex>>" + histname + "(" + to_string(8.0/binsize) + ",-1,7)"; + string histname = "cThetaLabGate_" + to_string((int) minTheta) + "-" + to_string((int) (minTheta+gatesize)); + string draw = "Ex>>" + histname + "(" + to_string(10.0/binsize) + ",-1,9)"; TCanvas *cEx_ThetaLabGate = new TCanvas(histname.c_str(),histname.c_str(),1000,1000); chain->Draw(draw.c_str(),gating.c_str(),"colz"); TH1F* Ex_ThetaLabGate = (TH1F*) gDirectory->Get(histname.c_str()); Ex_ThetaLabGate->GetXaxis()->SetTitle("Ex [MeV]"); Ex_ThetaLabGate->GetYaxis()->SetTitle(ytitle.c_str()); + Ex_ThetaLabGate->Sumw2(); Ex_ThetaLabGate->SetTitle(title.c_str()); list->Add(Ex_ThetaLabGate); delete cEx_ThetaLabGate; @@ -1243,3 +1249,39 @@ void GateThetaLab_MultiWrite(double startTheta, double finishTheta, int numGates list->Write("GateThetaLabHistograms",TObject::kSingleKey); file->ls(); } + +void GatePhaseSpaceByThetaLab_MultiWrite(double startTheta, double finishTheta, int numGates, double binsize){ + string core = "EventWeight*(Mugast.TelescopeNumber>0 && Mugast.TelescopeNumber<8 && ThetaLab > "; + string ytitle = "Counts / " + to_string(binsize) + " MeV"; + double gatesize = (finishTheta-startTheta)/numGates; + TList* list = new TList(); + + TFile* psfile = new TFile("../../../Outputs/Analysis/Sim_02Mar_47Kdp_PhaseSpace.root","READ"); + TTree* PSTree = (TTree*) psfile->FindObjectAny("PhysicsTree"); + + for (int i=0; i<numGates; i++){ + double minTheta = startTheta + (i * gatesize); + string title = to_string((int) minTheta)+" < ThetaLab < "+to_string((int) (minTheta+gatesize)); + string gating = core + + to_string(minTheta) + + " && ThetaLab < " + + to_string(minTheta+gatesize) + + ")"; + string histname = "cPSpaceThetaLabGate_" + to_string((int) minTheta) + "-" + to_string((int) (minTheta+gatesize)); + string draw = "Ex>>" + histname + "(" + to_string(10.0/binsize) + ",-1,9)"; + + TCanvas *cPSpace_ThetaLabGate = new TCanvas(histname.c_str(),histname.c_str(),1000,1000); + PSTree->Draw(draw.c_str(),gating.c_str(),"colz"); + TH1F* PSpace_ThetaLabGate = (TH1F*) gDirectory->Get(histname.c_str()); + PSpace_ThetaLabGate->GetXaxis()->SetTitle("Ex [MeV]"); + PSpace_ThetaLabGate->GetYaxis()->SetTitle(ytitle.c_str()); + PSpace_ThetaLabGate->Sumw2(); + PSpace_ThetaLabGate->SetTitle(title.c_str()); + list->Add(PSpace_ThetaLabGate); + delete cPSpace_ThetaLabGate; + } + + TFile* file = new TFile("GatePhaseSpaceThetaLabHistograms.root","RECREATE"); + list->Write("GatePhaseSpaceThetaLabHistograms",TObject::kSingleKey); + file->ls(); +} diff --git a/Projects/e793s/macro/KnownPeakFitter.h b/Projects/e793s/macro/KnownPeakFitter.h index c50f71d2cb5ff7300ff804477ab392d33dd0a9b3..c70c4d6d06a68935caa978f520bb7eca77588790 100644 --- a/Projects/e793s/macro/KnownPeakFitter.h +++ b/Projects/e793s/macro/KnownPeakFitter.h @@ -3,23 +3,24 @@ #include <cmath> #include "stdlib.h" - const int numPeaks = 14; - array<double,14> means = { 0.000, - 0.143, - 0.279, - 0.728, - 0.968, - 1.410, - 1.981, - 2.410, - 2.910, - 3.2, - 3.605, - 3.792, - 4.1, - 4.4 +const int numPeaks = 15; +array<double,numPeaks> means = { 0.000, + 0.143, + 0.279, + 0.728, + 0.968, + 1.410, + 1.981, + 2.410, + 2.910, + 3.2, + 3.605, + 3.792, + 4.1, + 4.4, + 5.24 }; - +/* Double_t f_bg(Double_t *x, Double_t *par){ // Flat bg [0] + semicircle [1]*sqrt(6.183^2 - (x-10.829)^2) Float_t xx = x[0]; @@ -32,72 +33,58 @@ Double_t f_bg(Double_t *x, Double_t *par){ } Double_t f_peak(Double_t *x, Double_t *par){ - Float_t xx = x[0]; - Double_t f = (par[2]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[1])/par[0],2)); + float xx = x[0]; + double f = (par[2]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[1])/par[0],2)); return f; } - -Double_t f_full(Double_t *x, Double_t *par){ - Float_t xx = x[0]; - Double_t f; - Double_t peaks = (par[2]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[1])/par[0],2)) - + (par[4]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[3])/par[0],2)) - + (par[6]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[5])/par[0],2)) - + (par[8]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[7])/par[0],2)) - + (par[10]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[9])/par[0],2)) - + (par[12]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[11])/par[0],2)) - + (par[14]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[13])/par[0],2)) - + (par[16]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[15])/par[0],2)) - + (par[18]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[17])/par[0],2)) - + (par[20]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[19])/par[0],2)) - + (par[22]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[21])/par[0],2)) - + (par[24]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[23])/par[0],2)) - + (par[26]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[25])/par[0],2)) - + (par[28]/(par[0]*sqrt(2*pi)))*exp(-0.5*pow((xx-par[27])/par[0],2)); - - Double_t bg; - Double_t a = TMath::Power(6.183,2); - Double_t b = TMath::Power(xx-10.829,2); - if(a > b){ bg = par[29] + (par[30]*TMath::Sqrt(a-b)); } - else{ bg = par[29]; } - - f = peaks + bg; - return f; +*/ + +Double_t f_full(Double_t *x, Double_t *par) { + float xx = x[0]; + double result, norm; + // Flat background + result = par[0]; + // Add N peaks + for(int pk=0; pk<numPeaks; pk++){ + result += (par[3+(pk*3)]/(par[1+(pk*3)]*sqrt(2*pi))) + * exp(-0.5*pow((xx-par[2+(pk*3)])/par[1+(pk*3)],2)); + } + return result; } vector<vector<double>> FitKnownPeaks_RtrnArry(TH1F* hist){ - double minFit=-1.0, maxFit=5.0; + double minFit=-1.0, maxFit=8.0; double binWidth = hist->GetXaxis()->GetBinWidth(3); double sigma = 0.14; - string nameBase = "Peak "; - string function = "([2]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[1])/[0],2))"; - - //Assign peak centroids -// const int numPeaks = 14; -// array<double,14> means = { 0.000, -// 0.143, -// 0.279, -// 0.728, -// 0.968, -// 1.410, -// 1.981, -// 2.410, -// 2.910, -// 3.2, -// 3.605, -// 3.792, -// 4.1, -// 4.4 -// }; + hist->Sumw2(); + + /* Construct flat BG to subtract */ + /** + cout << " REMOVING FLAT BG OF 36 COUNTS!!!!" << endl; + cout << " REMOVING FLAT BG OF 36 COUNTS!!!!" << endl; + cout << " REMOVING FLAT BG OF 36 COUNTS!!!!" << endl; + double ConstBG = 36.0; double ErrBG = 1.0; + int xbins = hist->GetXaxis()->GetNbins(); + double xmin = hist->GetXaxis()->GetXmin(); + double xmax = hist->GetXaxis()->GetXmax(); + TH1F *FlatBG = new TH1F("FlatBG","FlatBG", xbins, xmin, xmax); + for(int i=0; i<xbins;i++){ + FlatBG->SetBinContent(i,ConstBG); + FlatBG->SetBinError(i,ErrBG); + } + hist->Add(FlatBG,-1); + **/ //Build individual peak fit functions + string nameBase = "Peak "; + string function = "([2]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[1])/[0],2))"; TF1 **allPeaks = new TF1*[numPeaks]; for(int i=0; i<numPeaks; i++) { string nameHere = nameBase; nameHere +=to_string(i); - allPeaks[i] = new TF1(nameHere.c_str(), function.c_str(), -1, 5); + allPeaks[i] = new TF1(nameHere.c_str(), function.c_str(), minFit, maxFit); //allPeaks[i] = new TF1(nameHere.c_str(), f_peak, -1, 5); allPeaks[i]->SetLineColor(kBlack); allPeaks[i]->SetLineStyle(7); @@ -110,71 +97,24 @@ vector<vector<double>> FitKnownPeaks_RtrnArry(TH1F* hist){ bg->SetLineStyle(9); bg->SetParNames("Background"); - //Build IMPROVED background function - //TF1 *bg = new TF1 ("bg",f_bg, minFit, maxFit); - //bg->SetLineColor(kGreen); - //bg->SetLineStyle(9); - //bg->SetParNames("Background","BreakupScale"); - - //Build total function - TF1 *full = new TF1("fitAllPeaks", - " ([2]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[1])/[0],2)) " - "+ ([4]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[3])/[0],2)) " - "+ ([6]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[5])/[0],2)) " - "+ ([8]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[7])/[0],2)) " - "+ ([10]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[9])/[0],2)) " - "+ ([12]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[11])/[0],2)) " - "+ ([14]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[13])/[0],2)) " - "+ ([16]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[15])/[0],2)) " - "+ ([18]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[17])/[0],2)) " - "+ ([20]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[19])/[0],2)) " - "+ ([22]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[21])/[0],2)) " - "+ ([24]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[23])/[0],2)) " - "+ ([26]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[25])/[0],2)) " - "+ ([28]/([0]*sqrt(2*pi)))*exp(-0.5*pow((x-[27])/[0],2)) " - "+ [29]" , minFit, maxFit); - full->SetLineColor(kRed); - //Build IMPROVED total function - //TF1 *full = new TF1("fitAllPeaks", f_full, minFit, maxFit); - //full->SetLineColor(kRed); - - - //Annoyingly long parameter name assignment - //(SetParNames only works for up to 11 variables) - full->SetParName(0,"Sigma"); - full->SetParName(1,"Mean 01"); full->SetParName(2,"Area*BinWidth 01"); - full->SetParName(3,"Mean 02"); full->SetParName(4,"Area*BinWidth 02"); - full->SetParName(5,"Mean 03"); full->SetParName(6,"Area*BinWidth 03"); - full->SetParName(7,"Mean 04"); full->SetParName(8,"Area*BinWidth 04"); - full->SetParName(9,"Mean 05"); full->SetParName(10,"Area*BinWidth 05"); - full->SetParName(11,"Mean 06"); full->SetParName(12,"Area*BinWidth 06"); - full->SetParName(13,"Mean 07"); full->SetParName(14,"Area*BinWidth 07"); - full->SetParName(15,"Mean 08"); full->SetParName(16,"Area*BinWidth 08"); - full->SetParName(17,"Mean 09"); full->SetParName(18,"Area*BinWidth 09"); - full->SetParName(19,"Mean 10"); full->SetParName(20,"Area*BinWidth 10"); - full->SetParName(21,"Mean 11"); full->SetParName(22,"Area*BinWidth 11"); - full->SetParName(23,"Mean 12"); full->SetParName(24,"Area*BinWidth 12"); - full->SetParName(25,"Mean 13"); full->SetParName(26,"Area*BinWidth 13"); - full->SetParName(27,"Mean 14"); full->SetParName(28,"Area*BinWidth 14"); - full->SetParName(29,"Background"); - full->SetParName(30,"BreakupScale"); - - //Fix sigma & centroid, only allow area to vary - const int numParams = (numPeaks*2)+2; - full->FixParameter(0, sigma); + TF1 *full = new TF1("fitAllPeaks", f_full, minFit, maxFit, (int) 1+(3*numPeaks)); + full->SetLineColor(kRed); + const int numParams = (numPeaks*3)+1; for(int i=0; i<numPeaks; i++) { - full->FixParameter(2*i+1,means.at(i)); - full->SetParameter(2*i+2,1.0); - full->SetParLimits(2*i+2,0.0,1e5); + full->FixParameter((i*3)+1,sigma); + full->FixParameter((i*3)+2,means.at(i)); + full->SetParameter((i*3)+3,1e1); + full->SetParLimits((i*3)+3,0.0,1e5); } + //full->SetParameter(0,30.); + //full->SetParLimits(0,0.,40.); + full->FixParameter(0,0.); - //TESTING!!!!! - //full->FixParameter(6,0.); - - //full->FixParameter(numParams-1,0.0); - full->SetParameter(numParams-1,1.0); - full->SetParLimits(numParams-1,0.0,1e1); + // Specific limits + // Set max 279 counts to 100 + full->SetParLimits(9,0.0,1e2); // Doesnt work??? + allPeaks[14]->SetLineColor(kOrange); //Fit full function to histogram hist->Fit(full, "RQ", "", minFit, maxFit); @@ -184,9 +124,9 @@ vector<vector<double>> FitKnownPeaks_RtrnArry(TH1F* hist){ const Double_t* finalPar = full->GetParameters(); const Double_t* finalErr = full->GetParErrors(); for (int i=0; i<numPeaks; i++){ - allPeaks[i]->SetParameters(sigma, means.at(i), finalPar[2*i+2]); + allPeaks[i]->SetParameters(sigma, means.at(i), finalPar[3+(i*3)]); } - bg->SetParameter(0,finalPar[numParams-1]); + bg->SetParameter(0,finalPar[0]); bg->Draw("SAME"); full->Draw("SAME"); @@ -207,22 +147,24 @@ vector<vector<double>> FitKnownPeaks_RtrnArry(TH1F* hist){ vector<vector<double>> allpeaks; for(int i=0; i<numPeaks; i++){ - double A = finalPar[2*i+2]/binWidth; - double deltaA = A * (finalErr[2*i+2]/finalPar[2*i+2]); + double A = finalPar[(i*3)+3]/binWidth; + double deltaA = A * (finalErr[(i*3)+3]/finalPar[(i*3)+3]); cout << fixed << setprecision(3) << " #" << i << " " - << finalPar[2*i+1] << "\t" << setprecision(0) + << finalPar[(i*3)+2] << "\t" << setprecision(0) << A << "\t+- " << deltaA << setprecision(3) << endl; vector<double> onepeak; //energy, area and error for one peak - onepeak.push_back(finalPar[2*i+1]); + onepeak.push_back(finalPar[(i*3)+2]); onepeak.push_back(A); onepeak.push_back(deltaA); allpeaks.push_back(onepeak); } + cout << " BG " << full->GetParameter(0) + << " +- " << full->GetParError(0) << endl; return allpeaks; } diff --git a/Projects/e793s/macro/ThreeBodyBreakup.h b/Projects/e793s/macro/ThreeBodyBreakup.h index 5bdbe366e5519a29bc968ee0aecbc199d02dda8c..3df02dc9cc8c2d2b1211a0a78ac0c01cafa63e61 100644 --- a/Projects/e793s/macro/ThreeBodyBreakup.h +++ b/Projects/e793s/macro/ThreeBodyBreakup.h @@ -8,8 +8,12 @@ Double_t f_semi(Double_t *x, Double_t *par){ return f; } - void ThreeBodyBreakup(){ + TFile *fweight = new TFile("../../../Outputs/Simulation/EventWeight_25Feb.root"); + TCanvas *cweight = (TCanvas*)fweight->Get("c1"); + TH1F *hweight = (TH1F*)cweight->GetPrimitive("hEventWeight"); +// hweight->Draw(); + TGenPhaseSpace PS1p; //47K(d,p)47K+p+n @@ -42,10 +46,11 @@ void ThreeBodyBreakup(){ double ex=R.ReconstructRelativistic(ELab,theta); //cout << ELab << " " << ex << endl; Ex1p->Fill(ex,weight); - } + } TCanvas* c_Ex1p = new TCanvas("c_Ex1p","c_Ex1p",1000,500); Ex1p->Draw(); + Ex1p->Multiply(hweight); // TCanvas* c_semi = new TCanvas("c_semi","c_semi",1000,500); TF1 *f1 = new TF1("f_semi",f_semi,-10,40,3);