diff --git a/NPAnalysis/MUGAST/Analysis.cxx b/NPAnalysis/MUGAST/Analysis.cxx
new file mode 100755
index 0000000000000000000000000000000000000000..4849a27d93ec319a547ed1f02744becf92f1f8ea
--- /dev/null
+++ b/NPAnalysis/MUGAST/Analysis.cxx
@@ -0,0 +1,283 @@
+#include "Analysis.h"
+
+int main(int argc, char** argv){
+  // command line parsing
+  NPOptionManager* myOptionManager = NPOptionManager::getInstance(argc,argv);
+
+  // Instantiate RootInput
+  string runToReadfileName = myOptionManager->GetRunToReadFile();
+  RootInput:: getInstance("RunToTreat.txt");
+  TChain* Chain = RootInput:: getInstance()->GetChain();
+  // if input files are not given, use those from TAsciiFile
+  if (myOptionManager->IsDefault("DetectorConfiguration")) {
+    string name = RootInput::getInstance()->DumpAsciiFile("DetectorConfiguration");
+    myOptionManager->SetDetectorFile(name);
+  }
+
+  if (myOptionManager->IsDefault("EventGenerator")) {
+    string name = RootInput::getInstance()->DumpAsciiFile("EventGenerator");
+    myOptionManager->SetReactionFile(name);
+  }
+
+  // get input files from NPOptionManager
+  string detectorfileName    = myOptionManager->GetDetectorFile();
+  string OutputfileName      = myOptionManager->GetOutputFile();
+
+  // Instantiate RootOutput
+  RootOutput::getInstance("Analysis/"+OutputfileName, "ResultTree");
+  // RootOutput::getInstance()->GetFile()->SetCompressionLevel(0);
+  // Instantiate the detector using a file
+  NPA::DetectorManager* myDetector = new DetectorManager();
+  myDetector->ReadConfigurationFile(detectorfileName);
+  // Attach new branch
+  InitOutputBranch();
+  InitInputBranch();
+
+  //	Instantiate the Reaction
+  NPL::Reaction*  myReaction = new Reaction ;
+  myReaction	->	ReadConfigurationFile(myOptionManager->GetReactionFile());
+
+  ////////////////////////////////////////////////////////
+  // Get pointer to the different detector
+
+  TMust2Physics* M2  = (TMust2Physics*) myDetector -> GetDetector("MUST2");
+  GaspardTracker* GD = (GaspardTracker*)  myDetector -> GetDetector("GASPARD");
+
+  // Beam Energy
+  double BeamEnergy = 4.0* 74; // AMEV
+
+  // intermediate variable
+  TRandom3 Rand = TRandom3();
+  int DetectorNumber = 0 ;
+  double ThetaNormalTarget = 0 ;
+  double ThetaM2Surface = 0; 
+  double X_M2 = 0 ;
+  double Y_M2 = 0 ;
+  double Z_M2 = 0 ;
+  double Si_E_M2 = 0 ;
+  double CsI_E_M2 = 0 ; 
+  double Energy = 0;
+  double E_M2 = 0;
+  double Si_X_M2 = 0;
+  double Si_Y_M2 = 0;
+  double ZTarget = 0;
+  double TargetThickness = 9*micrometer;
+
+  double ThetaGDSurface = 0; 
+  double X_GD = 0 ;
+  double Y_GD = 0 ;
+  double Z_GD = 0 ;
+  double Si_E_GD = 0 ;
+  double E_GD = 0;
+  double Si_X_GD = 0;
+  double Si_Y_GD = 0;
+ 
+  
+  // Get number of events to treat
+  cout << endl << "///////// Starting Analysis ///////// "<< endl;
+  int nentries = Chain->GetEntries();
+  cout << " Number of Event to be treated : " << nentries << endl;
+  clock_t begin = clock();
+  clock_t end = begin;
+  cout.precision(5);
+  //////////////////////////////////////////////////////////////////////////////
+  // main loop on entries //
+  for (int i = 0 ; i < nentries; i++) {
+    if (i%10000 == 0 && i!=0)  {
+      end = clock();
+      long double TimeElapsed = (long double) (end-begin) / CLOCKS_PER_SEC;
+      double percent = (double)i/nentries;
+      double TimeToWait = (TimeElapsed/percent) - TimeElapsed;       
+      cout  << "                                                      "<< flush;
+      cout  << "\r Progression:" 
+        << percent*100 << " % \t | \t Remaining time : ~" 
+        <<  TimeToWait <<"s |  Analysis Rate : "
+        << (double) i/TimeElapsed << flush;
+    }
+    else if (i == nentries-1)  cout << "\r Progression:" << " 100% " <<endl;
+    // Get the raw Data
+    Chain -> GetEntry(i);
+    // Clear previous Event
+    myDetector->ClearEventPhysics();
+    // Build the current event
+    myDetector->BuildPhysicalEvent();
+    // Reinitiate calculated variable
+    ReInitValue();
+    
+    // Get the Init information on beam position and energy
+    // and apply by hand the experimental resolution
+    // This is because the beam diagnosis are not simulated
+    // PPAC position resolution on target is assumed to be 1mm
+    double XTarget = 0;
+    double YTarget = 0;
+    TVector3 BeamDirection = TVector3(0,0,1);
+
+    // Beam energy is measured using F3 and F2 plastic TOF
+    BeamEnergy = BeamCD2.Slow(BeamEnergy,TargetThickness/2.,0);
+    myReaction->SetBeamEnergy(BeamEnergy);
+
+    //////////////////////////// LOOP on MUST2 //////////////////
+    for(unsigned int countMust2 = 0 ; countMust2 < M2->Si_E.size() ; countMust2++){
+      /************************************************/
+      //Part 0 : Get the usefull Data
+      // MUST2
+      int X = M2->Si_X[countMust2];
+      int Y = M2->Si_Y[countMust2];
+      int TelescopeNumber = M2->TelescopeNumber[countMust2];
+      Si_X_M2 = X ;
+      Si_Y_M2 = Y ;
+
+      /************************************************/
+      // Part 1 : Impact Angle
+      ThetaM2Surface = 0;
+      ThetaNormalTarget = 0;
+      if(XTarget>-1000 && YTarget>-1000){
+        TVector3 BeamImpact(XTarget,YTarget,0);
+        TVector3 HitDirection = M2 -> GetPositionOfInteraction(countMust2) - BeamImpact ;
+        ThetaLab = HitDirection.Angle( BeamDirection );
+
+        ThetaM2Surface = HitDirection.Angle(- M2 -> GetTelescopeNormal(countMust2) );
+        ThetaNormalTarget = HitDirection.Angle( TVector3(0,0,1) ) ;
+        X_M2 = M2 -> GetPositionOfInteraction(countMust2).X() ;
+        Y_M2 = M2 -> GetPositionOfInteraction(countMust2).Y() ;
+        Z_M2 = M2 -> GetPositionOfInteraction(countMust2).Z() ;
+      }
+
+      else{
+        BeamDirection = TVector3(-1000,-1000,-1000);
+        ThetaM2Surface    = -1000  ;
+        ThetaNormalTarget = -1000  ;
+      }
+
+      /************************************************/
+
+      /************************************************/
+      // Part 2 : Impact Energy
+      Energy = ELab = 0;
+      Si_E_M2 = M2->Si_E[countMust2];
+      CsI_E_M2= M2->CsI_E[countMust2];
+
+      // if CsI
+      if(CsI_E_M2>0 ){
+        // The energy in CsI is calculate form dE/dx Table because 
+        // 20um resolution is poor
+        Energy = 
+          LightSi.EvaluateEnergyFromDeltaE(Si_E_M2,300*micrometer,
+              ThetaM2Surface, 0.01*MeV, 
+              450.*MeV,0.001*MeV ,1000);
+        E_M2=CsI_E_M2;
+      }
+
+      else
+        Energy = Si_E_M2;
+
+      E_M2 += Si_E_M2;
+
+      // Evaluate energy using the thickness 
+      ELab = LightAl.EvaluateInitialEnergy( Energy ,0.4*micrometer , ThetaM2Surface); 
+      // Target Correction
+      ELab   = LightCD2.EvaluateInitialEnergy( ELab ,TargetThickness/2., ThetaNormalTarget);
+      /************************************************/
+
+      /************************************************/
+      // Part 3 : Excitation Energy Calculation
+      Ex = myReaction -> ReconstructRelativistic( ELab , ThetaLab );
+      ThetaLab=ThetaLab/deg;
+      /************************************************/
+
+      /************************************************/
+      // Part 4 : Theta CM Calculation
+      ThetaCM  = myReaction -> EnergyLabToThetaCM( ELab , 0)/deg;
+      /************************************************/
+    }//end loop MUST2
+    
+    ////////////////////////////////////////////////////////////////////////////
+    ////////////////////////////////////////////////////////////////////////////
+    //////////////////////////// LOOP on GASPARD //////////////////
+    if(GD->GetEnergyDeposit()>0){
+      /************************************************/
+      // Part 1 : Impact Angle
+      ThetaGDSurface = 0;
+      ThetaNormalTarget = 0;
+      if(XTarget>-1000 && YTarget>-1000){
+        TVector3 BeamImpact(XTarget,YTarget,0);
+        TVector3 HitDirection = GD -> GetPositionOfInteraction() - BeamImpact ;
+        ThetaLab = HitDirection.Angle( BeamDirection );
+
+        ThetaGDSurface = HitDirection.Angle( TVector3(0,0,1) ) ;
+        ThetaNormalTarget = HitDirection.Angle( TVector3(0,0,1) ) ;
+        X_GD = GD -> GetPositionOfInteraction().X() ;
+        Y_GD = GD -> GetPositionOfInteraction().Y() ;
+        Z_GD = GD -> GetPositionOfInteraction().Z() ;
+      }
+
+      else{
+        BeamDirection = TVector3(-1000,-1000,-1000);
+        ThetaGDSurface    = -1000  ;
+        ThetaNormalTarget = -1000  ;
+      }
+
+      /************************************************/
+
+      /************************************************/
+      // Part 2 : Impact Energy
+      Energy = ELab = 0;
+      Energy = GD->GetEnergyDeposit();
+      
+      ELab = LightAl.EvaluateInitialEnergy( Energy ,0.4*micrometer , ThetaGDSurface); 
+      // Target Correction
+      ELab   = LightCD2.EvaluateInitialEnergy( ELab ,TargetThickness/2., ThetaNormalTarget);
+      /************************************************/
+
+      /************************************************/
+      // Part 3 : Excitation Energy Calculation
+      Ex = myReaction -> ReconstructRelativistic( ELab , ThetaLab );
+      if(Ex!=Ex){
+        cout << ELab << " " << ThetaLab << " " << Ex<< endl;
+      }
+      ThetaLab=ThetaLab/deg;
+      /************************************************/
+
+      /************************************************/
+      // Part 4 : Theta CM Calculation
+      ThetaCM  = myReaction -> EnergyLabToThetaCM( ELab , 0)/deg;
+      /************************************************/
+    }//end loop GASPARD
+
+    if(ELab>0)
+      RootOutput::getInstance()->GetTree()->Fill();
+   }// loop over events
+
+  cout << "A total of " << nentries << " event has been annalysed " << endl ;
+
+  RootOutput::getInstance()->Destroy();
+  RootInput::getInstance()->Destroy();
+  NPOptionManager::getInstance()->Destroy();
+  /////////////////////////////////////////////////////////////////////////////
+  return 0 ;
+}
+
+////////////////////////////////////////////////////////////////////////////////
+void InitOutputBranch() {
+  RootOutput::getInstance()->GetTree()->Branch("Ex",&Ex,"Ex/D");
+  RootOutput::getInstance()->GetTree()->Branch("ELab",&ELab,"ELab/D");
+  RootOutput::getInstance()->GetTree()->Branch("ThetaLab",&ThetaLab,"ThetaLab/D");
+  RootOutput::getInstance()->GetTree()->Branch("ThetaCM",&ThetaCM,"ThetaCM/D");
+}
+
+////////////////////////////////////////////////////////////////////////////////
+void InitInputBranch(){
+  RootInput:: getInstance()->GetChain()->SetBranchAddress("InitialConditions",&Init );
+  RootInput:: getInstance()->GetChain()->SetBranchStatus("InitialConditions",true );
+  RootInput:: getInstance()->GetChain()->SetBranchStatus("fIC_*",true );
+}
+////////////////////////////////////////////////////////////////////////////////     
+void ReInitValue(){
+  Ex = -1000 ;
+  ELab = -1000;
+  ThetaLab = -1000;
+  ThetaCM = -1000;
+}
+
+
+////////////////////////////////////////////////////////////////////////////////
diff --git a/NPAnalysis/MUGAST/Analysis.h b/NPAnalysis/MUGAST/Analysis.h
new file mode 100755
index 0000000000000000000000000000000000000000..4e36754d2768993edc66b6412c673760b983ee2e
--- /dev/null
+++ b/NPAnalysis/MUGAST/Analysis.h
@@ -0,0 +1,67 @@
+// You can use this file to declare your spectra, file, energy loss , ... and whatever you want.
+// This way you can remove all unnecessary declaration in the main programm.
+// In order to help debugging and organizing we use Name Space.
+
+/////////////////////////////////////////////////////////////////////////////////////////////////
+// -------------------------------------- VARIOUS INCLUDE ---------------------------------------
+
+// NPL
+#include "DetectorManager.h"
+#include "NPOptionManager.h"
+#include "NPReaction.h"
+#include "RootInput.h"
+#include "RootOutput.h"
+#include "TMust2Physics.h"
+#include "GaspardTracker.h"
+
+#include "TInitialConditions.h"
+#include "NPEnergyLoss.h"
+using namespace NPL ;
+// STL C++
+#include <iostream>
+#include <fstream>
+#include <sstream>
+#include <string>
+#include <cmath>
+#include <cstdlib>
+using namespace std;
+// ROOT
+#include <TROOT.h>
+#include <TChain.h>
+#include <TFile.h>
+#include <TVector3.h>
+#include <TRandom3.h>
+#include <TMath.h>
+#include <TObject.h>
+
+// ----------------------------------------------------------------------------------------------
+void InitOutputBranch() ;
+void InitInputBranch() ;
+void ReInitValue() ;
+/////////////////////////////////////////////////////////////////////////////////////////////////
+// ----------------------------------- DOUBLE, INT, BOOL AND MORE -------------------------------
+namespace VARIABLE{
+  double Ex;
+  double ELab;
+  double ThetaLab;
+  double ThetaCM;
+  TInitialConditions* Init = new TInitialConditions();
+}
+
+using namespace VARIABLE ;
+// ----------------------------------------------------------------------------------------------
+/////////////////////////////////////////////////////////////////////////////////////////////////
+// -----------------------------------ENERGY LOSS----------------------------------------------
+namespace ENERGYLOSS{
+  //	Energy loss table: the G4Table are generated by the simulation
+  EnergyLoss LightCD2 = EnergyLoss("proton_CD2.G4table","G4Table",100 );
+  EnergyLoss LightAl = EnergyLoss("proton_Al.G4table","G4Table",10);
+  EnergyLoss LightSi = EnergyLoss("proton_Si.G4table","G4Table",10);
+  EnergyLoss BeamCD2 = EnergyLoss("Kr74[0.0]_CD2.G4table","G4Table",100);
+}
+
+using namespace ENERGYLOSS ;
+// ----------------------------------------------------------------------------------------------
+/////////////////////////////////////////////////////////////////////////////////////////////////
+
+
diff --git a/NPAnalysis/MUGAST/Makefile b/NPAnalysis/MUGAST/Makefile
new file mode 100755
index 0000000000000000000000000000000000000000..abdac126fca99a6b559dbcf1b3f71fbd0baa1c94
--- /dev/null
+++ b/NPAnalysis/MUGAST/Makefile
@@ -0,0 +1,31 @@
+# include same architecture file than for NPLib
+# so that consistency is ensured
+include $(NPLIB)/Makefile.arch
+
+# additional libraries
+LIBRARY  = `$(NPLIB)/liblist`
+LIBRARY += -L$(CLHEP_LIB_DIR) -l$(CLHEP_LIB)
+
+PROGRAMS	= NPAnalysis
+
+all:	$(PROGRAMS)
+
+NPAnalysis:	Analysis.o
+	$(LD) $(LDFLAGS) $^ $(LIBS) $(LIBRARY) $(OutPutOpt) $@
+	@echo "$@ done"
+	
+
+# rule for creating .o from .cxx
+.SUFFIXES: .$(SrcSuf)
+.$(SrcSuf).$(ObjSuf):
+	$(CXX) $(CXXFLAGS) $(INCLUDE) -c $<
+
+# some cleaning
+clean:
+	rm -rf *.o
+
+distclean:
+	make clean; rm $(PROGRAMS)
+
+# dependences
+Analysis.o:	Analysis.cxx	Analysis.h
diff --git a/NPAnalysis/MUGAST/NPAnalysis b/NPAnalysis/MUGAST/NPAnalysis
new file mode 100755
index 0000000000000000000000000000000000000000..0d3882cc25d0c134a2037c81bb354721d0ab6dd2
Binary files /dev/null and b/NPAnalysis/MUGAST/NPAnalysis differ
diff --git a/NPAnalysis/MUGAST/RunToTreat.txt b/NPAnalysis/MUGAST/RunToTreat.txt
new file mode 100755
index 0000000000000000000000000000000000000000..237ac3af20e33924cd9305e8124184068af7fe29
--- /dev/null
+++ b/NPAnalysis/MUGAST/RunToTreat.txt
@@ -0,0 +1,5 @@
+TTreeName 
+	SimulatedTree
+RootFileName 
+	../../Outputs/Simulation/myResult.root
+
diff --git a/NPAnalysis/MUGAST/configs/ConfigMust2.dat b/NPAnalysis/MUGAST/configs/ConfigMust2.dat
new file mode 100755
index 0000000000000000000000000000000000000000..2c36d1d62aba8284349f5afb674c5f63153299da
--- /dev/null
+++ b/NPAnalysis/MUGAST/configs/ConfigMust2.dat
@@ -0,0 +1,26 @@
+ConfigMust2
+	MAX_STRIP_MULTIPLICITY 1
+	STRIP_ENERGY_MATCHING_NUMBER_OF_SIGMA 5
+  	STRIP_ENERGY_MATCHING_SIGMA 0.02
+	DISABLE_CHANNEL MM1STRY12
+	DISABLE_CHANNEL MM2STRY12
+	DISABLE_CHANNEL MM3STRY12
+	DISABLE_CHANNEL MM4STRY12
+	DISABLE_CHANNEL MM1STRX12
+   DISABLE_CHANNEL MM2STRX12
+   DISABLE_CHANNEL MM3STRX12
+   DISABLE_CHANNEL MM4STRX12
+	DISABLE_CHANNEL MM1STRY124
+	DISABLE_CHANNEL MM4STRX3 
+	DISABLE_CHANNEL MM4STRX4
+	DISABLE_CHANNEL MM4STRX5
+	DISABLE_CHANNEL MM4STRX6
+	DISABLE_CHANNEL MM4STRX8
+	DISABLE_CHANNEL MM4STRX31
+	DISABLE_ALL MM5
+	DISABLE_ALL MM6
+	DISABLE_ALL MM7
+	DISABLE_ALL MM8
+	SI_X_E_RAW_THRESHOLD 0
+  	CSI_E_RAW_THRESHOLD 0
+  	CSI_SIZE 256
diff --git a/NPAnalysis/MUGAST/configs/ConfigSSSD.dat b/NPAnalysis/MUGAST/configs/ConfigSSSD.dat
new file mode 100755
index 0000000000000000000000000000000000000000..a56fa0b905431080044528396495a410ba90dc7b
--- /dev/null
+++ b/NPAnalysis/MUGAST/configs/ConfigSSSD.dat
@@ -0,0 +1,4 @@
+ConfigSSSD
+  PEDESTAL_THRESHOLD 0
+  DISABLE_CHANNEL SI2STR1
+  DISABLE_CHANNEL SI4STR13