-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathvalidateJR.sh
executable file
·73 lines (69 loc) · 2.8 KB
/
validateJR.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#!/bin/bash
baseA=$1
baseB=$2
diffN=$3
inList=$4
stepN=${5:-"all"}
#noMiniAOD=$5
function waitForProcesses {
pidList=${pidList}" "${!}
export pidList
echo $pidList
nRunning=`ps -p $pidList | grep -c "^[ ]*[1-9]"`
while ((nRunning > 10 )); do
nRunning=`ps -p $pidList | grep -c "^[ ]*[1-9]"`
#echo $nRunning "still above 5 -> sleep 10 "
sleep 10
done
cd ${cWD}
echo $pidList > ${llistF}
}
cWD=`pwd`
export pidList=""
llistF=lastlist_${diffN}.txt
echo Start processing at `date`
grep root ${inList} | grep -v "#" | while read -r dsN fNP procN procR comm; do
fN=`echo ${baseA}/${fNP} | cut -d" " -f1 | sed -e "s?^${baseA}/??g"`
#[ ! -f "${baseA}/${fN}" ] && echo Missing ${baseA}/${fN} && continue
if [ -f "${baseA}/${fN}" -a -f "${baseB}/${fN}" ]; then
extN=${stepN}_${diffN}_${dsN}
mkdir -p ${extN}
cd ${cWD}/${extN}
cp ~/tools/validate.C ./
echo "Will run on ${fN} in ${cWD}/${extN}"
echo "Now in `pwd`"
#g++ -shared -o validate.so validate.C `root-config --cflags ` -fPIC
echo -e "gSystem->Load(\"libFWCoreFWLite.so\");\n AutoLibraryLoader::enable();\n FWLiteEnabler::enable();\n
.x validate.C+(\"${extN}\", \"${baseA}/${fN}\", \"${baseB}/${fN}\", \"${procN}\", 0, \"${procR}\");\n .qqqqqq" | root -l -b >& ${extN}.log &
waitForProcesses
fi
fNBase=`echo ${fN} | sed -e 's/.root$//g'`
mFN="${fNBase}_inMINIAOD.root"
if [ ! -f "${baseA}/${mFN}" ]; then
mFN="${fNBase}_inMINIAODSIM.root"
fi
#if [ -f "${baseA}/${mFN}" ] && [ ! $noMiniAOD ]; then
if [ -f "${baseA}/${mFN}" -a -f "${baseB}/${mFN}" ]; then
echo $mFN
extmN=${stepN}_mini_${diffN}_${dsN}
mkdir -p ${extmN}
cd ${cWD}/${extmN}
cp ~/tools/validate.C ./
echo "Will run on ${mFN} in ${cWD}/${extmN}"
echo "Now in `pwd`"
echo -e "gSystem->Load(\"libFWCoreFWLite.so\");\n AutoLibraryLoader::enable();\n FWLiteEnabler::enable();\n
.x validate.C+(\"${extmN}\", \"${baseA}/${mFN}\", \"${baseB}/${mFN}\", \"${procN}\", 0, \"${procR}\");\n .qqqqqq" | root -l -b >& ${extmN}.log &
waitForProcesses
fi
#manually set the make flags, not needed in most cases
#gSystem->SetMakeSharedLib(\"cd \$BuildDir ;g++ -c \$Opt -pipe -m64 -Wshadow -Wall -W -Woverloaded-virtual -fPIC -std=c++11 -Wno-deprecated-declarations -DG__MAXSTRUCT=36000 -DG__MAXTYPEDEF=36000 -DG__LONGLINE=4096 -pthread \$IncludePath \$SourceFiles ; g++ \$ObjectFiles -shared -Wl,-soname,\$LibName.so -m64 -Wl,--hash-style=gnu -O2 \$LinkedLibs -o \$SharedLib\");\n
#cout<< gSystem->GetMakeSharedLib()<<endl ;\n
done
allPids=`cat ${llistF}`
nRunning=1
while (( nRunning > 0 )); do
nRunning=`ps -p $allPids | grep -c "^[ ]*[1-9]"`
#echo $nRunning
sleep 10
done
echo done at `date`