mirror of
https://github.com/gwm17/Mask.git
synced 2024-11-22 10:18:50 -05:00
Fix some bugs in plotter, clean up a few debug statements.
This commit is contained in:
parent
63ddbab468
commit
29a136a14b
|
@ -110,6 +110,7 @@ void DetectorApp::Run()
|
||||||
nucleus.detectedKE = result.energy_deposited;
|
nucleus.detectedKE = result.energy_deposited;
|
||||||
nucleus.detectedTheta = result.direction.Theta();
|
nucleus.detectedTheta = result.direction.Theta();
|
||||||
nucleus.detectedPhi = result.direction.Phi();
|
nucleus.detectedPhi = result.direction.Phi();
|
||||||
|
nucleus.detectedPos = result.direction;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
m_fileWriter.PushData(data);
|
m_fileWriter.PushData(data);
|
||||||
|
|
|
@ -39,7 +39,7 @@ private:
|
||||||
static constexpr double s_detectorThickness = 500 * 1e-4 * 2.3926 * 1e6; // ug/cm^2 (500 um thick * density)
|
static constexpr double s_detectorThickness = 500 * 1e-4 * 2.3926 * 1e6; // ug/cm^2 (500 um thick * density)
|
||||||
static constexpr double s_degraderThickness = 70.0 * 1.0e-4 * 16.69 * 1e6; //tantalum degrader (70 um thick)
|
static constexpr double s_degraderThickness = 70.0 * 1.0e-4 * 16.69 * 1e6; //tantalum degrader (70 um thick)
|
||||||
|
|
||||||
static constexpr double s_energyThreshold = 0.2; //in MeV
|
static constexpr double s_energyThreshold = 0.25; //in MeV
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include "Math/Vector4D.h"
|
#include "Math/Vector4D.h"
|
||||||
|
#include "Math/Point3D.h"
|
||||||
#include "MassLookup.h"
|
#include "MassLookup.h"
|
||||||
|
|
||||||
namespace Mask {
|
namespace Mask {
|
||||||
|
@ -48,6 +49,8 @@ namespace Mask {
|
||||||
double detectedKE = 0.0;
|
double detectedKE = 0.0;
|
||||||
double detectedTheta = 0.0;
|
double detectedTheta = 0.0;
|
||||||
double detectedPhi = 0.0;
|
double detectedPhi = 0.0;
|
||||||
|
|
||||||
|
ROOT::Math::XYZPoint detectedPos = ROOT::Math::XYZPoint(0., 0., 0.);
|
||||||
};
|
};
|
||||||
|
|
||||||
Nucleus CreateNucleus(uint32_t z, uint32_t a);
|
Nucleus CreateNucleus(uint32_t z, uint32_t a);
|
||||||
|
|
|
@ -229,7 +229,6 @@ namespace Mask {
|
||||||
m_residual->vec4 = m_target->vec4 - m_ejectile->vec4;
|
m_residual->vec4 = m_target->vec4 - m_ejectile->vec4;
|
||||||
|
|
||||||
//energy loss for the *light* break up nucleus
|
//energy loss for the *light* break up nucleus
|
||||||
double keorig = m_ejectile->GetKE();
|
|
||||||
double ejectKE = m_ejectile->GetKE() -
|
double ejectKE = m_ejectile->GetKE() -
|
||||||
m_layeredTarget->GetEjectileEnergyLoss(m_ejectile->Z, m_ejectile->A, m_ejectile->GetKE(), m_rxnLayer, m_ejectile->vec4.Theta(), m_rxnDepth);
|
m_layeredTarget->GetEjectileEnergyLoss(m_ejectile->Z, m_ejectile->A, m_ejectile->GetKE(), m_rxnLayer, m_ejectile->vec4.Theta(), m_rxnDepth);
|
||||||
if(ejectKE > 0.0)
|
if(ejectKE > 0.0)
|
||||||
|
|
|
@ -59,21 +59,33 @@ void RootPlotter::Run(const std::string& inputname, const std::string& outputnam
|
||||||
|
|
||||||
void RootPlotter::FillData(const Mask::Nucleus& nuc)
|
void RootPlotter::FillData(const Mask::Nucleus& nuc)
|
||||||
{
|
{
|
||||||
std::string modifier = "";
|
std::string mod = "detected";
|
||||||
if(nuc.isDetected)
|
|
||||||
modifier = "detected";
|
|
||||||
|
|
||||||
std::string sym = nuc.isotopicSymbol;
|
std::string sym = nuc.isotopicSymbol;
|
||||||
std::string ke_vs_th_name = sym + modifier + "_ke_vs_theta";
|
std::string ke_vs_th_name = sym + "_ke_vs_theta";
|
||||||
std::string ke_vs_th_title = ke_vs_th_name + ";#theta_{lab} (degrees);Kinetic Energy (MeV)";
|
std::string ke_vs_th_title = ke_vs_th_name + ";#theta_{lab} (degrees);Kinetic Energy (MeV)";
|
||||||
std::string ke_vs_ph_name = sym + modifier + "_ke_vs_phi";
|
std::string ke_vs_th_name_det = sym + mod + "_ke_vs_theta";
|
||||||
|
std::string ke_vs_th_title_det = ke_vs_th_name + ";#theta_{lab} (degrees);Kinetic Energy (MeV)";
|
||||||
|
std::string ke_vs_ph_name = sym + "_ke_vs_phi";
|
||||||
std::string ke_vs_ph_title = ke_vs_ph_name + ";#phi_{lab} (degrees);Kinetic Energy (MeV)";
|
std::string ke_vs_ph_title = ke_vs_ph_name + ";#phi_{lab} (degrees);Kinetic Energy (MeV)";
|
||||||
std::string th_vs_ph_name = sym + modifier + "_theta_vs_phi";
|
std::string ke_vs_ph_name_det = sym + mod + "_ke_vs_phi";
|
||||||
|
std::string ke_vs_ph_title_det = ke_vs_ph_name + ";#phi_{lab} (degrees);Kinetic Energy (MeV)";
|
||||||
|
std::string th_vs_ph_name = sym + "_theta_vs_phi";
|
||||||
std::string th_vs_ph_title = th_vs_ph_name + ";#theta_{lab};#phi_{lab}";
|
std::string th_vs_ph_title = th_vs_ph_name + ";#theta_{lab};#phi_{lab}";
|
||||||
std::string ex_name = sym + modifier + "_ex";
|
std::string th_vs_ph_name_det = sym + mod + "_theta_vs_phi";
|
||||||
|
std::string th_vs_ph_title_det = th_vs_ph_name + ";#theta_{lab};#phi_{lab}";
|
||||||
|
std::string ex_name = sym + "_ex";
|
||||||
std::string ex_title = ex_name + ";E_{ex} (MeV);counts";
|
std::string ex_title = ex_name + ";E_{ex} (MeV);counts";
|
||||||
std::string angdist_name = sym + modifier +"_angDist";
|
std::string ex_name_det = sym + mod + "_ex";
|
||||||
|
std::string ex_title_det = ex_name + ";E_{ex} (MeV);counts";
|
||||||
|
std::string angdist_name = sym +"_angDist";
|
||||||
std::string angdist_title = angdist_name+";cos#right(#theta_{CM}#left);counts";
|
std::string angdist_title = angdist_name+";cos#right(#theta_{CM}#left);counts";
|
||||||
|
std::string angdist_name_det = sym + mod +"_angDist";
|
||||||
|
std::string angdist_title_det = angdist_name+";cos#right(#theta_{CM}#left);counts";
|
||||||
|
std::string hist_ke_th_name = sym + "_hist_ke_vs_theta";
|
||||||
|
std::string hist_ke_th_title = hist_ke_th_name + ";#theta_{lab};Kinetic Energy (MeV)";
|
||||||
|
std::string hist_ke_th_name_det = sym + mod + "_hist_ke_vs_theta";
|
||||||
|
std::string hist_ke_th_title_det = hist_ke_th_name + ";#theta_{lab};Kinetic Energy (MeV)";
|
||||||
|
|
||||||
MyFill(ke_vs_th_name, ke_vs_th_title, nuc.vec4.Theta()*s_rad2deg, nuc.GetKE(), 2);
|
MyFill(ke_vs_th_name, ke_vs_th_title, nuc.vec4.Theta()*s_rad2deg, nuc.GetKE(), 2);
|
||||||
MyFill(ke_vs_ph_name, ke_vs_ph_title, FullPhi(nuc.vec4.Phi())*s_rad2deg, nuc.GetKE(), 4);
|
MyFill(ke_vs_ph_name, ke_vs_ph_title, FullPhi(nuc.vec4.Phi())*s_rad2deg, nuc.GetKE(), 4);
|
||||||
|
@ -82,11 +94,12 @@ void RootPlotter::FillData(const Mask::Nucleus& nuc)
|
||||||
MyFill(angdist_name, angdist_title, 20, -1.0, 1.0, std::cos(nuc.thetaCM));
|
MyFill(angdist_name, angdist_title, 20, -1.0, 1.0, std::cos(nuc.thetaCM));
|
||||||
if(nuc.isDetected)
|
if(nuc.isDetected)
|
||||||
{
|
{
|
||||||
MyFill(ke_vs_th_name, ke_vs_th_title, nuc.vec4.Theta()*s_rad2deg, nuc.detectedKE, 2);
|
MyFill(ke_vs_th_name_det, ke_vs_th_title_det, nuc.vec4.Theta()*s_rad2deg, nuc.detectedKE, 2);
|
||||||
MyFill(ke_vs_ph_name, ke_vs_ph_title, FullPhi(nuc.vec4.Phi())*s_rad2deg, nuc.detectedKE, 4);
|
MyFill(ke_vs_ph_name_det, ke_vs_ph_title_det, FullPhi(nuc.vec4.Phi())*s_rad2deg, nuc.detectedKE, 4);
|
||||||
MyFill(th_vs_ph_name, th_vs_ph_title, nuc.vec4.Theta()*s_rad2deg, FullPhi(nuc.vec4.Phi())*s_rad2deg, 2);
|
MyFill(th_vs_ph_name_det, th_vs_ph_title_det, nuc.vec4.Theta()*s_rad2deg, FullPhi(nuc.vec4.Phi())*s_rad2deg, 2);
|
||||||
MyFill(ex_name, ex_title, 260, -1.0, 25, nuc.GetExcitationEnergy());
|
MyFill(ex_name_det, ex_title_det, 260, -1.0, 25, nuc.GetExcitationEnergy());
|
||||||
MyFill(angdist_name, angdist_title, 20, -1.0, 1.0, std::cos(nuc.thetaCM));
|
MyFill(angdist_name_det, angdist_title_det, 20, -1.0, 1.0, std::cos(nuc.thetaCM));
|
||||||
|
MyFill(hist_ke_th_name_det, hist_ke_th_title_det, 180, 0.0, 180.0, 400, 0.0, 20.0, nuc.vec4.Theta()*s_rad2deg, nuc.detectedKE);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user