diff --git a/Projects/e870/macros/DrawEx.cxx b/Projects/e870/macros/DrawEx.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..39ce5c15338186f94dac6de36e2789bd78d488c3
--- /dev/null
+++ b/Projects/e870/macros/DrawEx.cxx
@@ -0,0 +1,261 @@
+void DrawEx() {
+  TChain* t = new TChain("PhysicsTree");
+
+  TFile* fcutDEE3 = NULL;
+  TCutG* cutDEE3 = NULL;
+  TFile* fcutDEE4 = NULL;
+  TCutG* cutDEE4 = NULL;
+
+  TFile* fcutToF3 = NULL;
+  TCutG* cutToF3 = NULL;
+  bool ToF3 = false;
+  TFile* fcutToF4 = NULL;
+  TCutG* cutToF4 = NULL;
+  bool ToF4 = false;
+
+  /*
+  ////////////////////////////////////////////////////////////////////////////////
+  t->Add("../../Outputs/Analysis/Ana10Bepalpha_38AMeV_CH2.root"); // Name of simulated file
+  NPL::Reaction r("10Be(p,4He)7Li@380");
+
+  // YOUR 3 AND 4 CUT
+  fcutDEE3 = new TFile("cuts/CUT_alpha.root", "read");
+  cutDEE3 = (TCutG*)gDirectory->FindObjectAny("CUT_alpha");
+  fcutDEE4 = new TFile("cuts/CUT_7Li.root", "read");
+  cutDEE4 = (TCutG*)gDirectory->FindObjectAny("CUT_7Li");
+  */
+
+  ////////////////////////////////////////////////////////////////////////////////
+  t->Add("../../Outputs/Analysis/Ana10Bed6Li_20AMeV_CD2.root"); // Name of simulated file
+  NPL::Reaction r("10Be(d,6Li)6He@200");
+
+  // YOUR 3 AND 4 CUT
+  fcutDEE3 = new TFile("cuts/CUT_6Li.root", "read");
+  cutDEE3 = (TCutG*)gDirectory->FindObjectAny("CUT_6Li");
+  fcutDEE4 = new TFile("cuts/CUT_6He.root", "read");
+  cutDEE4 = (TCutG*)gDirectory->FindObjectAny("CUT_6He");
+
+  fcutToF3 = new TFile("cuts/CUTToF_6Li.root", "read");
+  cutToF3 = (TCutG*)gDirectory->FindObjectAny("CUTToF_6Li");
+  ToF3 = true;
+
+  ////////////////////////////////////////////////////////////////////////////////
+  TLorentzVector LV3, LV4, LVTarget;
+  double mBeam = r.GetParticle1()->Mass();
+  double mTarget = r.GetParticle2()->Mass();
+  double mParticle3 = r.GetParticle3()->Mass();
+  double mParticle4 = r.GetParticle4()->Mass();
+
+  TMust2Physics* M2 = new TMust2Physics();
+  std::vector<double>* ELab = 0;
+  std::vector<double>* ThetaLab = 0;
+  std::vector<double>* PhiLab = 0;
+  std::vector<double>* Ex = 0;
+  std::vector<double>* ExNoCATS = 0;
+  TBranch* b_ELab;
+  TBranch* b_ThetaLab;
+  TBranch* b_PhiLab;
+  TBranch* b_X;
+  TBranch* b_Y;
+  TBranch* b_Z;
+  TBranch* b_Ex;
+  TBranch* b_ExNoCATS;
+
+  t->SetBranchStatus("*", false);
+  t->SetBranchStatus("MUST2", true);
+  t->SetBranchAddress("MUST2", &M2);
+  t->SetBranchStatus("ELab", true);
+  t->SetBranchAddress("ELab", &ELab, &b_ELab);
+  t->SetBranchStatus("ThetaLab", true);
+  t->SetBranchAddress("ThetaLab", &ThetaLab, &b_ThetaLab);
+  t->SetBranchStatus("PhiLab", true);
+  t->SetBranchAddress("PhiLab", &PhiLab, &b_PhiLab);
+  t->SetBranchStatus("Ex", "true");
+  t->SetBranchAddress("Ex", &Ex, &b_Ex);
+  t->SetBranchStatus("ExNoCATS", "true");
+  t->SetBranchAddress("ExNoCATS", &ExNoCATS, &b_ExNoCATS);
+
+  TH1F* hExInv = new TH1F("hExInv", "hExInv", 200, -10, 10);
+  TH1F* hExMM = new TH1F("hExMM", "hExMM", 200, -10, 10);
+  TH1F* hExMMNoCATS = new TH1F("hExMMNoCATS", "hExMMNoCATS", 200, -10, 10);
+  TH2F* hE1E2 = new TH2F("hE1E2", "hE1E2", 200, 0, 500, 1000, 0, 500);
+  TH2F* hELabThetaLab = new TH2F("hELabThetLab", "hELabThetaLab", 1000, 0, 50, 1000, 0, 500);
+  TH2F* hExELab = new TH2F("hExELab", "hExELab", 1000, 0, 500, 1000, -10, 10);
+
+  ////////////////////////////////////////////////////////////////////////////////
+  int n_entries = t->GetEntries();
+  // int n_entries = 1e7;
+  for (unsigned int i = 0; i < n_entries; i++) {
+    t->GetEntry(i);
+
+    double e3 = -1000;
+    double theta3 = -1000;
+    double phi3 = -1000;
+
+    double e4 = -1000;
+    double theta4 = -1000;
+    double phi4 = -1000;
+
+    int Particle3 = -1000;
+    int Particle4 = -1000;
+    int number_of_match = 0;
+
+    if (M2->Si_E.size() == 2) {
+      if (M2->CsI_E[0] > 0) {
+        if (cutDEE3->IsInside(M2->CsI_E[0], M2->Si_E[0])) {
+          Particle3 = 0;
+          number_of_match++;
+        }
+      }
+      else if (M2->CsI_E[0] < 0 && ToF3 == true) {
+        if ((cutDEE3->IsInside(M2->CsI_E[0], M2->Si_E[0])) || (cutToF3->IsInside(M2->Si_E[0], M2->Si_T[0]))) {
+          Particle3 = 0;
+          number_of_match++;
+        }
+      }
+      if (M2->CsI_E[1] > 0) {
+        if (cutDEE4->IsInside(M2->CsI_E[1], M2->Si_E[1])) {
+          Particle4 = 1;
+          number_of_match++;
+        }
+      }
+      else if (M2->CsI_E[1] < 0 && ToF4 == true) {
+        if ((cutDEE4->IsInside(M2->CsI_E[1], M2->Si_E[1])) || (cutToF4->IsInside(M2->Si_E[1], M2->Si_T[1]))) {
+          Particle4 = 1;
+          number_of_match++;
+        }
+      }
+      if (cutDEE3->IsInside(M2->CsI_E[1], M2->Si_E[1])) {
+        Particle3 = 1;
+        number_of_match++;
+      }
+      else if (M2->CsI_E[1] < 0 && ToF3 == true) {
+        if ((cutDEE3->IsInside(M2->CsI_E[1], M2->Si_E[1])) || (cutToF3->IsInside(M2->Si_E[1], M2->Si_T[1]))) {
+          Particle3 = 1;
+          number_of_match++;
+        }
+      }
+      if (M2->CsI_E[0] > 0) {
+        if (cutDEE4->IsInside(M2->CsI_E[0], M2->Si_E[0])) {
+          Particle4 = 0;
+          number_of_match++;
+        }
+      }
+      else if (M2->CsI_E[0] < 0 && ToF4 == true) {
+        if ((cutDEE4->IsInside(M2->CsI_E[0], M2->Si_E[0])) || (cutToF4->IsInside(M2->Si_E[0], M2->Si_T[0]))) {
+          Particle4 = 0;
+          number_of_match++;
+        }
+      }
+
+      if (number_of_match == 2) {
+        if (Particle3 == 0 && Particle4 == 1) {
+          hExMM->Fill(Ex->at(0));
+          hExMMNoCATS->Fill(ExNoCATS->at(0));
+          e3 = ELab->at(0);
+          theta3 = ThetaLab->at(0) * M_PI / 180.;
+          phi3 = PhiLab->at(0);
+          if (phi3 + 180. > 360)
+            phi3 = phi3 - 180;
+          else
+            phi3 = phi3 + 180;
+          phi3 = phi3 * M_PI / 180.;
+
+          e4 = ELab->at(1);
+          theta4 = ThetaLab->at(1) * M_PI / 180.;
+          phi4 = PhiLab->at(1);
+          if (phi4 + 180. > 360)
+            phi4 = phi4 - 180;
+          else
+            phi4 = phi4 + 180;
+          phi4 = phi4 * M_PI / 180.;
+        }
+        if (Particle3 == 1 && Particle4 == 0) {
+          hExMM->Fill(Ex->at(1));
+          hExMMNoCATS->Fill(ExNoCATS->at(1));
+          e3 = ELab->at(1);
+          theta3 = ThetaLab->at(1) * M_PI / 180.;
+          phi3 = PhiLab->at(1);
+          if (phi3 + 180. > 360)
+            phi3 = phi3 - 180;
+          else
+            phi3 = phi3 + 180;
+          phi3 = phi3 * M_PI / 180.;
+
+          e4 = ELab->at(0);
+          theta4 = ThetaLab->at(0) * M_PI / 180.;
+          phi4 = PhiLab->at(0);
+          if (phi4 + 180. > 360)
+            phi4 = phi4 - 180;
+          else
+            phi4 = phi4 + 180;
+          phi4 = phi4 * M_PI / 180.;
+        }
+      }
+
+      if (e3 > 0 && e4 > 0) {
+        ////////////////////////////////////////////////////////////////////////////////
+        double gamma3 = e3 / mParticle3 + 1.;
+        double beta3 = sqrt(1 - 1 / (pow(gamma3, 2.)));
+        double p3_mag = gamma3 * mParticle3 * beta3;
+        double etot3 = sqrt(pow(p3_mag, 2) + pow(mParticle3, 2));
+
+        TVector3 p3(sin(theta3) * cos(phi3), // px
+                    sin(theta3) * sin(phi3), // py
+                    cos(theta3));            // pz
+        p3.SetMag(p3_mag);
+        LV3.SetPxPyPzE(p3.x(), p3.y(), p3.z(), etot3);
+
+        ////////////////////////////////////////////////////////////////////////////////
+        double gamma4 = e4 / mParticle4 + 1;
+        double beta4 = sqrt(1 - 1 / (pow(gamma4, 2.)));
+        double p4_mag = gamma4 * mParticle4 * beta4;
+        double etot4 = sqrt(pow(p4_mag, 2) + pow(mParticle4, 2));
+
+        TVector3 p4(sin(theta4) * cos(phi4), // px
+                    sin(theta4) * sin(phi4), // py
+                    cos(theta4));            // pz
+        p4.SetMag(p4_mag);
+        LV4.SetPxPyPzE(p4.x(), p4.y(), p4.z(), etot4);
+
+        LVTarget.SetPxPyPzE(0, 0, 0, mTarget);
+        TLorentzVector LV_total = LV3 + LV4 - LVTarget;
+
+        double ExTot = LV_total.Mag() - mBeam;
+        hExInv->Fill(ExTot);
+        hE1E2->Fill(e3, e4);
+        hELabThetaLab->Fill(theta3 * 180 / M_PI, e3);
+        hELabThetaLab->Fill(theta4 * 180 / M_PI, e4);
+        hExELab->Fill(e3, ExTot);
+        hExELab->Fill(e4, ExTot);
+      }
+    }
+  }
+  TCanvas* c1 = new TCanvas();
+  gStyle->SetOptStat(0);
+  hExInv->Draw();
+  hExMM->SetLineColor(kRed);
+  hExMM->Draw("same");
+
+  TF1* fitExTot = new TF1("fitExTot", "gaus", hExInv->GetXaxis()->GetXmin(), hExInv->GetXaxis()->GetXmax());
+  fitExTot->SetNpx(10000);
+  hExInv->Fit(fitExTot, "Q");
+  double sigmaExTot = fitExTot->GetParameter(2);
+  std::cout << "FWHM of hExInv: " << sigmaExTot * 2.35 << " MeV" << std::endl;
+
+  double fitRangeMin = 0.0;
+  double fitRangeMax = 15.0;
+  TF1* fitEx = new TF1("fitEx", "gaus", fitRangeMin, fitRangeMax);
+  fitEx->SetNpx(10000);
+  hExMM->Fit(fitEx, "Q", "", -10, 10);
+  double sigmaEx = fitEx->GetParameter(2);
+  std::cout << "FWHM of hEx: " << sigmaEx * 2.35 << " MeV" << std::endl;
+
+  TLegend* legend = new TLegend(0.75, 0.75, 0.85, 0.85);
+  legend->AddEntry(hExInv, "hExInv", "l"); // "l" for 4ne
+  legend->AddEntry(hExMM, "hExMM", "l");
+  legend->Draw();
+
+  TCanvas* c2 = new TCanvas();
+  hELabThetaLab->Draw("col");
+}
diff --git a/Projects/e870/macros/DrawExInvariant.cxx b/Projects/e870/macros/DrawExInvariant.cxx
index 6dc7883719c6c804f62e3aa354cf3a460ace5cad..2ff6ea1d03d51a1deafe3f9a1a8f4104df30b04c 100644
--- a/Projects/e870/macros/DrawExInvariant.cxx
+++ b/Projects/e870/macros/DrawExInvariant.cxx
@@ -6,6 +6,7 @@ void DrawExInvariant() {
   double m_7Li = 7 * mu + 14.91;   // MeV/c2
   double m_10Be = 10 * mu + 12.61; // MeV/c2
   double mp = mu + 7.289;          // MeV/c2
+  cout << m_10Be << " " << mp << " " << m_alpha << " " << m_7Li << endl;
   // double m_5Li = 5 * mu + 11.68;       // MeV/c2
 
   TChain* t = new TChain("PhysicsTree");
@@ -118,8 +119,10 @@ void DrawExInvariant() {
       if (e_alpha > 0 && e_li > 0) {
         ////////////////////////////////////////////////////////////////////////////////
         double gamma_alpha = e_alpha / m_alpha + 1;
+        cout << gamma_alpha <<endl;
         double beta_alpha = sqrt(1 - 1 / (pow(gamma_alpha, 2.)));
         double p_alpha_mag = gamma_alpha * m_alpha * beta_alpha;
+        // cout << p_alpha_mag << endl;
         double etot_alpha = sqrt(pow(p_alpha_mag, 2) + pow(m_alpha, 2));
 
         TVector3 p_alpha(sin(theta_alpha) * cos(phi_alpha), // px