MpdMapPar.cxx 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. // -------------------------------------------------------------------------
  2. // MpdMapPar source file -----
  3. // Created 23/07/13 by P. Batyuk (MPD) <batyuk@jinr.ru> -----
  4. // from MpdMapPar (PNDROOT) -----
  5. // -------------------------------------------------------------------------
  6. /// Last modified: 24.07.2013, P.B.
  7. #include <iostream>
  8. #include "MpdFieldMap.h"
  9. #include "MpdMapPar.h"
  10. #include "FairParamList.h"
  11. using namespace std;
  12. // ------ Constructor --------------------------------------------------
  13. MpdMapPar::MpdMapPar(const char* name, const char* title,
  14. const char* context)
  15. : FairParGenericSet(name, title, context) {
  16. fType = -1;
  17. fXmin = fXmax = fYmin = fYmax = fZmin = fZmax = 0.;
  18. fMapName = "";
  19. fPosX = fPosY = fPosZ = 0.;
  20. fScale = 0.;
  21. }
  22. // -------------------------------------------------------------------------
  23. MpdMapPar::MpdMapPar()
  24. {
  25. fType = -1;
  26. fXmin = fXmax = fYmin = fYmax = fZmin = fZmax = 0.;
  27. fMapName = "";
  28. fPosX = fPosY = fPosZ = 0.;
  29. fScale = 0.;
  30. }
  31. // ------ Destructor ---------------------------------------------------
  32. MpdMapPar::~MpdMapPar() { }
  33. // ------ Put parameters -----------------------------------------------
  34. void MpdMapPar::putParams(FairParamList* list) {
  35. if ( ! list ) return;
  36. list->add("Field Type", fType);
  37. list->add("Field map name", fMapName);
  38. list->add("Field x position", fPosX);
  39. list->add("Field y position", fPosY);
  40. list->add("Field z position", fPosZ);
  41. list->add("Field scaling factor", fScale);
  42. }
  43. // -------- Get parameters ---------------------------------------------
  44. Bool_t MpdMapPar::getParams(FairParamList* list) {
  45. if ( ! list ) return kFALSE;
  46. if ( ! list->fill("Field Type", &fType) ) return kFALSE;
  47. Text_t mapName[80];
  48. if ( ! list->fill("Field map name", mapName, 80) ) return kFALSE;
  49. fMapName = mapName;
  50. if ( ! list->fill("Field x position", &fPosX) ) return kFALSE;
  51. if ( ! list->fill("Field y position", &fPosY) ) return kFALSE;
  52. if ( ! list->fill("Field z position", &fPosZ) ) return kFALSE;
  53. if ( ! list->fill("Field scaling factor", &fScale) ) return kFALSE;
  54. return kTRUE;
  55. }
  56. // --------- Set parameters from FairField ------------------------------
  57. void MpdMapPar::SetParameters(FairField* field) {
  58. if ( ! field ) {
  59. cerr << "-W- MpdMapPar::SetParameters: Empty field pointer!" << endl;
  60. return;
  61. }
  62. MpdFieldMap* fieldMap = (MpdFieldMap*) field;
  63. fXmin = fXmax = fYmin = fYmax = fZmin = fZmax = 0.;
  64. fMapName = field->GetName();
  65. fPosX = fieldMap->GetPositionX();
  66. fPosY = fieldMap->GetPositionY();
  67. fPosZ = fieldMap->GetPositionZ();
  68. fScale = fieldMap->GetScale();
  69. fType = fieldMap->GetType();
  70. }
  71. ClassImp(MpdMapPar)