// @(#) $Id$ // ************************************************************************** // This file is property of and copyright by the ALICE HLT Project * // ALICE Experiment at CERN, All rights reserved. * // * // Primary Authors: Sergey Gorbunov * // Ivan Kisel * // for The ALICE HLT Project. * // * // 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. * // * //*************************************************************************** #include "AliHLTTPCCAParam.h" #include "AliHLTTPCCAMath.h" #if !defined(HLTCA_GPUCODE) GPUd() AliHLTTPCCAParam::AliHLTTPCCAParam() : fISlice( 0 ), fNRows( 63 ), fAlpha( 0.174533 ), fDAlpha( 0.349066 ), fCosAlpha( 0 ), fSinAlpha( 0 ), fAngleMin( 0 ), fAngleMax( 0 ), fRMin( 83.65 ), fRMax( 133.3 ), fZMin( 0.0529937 ), fZMax( 249.778 ), fErrX( 0 ), fErrY( 0 ), fErrZ( 0.228808 ), fPadPitch( 0.4 ), fBz( -5. ), fHitPickUpFactor( 1. ), fMaxTrackMatchDRow( 4 ), fTrackConnectionFactor( 3.5 ), fTrackChiCut( 3.5 ), fTrackChi2Cut( 10 ) { // constructor fParamS0Par[0][0][0] = 0.00047013; fParamS0Par[0][0][1] = 2.00135e-05; fParamS0Par[0][0][2] = 0.0106533; fParamS0Par[0][0][3] = 5.27104e-08; fParamS0Par[0][0][4] = 0.012829; fParamS0Par[0][0][5] = 0.000147125; fParamS0Par[0][0][6] = 4.99432; fParamS0Par[0][1][0] = 0.000883342; fParamS0Par[0][1][1] = 1.07011e-05; fParamS0Par[0][1][2] = 0.0103187; fParamS0Par[0][1][3] = 4.25141e-08; fParamS0Par[0][1][4] = 0.0224292; fParamS0Par[0][1][5] = 8.27274e-05; fParamS0Par[0][1][6] = 4.17233; fParamS0Par[0][2][0] = 0.000745399; fParamS0Par[0][2][1] = 5.62408e-06; fParamS0Par[0][2][2] = 0.0151562; fParamS0Par[0][2][3] = 5.08757e-08; fParamS0Par[0][2][4] = 0.0601004; fParamS0Par[0][2][5] = 7.97129e-05; fParamS0Par[0][2][6] = 4.84913; fParamS0Par[1][0][0] = 0.00215126; fParamS0Par[1][0][1] = 6.82233e-05; fParamS0Par[1][0][2] = 0.0221867; fParamS0Par[1][0][3] = -6.27825e-09; fParamS0Par[1][0][4] = -0.00745378; fParamS0Par[1][0][5] = 0.000172629; fParamS0Par[1][0][6] = 6.24987; fParamS0Par[1][1][0] = 0.00181667; fParamS0Par[1][1][1] = -4.17772e-06; fParamS0Par[1][1][2] = 0.0253429; fParamS0Par[1][1][3] = 1.3011e-07; fParamS0Par[1][1][4] = -0.00362827; fParamS0Par[1][1][5] = 0.00030406; fParamS0Par[1][1][6] = 17.7775; fParamS0Par[1][2][0] = 0.00158251; fParamS0Par[1][2][1] = -3.55911e-06; fParamS0Par[1][2][2] = 0.0247899; fParamS0Par[1][2][3] = 7.20604e-08; fParamS0Par[1][2][4] = 0.0179946; fParamS0Par[1][2][5] = 0.000425504; fParamS0Par[1][2][6] = 20.9294; const double kCLight = 0.000299792458; fPolinomialFieldBz[0] = kCLight * 4.99643; fPolinomialFieldBz[1] = kCLight * -2.27193e-06; fPolinomialFieldBz[2] = kCLight * 0.000116475; fPolinomialFieldBz[3] = kCLight * -1.49956e-06; fPolinomialFieldBz[4] = kCLight * -1.01721e-07; fPolinomialFieldBz[5] = kCLight * 4.85701e-07; Update(); } #endif GPUd() void AliHLTTPCCAParam::Initialize( int iSlice, int nRows, float rowX[], float alpha, float dAlpha, float rMin, float rMax, float zMin, float zMax, float padPitch, float zSigma, float bz ) { // initialization fISlice = iSlice; fAlpha = alpha; fDAlpha = dAlpha; fRMin = rMin; fRMax = rMax; fZMin = zMin; fZMax = zMax; fPadPitch = padPitch; fErrY = 1.; // not in use fErrZ = zSigma; fBz = bz; fNRows = nRows; for ( int irow = 0; irow < nRows; irow++ ) { fRowX[irow] = rowX[irow]; std::cout<<" row "<