00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00015
00016 #include "Calibrator/CalMapperFits.h"
00017 #include "MessageService/MsgService.h"
00018 #include "DatabaseInterface/DbiOutRowStream.h"
00019 #include "DatabaseInterface/DbiResultSet.h"
00020 #include "DatabaseInterface/DbiValidityRec.h"
00021 #include <cmath>
00022
00023 ClassImp(CalMapperFits)
00024
00025 CVSID("$Id: CalMapperFits.cxx,v 1.15 2007/01/15 19:52:01 rhatcher Exp $\n \
00026 CVSID_DBIRESULTPTR ");
00027
00028
00029
00030
00031 #include "DatabaseInterface/DbiResultPtr.tpl"
00032 template class DbiResultPtr<CalMapperFits>;
00033
00034 #include "DatabaseInterface/DbiWriter.tpl"
00035 template class DbiWriter<CalMapperFits>;
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 void CalMapperFits::Fill(DbiResultSet& rs,
00047 const DbiValidityRec* ) {
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073 if ( rs.TableName() == "CALMAPPERFITS" ) {
00074
00075 rs >> fSEIDkey >> fStripEndId >> fTestID >> fStripNum >> fStripEnd >> fNorm >> fNPoints >> fC1 >> fC1Err >> fLambda1 >> fLambda1Err >> fC2 >> fC2Err >> fLambda2 >> fLambda2Err;
00076 }
00077 else {
00078
00079
00080 Int_t numCol = rs.NumCols();
00081
00082 for (Int_t curCol = rs.HasRowCounter() ? 3 : 2; curCol <= numCol; ++curCol) {
00083 string colName = rs.CurColName();
00084 if ( colName == "STRIPENDID" ) rs >> fStripEndId;
00085 else if( colName == "SEIDKEY" ) rs >> fSEIDkey;
00086 else if( colName == "TESTID" ) rs >> fTestID;
00087 else if( colName == "STRIPNUM" ) rs >> fStripNum;
00088 else if( colName == "STRIPEND" ) rs >> fStripEnd;
00089 else if( colName == "NORM" ) rs >> fNorm;
00090 else if( colName == "NPOINTS" ) rs >> fNPoints;
00091 else if( colName == "C1" ) rs >> fC1;
00092 else if( colName == "C1ERR" ) rs >> fC1Err;
00093 else if( colName == "LAMBDA1" ) rs >> fLambda1;
00094 else if( colName == "LAMBDA1ERR" ) rs >> fLambda1Err;
00095 else if( colName == "C2" ) rs >> fC2;
00096 else if( colName == "C2ERR" ) rs >> fC2Err;
00097 else if( colName == "LAMBDA2" ) rs >> fLambda2;
00098 else if( colName == "LAMBDA2ERR" ) rs >> fLambda2Err;
00099 else {
00100 MSG("Dbi",Msg::kDebug) << "Ignoring column " << curCol
00101 << "(" << colName << ")"
00102 << "; not part of CalMapperFits"
00103 << endl;
00104 rs.IncrementCurCol();
00105 }
00106 }
00107 }
00108
00109 }
00110
00111
00112
00113 void CalMapperFits::Store(DbiOutRowStream& ors,
00114 const DbiValidityRec* ) const {
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138 ors << fSEIDkey << fStripEndId << fTestID << fStripNum << fStripEnd << fNorm << fNPoints << fC1 << fC1Err << fLambda1 << fLambda1Err << fC2 << fC2Err << fLambda2 << fLambda2Err;
00139
00140 }
00141
00142
00143
00144 Float_t CalMapperFits::AttenCorrected(const Float_t rawcharge, const Float_t Y) const {
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166 Float_t Corr = fC1 * exp(-Y/fLambda1) + fC2 * exp(-Y/fLambda2);
00167
00168 MSG("Calib",Msg::kVerbose) << "StripEndId " << fStripEndId
00169 << " raw charge " << rawcharge
00170 << " C1 " << fC1
00171 << " C2 " << fC2
00172 << " Lambda1 " << fLambda1
00173 << " Lambda2 " << fLambda2
00174 << " Y " << Y
00175 << " Corr " << Corr
00176 << " Atten Corrected "
00177 << rawcharge/Corr << "\n";
00178 return (rawcharge / Corr);
00179 }
00180
00181