diff --git a/Inputs/DetectorConfiguration/NeutronWall.detector b/Inputs/DetectorConfiguration/NeutronWall.detector
index 871d2ed7997e17f7adfee49eb6440fbadc9e30bf..d930a84f0c0abb6ed848fb9d9ef34d2e3711064f 100644
--- a/Inputs/DetectorConfiguration/NeutronWall.detector
+++ b/Inputs/DetectorConfiguration/NeutronWall.detector
@@ -2,7 +2,7 @@
 GeneralTarget
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Target
-	THICKNESS= 10
+        THICKNESS= 10
 	RADIUS=	20
 	MATERIAL= CD2
 	ANGLE= 0
@@ -15,9 +15,26 @@ Target
 %	Y= -3.75
 %	Z= 566.54
 %	Rot= 16.61
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 NeutronWall
-  THETA= 20
+  THETA= 0
   PHI= 0
-  R= 4
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+  R= 4000
+  BARS= 25
+  VETOWALL= 0
+  VWDISTANCE= 400
+  OVERLAP= 3
+  VWMATERIAL= BC400
+  NWMATERIAL= NE213
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+NeutronWall
+  THETA= 0
+  PHI= 0
+  R= 6000
+  BARS= 25
+  VETOWALL= 0
+  VWDISTANCE= 1000
+  OVERLAP= 3
+  VWMATERIAL= BC400
+  NWMATERIAL= NE213
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
diff --git a/Inputs/EventGenerator/3He.source b/Inputs/EventGenerator/3He.source
index b80e9a4a1fec2107cdf38b2507847f66ca9022fa..66efecc3e4be50185b581bdd2afda851991e014b 100644
--- a/Inputs/EventGenerator/3He.source
+++ b/Inputs/EventGenerator/3He.source
@@ -5,9 +5,9 @@
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Isotropic
 	EnergyLow=  0	
-	EnergyHigh= 710
+	EnergyHigh= 525
 	HalfOpenAngleMin= 0
-	HalfOpenAngleMax= 10
+	HalfOpenAngleMax= 90
 	x0= 0	
 	y0= 0	
 	z0= 0	
diff --git a/Inputs/EventGenerator/alpha.source b/Inputs/EventGenerator/alpha.source
index 9c9bc63fd260253abb84404ccf4e4b31a487ef90..1c9997fde237f339d97cecb394ca6d5542eea6a5 100644
--- a/Inputs/EventGenerator/alpha.source
+++ b/Inputs/EventGenerator/alpha.source
@@ -5,9 +5,9 @@
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Isotropic
   EnergyLow= 0
-  EnergyHigh= 795 
+  EnergyHigh= 590 
   HalfOpenAngleMin= 0
-  HalfOpenAngleMax= 10
+  HalfOpenAngleMax= 90
   x0= 0
   y0= 0 
   z0= 0
diff --git a/Inputs/EventGenerator/deuton.source b/Inputs/EventGenerator/deuton.source
index 7a864b0fb3018a654583b78a9f4ab1e2d1e00a19..4bd428cd0b4f89d52538700126a6914038b11e9a 100644
--- a/Inputs/EventGenerator/deuton.source
+++ b/Inputs/EventGenerator/deuton.source
@@ -5,9 +5,9 @@
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Isotropic
 	EnergyLow=  0	
-	EnergyHigh= 265
+	EnergyHigh= 205
 	HalfOpenAngleMin= 0
-	HalfOpenAngleMax= 10
+	HalfOpenAngleMax= 90
 	x0= 0	
 	y0= 0	
 	z0= 0	
diff --git a/Inputs/EventGenerator/proton.source b/Inputs/EventGenerator/proton.source
index 5e33cde9ba90f3b2077da3ec30448bfe620cace0..75ce81c443c5a62b35a19132ac185721b8412dde 100644
--- a/Inputs/EventGenerator/proton.source
+++ b/Inputs/EventGenerator/proton.source
@@ -5,7 +5,7 @@
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Isotropic
 	EnergyLow=  0	
-	EnergyHigh= 195
+	EnergyHigh= 250
 	HalfOpenAngleMin= 0
 	HalfOpenAngleMax= 90
 	x0= 0	
diff --git a/Inputs/EventGenerator/triton.source b/Inputs/EventGenerator/triton.source
index f67b1d5fb4d199a7907c33275ed56469da4ba73c..28ecc223289d59d56ff668874ffa5543fe304440 100644
--- a/Inputs/EventGenerator/triton.source
+++ b/Inputs/EventGenerator/triton.source
@@ -5,9 +5,9 @@
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 Isotropic
 	EnergyLow=  0	
-	EnergyHigh= 315
+	EnergyHigh= 235
 	HalfOpenAngleMin= 0
-	HalfOpenAngleMax= 10
+	HalfOpenAngleMax= 90
 	x0= 0	
 	y0= 0	
 	z0= 0	
diff --git a/NPLib/Detectors/NeutronWall/TNeutronWallData.h b/NPLib/Detectors/NeutronWall/TNeutronWallData.h
index caee4ad88eb9ddcf46f11fd553455fea86e27778..f36a9733a03fe23dbcf8ea88e46ded95ff15dded 100644
--- a/NPLib/Detectors/NeutronWall/TNeutronWallData.h
+++ b/NPLib/Detectors/NeutronWall/TNeutronWallData.h
@@ -36,12 +36,24 @@ class TNeutronWallData : public TObject {
   private: 
     // Energy
     vector<UShort_t>   fNeutronWall_E_DetectorNbr;
+    vector<UShort_t>   fNeutronWall_E_PadNbr;
     vector<Double_t>   fNeutronWall_Energy;
 
     // Time
     vector<UShort_t>   fNeutronWall_T_DetectorNbr;
+    vector<UShort_t>   fNeutronWall_T_PadNbr;
     vector<Double_t>   fNeutronWall_Time;
 
+    // Energy
+    vector<UShort_t>   fVetoWall_E_DetectorNbr;
+    vector<UShort_t>   fVetoWall_E_PadNbr;
+    vector<Double_t>   fVetoWall_Energy;
+
+    // Time
+    vector<UShort_t>   fVetoWall_T_DetectorNbr;
+    vector<UShort_t>   fVetoWall_T_PadNbr;
+    vector<Double_t>   fVetoWall_Time;
+
 
   //////////////////////////////////////////////////////////////
   // Constructor and destructor
@@ -64,36 +76,73 @@ class TNeutronWallData : public TObject {
   // frequently used methods
   // add //! to avoid ROOT creating dictionnary for the methods
   public:
-    //////////////////////    SETTERS    ////////////////////////
+    //////////////////////    SETTERS NEUTRON WALL   ////////////////////////
     // Energy
     inline void SetE_DetectorNbr(const UShort_t& DetNbr)
       {fNeutronWall_E_DetectorNbr.push_back(DetNbr);} //!
+    inline void SetE_PadNbr(const UShort_t& PadNbr)
+      {fNeutronWall_E_PadNbr.push_back(PadNbr);} //!
     inline void Set_Energy(const Double_t& Energy)
       {fNeutronWall_Energy.push_back(Energy);}//!
     // Prefer global setter so that all vectors have the same size
-    inline void SetEnergy(const UShort_t& DetNbr,const Double_t& Energy) {
+    inline void SetEnergy(const UShort_t& DetNbr, const UShort_t& PadNbr, const Double_t& Energy) {
       SetE_DetectorNbr(DetNbr);
+      SetE_PadNbr(PadNbr);
       Set_Energy(Energy);
     };//!
 
     // Time
     inline void SetT_DetectorNbr(const UShort_t& DetNbr)
       {fNeutronWall_T_DetectorNbr.push_back(DetNbr);} //!
+    inline void SetT_PadNbr(const UShort_t& PadNbr)
+      {fNeutronWall_T_PadNbr.push_back(PadNbr);} //!
     inline void Set_Time(const Double_t& Time)
       {fNeutronWall_Time.push_back(Time);}//!
     // Prefer global setter so that all vectors have the same size
-    inline void SetTime(const UShort_t& DetNbr,const Double_t& Time)	{
+    inline void SetTime(const UShort_t& DetNbr,const UShort_t& PadNbr,const Double_t& Time)	{
       SetT_DetectorNbr(DetNbr);
+      SetT_PadNbr(PadNbr);
       Set_Time(Time);
     };//!
 
+    //////////////////////    SETTERS VETO WALL   ////////////////////////
+    // Energy
+    inline void SetE_VetoDetectorNbr(const UShort_t& DetNbr)
+      {fVetoWall_E_DetectorNbr.push_back(DetNbr);} //!
+    inline void SetE_VetoPadNbr(const UShort_t& PadNbr)
+      {fVetoWall_E_PadNbr.push_back(PadNbr);} //!
+    inline void Set_VetoEnergy(const Double_t& Energy)
+      {fVetoWall_Energy.push_back(Energy);}//!
+    // Prefer global setter so that all vectors have the same size
+    inline void SetVetoEnergy(const UShort_t& DetNbr,const UShort_t& PadNbr,const Double_t& Energy) {
+      SetE_VetoDetectorNbr(DetNbr);
+      SetE_VetoPadNbr(PadNbr);
+      Set_VetoEnergy(Energy);
+    };//!
+
+    // Time
+    inline void SetT_VetoDetectorNbr(const UShort_t& DetNbr)
+      {fVetoWall_T_DetectorNbr.push_back(DetNbr);} //!
+    inline void SetT_VetoPadNbr(const UShort_t& PadNbr)
+      {fVetoWall_T_PadNbr.push_back(PadNbr);} //!
+    inline void Set_VetoTime(const Double_t& Time)
+      {fVetoWall_Time.push_back(Time);}//!
+    // Prefer global setter so that all vectors have the same size
+    inline void SetVetoTime(const UShort_t& DetNbr,const UShort_t& PadNbr,const Double_t& Time)	{
+      SetT_VetoDetectorNbr(DetNbr);
+      SetT_VetoPadNbr(PadNbr);
+      Set_VetoTime(Time);
+    };//!
+
 
-    //////////////////////    GETTERS    ////////////////////////
+    //////////////////////    GETTERS NEUTRON WALL    ////////////////////////
     // Energy
     inline UShort_t GetMultEnergy() const
       {return fNeutronWall_E_DetectorNbr.size();}
     inline UShort_t GetE_DetectorNbr(const unsigned int &i) const 
       {return fNeutronWall_E_DetectorNbr[i];}//!
+    inline UShort_t GetE_PadNbr(const unsigned int &i) const 
+      {return fNeutronWall_E_PadNbr[i];}//!
     inline Double_t Get_Energy(const unsigned int &i) const 
       {return fNeutronWall_Energy[i];}//!
 
@@ -102,9 +151,30 @@ class TNeutronWallData : public TObject {
       {return fNeutronWall_T_DetectorNbr.size();}
     inline UShort_t GetT_DetectorNbr(const unsigned int &i) const 
       {return fNeutronWall_T_DetectorNbr[i];}//!
+    inline UShort_t GetT_PadNbr(const unsigned int &i) const 
+      {return fNeutronWall_T_PadNbr[i];}//!
     inline Double_t Get_Time(const unsigned int &i) const 
       {return fNeutronWall_Time[i];}//!
 
+    //////////////////////    GETTERS VETO WALL    ////////////////////////
+    // Energy
+    inline UShort_t GetVetoMultEnergy() const
+      {return fVetoWall_E_DetectorNbr.size();}
+    inline UShort_t GetE_VetoDetectorNbr(const unsigned int &i) const 
+      {return fVetoWall_E_DetectorNbr[i];}//!
+    inline UShort_t GetE_VetoPadNbr(const unsigned int &i) const 
+      {return fVetoWall_E_PadNbr[i];}//!
+    inline Double_t Get_VetoEnergy(const unsigned int &i) const 
+      {return fVetoWall_Energy[i];}//!
+
+    // Time
+    inline UShort_t GetVetoMultTime() const
+      {return fVetoWall_T_DetectorNbr.size();}
+    inline UShort_t GetT_VetoDetectorNbr(const unsigned int &i) const 
+      {return fVetoWall_T_DetectorNbr[i];}//!
+    inline Double_t Get_VetoTime(const unsigned int &i) const 
+      {return fVetoWall_Time[i];}//!
+
 
   //////////////////////////////////////////////////////////////
   // Required for ROOT dictionnary
diff --git a/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.cxx b/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.cxx
index 5cb68a7cdb5c5a2d22b49e2cf61b1e2de723ffce..ddd29285e666c7ac50ce7848cdd0d6c0aa093dd5 100644
--- a/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.cxx
+++ b/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.cxx
@@ -71,6 +71,7 @@ void TNeutronWallPhysics::BuildPhysicalEvent() {
     for (UShort_t t = 0; t < m_PreTreatedData->GetMultTime(); t++) {
       if (m_PreTreatedData->GetE_DetectorNbr(e) == m_PreTreatedData->GetT_DetectorNbr(t)) {
         DetectorNumber.push_back(m_PreTreatedData->GetE_DetectorNbr(e));
+        PadNumber.push_back(m_PreTreatedData->GetE_PadNbr(e));
         Energy.push_back(m_PreTreatedData->Get_Energy(e));
         Time.push_back(m_PreTreatedData->Get_Time(t));
       }
@@ -94,7 +95,7 @@ void TNeutronWallPhysics::PreTreat() {
     if (m_EventData->Get_Energy(i) > m_E_RAW_Threshold) {
       Double_t Energy = Cal->ApplyCalibration("NeutronWall/ENERGY"+NPL::itoa(m_EventData->GetE_DetectorNbr(i)),m_EventData->Get_Energy(i));
       if (Energy > m_E_Threshold) {
-        m_PreTreatedData->SetEnergy(m_EventData->GetE_DetectorNbr(i), Energy);
+        m_PreTreatedData->SetEnergy(m_EventData->GetE_DetectorNbr(i),m_EventData->GetE_PadNbr(i), Energy);
       }
     }
   }
@@ -102,7 +103,7 @@ void TNeutronWallPhysics::PreTreat() {
   // Time 
   for (UShort_t i = 0; i < m_EventData->GetMultTime(); ++i) {
     Double_t Time= Cal->ApplyCalibration("NeutronWall/TIME"+NPL::itoa(m_EventData->GetT_DetectorNbr(i)),m_EventData->Get_Time(i));
-    m_PreTreatedData->SetTime(m_EventData->GetT_DetectorNbr(i), Time);
+    m_PreTreatedData->SetTime(m_EventData->GetT_DetectorNbr(i),m_EventData->GetT_PadNbr(i), Time);
   }
 }
 
@@ -175,6 +176,7 @@ void TNeutronWallPhysics::ReadAnalysisConfig() {
 ///////////////////////////////////////////////////////////////////////////
 void TNeutronWallPhysics::Clear() {
   DetectorNumber.clear();
+  PadNumber.clear();
   Energy.clear();
   Time.clear();
 }
diff --git a/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.h b/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.h
index 340646e0c3fd7e9787b71162bf3a200a106a6ffd..c837d531c15a066c6b1b0f578fed318196d15489 100644
--- a/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.h
+++ b/NPLib/Detectors/NeutronWall/TNeutronWallPhysics.h
@@ -64,6 +64,7 @@ class TNeutronWallPhysics : public TObject, public NPL::VDetector {
   // output ROOT file
   public:
     vector<int>      DetectorNumber;
+    vector<int>      PadNumber;
     vector<double>   Energy;
     vector<double>   Time;
 
diff --git a/NPSimulation/Detectors/NeutronWall/NeutronWall.cc b/NPSimulation/Detectors/NeutronWall/NeutronWall.cc
index eef734ea40e5e2149e92feb9a75a39d26b58af51..20456b6ff7132d38ea561a02f145470f4e31f9fe 100644
--- a/NPSimulation/Detectors/NeutronWall/NeutronWall.cc
+++ b/NPSimulation/Detectors/NeutronWall/NeutronWall.cc
@@ -1,18 +1,18 @@
 /*****************************************************************************
- * Copyright (C) 2009-2016   this file is part of the NPTool Project       *
+ * Copyright (C) 2009-2016   this file is part of the NPTool Project         *
  *                                                                           *
  * For the licensing terms see $NPTOOL/Licence/NPTool_Licence                *
  * For the list of contributors see $NPTOOL/Licence/Contributors             *
  *****************************************************************************/
 
 /*****************************************************************************
- * Original Author: Pierre Morfouace  contact address: morfouac@nscl.msu.edu                        *
+ * Original Author: Pierre Morfouace  contact address: morfouac@nscl.msu.edu *
  *                                                                           *
- * Creation Date  : June 2016                                           *
+ * Creation Date  : June 2016                                                *
  * Last update    :                                                          *
  *---------------------------------------------------------------------------*
  * Decription:                                                               *
- *  This class describe  NeutronWall simulation                             *
+ *  This class describe  NeutronWall simulation                              *
  *                                                                           *
  *---------------------------------------------------------------------------*
  * Comment:                                                                  *
@@ -23,10 +23,14 @@
 #include <sstream>
 #include <cmath>
 #include <limits>
+#include <cstring>
+#include <string>
+
 //G4 Geometry object
 #include "G4Tubs.hh"
 #include "G4Box.hh"
 #include "G4Trd.hh"
+#include "G4SubtractionSolid.hh"
 
 //G4 sensitive
 #include "G4SDManager.hh"
@@ -58,20 +62,49 @@ namespace NeutronWall_NS{
     const double EnergyThreshold = 0.1*MeV;
     const double ResoTime = 4.5*ns ;
     const double ResoEnergy = 5.0*MeV ;
-    const double NS_X = 1.1*m;
-    const double NS_Y = 1.1*m;
-    const double NS_Z = 5*cm;
-    const double Al_X = 1.1*m;
-    const double Al_Y = 1.1*m;
-    const double Al_Z = 0.2*m;
-    const double NE213_X = 1.0*m;
-    const double NE213_Y = 3.66*cm;
-    const double NE213_Z = 3.025*cm;
-    const double Py_X = 1.006*m;
-    const double Py_Y = 3.81*cm;
-    const double Py_Z = 3.175*cm;
-    
-    const string Scintillator = "NE213";
+    //The size of NS should depend on the distance between NeutronWall and plastic Bar right now
+    double NS_X = 2020.0*mm;
+    double NS_Y = 2020.0*mm;
+    //the front and back aluminum sheet are both 0.8 thick whereas 143.5 is user assumed heigh in z
+    double NS_Z = (143.5+0.8+0.8)*mm;
+    //using Alouter minus Alinner, one get an Al frame
+    const double Alinner_X = 2000.0*mm;
+    const double Alinner_Y = 2000.0*mm;
+    const double Alinner_Z = 143.5*mm;
+    const double Alouter_X = 2020.0*mm;
+    const double Alouter_Y = 2020.0*mm;
+    const double Alouter_Z = (143.5+0.8+0.8)*mm;
+    
+    const double frame_thickness = 10*mm;
+    
+    const double Scintillator_X = 1994.0*mm;
+    const double Scintillator_Y = 70.2*mm;
+    const double Scintillator_Z = 57.5*mm;
+    //do the same thing to Pyrex tube to create a volume to store Scintillator
+    
+    const double Py_Xinner = 1994.0*mm;
+    const double Py_Yinner = 70.2*mm;
+    const double Py_Zinner = 57.5*mm;
+    const double Py_Xouter = 2000.0*mm;
+    const double Py_Youter = 76.2*mm;
+    const double Py_Zouter = 63.5*mm;
+    
+    const double seperation_between_pyrex = 3.0*mm;
+    const double upper_gap = 10.0*mm;
+    
+    //Add elements about the plastic bars
+    double PlasticBar_X = 0.0*mm;
+    double PlasticBar_Y = 0.0*mm;
+    double PlasticBar_Z = 10.0*mm;
+    
+    //Add total height of neutronwall and vetowall for comparision
+    double TotalHeightOfNeutronWall = 0.0*mm;
+    double TotalHeightOfVetoWall = 0.0*mm;
+    
+    //Scale down factor
+    double ScaleDownFactor = 0;
+    
+    
 }
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
@@ -80,27 +113,30 @@ namespace NeutronWall_NS{
 NeutronWall::NeutronWall(){
     m_Event = new TNeutronWallData() ;
     m_NeutronWallScorer = 0;
+    m_VetoWallScorer = 0;
     m_NeutronWall_log = 0;
     m_AlCase_log = 0;
     m_Quartz_log = 0;
     m_QuartzCap_log = 0;
     m_PMTube_log = 0;
-    m_NE213_log = 0;
+    m_Scintillator_log = 0;
     m_ShadowBar_log = 0;
+    m_PlasticBar_log = 0;
     
     
     // RGB Color + Transparency
-    m_VisNE213 = new G4VisAttributes(G4Colour(0, 1, 0, 0.5));
-    m_VisQuartz = new G4VisAttributes(G4Colour(0, 1, 1, 0.5));
-    m_VisAl = new G4VisAttributes(G4Colour(0.5,0.5,0.5,0.5));
-    m_VisNW = new G4VisAttributes(G4Colour(0.4,0.2,0.8,0.5));
+    m_VisScintillator = new G4VisAttributes(G4Colour(1, 0.843137, 0, 0.3)); //gold
+    m_VisQuartz = new G4VisAttributes(G4Colour(0,1, 0, 0.1)); //green
+    m_VisAl = new G4VisAttributes(G4Colour(173.0/255.0,178.0/255.0,189.0/255.0,0.3)); //Al
+    m_VisNW = new G4VisAttributes(G4Colour(0.972549,0.972549,1,0.1)); //ghostwhite
+    m_VisPlasticBar = new G4VisAttributes(G4Colour(0.9,0,0.9,1.0)); //pink
 }
 
 NeutronWall::~NeutronWall(){
 }
 
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
-void NeutronWall::AddNeutronWall(double  R, double  Theta, double  Phi, double X, double Y, double Z, double Rotation){
+void NeutronWall::AddNeutronWall(double  R, double  Theta, double  Phi, double X, double Y, double Z, double Rotation, int Bars, string NWMaterial, double VWDistance, int VetoWall, string VWMaterial, double Overlap){
     m_R.push_back(R);
     m_Theta.push_back(Theta);
     m_Phi.push_back(Phi);
@@ -108,12 +144,18 @@ void NeutronWall::AddNeutronWall(double  R, double  Theta, double  Phi, double X
     m_Y.push_back(Y);
     m_Z.push_back(Z);
     m_Rot.push_back(Rotation);
+    m_Bars.push_back(Bars);
+    m_NWMaterial.push_back(NWMaterial);
+    m_VWDistance.push_back(VWDistance);
+    m_VetoWall.push_back(VetoWall);
+    m_VWMaterial.push_back(VWMaterial);
+    m_Overlap.push_back(Overlap);
 }
 
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 void NeutronWall::BuildDetector(){
-
-
+    
+    
 }
 
 
@@ -134,6 +176,12 @@ void NeutronWall::ReadConfiguration(string Path){
     double Theta = 0 , Phi = 0 , R = 0 ;
     double X = 0 , Y = 0 , Z = 0 ;
     double Rot =0;
+    int Bars = 0;
+    string NWMaterial = "NE213";
+    double VWDistance = 0.0;
+    int VetoWall = 0;
+    string VWMaterial = "BC400";
+    double Overlap = 3;
     
     bool check_Theta = false ;
     bool check_Phi = false ;
@@ -143,7 +191,11 @@ void NeutronWall::ReadConfiguration(string Path){
     bool check_Y = false ;
     bool check_Z = false ;
     bool ReadingStatus = false ;
-    
+    bool check_Bars = false ;
+    bool check_NWMaterial = false ;
+    //bool check_VWDistance = false ;
+    //bool check_VetoWall = false ;
+    //bool check_VWMaterial = false ;
     
     while (!ConfigFile.eof()) {
         getline(ConfigFile, LineBuffer);
@@ -197,8 +249,8 @@ void NeutronWall::ReadConfiguration(string Path){
                 check_R = true;
                 ConfigFile >> DataBuffer ;
                 R = atof(DataBuffer.c_str()) ;
-                R = R * m;
-                G4cout << "R:  " << R/m << G4endl;
+                R = R * mm;
+                G4cout << "R:  " << R/mm << G4endl;
             }
             
             //Position method
@@ -236,6 +288,56 @@ void NeutronWall::ReadConfiguration(string Path){
                 G4cout << "Rotation:  " << Rot/deg << G4endl;
             }
             
+            //Bar number
+            else if (DataBuffer.compare(0, 5, "BARS=") == 0){
+                check_Bars = true;
+                ConfigFile >> DataBuffer ;
+                Bars = atoi(DataBuffer.c_str()) ;
+                G4cout << "Bars:  " << Bars << G4endl;
+            }
+            
+            
+            //Material type
+            else if (DataBuffer.compare(0, 11, "NWMATERIAL=") == 0){
+                check_NWMaterial = true;
+                ConfigFile >> DataBuffer ;
+                NWMaterial = DataBuffer;
+                G4cout << "NWMaterials:  " << NWMaterial << G4endl;
+            }
+            
+            //Distance
+            else if (DataBuffer.compare(0, 11, "VWDISTANCE=") == 0){
+                //check_VWDistance = true;
+                ConfigFile >> DataBuffer ;
+                VWDistance = atof(DataBuffer.c_str());
+                VWDistance = VWDistance * mm;
+                G4cout << "VWDistance: " << VWDistance << G4endl;
+            }
+            
+            //Decide whether to add the vetowall or not, 1 means yes, 0 means no
+            else if (DataBuffer.compare(0, 9, "VETOWALL=") == 0){
+                //check_VetoWall = true;
+                ConfigFile >> DataBuffer ;
+                VetoWall = atoi(DataBuffer.c_str());
+                G4cout << "VetoWall:  " << VetoWall << G4endl;
+            }
+            
+            //VetoWall Material
+            else if (DataBuffer.compare(0, 11, "VWMATERIAL=") == 0){
+                //check_VWMaterial = true;
+                ConfigFile >> DataBuffer ;
+                VWMaterial = DataBuffer ;
+                G4cout << "VWMaterial:  " << VWMaterial << G4endl;
+            }
+            
+            //Overlap
+            else if (DataBuffer.compare(0, 8, "OVERLAP=") == 0){
+                ConfigFile >> DataBuffer ;
+                Overlap = atof(DataBuffer.c_str());
+                Overlap = Overlap*mm;
+                G4cout << "Overlap:  " << Overlap << G4endl;
+            }
+            
             ///////////////////////////////////////////////////
             //   If no Detector Token and no comment, toggle out
             else{
@@ -246,9 +348,9 @@ void NeutronWall::ReadConfiguration(string Path){
             /////////////////////////////////////////////////
             //   If All necessary information there, toggle out
             
-            if (( check_Theta && check_Phi && check_R)
+            if (( check_Theta && check_Phi && check_R && check_Bars && check_NWMaterial)
                 ||
-                ( check_X && check_Y && check_Z && check_rotation)){
+                ( check_X && check_Y && check_Z && check_rotation && check_Bars && check_NWMaterial)){
                 
                 
                 // Convert Cartesian to Spherical (detector always face the target)
@@ -258,7 +360,7 @@ void NeutronWall::ReadConfiguration(string Path){
                     Phi = atan2(Y,X);
                 }
                 
-                AddNeutronWall(R,Theta,Phi,X,Y,Z,Rot);
+                AddNeutronWall(R,Theta,Phi,X,Y,Z,Rot, Bars, NWMaterial, VWDistance, VetoWall, VWMaterial, Overlap);
                 
                 //   Reinitialisation of Check Boolean
                 check_Theta = false ;
@@ -269,6 +371,11 @@ void NeutronWall::ReadConfiguration(string Path){
                 check_Y = false ;
                 check_Z = false ;
                 ReadingStatus = false ;
+                check_Bars = false ;
+                check_NWMaterial = false ;
+                //check_VWDistance = false ;
+                //check_VetoWall = false ;
+                //check_VWMaterial = false ;
                 G4cout << "///"<< G4endl ;
             }
         }
@@ -295,13 +402,27 @@ void NeutronWall::ConstructDetector(G4LogicalVolume* world){
         G4ThreeVector Y(ii,jj,kk);
         G4ThreeVector w = Det_pos.unit();
         G4ThreeVector u = w.cross(Y);
-        G4ThreeVector v = w.cross(u);
+        G4ThreeVector v = u.cross(w);
         v = v.unit();
         u = u.unit();
         
-        G4RotationMatrix* Rot = new G4RotationMatrix(u,v,w);
         
-        G4Material* ScintMaterial = MaterialManager::getInstance()->GetMaterialFromLibrary(NeutronWall_NS::Scintillator);
+        
+        //Initialize scale down factor , measured from face to face but VWDistance is from center to center
+        NeutronWall_NS::ScaleDownFactor = ((m_R[i]+NeutronWall_NS::NS_Z*0.5-(m_VWDistance[i]-NeutronWall_NS::NS_Z*0.5+0.5*NeutronWall_NS::PlasticBar_Z))/(m_R[i]+NeutronWall_NS::NS_Z*0.5));
+        
+        if (m_VetoWall[i] == 1){
+            //Initialize property about the plastic bar, if exists
+            NeutronWall_NS::PlasticBar_X = NeutronWall_NS::Py_Xouter;
+            NeutronWall_NS::PlasticBar_Y = NeutronWall_NS::Py_Youter;
+            
+            // If VetoWall exists, then extend the space of NeutronWall_NS add 3mm to Z in order to house the 1mm seperation between front and back layer of the veto wall
+            NeutronWall_NS::NS_Z = 2.0*(m_VWDistance[i]+1.5*NeutronWall_NS::PlasticBar_Z+3.0*mm);
+        }
+        
+        G4RotationMatrix* Rot = new G4RotationMatrix(v,u,w);
+        
+        G4Material* ScintMaterial = MaterialManager::getInstance()->GetMaterialFromLibrary(m_NWMaterial[i]);
         G4Material* vacuum = MaterialManager::getInstance()->GetMaterialFromLibrary("Vacuum");
         G4Material* Aluminum = MaterialManager::getInstance()->GetMaterialFromLibrary("Al");
         G4Material* Pyrex = MaterialManager::getInstance()->GetMaterialFromLibrary("Pyrex");
@@ -312,57 +433,90 @@ void NeutronWall::ConstructDetector(G4LogicalVolume* world){
         m_NeutronWall_log = new G4LogicalVolume(NeutronWall_box,vacuum,"NeutronWall_Log",0,0,0);
         m_NeutronWall_log->SetVisAttributes(m_VisNW);
         
-        //Aluminum case
-        G4Box* AlCase_box = new G4Box("AlCase_Box",NeutronWall_NS::Al_X*0.5,NeutronWall_NS::Al_Y*0.5,NeutronWall_NS::Al_Z*0.5);
-        m_AlCase_log = new G4LogicalVolume(AlCase_box,Aluminum,"AlCase_Log",0,0,0);
+        //Aluminum inner box (subtractee)
+        G4Box* Alinner_box = new G4Box("Alinner_box",NeutronWall_NS::Alinner_X*0.5,NeutronWall_NS::Alinner_Y*0.5,NeutronWall_NS::Alinner_Z*0.5);
+        //Aluminum outer box (subtracter)
+        G4Box* Alouter_box = new G4Box("Alouter_box",NeutronWall_NS::Alouter_X*0.5,NeutronWall_NS::Alouter_Y*0.5,NeutronWall_NS::Alouter_Z*0.5);
+        
+        G4SubtractionSolid* AlCase_frame = new G4SubtractionSolid("AlCase_frame", Alouter_box, Alinner_box);
+        
+        m_AlCase_log = new G4LogicalVolume(AlCase_frame,Aluminum,"AlCase_Log",0,0,0);
         
         m_AlCase_log->SetVisAttributes(m_VisAl);
         
-        //Quartz tube volume
-        G4Box* Quartz_box = new G4Box("Quartz_Box",NeutronWall_NS::Py_X*0.5,NeutronWall_NS::Py_Y*0.5,NeutronWall_NS::Py_Z*0.5);
+        //Quartz tube
+        G4Box* Quartz_boxinner = new G4Box("Quartz_Boxinner",NeutronWall_NS::Py_Xinner*0.5,NeutronWall_NS::Py_Yinner*0.5,NeutronWall_NS::Py_Zinner*0.5);
+        G4Box* Quartz_boxouter = new G4Box("Quartz_Box",NeutronWall_NS::Py_Xouter*0.5,NeutronWall_NS::Py_Youter*0.5,NeutronWall_NS::Py_Zouter*0.5);
+        G4SubtractionSolid* Quartz_box = new G4SubtractionSolid("Quartz_box", Quartz_boxouter, Quartz_boxinner);
+        
         m_Quartz_log = new G4LogicalVolume(Quartz_box,Pyrex,"Quartz_Log",0,0,0);
         
         m_Quartz_log->SetVisAttributes(m_VisQuartz);
         
+        //??currently unused
         G4Tubs* QuartzCap_tube = new G4Tubs("QuartsCap_Tube",0,7.99*cm,0.3175*cm,0.0*deg,360.0*deg);
         m_QuartzCap_log = new G4LogicalVolume(QuartzCap_tube,Aluminum,"QuartzCap_Log",0,0,0);
         
-        //NE213 Volume
-        G4Box* NE213_box = new G4Box("NE213_Box",NeutronWall_NS::NE213_X*0.5,NeutronWall_NS::NE213_Y*0.5,NeutronWall_NS::NE213_Z*0.5);
-        m_NE213_log = new G4LogicalVolume(NE213_box,ScintMaterial,"NE213_Log",0,0,0);
+        //Scintillator
+        G4Box* Scintillator_box = new G4Box("Scintillator_Box",NeutronWall_NS::Scintillator_X*0.5,NeutronWall_NS::Scintillator_Y*0.5,NeutronWall_NS::Scintillator_Z*0.5);
+        m_Scintillator_log = new G4LogicalVolume(Scintillator_box,ScintMaterial,"Scintillator_Log",0,0,0);
         
-        m_NE213_log->SetVisAttributes(m_VisNE213);
-        m_NE213_log->SetSensitiveDetector(m_NeutronWallScorer);
+        m_Scintillator_log->SetVisAttributes(m_VisScintillator);
+        m_Scintillator_log->SetSensitiveDetector(m_NeutronWallScorer);
         
-        //Shadow bar construction
+        //Shadow bar construction??currently unused
         G4Trd* ShadowBar_trd = new G4Trd("ShadowBar_Trd",6.51/2*cm, 7.23/2*cm, 6.79/2*cm, 7.66/2*cm, 30./2*cm);
         m_ShadowBar_log = new G4LogicalVolume(ShadowBar_trd, Aluminum, "ShadowBar_Log");
         
         
-        //******************* Placement *******************//
-        m_NE213Tube_phys = new G4PVPlacement(0,G4ThreeVector(0,0,0),
-                                             m_NE213_log,
-                                             "NE213Tube_phys",
-                                             m_Quartz_log,
-                                             false,
-                                             0);
-        for (int j = 0; j < 12; j++ ) {
-            G4double detector_y = (j-6)*8.60*cm;
-            m_Quartz_phys = new G4PVPlacement(0,G4ThreeVector(0,detector_y,0),m_Quartz_log,
-                                            "Quartz_phys",m_NeutronWall_log,false,j);
+        if (m_VetoWall[i] == 1){
+            //Initialize total height
+            NeutronWall_NS::TotalHeightOfNeutronWall = m_Bars[i]*NeutronWall_NS::Py_Youter + (m_Bars[i]-1)*NeutronWall_NS::seperation_between_pyrex;
+            NeutronWall_NS::TotalHeightOfVetoWall = (m_Bars[i]+1)/2*NeutronWall_NS::PlasticBar_Y+(m_Bars[i]-1)/2*(NeutronWall_NS::PlasticBar_Y-2*m_Overlap[i]);
+            if (NeutronWall_NS::TotalHeightOfNeutronWall*NeutronWall_NS::ScaleDownFactor > NeutronWall_NS::TotalHeightOfVetoWall){
+                G4cout << "\t*************************************************************" <<endl;
+                G4cout << "\t* The shadow of VetoWall is not enough to cover NeutronWall *" <<endl;
+                G4cout << "\t*            Re-input VWDistance and Overlap                *" <<endl;
+                G4cout << "\t*************************************************************" <<endl;
+                exit(1);
+            }
+            //PlasticBar
+            G4Material* Plastic = MaterialManager::getInstance()->GetMaterialFromLibrary(m_VWMaterial[i]);
+            G4Box* PlasticBar_box = new G4Box("PlasticBar_Box", NeutronWall_NS::PlasticBar_X*0.5, NeutronWall_NS::PlasticBar_Y*0.5, NeutronWall_NS::PlasticBar_Z*0.5);
+            m_PlasticBar_log = new G4LogicalVolume(PlasticBar_box, Plastic, "PlasticBar_Log");
+            m_PlasticBar_log->SetSensitiveDetector(m_VetoWallScorer);
+            m_PlasticBar_log->SetVisAttributes(m_VisPlasticBar);
         }
         
+        
+        //******************* Placement *******************//
         //----Aluminum Case----
-        m_AlCase_phys = new G4PVPlacement(0,G4ThreeVector(0,0, 4.2*cm),m_AlCase_log,
+        m_AlCase_phys = new G4PVPlacement(0,G4ThreeVector(0,0,0),m_AlCase_log,
                                           "AlCase_phys",m_NeutronWall_log,false,0);
         
+        for (int j = 0; j < 25; j++ ) {
+            m_ScintillatorTube_phys = new G4PVPlacement(0,G4ThreeVector(0,(NeutronWall_NS::NS_Y*0.5-NeutronWall_NS::frame_thickness-NeutronWall_NS::upper_gap-NeutronWall_NS::Py_Youter*0.5-j*(NeutronWall_NS::Py_Youter+NeutronWall_NS::seperation_between_pyrex)),0),m_Scintillator_log,"ScintillatorTube_phys",m_NeutronWall_log,false,j);
+            m_Quartz_phys = new G4PVPlacement(0,G4ThreeVector(0*mm,(NeutronWall_NS::NS_Y*0.5-NeutronWall_NS::frame_thickness-NeutronWall_NS::upper_gap-NeutronWall_NS::Py_Youter*0.5-j*(NeutronWall_NS::Py_Youter+NeutronWall_NS::seperation_between_pyrex)),0*mm),m_Quartz_log,
+                                              "Quartz_phys",m_NeutronWall_log,false,j);
+        }
         
+        for(int j = 0; j<25; j++){
+            if (m_VetoWall[i] == 1){
+                G4ThreeVector VetoTransB = G4ThreeVector(0,0.5*NeutronWall_NS::TotalHeightOfVetoWall-0.5*NeutronWall_NS::PlasticBar_Y-(j/2)*(NeutronWall_NS::PlasticBar_Y+NeutronWall_NS::PlasticBar_Y-2*m_Overlap[i]),-m_VWDistance[i]);//+Det_pos;
+                G4ThreeVector VetoTransF = G4ThreeVector(0,0.5*NeutronWall_NS::TotalHeightOfVetoWall-1.5*NeutronWall_NS::PlasticBar_Y+m_Overlap[i]-(j/2)*(NeutronWall_NS::PlasticBar_Y+NeutronWall_NS::PlasticBar_Y-2*m_Overlap[i]),-m_VWDistance[i]-1*mm-NeutronWall_NS::PlasticBar_Z);//+Det_pos;
+                if (j%2 == 0){
+                    m_PlasticBar_phys = new G4PVPlacement(0,VetoTransB,m_PlasticBar_log,"PlasticBar_phys",m_NeutronWall_log,false,j);
+                }
+                else {
+                    m_PlasticBar_phys = new G4PVPlacement(0, VetoTransF,m_PlasticBar_log,"PlasticBar_phys",m_NeutronWall_log,false,j);
+                    
+                }
+            }
+        }
         /****************** Place the walls*************************/
         m_NeutronWall_phys = new G4PVPlacement(G4Transform3D(*Rot, Det_pos),
-                                                m_NeutronWall_log,
-                                                "NeutronWall_phys",world,false,i);
-
-
+                                               m_NeutronWall_log,
+                                               "NeutronWall_phys",world,false,i);
     }
 }
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
@@ -374,7 +528,7 @@ void NeutronWall::InitializeRootOutput(){
     pTree->Branch("NeutronWall", "TNeutronWallData", &m_Event) ;
     pTree->SetBranchAddress("NeutronWall", &m_Event) ;
 }
-
+//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 // Read sensitive part and fill the Root tree.
 // Called at in the EventAction::EndOfEventAvtion
@@ -398,18 +552,54 @@ void NeutronWall::ReadSensitive(const G4Event* event){
         double Energy = RandGauss::shoot(Info[0],NeutronWall_NS::ResoEnergy);
         if(Energy>NeutronWall_NS::EnergyThreshold){
             double Time = RandGauss::shoot(Info[1],NeutronWall_NS::ResoTime);
-            int DetectorNbr = (int) Info[2];
-            m_Event->SetEnergy(DetectorNbr,Energy);
-            m_Event->SetTime(DetectorNbr,Time);
+            int DetectorNbr = (int) Info[3];
+            int PadNbr = (int) Info[2];
+            //cout << Info[2] << " " << Info[3] << endl;
+            m_Event->SetEnergy(DetectorNbr,PadNbr,Energy);
+            m_Event->SetTime(DetectorNbr,PadNbr,Time);
         }
     }
     // clear map for next event
     CaloHitMap->clear();
+    
+    ///////////
+    // Veto wall scorer
+    G4THitsMap<G4double*>* VetoHitMap;
+    std::map<G4int, G4double**>::iterator Veto_itr;
+    
+    G4int VetoCollectionID = G4SDManager::GetSDMpointer()->GetCollectionID("VetoWallScorer/VetoCalorimeter");
+    VetoHitMap = (G4THitsMap<G4double*>*)(event->GetHCofThisEvent()->GetHC(VetoCollectionID));
+    
+    
+    // Loop on the Calo map
+    for (Veto_itr = VetoHitMap->GetMap()->begin() ; Veto_itr != VetoHitMap->GetMap()->end() ; Veto_itr++){
+        
+        G4double* Info = *(Veto_itr->second);
+        //(Info[0]/2.35)*((Info[0]*1.02)*pow((Info[0]*1.8),.5))
+        // double Energy = RandGauss::shoot(Info[0],((Info[0]*1000*1.02/2.35)*pow((Info[0]*1000*1.8),.5)) );
+        double Energy = RandGauss::shoot(Info[0],NeutronWall_NS::ResoEnergy);
+        if(Energy>NeutronWall_NS::EnergyThreshold){
+            double Time = RandGauss::shoot(Info[1],NeutronWall_NS::ResoTime);
+            int DetectorNbr = (int) Info[3];
+            int PadNbr = (int) Info[2];
+            
+            m_Event->SetVetoEnergy(DetectorNbr,PadNbr,Energy);
+            m_Event->SetVetoTime(DetectorNbr,PadNbr,Time);
+        }
+    }
+    // clear map for next event
+    VetoHitMap->clear();
+    
 }
 
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 ////////////////////////////////////////////////////////////////
 void NeutronWall::InitializeScorers() {
+    // Otherwise the scorer is initialised
+    vector<int> level;
+    level.push_back(0);
+    level.push_back(1);
+    
     // This check is necessary in case the geometry is reloaded
     bool already_exist = false;
     m_NeutronWallScorer = CheckScorer("NeutronWallScorer",already_exist) ;
@@ -417,12 +607,23 @@ void NeutronWall::InitializeScorers() {
     if(already_exist)
         return ;
     
-    // Otherwise the scorer is initialised
-    vector<int> level; level.push_back(0);
-    G4VPrimitiveScorer* Calorimeter= new CALORIMETERSCORERS::PS_Calorimeter("Calorimeter",level, 0) ;
-    //and register it to the multifunctionnal detector
+    // Neutron Wall Scorer
+    G4VPrimitiveScorer* Calorimeter= new CALORIMETERSCORERS::PS_Calorimeter("Calorimeter",level,1) ;
+    //and register it to the multifunctional detector
     m_NeutronWallScorer->RegisterPrimitive(Calorimeter);
     G4SDManager::GetSDMpointer()->AddNewDetector(m_NeutronWallScorer) ;
+    
+    
+    // Veto Wall Scorer
+    already_exist = false;
+    m_VetoWallScorer = CheckScorer("VetoWallScorer",already_exist) ;
+    if(already_exist)
+        return;
+    
+    G4VPrimitiveScorer* VetoCalorimeter= new CALORIMETERSCORERS::PS_Calorimeter("VetoCalorimeter",level,1) ;
+    //and register it to the multifunctional detector
+    m_VetoWallScorer->RegisterPrimitive(VetoCalorimeter);
+    G4SDManager::GetSDMpointer()->AddNewDetector(m_VetoWallScorer) ;
 }
 
 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
diff --git a/NPSimulation/Detectors/NeutronWall/NeutronWall.hh b/NPSimulation/Detectors/NeutronWall/NeutronWall.hh
index 934ddec2d6a8532cf81a92883c20c07d32b634b9..82576bc2a60715471ff571848d1f94fe1c123609 100644
--- a/NPSimulation/Detectors/NeutronWall/NeutronWall.hh
+++ b/NPSimulation/Detectors/NeutronWall/NeutronWall.hh
@@ -55,7 +55,13 @@ public:
                         double X,
                         double Y,
                         double Z,
-                        double Rotation);
+                        double Rotation,
+			int Bars,
+			string NWMaterial,
+			double VWDistance,
+			int VetoWall,
+			string VWMaterial,
+			double Overlap);
     
     void BuildDetector();
     
@@ -65,13 +71,15 @@ private:
     G4LogicalVolume* m_Quartz_log;
     G4LogicalVolume* m_QuartzCap_log;
     G4LogicalVolume* m_PMTube_log;
-    G4LogicalVolume* m_NE213_log;
+    G4LogicalVolume* m_Scintillator_log;
     G4LogicalVolume* m_ShadowBar_log;
+    G4LogicalVolume* m_PlasticBar_log;
     
-    G4VPhysicalVolume* m_NE213Tube_phys;
+    G4VPhysicalVolume* m_ScintillatorTube_phys;
     G4VPhysicalVolume* m_Quartz_phys;
     G4VPhysicalVolume* m_AlCase_phys;
     G4VPhysicalVolume* m_NeutronWall_phys;
+    G4VPhysicalVolume* m_PlasticBar_phys;
     
     ////////////////////////////////////////////////////
     //////  Inherite from NPS::VDetector class /////////
@@ -99,6 +107,7 @@ public:   // Scorer
     
     //   Associated Scorer
     G4MultiFunctionalDetector* m_NeutronWallScorer ;
+    G4MultiFunctionalDetector* m_VetoWallScorer ;
     ////////////////////////////////////////////////////
     ///////////Event class to store Data////////////////
     ////////////////////////////////////////////////////
@@ -117,13 +126,20 @@ private: // Geometry
     vector<double>  m_Y;
     vector<double>  m_Z;
     vector<double>  m_Rot;
+    vector<int>     m_Bars;
+    vector<string>  m_NWMaterial;
+    vector<double>  m_VWDistance;
+    vector<int>     m_VetoWall;
+    vector<string>  m_VWMaterial;
+    vector<double>  m_Overlap;
     
     
     // Visualisation Attribute
-    G4VisAttributes* m_VisNE213;
+    G4VisAttributes* m_VisScintillator;
     G4VisAttributes* m_VisQuartz;
     G4VisAttributes* m_VisAl;
     G4VisAttributes* m_VisNW;
+    G4VisAttributes* m_VisPlasticBar;
     
     // Needed for dynamic loading of the library
 public:
diff --git a/Projects/Lassa/Analysis.cxx b/Projects/Lassa/Analysis.cxx
index 7b40f5a52b8986cefb9fa650fdf3f429ebf5caf3..3e560153cc647bbaa08f67b73bb2711174b7f2bf 100644
--- a/Projects/Lassa/Analysis.cxx
+++ b/Projects/Lassa/Analysis.cxx
@@ -40,9 +40,6 @@ void Analysis::Init(){
     InitialConditions = new TInitialConditions();
     InitOutputBranch();
     InitInputBranch();
-    totalEvents = 0;
-    detectedEvents = 0;
-    peakEvents = 0;
     
     f_proton = new TF1("f_proton","1 - TMath::Exp(-(x-0.0918309)/27.7746)",0,10);
     f_deuton = new TF1("f_deuton","1 - TMath::Exp(-(x-0.0434552)/21.134)",0,10);
@@ -52,8 +49,14 @@ void Analysis::Init(){
     Proton_CsI = EnergyLoss("proton_CsI.G4table","G4Table",100 );
     Deuton_CsI = EnergyLoss("deuteron_CsI.G4table","G4Table",100 );
     Triton_CsI = EnergyLoss("triton_CsI.G4table","G4Table",100 );
+    He3_CsI = EnergyLoss("He3_CsI.G4table","G4Table",100 );
+
     
     proton = new NPL::Nucleus("1H");
+    deuton = new NPL::Nucleus("2H");
+    triton = new NPL::Nucleus("3H");
+    helium3 = new NPL::Nucleus("3He");
+    alpha = new NPL::Nucleus("4He");
     beam = new NPL::Nucleus("112Sn");
     target = new NPL::Nucleus("112Sn");
 }
@@ -79,21 +82,22 @@ void Analysis::TreatEvent(){
     double BetaCM = fEnergyImpulsionLab_total.Beta();
 
     
-    double ParticleEnergy = InitialConditions->GetKineticEnergy(0);
+    InitialEnergy = InitialConditions->GetKineticEnergy(0);
     double EDelta = 2.0;
 
-    InitialEnergy = ParticleEnergy;
-    //if(Lassa->ThickSi_E.size()>0) InitialEnergy = ParticleEnergy;
+    if(Lassa->ThickSi_E.size()>0) InitialEnergy_Lassa = InitialEnergy;
     double phi_in = acos(InitialConditions->GetMomentumDirectionX(0)/sin(InitialConditions->GetThetaCM(0)*deg));
-    if(InitialEnergy>0){
-        ECM_initial = proton->GetEnergyCM(InitialEnergy, InitialConditions->GetThetaCM(0)*deg, phi_in, BetaCM);
+    
+    ECM_initial = alpha->GetEnergyCM(InitialEnergy, InitialConditions->GetThetaCM(0)*deg, phi_in, BetaCM);
+    
+    if(Lassa->ThickSi_E.size()>0){
+        ECM_initial_Lassa = alpha->GetEnergyCM(InitialEnergy_Lassa, InitialConditions->GetThetaCM(0)*deg, phi_in, BetaCM);
     }
-    else ECM_initial = -100;
+    else ECM_initial_Lassa = -100;
     ///////////////////////////LOOP on Lassa Hit//////////////////////////////////
     if(Lassa->ThickSi_E.size() == 1){
         detectedEvents++;
         
-
         //for(unsigned int countLassa = 0 ; countLassa < Lassa->ThickSi_E.size(); countLassa++){
         TelescopeNumber = Lassa->TelescopeNumber[0];
 
@@ -133,6 +137,9 @@ void Analysis::TreatEvent(){
         if(Lassa->CsI_E.size()==1){
             E_CsI = Lassa->CsI_E[0];
             ELab += E_CsI;
+            
+            PID = pow(E_ThickSi+E_CsI,1.78)-pow(E_CsI,1.78);
+
             //Try to simulate the nuclear reaction loss
             //ThicknessCsI = Proton_CsI.EvaluateMaterialThickness(0*MeV, Lassa->CsI_E[0]*MeV, 200*millimeter, 0.1*millimeter);
             //ThicknessCsI = Deuton_CsI.EvaluateMaterialThickness(0*MeV, Lassa->CsI_E[0]*MeV, 200*millimeter, 0.1*millimeter);
@@ -148,14 +155,14 @@ void Analysis::TreatEvent(){
             
         }
     
-        if(fabs(ParticleEnergy-ELab)>EDelta){
+        if(fabs(InitialEnergy-ELab)>EDelta){
             ELab = -100;
         }
 
-        if(fabs(ParticleEnergy-ELab_nucl)>EDelta) ELab_nucl = -100;
+        if(fabs(InitialEnergy-ELab_nucl)>EDelta) ELab_nucl = -100;
         
         if(ELab>0){
-            ECM = proton->GetEnergyCM(ELab, ThetaLab, PhiLab, BetaCM);
+            ECM = alpha->GetEnergyCM(ELab, ThetaLab, PhiLab, BetaCM);
         }
         else ECM = -100;
         
@@ -189,10 +196,13 @@ void Analysis::InitOutputBranch() {
     RootOutput::getInstance()->GetTree()->Branch("ThetaLab",&ThetaLab,"ThetaLab/D");
     RootOutput::getInstance()->GetTree()->Branch("PhiLab",&PhiLab,"PhiLab/D");
     RootOutput::getInstance()->GetTree()->Branch("InitialEnergy",&InitialEnergy,"InitialEnergy/D");
+    RootOutput::getInstance()->GetTree()->Branch("InitialEnergy_Lassa",&InitialEnergy_Lassa,"InitialEnergy_Lassa/D");
     RootOutput::getInstance()->GetTree()->Branch("ECM_initial",&ECM_initial,"ECM_initial/D");
+    RootOutput::getInstance()->GetTree()->Branch("ECM_initial_Lassa",&ECM_initial_Lassa,"ECM_initial_Lassa/D");
     RootOutput::getInstance()->GetTree()->Branch("E_ThickSi",&E_ThickSi,"E_ThickSi/D");
     RootOutput::getInstance()->GetTree()->Branch("E_CsI",&E_CsI,"E_CsI/D");
     RootOutput::getInstance()->GetTree()->Branch("R_alpha",&R_alpha,"R_alpha/D");
+    RootOutput::getInstance()->GetTree()->Branch("PID",&PID,"PID/D");
     //  RootOutput::getInstance()->GetTree()->Branch("peakEvents",&peakEvents,"peakEvents/I");
 }
 
@@ -217,9 +227,12 @@ void Analysis::ReInitValue(){
     Z = -100;
     TelescopeNumber = -1;
     InitialEnergy = -100;
+    InitialEnergy_Lassa = -100;
+    ECM_initial_Lassa = -100;
     ECM_initial = -100;
     ThicknessCsI = -1;
     R_alpha = -100;
+    PID = -1;
 }
 
 ////////////////////////////////////////////////////////////////////////////////
diff --git a/Projects/Lassa/Analysis.h b/Projects/Lassa/Analysis.h
index 56796c57dc7d0e0e6ed656dd585dd1655b827019..14ccdd9f335b1c89db89468fca13a917794d255d 100644
--- a/Projects/Lassa/Analysis.h
+++ b/Projects/Lassa/Analysis.h
@@ -54,10 +54,13 @@ class Analysis: public NPL::VAnalysis{
     double TelescopeNumber;
     double thresholdEnergy;
     double InitialEnergy;
+    double InitialEnergy_Lassa;
     double ECM_initial;
+    double ECM_initial_Lassa;
     double ThicknessCsI;
     double R_alpha;
-
+    double PID;
+    
     int totalEvents;
     int detectedEvents;
     int peakEvents;
@@ -76,8 +79,13 @@ class Analysis: public NPL::VAnalysis{
     NPL::EnergyLoss Proton_CsI;
     NPL::EnergyLoss Deuton_CsI;
     NPL::EnergyLoss Triton_CsI;
+    NPL::EnergyLoss He3_CsI;
     
     NPL::Nucleus *proton;
+    NPL::Nucleus *deuton;
+    NPL::Nucleus *triton;
+    NPL::Nucleus *helium3;
+    NPL::Nucleus *alpha;
     NPL::Nucleus *beam;
     NPL::Nucleus *target;
     
diff --git a/Projects/Lassa/RunToTreat.txt b/Projects/Lassa/RunToTreat.txt
index ad4003db5e8eb9348ba767b403e2a391f15319fd..e13a324518cca0d05be9944222d179618b3206c2 100755
--- a/Projects/Lassa/RunToTreat.txt
+++ b/Projects/Lassa/RunToTreat.txt
@@ -1,7 +1,7 @@
 TTreeName 
 	SimulatedTree
 RootFileName 
-  ../../Outputs/Simulation/test2.root
+  ../../Outputs/Simulation/e09042_alphasource_nucl.root
   %../../Outputs/Simulation/lassa_pid_d.root
 	%../../Outputs/Simulation/lassa_pid_t.root
 
diff --git a/Projects/macros/GeometricalEfficiency.C b/Projects/macros/GeometricalEfficiency.C
index b82c1ba513d5a86501adfb9f587d713ad7b820a4..67ee4183bd70ab6246e9da0a2e96c93b9af8b594 100644
--- a/Projects/macros/GeometricalEfficiency.C
+++ b/Projects/macros/GeometricalEfficiency.C
@@ -48,7 +48,7 @@
 using namespace std;
 
 
-void GeometricalEfficiency(const char * fname = "hiraU_flat_nucl"){
+void GeometricalEfficiency(const char * fname = "hiraU_flat_p_nucl"){
   // Open output ROOT file from NPTool simulation run
   TString path = gSystem->Getenv("NPTOOL");
   path += "/Outputs/Simulation/";