CMS 3D CMS Logo

Public Member Functions | Private Member Functions | Private Attributes | Friends

CaliTempDat Class Reference

#include <CaliTempDat.h>

Inheritance diagram for CaliTempDat:
IDataItem IDBObject

List of all members.

Public Member Functions

 CaliTempDat ()
float getBeta () const
float getOffset () const
float getR25 () const
std::string getTable ()
bool getTaskStatus () const
void setBeta (float c)
void setOffset (float c)
void setR25 (float c)
void setTaskStatus (bool s)
 ~CaliTempDat ()

Private Member Functions

void fetchData (std::map< EcalLogicID, CaliTempDat > *fillVec, CaliIOV *iov) throw (std::runtime_error)
void prepareWrite () throw (std::runtime_error)
void writeArrayDB (const std::map< EcalLogicID, CaliTempDat > *data, CaliIOV *iov) throw (std::runtime_error)
void writeDB (const EcalLogicID *ecid, const CaliTempDat *item, CaliIOV *iov) throw (std::runtime_error)

Private Attributes

float m_beta
float m_offset
float m_r25
bool m_taskStatus

Friends

class EcalCondDBInterface

Detailed Description

Definition at line 12 of file CaliTempDat.h.


Constructor & Destructor Documentation

CaliTempDat::CaliTempDat ( )

Definition at line 12 of file CaliTempDat.cc.

References NULL.

{
  m_env = NULL;
  m_conn = NULL;
  m_writeStmt = NULL;

  m_beta = 0;
  m_r25 = 0;
  m_offset = 0;
  m_taskStatus = false;
}
CaliTempDat::~CaliTempDat ( )

Definition at line 26 of file CaliTempDat.cc.

{
}

Member Function Documentation

void CaliTempDat::fetchData ( std::map< EcalLogicID, CaliTempDat > *  fillVec,
CaliIOV iov 
) throw (std::runtime_error) [private]

Definition at line 79 of file CaliTempDat.cc.

References alignCSCRings::e, edm::pset::fillMap(), o2o::iov, AlCaHLTBitMon_ParallelJobs::p, setBeta(), setOffset(), setR25(), and setTaskStatus().

{
  this->checkConnection();
  fillMap->clear();
  
  iov->setConnection(m_env, m_conn);
  int iovID = iov->fetchID();
  if (!iovID) { 
    //  throw(std::runtime_error("CaliTempDat::writeDB:  IOV not in DB")); 
    return;
  }
  
  try {
    
    m_readStmt->setSQL("SELECT cv.name, cv.logic_id, cv.id1, cv.id2, cv.id3, cv.maps_to, "
                 "d.beta, d.r25, d.offset, d.task_status "
                 "FROM channelview cv JOIN cali_temp_dat d "
                 "ON cv.logic_id = d.logic_id AND cv.name = cv.maps_to "
                 "WHERE d.iov_id = :iov_id");
    m_readStmt->setInt(1, iovID);
    ResultSet* rset = m_readStmt->executeQuery();
    
    std::pair< EcalLogicID, CaliTempDat > p;
    CaliTempDat dat;
    while(rset->next()) {
      p.first = EcalLogicID( rset->getString(1),     // name
                             rset->getInt(2),        // logic_id
                             rset->getInt(3),        // id1
                             rset->getInt(4),        // id2
                             rset->getInt(5),        // id3
                             rset->getString(6));    // maps_to
      
      dat.setBeta( rset->getFloat(7) );
      dat.setR25( rset->getFloat(8) );
      dat.setOffset( rset->getFloat(9) );
      dat.setTaskStatus( rset->getInt(10) );
      
      p.second = dat;
      fillMap->insert(p);
    }
  } catch (SQLException &e) {
    throw(std::runtime_error("CaliTempDat::fetchData():  "+e.getMessage()));
  }
}
float CaliTempDat::getBeta ( ) const [inline]

Definition at line 22 of file CaliTempDat.h.

References m_beta.

Referenced by writeArrayDB().

{ return m_beta; }
float CaliTempDat::getOffset ( ) const [inline]

Definition at line 28 of file CaliTempDat.h.

References m_offset.

Referenced by writeArrayDB().

{ return m_offset; }
float CaliTempDat::getR25 ( ) const [inline]

Definition at line 25 of file CaliTempDat.h.

References m_r25.

Referenced by writeArrayDB().

{ return m_r25; }
std::string CaliTempDat::getTable ( ) [inline, virtual]

Implements IDataItem.

Definition at line 19 of file CaliTempDat.h.

{ return "CALI_TEMP_DAT"; }
bool CaliTempDat::getTaskStatus ( ) const [inline]

Definition at line 31 of file CaliTempDat.h.

References m_taskStatus.

Referenced by writeArrayDB().

{ return m_taskStatus; }
void CaliTempDat::prepareWrite ( ) throw (std::runtime_error) [private, virtual]

Implements IDataItem.

Definition at line 32 of file CaliTempDat.cc.

References alignCSCRings::e.

{
  this->checkConnection();
  
  try {
    m_writeStmt = m_conn->createStatement();
    m_writeStmt->setSQL("INSERT INTO cali_temp_dat (iov_id, logic_id, "
                        " beta, r25, offset,  task_status) "
                        "VALUES (:iov_id, :logic_id, "
                        ":3, :4, :5, :6 )");
  } catch (SQLException &e) {
    throw(std::runtime_error("CaliTempDat::prepareWrite():  "+e.getMessage()));
  }
}
void CaliTempDat::setBeta ( float  c) [inline]

Definition at line 21 of file CaliTempDat.h.

References trackerHits::c, and m_beta.

Referenced by fetchData().

{ m_beta = c; }
void CaliTempDat::setOffset ( float  c) [inline]

Definition at line 27 of file CaliTempDat.h.

References trackerHits::c, and m_offset.

Referenced by fetchData().

{ m_offset = c; }
void CaliTempDat::setR25 ( float  c) [inline]

Definition at line 24 of file CaliTempDat.h.

References trackerHits::c, and m_r25.

Referenced by fetchData().

{ m_r25 = c; }
void CaliTempDat::setTaskStatus ( bool  s) [inline]

Definition at line 30 of file CaliTempDat.h.

References m_taskStatus, and alignCSCRings::s.

Referenced by fetchData().

{ m_taskStatus = s; }
void CaliTempDat::writeArrayDB ( const std::map< EcalLogicID, CaliTempDat > *  data,
CaliIOV iov 
) throw (std::runtime_error) [private]

Definition at line 125 of file CaliTempDat.cc.

References prof2calltree::count, data, alignCSCRings::e, getBeta(), EcalLogicID::getLogicID(), getOffset(), getR25(), getTaskStatus(), o2o::iov, AlCaHLTBitMon_ParallelJobs::p, x, detailsBasic3DVector::y, and z.

{
  this->checkConnection();
  this->checkPrepare();

  int iovID = iov->fetchID();
  if (!iovID) { throw(std::runtime_error("CaliTempDat::writeArrayDB:  IOV not in DB")); }


  int nrows=data->size();
  int* ids= new int[nrows];
  int* iovid_vec= new int[nrows];
  float* xx= new float[nrows];
  float* yy= new float[nrows];
  float* zz= new float[nrows];
  int* st= new int[nrows];

  ub2* ids_len= new ub2[nrows];
  ub2* iov_len= new ub2[nrows];
  ub2* x_len= new ub2[nrows];
  ub2* y_len= new ub2[nrows];
  ub2* z_len= new ub2[nrows];
  ub2* st_len= new ub2[nrows];

  const EcalLogicID* channel;
  const CaliTempDat* dataitem;
  int count=0;
  typedef map< EcalLogicID, CaliTempDat >::const_iterator CI;
  for (CI p = data->begin(); p != data->end(); ++p) {
    channel = &(p->first);
    int logicID = channel->getLogicID();
    if (!logicID) { throw(std::runtime_error("CaliTempDat::writeArrayDB:  Bad EcalLogicID")); }
    ids[count]=logicID;
    iovid_vec[count]=iovID;

    dataitem = &(p->second);
    // dataIface.writeDB( channel, dataitem, iov);
    float x=dataitem->getBeta();
    float y=dataitem->getR25();
    float z=dataitem->getOffset();
    int statu=dataitem->getTaskStatus();



    xx[count]=x;
    yy[count]=y;
    zz[count]=z;
    st[count]=statu;


    ids_len[count]=sizeof(ids[count]);
    iov_len[count]=sizeof(iovid_vec[count]);

    x_len[count]=sizeof(xx[count]);
    y_len[count]=sizeof(yy[count]);
    z_len[count]=sizeof(zz[count]);
    st_len[count]=sizeof(st[count]);

    count++;
  }


  try {
    m_writeStmt->setDataBuffer(1, (dvoid*)iovid_vec, OCCIINT, sizeof(iovid_vec[0]),iov_len);
    m_writeStmt->setDataBuffer(2, (dvoid*)ids, OCCIINT, sizeof(ids[0]), ids_len );
    m_writeStmt->setDataBuffer(3, (dvoid*)xx, OCCIFLOAT , sizeof(xx[0]), x_len );
    m_writeStmt->setDataBuffer(4, (dvoid*)yy, OCCIFLOAT , sizeof(yy[0]), y_len );
    m_writeStmt->setDataBuffer(5, (dvoid*)zz, OCCIFLOAT , sizeof(zz[0]), z_len );
    m_writeStmt->setDataBuffer(6, (dvoid*)st, OCCIINT , sizeof(st[0]), st_len );


    m_writeStmt->executeArrayUpdate(nrows);

    delete [] ids;
    delete [] iovid_vec;
    delete [] xx;
    delete [] yy;
    delete [] zz;
    delete [] st;


    delete [] ids_len;
    delete [] iov_len;
    delete [] x_len;
    delete [] y_len;
    delete [] z_len;

    delete [] st_len;



  } catch (SQLException &e) {
    throw(std::runtime_error("MonPedestalsDat::writeArrayDB():  "+e.getMessage()));
  }
}
void CaliTempDat::writeDB ( const EcalLogicID ecid,
const CaliTempDat item,
CaliIOV iov 
) throw (std::runtime_error) [private]

Definition at line 50 of file CaliTempDat.cc.

References alignCSCRings::e, and o2o::iov.

{
  this->checkConnection();
  this->checkPrepare();
  
  int iovID = iov->fetchID();
  if (!iovID) { throw(std::runtime_error("CaliTempDat::writeDB:  IOV not in DB")); }
  
  int logicID = ecid->getLogicID();
  if (!logicID) { throw(std::runtime_error("CaliTempDat::writeDB:  Bad EcalLogicID")); }
  
  try {
    m_writeStmt->setInt(1, iovID);
    m_writeStmt->setInt(2, logicID);
    
    m_writeStmt->setFloat(3, item->getBeta() );
    m_writeStmt->setFloat(4, item->getR25() );
    m_writeStmt->setFloat(5, item->getOffset() );
    m_writeStmt->setInt(6, item->getTaskStatus() );
    
    m_writeStmt->executeUpdate();
  } catch (SQLException &e) {
    throw(std::runtime_error("CaliTempDat::writeDB():  "+e.getMessage()));
  }
}

Friends And Related Function Documentation

friend class EcalCondDBInterface [friend]

Reimplemented from IDBObject.

Definition at line 14 of file CaliTempDat.h.


Member Data Documentation

float CaliTempDat::m_beta [private]

Definition at line 49 of file CaliTempDat.h.

Referenced by getBeta(), and setBeta().

float CaliTempDat::m_offset [private]

Definition at line 51 of file CaliTempDat.h.

Referenced by getOffset(), and setOffset().

float CaliTempDat::m_r25 [private]

Definition at line 50 of file CaliTempDat.h.

Referenced by getR25(), and setR25().

bool CaliTempDat::m_taskStatus [private]

Definition at line 52 of file CaliTempDat.h.

Referenced by getTaskStatus(), and setTaskStatus().