ROOT logo
/**************************************************************************
 * Copyright(c) 2007-2010, ALICE Experiment at CERN, All rights reserved. *
 *                                                                        *
 * Author: The ALICE Off-line Project.                                    *
 * Contributors are mentioned in the code where appropriate.              *
 *                                                                        *
 * Permission to use, copy, modify and distribute this software and its   *
 * documentation strictly for non-commercial purposes is hereby granted   *
 * without fee, provided that the above copyright notice appears in all   *
 * copies and that both the copyright notice and this permission notice   *
 * appear in the supporting documentation. The authors make no claims     *
 * about the suitability of this software for any purpose. It is          *
 * provided "as is" without express or implied warranty.                  *
 **************************************************************************/

//========================================================================
//
// This class generates misalignment for ZDC. In particular it defines
// the misalignment in the three canonical scenarios: "ideal", "residual"
// and "full".
// It is meant to be run standalone or from the steering macro
// $ALICE_ROOT/macros/MakeAlignmentObjs.C
// looping on the detectors.
//
//========================================================================

#include "AliZDCMisAligner.h"
#include "AliGeomManager.h"
#include "TClonesArray.h"
#include "AliAlignObjParams.h"
#include "AliLog.h"

ClassImp(AliZDCMisAligner)

    //_______________________________________________________________________________________
AliZDCMisAligner::AliZDCMisAligner() : AliMisAligner()
{
    //
    // dummy constructor
    //
}

//_______________________________________________________________________________________
TClonesArray* AliZDCMisAligner::MakeAlObjsArray() {
    // builds and returns the array of alignment objects
    // according to the spcified misalignment scenario
    // ("ideal", "residual" or "full").
    //
    TClonesArray *array = new TClonesArray("AliAlignObjParams",10);
    TClonesArray &alobj = *array;

    Double_t dx,dy,dz,dpsi,dtheta,dphi;
    if(TString(GetMisalType())=="ideal")
    {
	dx=0., dy=0., dz=0.;
	dpsi=0., dtheta=0., dphi=0.;
    }else if(TString(GetMisalType())=="residual" || TString(GetMisalType())=="full")
    {
	dx=0., dy=0.05, dz=0.;
	dpsi=0., dtheta=0., dphi=0.;
    }else{
	AliError(Form("\"%s\" is not a valid identifier for misalignment types. Exiting ...",GetMisalType()));
	return 0;
    }

    const char *zdcCn="ZDC/NeutronZDC_C";
    const char *zdcCp="ZDC/ProtonZDC_C";
    const char *zdcAn="ZDC/NeutronZDC_A";
    const char *zdcAp="ZDC/ProtonZDC_A";

    UShort_t iIndex=0;
    AliGeomManager::ELayerID iLayer = AliGeomManager::kInvalidLayer;
    UShort_t volid = AliGeomManager::LayerToVolUID(iLayer,iIndex);

    new(alobj[0]) AliAlignObjParams(zdcCn, volid, dx, dy, dz, dpsi, dtheta, dphi, kTRUE);
    new(alobj[1]) AliAlignObjParams(zdcCp, volid, dx, dy, dz, dpsi, dtheta, dphi, kTRUE);
    new(alobj[2]) AliAlignObjParams(zdcAn, volid, dx, dy, dz, dpsi, dtheta, dphi, kTRUE);
    new(alobj[3]) AliAlignObjParams(zdcAp, volid, dx, dy, dz, dpsi, dtheta, dphi, kTRUE);

    return array;
}

//_______________________________________________________________________________________
AliCDBMetaData* AliZDCMisAligner::GetCDBMetaData() const {
    // Returns the comment and responsible for the
    // AliCDBMetaData to be associated with the OCDB entry
    // containing the ZDC array of misalignment objects
    //
    AliCDBMetaData* md = new AliCDBMetaData();
    md->SetResponsible("Chiara Oppedisano");

    if(TString(GetMisalType())=="ideal")
	md->SetComment("Alignment objects for ZDC ideal misalignment");
    if(TString(GetMisalType())=="residual")
	md->SetComment("Alignment objects for ZDC residual misalignment");
    if(TString(GetMisalType())=="full")
	md->SetComment("Alignment objects for ZDC full misalignment");

    return md;
}
 AliZDCMisAligner.cxx:1
 AliZDCMisAligner.cxx:2
 AliZDCMisAligner.cxx:3
 AliZDCMisAligner.cxx:4
 AliZDCMisAligner.cxx:5
 AliZDCMisAligner.cxx:6
 AliZDCMisAligner.cxx:7
 AliZDCMisAligner.cxx:8
 AliZDCMisAligner.cxx:9
 AliZDCMisAligner.cxx:10
 AliZDCMisAligner.cxx:11
 AliZDCMisAligner.cxx:12
 AliZDCMisAligner.cxx:13
 AliZDCMisAligner.cxx:14
 AliZDCMisAligner.cxx:15
 AliZDCMisAligner.cxx:16
 AliZDCMisAligner.cxx:17
 AliZDCMisAligner.cxx:18
 AliZDCMisAligner.cxx:19
 AliZDCMisAligner.cxx:20
 AliZDCMisAligner.cxx:21
 AliZDCMisAligner.cxx:22
 AliZDCMisAligner.cxx:23
 AliZDCMisAligner.cxx:24
 AliZDCMisAligner.cxx:25
 AliZDCMisAligner.cxx:26
 AliZDCMisAligner.cxx:27
 AliZDCMisAligner.cxx:28
 AliZDCMisAligner.cxx:29
 AliZDCMisAligner.cxx:30
 AliZDCMisAligner.cxx:31
 AliZDCMisAligner.cxx:32
 AliZDCMisAligner.cxx:33
 AliZDCMisAligner.cxx:34
 AliZDCMisAligner.cxx:35
 AliZDCMisAligner.cxx:36
 AliZDCMisAligner.cxx:37
 AliZDCMisAligner.cxx:38
 AliZDCMisAligner.cxx:39
 AliZDCMisAligner.cxx:40
 AliZDCMisAligner.cxx:41
 AliZDCMisAligner.cxx:42
 AliZDCMisAligner.cxx:43
 AliZDCMisAligner.cxx:44
 AliZDCMisAligner.cxx:45
 AliZDCMisAligner.cxx:46
 AliZDCMisAligner.cxx:47
 AliZDCMisAligner.cxx:48
 AliZDCMisAligner.cxx:49
 AliZDCMisAligner.cxx:50
 AliZDCMisAligner.cxx:51
 AliZDCMisAligner.cxx:52
 AliZDCMisAligner.cxx:53
 AliZDCMisAligner.cxx:54
 AliZDCMisAligner.cxx:55
 AliZDCMisAligner.cxx:56
 AliZDCMisAligner.cxx:57
 AliZDCMisAligner.cxx:58
 AliZDCMisAligner.cxx:59
 AliZDCMisAligner.cxx:60
 AliZDCMisAligner.cxx:61
 AliZDCMisAligner.cxx:62
 AliZDCMisAligner.cxx:63
 AliZDCMisAligner.cxx:64
 AliZDCMisAligner.cxx:65
 AliZDCMisAligner.cxx:66
 AliZDCMisAligner.cxx:67
 AliZDCMisAligner.cxx:68
 AliZDCMisAligner.cxx:69
 AliZDCMisAligner.cxx:70
 AliZDCMisAligner.cxx:71
 AliZDCMisAligner.cxx:72
 AliZDCMisAligner.cxx:73
 AliZDCMisAligner.cxx:74
 AliZDCMisAligner.cxx:75
 AliZDCMisAligner.cxx:76
 AliZDCMisAligner.cxx:77
 AliZDCMisAligner.cxx:78
 AliZDCMisAligner.cxx:79
 AliZDCMisAligner.cxx:80
 AliZDCMisAligner.cxx:81
 AliZDCMisAligner.cxx:82
 AliZDCMisAligner.cxx:83
 AliZDCMisAligner.cxx:84
 AliZDCMisAligner.cxx:85
 AliZDCMisAligner.cxx:86
 AliZDCMisAligner.cxx:87
 AliZDCMisAligner.cxx:88
 AliZDCMisAligner.cxx:89
 AliZDCMisAligner.cxx:90
 AliZDCMisAligner.cxx:91
 AliZDCMisAligner.cxx:92
 AliZDCMisAligner.cxx:93
 AliZDCMisAligner.cxx:94
 AliZDCMisAligner.cxx:95
 AliZDCMisAligner.cxx:96
 AliZDCMisAligner.cxx:97
 AliZDCMisAligner.cxx:98
 AliZDCMisAligner.cxx:99
 AliZDCMisAligner.cxx:100