Ignore:
Timestamp:
06/17/08 13:06:44 (17 years ago)
Author:
hoehne
Message:
*** empty log message ***
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/datacenter/scripts/mcsequences

    r8763 r8967  
    1919#
    2020#   Author(s): Daniela Dorner  12/2005 <mailto:dorner@astro.uni-wuerzburg.de>
    21 #
    22 #   Copyright: MAGIC Software Development, 2000-2007
     21#   Author(s): Daniela Dorner  06/2008 <mailto:hoehne@astro.uni-wuerzburg.de>
     22#
     23#   Copyright: MAGIC Software Development, 2000-2008
    2324#
    2425#
    2526# ========================================================================
    2627#
    27 # This script is an intermediate solution to process the montecarlo files.
    28 # As soon as the montecarlo database is running, this script shall be
    29 # exchanged.
    30 #
    31 # The script is building one sequence per directory. As the files are
    32 # structured by condition, the files in one directory and such in one
    33 # sequence have the same observation mode, psf, zbin, ...
     28# The script is building two sequences per directory and epoch. One for
     29# training and one for testing. The relevant parameters are taken from
     30# the MC database.
    3431#
    3532
     
    4643lockfile=$lockpath/lock-$program.txt
    4744checklock  >> $scriptlog 2>&1
    48 
    49 # find montecarlo directories, build one sequence per directory and write sequence file
    50 printprocesslog "INFO building one sequence per mcdirectory and epoch"
    51 
    52 user="test"
    53 db="TestMonteCarlo"
    54 pw="Ics+eaTD"
     45                                             
     46# find montecarlo directories, build two sequences per directory and write sequence files
     47printprocesslog "INFO building two sequences per mcdirectory and epoch, one for training and one for testing"
     48
     49#user="test"
     50#db="TestMonteCarlo"
     51#pw="Ics+eaTD"
     52user="operator"
     53db="MyMagicMonteCarlo"
     54pw="Ics+eMM!"
    5555
    5656dirs=`find $mcrawpath -type d`
    5757for dir in ${dirs[@]}
    5858do
    59    cont=`echo $dir | cut -d/ -f6`
    60 #   cont=`echo $dir | cut -d/ -f10`
     59   cont=`echo $dir | cut -d/ -f7`
     60   #cont=`echo $dir | cut -d/ -f10`
    6161   if [ "$cont" == "" ]
    6262   then
     
    6565   echo $dir >> $scriptlog 2>&1
    6666   
    67    epochs=`ls -l $mcpath/camera | cut -c 52-70`
     67   epochs=`ls -l $mcpath/camera | cut -c 52-80`
    6868   for epoch in ${epochs[@]}
    6969   do
     
    8181         if [ "$datruns" != "" ]
    8282         then
     83            num=`echo $datruns | wc -w`
     84            train=`expr $num / 5`
     85            test=`expr $num - $train`
     86            last=`expr $num \* 9`
     87            train2=`expr $train \* 9`
    8388            firstrun=`echo $datruns | cut -c 0-8`
     89            trainruns=`echo $datruns | cut -c 0-$train2`
     90            trainruns2=`echo $trainruns | sed -e 's/ /,/g'`
     91            testruns=`echo $datruns | cut -c $train2-$last`
     92            testruns2=`echo $testruns | sed -e 's/ /,/g'`
     93            firstruntrain=`echo $trainruns | cut -c 0-8`
     94            firstruntest=`echo $testruns | cut -c 0-8`
     95
    8496            date=`echo $dir | cut -c 28-37 | sed -e 's/\//-/g'`
    8597            #date=`echo $dir | cut -c 57-66 | sed -e 's/\//-/g'`
    8698            zbin=`echo $date | cut -c 3,4`
    87            
    88             for datrun in ${datruns[@]}
     99
     100
     101            #training runs
     102            for trainrun in ${trainruns[@]}
    89103            do
    90                update=" update MCRunData set fSequenceFirst=\"$firstrun\" where fRunNumber=\"$datrun\" "
    91                mysql -ss -u $user --password=$pw --host=vela $db -e " $update "
     104               trainupdate=" update MCRunData set fSequenceFirst=\"$firstruntrain\" where fRunNumber=\"$trainrun\" "
     105               mysql -ss -u $user --password=$pw --host=vela $db -e " $trainupdate "
    92106            done   
    93107
    94             query=" select fSpectrumKEY, fPSFKEY, fAmplFadcKEY, fAtmosphericModelKEY, fObservationModeKEY, fMCParticleKEY, fReflectorVersionKEY, fCorsikaVersionKEY, fCameraVersionKEY, fViewConeAngleOKEY from MCRunData where fRunNumber=\"$firstrun\" "
    95             values=`mysql -ss -u $user --password=$pw --host=vela $db -e " $query "`
    96             spec=`echo $values | cut -d" " -f1`
    97             psf=`echo $values | cut -d" " -f2`
    98             amplfadc=`echo $values | cut -d" " -f3`
    99             atmo=`echo $values | cut -d" " -f4`
    100             obs=`echo $values | cut -d" " -f5`
    101             part=`echo $values | cut -d" " -f6`
    102             refl=`echo $values | cut -d" " -f7`
    103             cors=`echo $values | cut -d" " -f8`
    104             cam=`echo $values | cut -d" " -f9`
    105             view=`echo $values | cut -d" " -f10`
    106             query1=" select fSequenceFirst from MCSequenceProcessStatus where fSequenceFirst=\"$firstrun\" "
    107             query2=" select fSequenceFirst from MCSequences where fSequenceFirst=\"$firstrun\" "
    108             check1=`mysql -ss -u $user --password=$pw --host=vela $db -e " $query1 "`
    109             check2=`mysql -ss -u $user --password=$pw --host=vela $db -e " $query2 "`
    110             insert1=" insert MCSequenceProcessStatus set fSequenceFirst=\"$firstrun\", fSequenceFileWritten=Now() "
    111             insert2=" insert MCSequences set fSequenceFirst=\"$firstrun\", fRunStart=\"$date\", fZBin=\"$zbin\", fSpectrumKEY=\"$spec\", fPSFKEY=\"$psf\", fAmplFadcKEY=\"$amplfadc\", fAtmosphericModelKEY=\"$atmo\", fObservationModeKEY=\"$obs\", fMCParticleKEY=\"$part\", fReflectorVersionKEY=\"$refl\", fCorsikaVersionKEY=\"$cors\", fCameraVersionKEY=\"$cam\", fViewConeAngleOKEY=\"$view\" "
    112             update2=" update MCSequences set fRunStart=\"$date\", fZBin=\"$zbin\", fSpectrumKEY=\"$spec\", fPSFKEY=\"$psf\", fAmplFadcKEY=\"$amplfadc\", fAtmosphericModelKEY=\"$atmo\", fObservationModeKEY=\"$obs\", fMCParticleKEY=\"$part\", fReflectorVersionKEY=\"$refl\", fCorsikaVersionKEY=\"$cors\", fCameraVersionKEY=\"$cam\", fViewConeAngleOKEY=\"$view\" where fSequenceFirst=\"$firstrun\" "
    113             if [ "$check1" == "" ]
    114             then
    115                mysql -ss -u $user --password=$pw --host=vela $db -e " $insert1 "
    116             fi
    117             if [ "$check2" == "" ]
    118             then
    119                mysql -ss -u $user --password=$pw --host=vela $db -e " $insert2 "
     108            trainquery1=" select fSpectrumKEY, fPSFKEY, fAmplFadcKEY, fAtmosphericModelKEY, fObservationModeKEY, fMCParticleKEY, fReflectorVersionKEY, fCorsikaVersionKEY, fCameraVersionKEY, fViewConeAngleOKEY, fAddSpotSizeKEY from MCRunData where fRunNumber=\"$firstruntrain\" "
     109            trainquery2=" select sum(fNumEvents), sum(fNumtriggers) from MCRunData where fRunNumber in ($trainruns2) "
     110            trainvalues=`mysql -ss -u $user --password=$pw --host=vela $db -e " $trainquery1 "`
     111            trainvalues2=`mysql -ss -u $user --password=$pw --host=vela $db -e " $trainquery2 "`
     112            trainspec=`echo $trainvalues | cut -d" " -f1`
     113            trainpsf=`echo $trainvalues | cut -d" " -f2`
     114            trainamplfadc=`echo $trainvalues | cut -d" " -f3`
     115            traintrainatmo=`echo $trainvalues | cut -d" " -f4`
     116            trainobs=`echo $trainvalues | cut -d" " -f5`
     117            trainpart=`echo $trainvalues | cut -d" " -f6`
     118            trainrefl=`echo $trainvalues | cut -d" " -f7`
     119            traincors=`echo $trainvalues | cut -d" " -f8`
     120            traincam=`echo $trainvalues | cut -d" " -f9`
     121            trainview=`echo $trainvalues | cut -d" " -f10`
     122            trainass=`echo $trainvalues | cut -d" " -f11`
     123            trainevents=`echo $trainvalues2 | cut -d" " -f1`
     124            traintriggers=`echo $trainvalues2 | cut -d" " -f2`
     125            trainquery3=" select fSequenceFirst from MCSequenceProcessStatus where fSequenceFirst=\"$firstruntrain\" "
     126            trainquery4=" select fSequenceFirst from MCSequences where fSequenceFirst=\"$firstruntrain\" "
     127            traincheck3=`mysql -ss -u $user --password=$pw --host=vela $db -e " $trainquery3 "`
     128            traincheck4=`mysql -ss -u $user --password=$pw --host=vela $db -e " $trainquery4 "`
     129            traininsert1=" insert MCSequenceProcessStatus set fSequenceFirst=\"$firstruntrain\", fSequenceFileWritten=Now() "
     130            traininsert2=" insert MCSequences set fSequenceFirst=\"$firstruntrain\", fRunStart=\"$date\", fNumEvents=\"$trainevents\", fNumTriggers=\"$traintriggers\", fZBin=\"$zbin\", fSpectrumKEY=\"$trainspec\", fPSFKEY=\"$trainpsf\", fAddSpotSizeKEY=\"$trainass\", fAmplFadcKEY=\"$trainamplfadc\", fAtmosphericModelKEY=\"$trainatmo\", fObservationModeKEY=\"$trainobs\", fMCParticleKEY=\"$trainpart\", fReflectorVersionKEY=\"$trainrefl\", fCorsikaVersionKEY=\"$traincors\", fCameraVersionKEY=\"$traincam\", fViewConeAngleOKEY=\"$trainview\", fTestTrainKEY=2 "
     131            trainupdate2=" update MCSequences set fRunStart=\"$date\", fNumEvents=\"$trainevents\", fNumTriggers=\"$traintriggers\", fZBin=\"$zbin\", fSpectrumKEY=\"$trainspec\", fPSFKEY=\"$trainpsf\", fAddSpotSizeKEY=\"$trainass\", fAmplFadcKEY=\"$trainamplfadc\", fAtmosphericModelKEY=\"$trainatmo\", fObservationModeKEY=\"$trainobs\", fMCParticleKEY=\"$trainpart\", fReflectorVersionKEY=\"$trainrefl\", fCorsikaVersionKEY=\"$traincors\", fCameraVersionKEY=\"$traincam\", fViewConeAngleOKEY=\"$trainview\", fTestTrainKEY=2 where fSequenceFirst=\"$firstruntrain\" "
     132            if [ "$traincheck3" == "" ]
     133            then
     134               mysql -ss -u $user --password=$pw --host=vela $db -e " $traininsert1 "
     135            fi
     136            if [ "$traincheck4" == "" ]
     137            then
     138               mysql -ss -u $user --password=$pw --host=vela $db -e " $traininsert2 "
    120139            else
    121                mysql -ss -u $user --password=$pw --host=vela $db -e " $update2 "
     140               mysql -ss -u $user --password=$pw --host=vela $db -e " $trainupdate2 "
    122141            fi
    123142           
    124             no=`echo $firstrun | cut -c 0-4`
    125             sequpath=$mcsequpath/$no
    126             makedir $sequpath >> $scriptlog 2>&1
    127             sequfile=$sequpath/sequence$firstrun.txt
    128             echo "writing sequfile "$sequfile >> $scriptlog 2>&1
    129             printprocesslog "INFO writing sequencefile $sequfile"
     143            trainno=`echo $firstruntrain | cut -c 0-4`
     144            trainsequpath=$mcsequpath/$trainno
     145            makedir $trainsequpath >> $scriptlog 2>&1
     146            trainsequfile=$trainsequpath/sequence$firstruntrain.txt
     147            echo "writing train sequfile "$trainsequfile >> $scriptlog 2>&1
     148            printprocesslog "INFO writing train sequencefile $trainsequfile"
    130149   
    131             echo "Sequence:        $firstrun" >| $sequfile
    132             echo "Night:           $date" >> $sequfile
    133             echo "Epoch:           $epoch" >> $sequfile
    134             echo "Mode:            $mode" >> $sequfile
    135             echo "" >> $sequfile
    136             echo "CalRuns:         $calrun" >> $sequfile
    137             echo "PedRuns:         $pedrun" >> $sequfile
    138             echo "DatRuns:         $datruns" >> $sequfile
    139             echo "" >> $sequfile
    140             echo "MonteCarlo: Yes" >> $sequfile
    141             echo "" >> $sequfile
     150            echo "Sequence:        $firstruntrain" >| $trainsequfile
     151            echo "Night:           $date" >> $trainsequfile
     152            echo "Epoch:           $epoch" >> $trainsequfile
     153            echo "Mode:            $mode" >> $trainsequfile
     154            echo "" >> $trainsequfile
     155            echo "CalRuns:         $calrun" >> $trainsequfile
     156            echo "PedRuns:         $pedrun" >> $trainsequfile
     157            echo "DatRuns:         $trainruns" >> $trainsequfile
     158            echo "" >> $trainsequfile
     159            echo "MonteCarlo: Yes" >> $trainsequfile
     160            echo "Training sequence" >> $trainsequfile
     161            echo "" >> $trainsequfile
     162
     163
     164            #test runs
     165            for testrun in ${testruns[@]}
     166            do
     167               testupdate=" update MCRunData set fSequenceFirst=\"$firstruntest\" where fRunNumber=\"$testrun\" "
     168               mysql -ss -u $user --password=$pw --host=vela $db -e " $testupdate "
     169            done   
     170
     171            testquery1=" select fSpectrumKEY, fPSFKEY, fAmplFadcKEY, fAtmosphericModelKEY, fObservationModeKEY, fMCParticleKEY, fReflectorVersionKEY, fCorsikaVersionKEY, fCameraVersionKEY, fViewConeAngleOKEY, fAddSpotSizeKEY from MCRunData where fRunNumber=\"$firstruntest\" "
     172            testquery2=" select sum(fNumEvents), sum(fNumtriggers) from MCRunData where fRunNumber in ($testruns2) "
     173            testvalues=`mysql -ss -u $user --password=$pw --host=vela $db -e " $testquery1 "`
     174            testvalues2=`mysql -ss -u $user --password=$pw --host=vela $db -e " $testquery2 "`
     175            testspec=`echo $testvalues | cut -d" " -f1`
     176            testpsf=`echo $testvalues | cut -d" " -f2`
     177            testamplfadc=`echo $testvalues | cut -d" " -f3`
     178            testatmo=`echo $testvalues | cut -d" " -f4`
     179            testobs=`echo $testvalues | cut -d" " -f5`
     180            testpart=`echo $testvalues | cut -d" " -f6`
     181            testrefl=`echo $testvalues | cut -d" " -f7`
     182            testcors=`echo $testvalues | cut -d" " -f8`
     183            testcam=`echo $testvalues | cut -d" " -f9`
     184            testview=`echo $testvalues | cut -d" " -f10`
     185            testass=`echo $testvalues | cut -d" " -f11`
     186            testevents=`echo $testvalues2 | cut -d" " -f1`
     187            testtriggers=`echo $testvalues2 | cut -d" " -f2`
     188            testquery3=" select fSequenceFirst from MCSequenceProcessStatus where fSequenceFirst=\"$firstruntest\" "
     189            testquery4=" select fSequenceFirst from MCSequences where fSequenceFirst=\"$firstruntest\" "
     190            testcheck3=`mysql -ss -u $user --password=$pw --host=vela $db -e " $testquery3 "`
     191            testcheck4=`mysql -ss -u $user --password=$pw --host=vela $db -e " $testquery4 "`
     192            testinsert1=" insert MCSequenceProcessStatus set fSequenceFirst=\"$firstruntest\", fSequenceFileWritten=Now() "
     193            testinsert2=" insert MCSequences set fSequenceFirst=\"$firstruntest\", fRunStart=\"$date\", fNumEvents=\"$testevents\", fNumTriggers=\"$testtriggers\", fZBin=\"$zbin\", fSpectrumKEY=\"$testspec\", fPSFKEY=\"$testpsf\", fAddSpotSizeKEY=\"$testass\", fAmplFadcKEY=\"$testamplfadc\", fAtmosphericModelKEY=\"$testatmo\", fObservationModeKEY=\"$testobs\", fMCParticleKEY=\"$testpart\", fReflectorVersionKEY=\"$testrefl\", fCorsikaVersionKEY=\"$testcors\", fCameraVersionKEY=\"$testcam\", fViewConeAngleOKEY=\"$testview\", fTestTrainKEY=3 "
     194            testupdate2=" update MCSequences set fRunStart=\"$date\", fNumEvents=\"$testevents\", fNumTriggers=\"$testtriggers\", fZBin=\"$zbin\", fSpectrumKEY=\"$testspec\", fPSFKEY=\"$testpsf\", fAddSpotSizeKEY=\"$testass\", fAmplFadcKEY=\"$testamplfadc\", fAtmosphericModelKEY=\"$testatmo\", fObservationModeKEY=\"$testobs\", fMCParticleKEY=\"$testpart\", fReflectorVersionKEY=\"$testrefl\", fCorsikaVersionKEY=\"$testcors\", fCameraVersionKEY=\"$testcam\", fViewConeAngleOKEY=\"$testview\", fTestTrainKEY=3 where fSequenceFirst=\"$firstruntest\" "
     195            if [ "$testcheck3" == "" ]
     196            then
     197               mysql -ss -u $user --password=$pw --host=vela $db -e " $testinsert1 "
     198            fi
     199            if [ "$testcheck4" == "" ]
     200            then
     201               mysql -ss -u $user --password=$pw --host=vela $db -e " $testinsert2 "
     202            else
     203               mysql -ss -u $user --password=$pw --host=vela $db -e " $testupdate2 "
     204            fi
     205           
     206            testno=`echo $firstruntest | cut -c 0-4`
     207            testsequpath=$mcsequpath/$testno
     208            makedir $testsequpath >> $scriptlog 2>&1
     209            testsequfile=$testsequpath/sequence$firstruntest.txt
     210            echo "writing test sequfile "$testsequfile >> $scriptlog 2>&1
     211            printprocesslog "INFO writing test sequencefile $testsequfile"
     212   
     213            echo "Sequence:        $firstruntest" >| $testsequfile
     214            echo "Night:           $date" >> $testsequfile
     215            echo "Epoch:           $epoch" >> $testsequfile
     216            echo "Mode:            $mode" >> $testsequfile
     217            echo "" >> $testsequfile
     218            echo "CalRuns:         $calrun" >> $testsequfile
     219            echo "PedRuns:         $pedrun" >> $testsequfile
     220            echo "DatRuns:         $testruns" >> $testsequfile
     221            echo "" >> $testsequfile
     222            echo "MonteCarlo: Yes" >> $testsequfile
     223            echo "Test sequence" >> $testsequfile
     224            echo "" >> $testsequfile
    142225         fi
    143226      done
Note: See TracChangeset for help on using the changeset viewer.