Produce and read microDSTs using the Grid
Producing microDSTs standalone
Getting the relevant packages and setting the environment
SetupProject DaVinci v22r0p2 --build-env
SetupProject DaVinci v22r0p2
getpack Phys/DaVinci v22r0p2
getpack PhysSel/Ccbar
getpack Ex/MicroDSTExample
cd ${User_release_area}/DaVinci_v22r0p2/Phys/DaVinci_v22r0p2/Phys/DaVinci/cmt
gmake
cd ${User_release_area}/DaVinci_v22r0p2/Ex/MicroDSTExample/cmt
gmake
cd ${User_release_area}/DaVinci_v22r0p2/PhysSel/Ccbar/cmt
gmake
Making the microDST
Do
cd ${User_release_area}/DaVinci_v22r0p2/Ex/MicroDSTExample/job
gaudirun.py ../options/TestMicroDSTMake.py
ls -ltr
You should now see a .dst file in this directory which has just been created. For this standalone production of microDSTs take care that the following lines are set properly in the file ${User_release_area}/DaVinci_v22r0p2/Ex/MicroDSTExample/options/TestMicroDSTMake.py:
#importOptions( "$MICRODSTEXAMPLEROOT/options/JpsiPhiDataLFN.py") importOptions( "$MICRODSTEXAMPLEROOT/options/JpsiPhiDataPFN.py")
This takes care of using the PFN (physical file name) this time instead of the LFN (logical file name), which we will use later working with the Grid.
Producing microDSTs on the Grid
Become a gRidder
First obtain a Grid Certificate from the Dutch Grid CA.
When you've done this, become a member of the LHCb VO by following this link.
To use the Grid from lxplus you need to copy your certificate to lxplus. You do this by copying the entire .globus directory to your home on lxplus.
Configure Ganga
To setup Ganga do
GangaEnv
Now we still have to configure the file ${User_release_area}/DaVinci_v22r0p2/Ex/MicroDSTExample/job/MicroDST_Ganga.py
First set the correct DaVinci version in this line:
dv = DaVinci( version = 'v22r0p2' )
Now choose the desired backend. To run jobs on the Grid uncomment
#j.backend = Dirac()
ISSUE WITH LFN's PFN's?
When all options are set correctly, submit the jobs:
ganga MicroDST_Ganga.py
This is where you will be asked for your Grid Password. If you work on a 64-bit machine (which you do when logged in on lxplus) you get an error message saying that only slc4_ia32_gcc34 is allowed on the Grid. So you should type
setenv CMTCONFIG slc4_ia32_gcc34
Now the jobs will be submitted. For some general Ganga commands take a look here.
Now the output of these jobs (in this case the microDSTs) will go to your ~/gangadir. But if you are generating a lot of possibly large files, it is more convenient to let Ganga send these files somewhere else.
If in your ~/.gangarc file you change the following line
outputsandbox_types = ['NTupleSvc', 'HistogramPersistencySvc', 'MicroDSTStream\']
into this one
outputsandbox_types = []
the MicroDSTStream does not go to your outputsandbox, but to 'dataoutput' which is the Grid SE (Storage Element), so in case of backend.Dirac() it is
/castor/cern.ch/grid/lhcb/user/<letter>/<UID>/<first four digits of jobID>/<jobID>
Where <letter> stands for the first letter in your Cern User ID <UID>.
While if you chose backend.Local() then 'dataoutput' is
/castor/cern.ch/user/<letter>/<UID>/<ganga jobnumber>/outputdata
You find the jobID in the following way: In Ganga do
jobs(<gangajobnr>).backend.id
or in case you splitted the job in subjobs:
jobs("<gangajobnr.subjobnumber>").backend.id
Basic Castor commands
Here are some basic commands that you can use on Castor:
- Copy a file from a local directory to CASTOR:
- rfcp MyFileName /castor/cern.ch/user/<letter>/<UID>/MyDirectory/MyFileName
- Copy a file from CASTOR to a local directory:
- rfcp /castor/cern.ch/user/<letter>/<UID>/MyDirectory/MyFileName MyFileName
- Copy a file from one CASTOR location to another:
- rfcp /castor/cern.ch/user/<letter>/<UID>/MyDirectory1/MyFileName1 /castor/cern.ch/<letter>/<UID>/MyDirectory2/MyFileName2
- Delete a file from CASTOR (to delete a directory use option -r):
- rfrm /castor/cern.ch/user/<letter>/<UID>/MyDirectory/MyFileName
- Create a directory in CASTOR:
- rfmkdir /castor/cern.ch/user/<letter>/<UID>/MyNewDirectory/
- Move a file in CASTOR:
- rfrename /castor/cern.ch/user/<letter>/<UID>/MyDirectory/MyOldFileName /castor/cern.ch/<letter>/<UID>/MyDirectory/MyNewFileName
- List the contents of a CASTOR directory:
- rfdir /castor/cern.ch/user/<letter>/<UID>/MyDirectory
or
- nsls -l /castor/cern.ch/user/<letter>/<UID>/MyDirectory
Copying microDSTs from Grid to Sara Tier1
First we want to make a directory at the Sara Tier1 where we can store our files.
Find Gerhard's script
then your grid script
then rfmkdir
Now we can copy the files from Castor to the LHCb storage on the Sara Amsterdam Tier1. We can do this either by starting the Dirac environment (CHECKTHIS!)
Or by manually entering the following that enabels us to use the lcg-cp command:
Do:
lhcb-proxy-init source /afs/cern.ch/project/gd/LCG-Share/current/etc/profile.d/grid_env.csh
Now you can use the lcg-commands. Look here for an explanation of some lcg commands.
For copying use:
lcg-cp -v srm://srm-lhcb.cern.ch/castor/cern.ch/grid/lhcb/user/<letter>/<UID>/MyFileName srm://tbn18.nikhef.nl/dpm/nikhef.nl/home/lhcb/<username>/MyFileName
The directory
Stageing the Sara microDSTs on Stoomboot
Reading microDSTs
microDSTReadingExample.py
of maak wat nieuws in Bender
Analysis
P2VV
getpack PhysFit/P2VV getpack PhysFit/P2VVPython
and use the RooFit based fit package