00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00015 #include "Calibrator/CalTempCalibration.h"
00016 #include "MessageService/MsgService.h"
00017 #include "DatabaseInterface/DbiOutRowStream.h"
00018 #include "DatabaseInterface/DbiResultSet.h"
00019 #include "DatabaseInterface/DbiValidityRec.h"
00020
00021 #define REFTEMP 18.0 // reference temperature
00022 #define TCONVERT_M -0.016 // conversion factors: temperature->light output
00023 #define TCONVERT_ICEPT 4.342 // from linear fit
00024
00025 ClassImp(CalTempCalibration)
00026
00027
00028
00029
00030 CVSID("$Id: CalTempCalibration.cxx,v 1.4 2005/03/11 16:17:48 west Exp $\n \
00031 CVSID_DBIRESULTPTR ");
00032
00033
00034
00035
00036 #include "DatabaseInterface/DbiResultPtr.tpl"
00037 template class DbiResultPtr<CalTempCalibration>;
00038
00039 #include "DatabaseInterface/DbiWriter.tpl"
00040 template class DbiWriter<CalTempCalibration>;
00041
00042
00043
00044
00045
00046
00047
00048 void CalTempCalibration::Fill(DbiResultSet& rs,
00049 const DbiValidityRec* ) {
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075 if ( rs.TableName() == "CALTEMPCALIBRATION" ) {
00076
00077 rs >> fTemp >> fTempErr;
00078 }
00079 else {
00080
00081
00082 Int_t numCol = rs.NumCols();
00083
00084 for (Int_t curCol = rs.HasRowCounter() ? 3 : 2; curCol <= numCol; ++curCol) {
00085 string colName = rs.CurColName();
00086 if ( colName == "TEMP" ) rs >> fTemp;
00087 else if ( colName == "TEMPERR" ) rs >> fTempErr;
00088 else {
00089 MSG("Dbi",Msg::kDebug) << "Ignoring column " << curCol
00090 << "(" << colName << ")"
00091 << "; not part of CalTempCalibration"
00092 << endl;
00093 rs.IncrementCurCol();
00094 }
00095 }
00096 }
00097
00098
00099 }
00100
00101
00102
00103 void CalTempCalibration::Store(DbiOutRowStream& ors,
00104 const DbiValidityRec* ) const {
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128 ors << fTemp << fTempErr;
00129
00130 }
00131
00132
00133
00134 Float_t CalTempCalibration::GetCorrection() const {
00135
00136 return (REFTEMP*TCONVERT_M + TCONVERT_ICEPT)
00137 /(fTemp*TCONVERT_M + TCONVERT_ICEPT);
00138
00139 }
00140
00141 Float_t CalTempCalibration::GetCorrected(const Float_t rawcharge) const {
00142
00143
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162 Float_t cor = GetCorrection();
00163
00164 MSG("Calib",Msg::kVerbose) << " Input " << rawcharge
00165 << " Temp " << fTemp
00166 << " Corrected "
00167 << cor*rawcharge << "\n";
00168 return (cor*rawcharge);
00169 }
00170
00171
00172
00173
00174
00175
00176
00177
00178
00179
00180
00181
00182
00183
00184
00185
00186
00187
00188
00189
00190
00191
00192
00193
00194
00195