1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
17 $Log: AliT0Align.cxx,v $
19 Removing code violations
22 Preliminary test version (T.Malkiewicz)
25 #include "AliT0Align.h"
27 #include "Riostream.h"
32 #include "AliSurveyObj.h"
33 #include "AliAlignObjParams.h"
34 #include "AliCDBStorage.h"
35 #include <TClonesArray.h>
38 #include "AliCDBManager.h"
39 #include "AliSurveyPoint.h"
41 // Class creating the T0 aligmnent objects
42 // from the surveys done by surveyers at Point2.
43 // Survey results are fetched from
44 // Survey Depot, based on survey results
45 // position of T0 alignment objects is computed.
51 AliT0Align::AliT0Align() :
67 // default constructor
70 //________________________________________________________________________
71 AliT0Align::AliT0Align(Int_t reportloc, Int_t side, Int_t reportglob) :
87 // constructor - defines data files
90 fRepGlob = reportglob;
93 TString path = Form("%s",gSystem->Getenv("ALICE_ROOT")) ;
94 // fFileGlob = new Char_t[80];
95 // fUser = new Char_t[10];
96 fFileGlob = Form("%s/T0/Survey_%d_V0.txt",path.Data(),reportglob);
97 fUser = Form("%s/T0/Survey_%d_V0.txt",path.Data(),reportglob);
98 // sprintf(path,gSystem->Getenv("ALICE_ROOT"));
100 // sprintf(fFileLoc,"%s/T0/Survey_%d_T0.txt",path,reportloc);
101 // sprintf(fFileGlob,"%s/T0/Survey_%d_V0.txt",path,reportglob);
103 // sprintf(fUser,gSystem->Getenv("alien_API_USER"));
105 //_________________________________________________________________________
106 AliT0Align::AliT0Align(const AliT0Align &align) :
122 // copy constructor - dummy
124 ((AliT0Align &) align).Copy(*this);
127 //__________________________________________________________________________
128 AliT0Align & AliT0Align::operator =(const AliT0Align & align)
131 // assignment operator - dummy
133 if (this != &align) ((AliT0Align &) align).Copy(*this);
138 //__________________________________________________________________________
139 AliT0Align::~AliT0Align()
144 if(fT0AAlignObj) delete fT0AAlignObj;
145 if(fT0CAlignObj) delete fT0CAlignObj;
146 if(fFileGlob) delete[] fFileGlob;
147 if(fUser) delete[] fUser;
149 //__________________________________________________________________________
150 Bool_t AliT0Align::LoadSurveyData()
153 // Create a new survey object and fill it.
155 AliSurveyObj * s1 = new AliSurveyObj();
156 const int numberPoints = 2;
157 TString pointNames[numberPoints]={"Flange_0","C67_6_Beamcircle"};
162 // Filling from DCDB (via GRID)
164 s1->SetGridUser(fUser);
167 s1->Fill("T0", fRepGlob, fUser);
171 s1->Fill("VZERO", fRepGlob, fUser);
175 cout<<"Enter the side properly: '0'- A side, '1'- C side'" <<endl;
181 // Filling from local file
184 s1->FillFromLocalFile(fFileGlob);
187 Float_t surveyedPoints [numberPoints][2];
188 AliSurveyPoint *currPoint;
191 for(Int_t i=0;i<numberPoints;i++)
194 currPoint = (AliSurveyPoint *) s1->GetData()->FindObject(pointNames[i]);
198 surveyedPoints[i][0]=currPoint->GetX();
199 surveyedPoints[i][1]=currPoint->GetY();
200 // surveyedPoints[i]=currPoint->GetZ();
202 Printf("INFO: Point %s coordinates read.\n", pointNames[i].Data() ) ;
208 Printf("ERROR: Essential point missing: %s\n", pointNames[i].Data() ) ;
215 fXPosA = surveyedPoints[0][0];
216 fYPosA = surveyedPoints[0][1];
220 fXPosC = surveyedPoints[1][0];
221 fYPosC = surveyedPoints[1][1];
228 //_________________________________________________________________
230 Double_t AliT0Align::ComputePosition()
232 // Float_t fZPos, shift;
233 // fZPos = surveyedPoints[3] - shift;
236 //_______________________________________________________________________
237 void AliT0Align::CreateAlignObj()
240 // TClonesArray *array = new TClonesArray("AliAlignObjParams",2);
241 // TClonesArray &alobj = *array;
243 Double_t dx=0., dy=0., dz=0., dpsi=0., dtheta=0., dphi=0.;
246 fT0AAlignObj = new AliAlignObjParams("ALIC_1/0STL_1",0,dx,dy,dz,dpsi,dtheta,dphi,kTRUE);
250 // dz=surveyedPoints[2];
252 fT0CAlignObj = new AliAlignObjParams("ALIC_1/0STR_1",0,dx,dy,dz,dpsi,dtheta,dphi,kTRUE);
256 //______________________________________________________________________
257 void AliT0Align::Run()
260 // runs the full chain
263 Bool_t flag = LoadSurveyData();
266 cout<<"Missing points"<<endl;
269 // ComputePosition();
273 //_________________________________________________________________________
275 void AliT0Align::StoreAlignObj()
278 // Storing T0 alignment objects
280 AliCDBManager* cdb = AliCDBManager::Instance();
281 if(!cdb->IsDefaultStorageSet()) cdb->SetDefaultStorage("local://$ALICE_ROOT/OCDB");
283 TClonesArray *array = new TClonesArray("AliAlignObjParams",2);
288 fT0AAlignObj->GetPars(shifts,rots);
289 new((*array)[0]) AliAlignObjParams(fT0AAlignObj->GetSymName(),0,shifts[0],
290 shifts[1],shifts[2],rots[0],rots[1],rots[2],kTRUE);
291 fT0CAlignObj->GetPars(shifts,rots);
292 new((*array)[1]) AliAlignObjParams(fT0CAlignObj->GetSymName(),0,shifts[0],
293 shifts[1],shifts[2],rots[0],rots[1],rots[2],kTRUE);
297 // storing either in the OCDB or local file
299 if( TString(gSystem->Getenv("TOCDB")) != TString("kTRUE") ){
301 const char* filename = "T0SurveyMisalignment.root";
302 // Char_t fullname[80];
303 // sprintf(fullname,"%s/T0/Align/Data/%s",gSystem->Getenv("ALICE_ROOT"),filename);
304 TString fullname = Form("%s/T0/Align/Data/%s",gSystem->Getenv("ALICE_ROOT"), filename);
305 TFile *f = new TFile(fullname.Data(),"RECREATE");
307 AliError("cannot open file for output\n");
310 AliInfo(Form("Saving alignment objects to the file %s", filename));
312 f->WriteObject(array,"T0AlignObjs","kSingleKey");
315 // save in CDB storage
316 AliCDBStorage* storage;
318 TString Storage = gSystem->Getenv("STORAGE");
319 if(!Storage.BeginsWith("local://") && !Storage.BeginsWith("alien://")) {
321 "STORAGE variable set to %s is not valid. Exiting\n",Storage.Data()));
324 storage = cdb->GetStorage(Storage.Data());
326 AliError(Form("Unable to open storage %s\n",Storage.Data()));
330 AliCDBMetaData* md = new AliCDBMetaData();
331 md->SetResponsible("Tomasz Malkiewicz");
332 md->SetComment("Position of T0-A and T0-C from survey");
333 AliCDBId id("T0/Align/Data",0,AliCDBRunRange::Infinity());
334 storage->Put(array,id,md);