Changeset 1449
- Timestamp:
- 07/29/02 09:10:23 (23 years ago)
- Location:
- trunk
- Files:
-
- 4 added
- 14 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MagicSoft/Mars/mhist/MH.cc
r1446 r1449 52 52 #include <TH2.h> 53 53 #include <TH3.h> 54 #include <TGaxis.h> 54 55 #include <TCanvas.h> 55 56 … … 335 336 ScaleAxis(*h->GetXaxis()->GetXbins(), fx); 336 337 } 338 339 void MH::FindGoodLimits(Int_t nbins, Int_t &newbins, Double_t &xmin, Double_t &xmax, Bool_t isInteger) 340 { 341 //*-*-*-*-*-*-*-*-*Find reasonable bin values*-*-*-*-*-*-*-*-*-*-*-*-*-*-* 342 //*-* ========================== 343 344 Double_t dx = 0.1*(xmax-xmin); 345 Double_t umin = xmin - dx; 346 Double_t umax = xmax + dx; 347 348 if (umin < 0 && xmin >= 0) 349 umin = 0; 350 351 if (umax > 0 && xmax <= 0) 352 umax = 0; 353 354 Int_t n=0; 355 Double_t binlow =0; 356 Double_t binhigh =0; 357 Double_t binwidth=0; 358 TGaxis::Optimize(umin, umax, nbins, binlow, binhigh, n, binwidth, ""); 359 360 if (binwidth <= 0 || binwidth > 1.e+39) 361 { 362 xmin = -1; 363 xmax = 1; 364 } 365 else 366 { 367 xmin = binlow; 368 xmax = binhigh; 369 } 370 371 if (isInteger) 372 { 373 Int_t ixmin = (Int_t)xmin; 374 Int_t ixmax = (Int_t)xmax; 375 Double_t dxmin = (Double_t)ixmin; 376 Double_t dxmax = (Double_t)ixmax; 377 378 xmin = xmin<0 && xmin!=dxmin ? dxmin - 1 : dxmin; 379 xmax = xmax>0 && xmax!=dxmax ? dxmax + 1 : dxmax; 380 381 if (xmin>=xmax) 382 xmax = xmin+1; 383 384 Int_t bw = 1 + (Int_t)((xmax-xmin)/nbins); 385 386 nbins = (Int_t)((xmax-xmin)/bw); 387 388 if (xmin+nbins*bw < xmax) 389 { 390 nbins++; 391 xmax = xmin +nbins*bw; 392 } 393 } 394 395 newbins = nbins; 396 } 397 398 Double_t MH::GetMinimumGT(const TH1 &h, Double_t gt) 399 { 400 Double_t min = FLT_MAX; 401 402 const TAxis &axe = *((TH1&)h).GetXaxis(); 403 404 for (int i=1; i<=axe.GetNbins(); i++) 405 { 406 Double_t x = h.GetBinContent(i); 407 if (gt<x && x<min) 408 min = x; 409 } 410 return min; 411 } -
trunk/MagicSoft/Mars/mhist/MH.h
r1441 r1449 47 47 static void ScaleAxis(TH1 *bins, Double_t fx=1, Double_t fy=1, Double_t fz=1); 48 48 49 static void FindGoodLimits(Int_t nbins, Int_t &newbins, Double_t &xmin, Double_t &xmax, Bool_t isInteger); 50 static Double_t GetMinimumGT(const TH1 &h, Double_t gt=0); 51 49 52 ClassDef(MH, 1) //A histogram base class for Mars histograms 50 53 }; -
trunk/WuerzburgSoft/Thomas/mphys/Changelog
r1448 r1449 1 1 -*-*- END -*-*- 2 2002/06/29: Thomas Bretz 3 4 * MElectron.[h,cc]: 5 - if the photon energy is to small return a straight line in 6 Compton 7 - changed lolimit of p_e integration -0.5 8 - changed number of calculated points to 50 for fP, fQ 9 - changed usage of TRandom to gRandom 10 - changed some TVector and TMatrix objects to static 11 - added new copy constructors 12 13 * MPairProduction.cc: 14 - use the new copy constructor of MElectron 15 16 * MParticle.[h,cc]: 17 - added new copy constructors 18 - Added a TAxis object in Planck 19 - replaced usage of TRandom by gRandom 20 - replaced TVector, TMatrix by TVector3, TRotation 21 - fixed a bug in SetNewPosition (fX was not incremented if the 22 particle reached the observers plain) 23 - incremented version-number 24 25 * MPhoton.[h,cc]: 26 - added Fill member function 27 - added new copy constructors 28 29 * MFit.[h,cc], MCascade.[h,cc]: 30 - added 31 32 * phys.C: 33 - moved code to MCascade 34 35 * Makefile, PhysLinkDef.h: 36 - added MFit, MCascade 37 38 * analp.C: 39 - simplified 40 - added fit for cutoff 41 42 43 2 44 2002/06/26: Thomas Bretz 3 45 -
trunk/WuerzburgSoft/Thomas/mphys/MElectron.cc
r1448 r1449 129 129 const Double_t E = k[0]; 130 130 131 Double_t omega = epsilon*E/(E0*E0); 131 Double_t flim; 132 if (epsilon<1e-14) 133 { 134 const Double_t d = E/(E0*E0); 135 136 Double_t omega1 = 1e-13*d; 137 Double_t omega2 = 1e-12*d; 138 139 const Double_t f1 = Flim(&omega1); 140 const Double_t f2 = Flim(&omega2); 141 142 const Double_t m = log10(f2/f1); 143 const Double_t t = pow(f2, 13)/pow(f1, 12); 144 145 flim = pow(epsilon, m) * t; 146 } 147 else 148 { 149 Double_t omega = epsilon*E/(E0*E0); 150 flim = Flim(&omega); 151 } 132 152 133 153 const Double_t n = MParticle::Planck(&epsilon, &z)/epsilon/epsilon; // [1] 134 return Flim(&omega)*n;154 return flim*n; 135 155 } 136 156 … … 250 270 const Double_t E0 = 511e-6; //[GeV] 251 271 252 const Double_t lolim = -log10(E)/7*4-13; 253 254 TF1 fP("p_e", p_e, lolim, -10.6, 2); 255 TF1 fQ("G", G_q, 0, 1., 1); 256 272 const Double_t lolim = -log10(E)/7*4-13.5; 273 274 static TF1 fP("p_e", p_e, lolim, -10.6, 2); 275 static TF1 fQ("G", G_q, 0, 1., 1); 276 277 fP.SetNpx(50); 278 fQ.SetNpx(50); 279 280 fP.SetRange(lolim, -10.6); 257 281 fP.SetParameter(0, E); 258 282 fP.SetParameter(1, z); … … 288 312 MPhoton *MElectron::DoInvCompton(Double_t theta) 289 313 { 290 static TRandom rand(0);291 292 314 const Double_t E0 = 511e-6; //[GeV] 293 315 … … 304 326 const Double_t f = fEnergy/e; 305 327 306 Double_t t=-1 ;328 Double_t t=-10; 307 329 Double_t arg; 308 330 do 309 331 { 310 if (t> 0)332 if (t>-10) 311 333 cout << "~" << flush; 312 t = rand.Uniform(TMath::Pi())+TMath::Pi()/2; 313 Double_t er = epsilon*(gamma-gammabeta*cos(t)); // photon energy rest frame 314 arg = (f - E0/er - 1)/(sqrt(fEnergy*fEnergy-E0*E0)/e+1); 334 335 // 336 // Create an angle uniformly distributed in the range of possible 337 // interaction angles due to the known energies. 338 // 339 // The distibution is a theta-function which is incorrect, but 340 // should be correct in a first order... 341 // 342 t = gRandom->Uniform(TMath::Pi())+TMath::Pi()/2; 343 Double_t er = epsilon*(gamma-gammabeta*cos(t)); // photon energy rest frame 344 Double_t n = sqrt(fEnergy*fEnergy-E0*E0)/e+1; 345 arg = (f - E0/er - 1)/n; 346 347 /* ------------------ some hints ------------------------------ 348 -1 < arg < 1 349 -n < f - r/er - 1 < n 350 1-f-n < r/er < 1-f+n 351 r/(1-f+n) < er < r/(1-f-n) 352 r/(1-f+n) < gamma-gammabeta*cos(t) < r/(1-f-n) 353 r/(1-f+n)-gamma < -gammabeta*cos(t) < r/(1-f-n)-gamma 354 gamma-r/(1-f-n) < gammabeta*cos(t) < gamma-r/(1-f+n) 355 (gamma-r/(1-f-n))/gammabeta < cos(t) < (gamma-r/(1-f+n))/gammabeta 356 acos((gamma-r/(1-f+n))/gammabeta) < t < acos((gamma-r/(1-f-n))/gammabeta) 357 358 359 (gamma+E0/(n*arg+1-f)/epsilon)/gammabeta = cos(t); 360 1 = (epsilon/E0*cos(t)*gammabeta-gamma)*(n*arg+1-f); 361 362 arg=1: (gamma+E0/epsilon*(1-f+n))/gammabeta = cos(t); 363 arg=-1 : (gamma+E0/epsilon*(1-f-n))/gammabeta = cos(t); 364 365 (E0/(1-f-n)/epsilon+gamma)/gammabeta < cos(t) < (E0/(1-f+n)/epsilon+gamma)/gammabeta 366 */ 315 367 316 368 } while (arg<-1 || arg>1); 317 369 318 370 const Double_t theta1s = acos(arg); 319 const Double_t thetas = atan(sin(t)/(gamma*cos(t)-gammabeta));371 const Double_t thetas = atan(sin(t)/(gamma*cos(t)-gammabeta)); 320 372 321 373 const Double_t thetastar = thetas-theta1s; … … 325 377 fEnergy -= e; 326 378 327 const Double_t phi = rand.Uniform(TMath::Pi()*2); 328 379 const Double_t phi = gRandom->Uniform(TMath::Pi()*2); 380 381 /* 329 382 MPhoton &p = *new MPhoton(e, fZ); 330 383 p = *this; 384 */ 385 MPhoton &p = *new MPhoton(*this, e); 331 386 p.SetNewDirection(theta1, phi); 332 387 … … 374 429 return SetNewPosition(); 375 430 376 static TRandom rand(0); 377 Double_t x = rand.Exp(GetInteractionLength()); 431 Double_t x = gRandom->Exp(GetInteractionLength()); 378 432 379 433 // ----------------------------- … … 381 435 const Double_t E0 = 511e-6; //[GeV] 382 436 383 Double_t B_theta = rand.Uniform(TMath::Pi());384 Double_t B_phi = rand.Uniform(TMath::Pi()*2);385 386 TMatrixD M(3,3);437 Double_t B_theta = gRandom->Uniform(TMath::Pi()); 438 Double_t B_phi = gRandom->Uniform(TMath::Pi()*2); 439 440 static TMatrixD M(3,3); 387 441 388 442 M(0, 0) = sin(B_theta)*cos(B_phi); … … 398 452 M(2, 2) = 0; 399 453 400 const Double_t beta = sqrt(1 -E0/fEnergy*E0/fEnergy);454 const Double_t beta = sqrt(1.-E0/fEnergy*E0/fEnergy); 401 455 402 456 // … … 404 458 // which the x-axis is identical with the B-Field 405 459 // 406 TVectorD v(3);460 static TVectorD v(3); 407 461 v(0) = beta*sin(fTheta)*cos(fPsi); 408 462 v(1) = beta*sin(fTheta)*sin(fPsi); … … 418 472 // ----------------------------- 419 473 420 TMatrixD N(3,3);474 static TMatrixD N(3,3); 421 475 N(0, 0) = 1; 422 476 N(1, 0) = 0; … … 436 490 // v(2) = 0 437 491 // ----------------------------- 438 TVectorD p(3);492 static TVectorD p(3); 439 493 440 494 Double_t rho = 0; … … 469 523 } 470 524 471 TVectorD s(3);525 static TVectorD s(3); 472 526 s(0) = fR*cos(fPhi); 473 527 s(1) = fR*sin(fPhi); … … 494 548 // ----------------------------- 495 549 496 TVectorD w(3);550 static TVectorD w(3); 497 551 w(0) = beta_p/beta; 498 552 w(1) = beta_o/beta*cos(rho); -
trunk/WuerzburgSoft/Thomas/mphys/MElectron.h
r1430 r1449 16 16 fZ = z; 17 17 } 18 19 MElectron(MParticle &p, Bool_t type=kFALSE) : MParticle(p, type?MParticle::kEPositron:MParticle::kEElectron) { } 20 MElectron(MParticle &p, Double_t e, Bool_t type=kFALSE) : MParticle(p, e, type?MParticle::kEPositron:MParticle::kEElectron) {} 18 21 19 22 void operator=(MParticle &p) { MParticle::operator=(p); } -
trunk/WuerzburgSoft/Thomas/mphys/MPairProduction.cc
r1370 r1449 119 119 // cout << " {" << f << "," << E << "," << atan(tan1) << "," << atan(-tan2) << "} " << flush; 120 120 121 MElectron &p0 = *new MElectron(E*(1.-f), gamma->GetZ(), kTRUE); 122 MElectron &p1 = *new MElectron(E*(1.+f), gamma->GetZ(), kFALSE); 123 p0 = *gamma; // Set Position and direction 124 p1 = *gamma; // Set Position and direction 121 MElectron &p0 = *new MElectron(*gamma, E*(1.-f), kTRUE); 122 MElectron &p1 = *new MElectron(*gamma, E*(1.+f), kFALSE); 125 123 126 static TRandom rand(0); 127 Double_t rnd = rand.Uniform(TMath::Pi() * 2); 124 Double_t rnd = gRandom->Uniform(TMath::Pi() * 2); 128 125 p0.SetNewDirection(atan(+tan1), rnd); 129 126 p1.SetNewDirection(atan(-tan2), rnd+TMath::Pi()); -
trunk/WuerzburgSoft/Thomas/mphys/MParticle.cc
r1448 r1449 9 9 #include <TRandom.h> 10 10 #include <TMatrixD.h> 11 #include <TRotation.h> 11 12 12 13 ClassImp(MParticle); … … 39 40 const Double_t r = x[0] /pc*ly*1e3; // [m] 40 41 41 const Double_t R = 1./(1 -r*H0/c/2); // [1]42 const Double_t R = 1./(1.-r*H0/c/2); // [1] 42 43 43 44 return R*R - 1; … … 67 68 const Double_t pc = 1./3.258; // [pc/ly] 68 69 69 const Double_t R = c/H0 * 2 * (1 - 1./sqrt(z1)); // [m]70 const Double_t R = c/H0 * 2 * (1. - 1./sqrt(z1)); // [m] 70 71 71 72 return R * pc/ly/1e3; // [kpc] … … 85 86 if (!isloaded) 86 87 { 87 Double_t c = 299792458; // [m/s]88 Double_t e = 1.602176462e-19; // [C]89 Double_t h = 1e-9/e*6.62606876e-34; // [GeVs]90 Double_t hc = h*c; // [GeVm]88 Double_t c = 299792458; // [m/s] 89 Double_t e = 1.602176462e-19; // [C] 90 Double_t h = 1e-9/e*6.62606876e-34; // [GeVs] 91 Double_t hc = h*c; // [GeVm] 91 92 Double_t konst = 4.*TMath::Pi() * 2. / (hc*hc*hc); 92 93 … … 123 124 } 124 125 126 static TAxis &axez = *hist2->GetXaxis(); 127 static TAxis &axee = *hist2->GetYaxis(); 128 125 129 // 126 130 // y = (y1-y0)/(x1-x0) * (x-x0) + y0 … … 129 133 Double_t E = x[0]; 130 134 131 Int_t i = hist2->GetXaxis()->FindFixBin(z);132 Int_t j = hist2->GetYaxis()->FindFixBin(E);133 134 Double_t z1 = hist2->GetXaxis()->GetBinLowEdge(i+1);135 Double_t z0 = hist2->GetXaxis()->GetBinLowEdge(i);136 137 Double_t E1 = hist2->GetYaxis()->GetBinLowEdge(j+1);138 Double_t E0 = hist2->GetYaxis()->GetBinLowEdge(j);135 Int_t i = axez.FindFixBin(z); 136 Int_t j = axee.FindFixBin(E); 137 138 Double_t z1 = axez.GetBinLowEdge(i+1); 139 Double_t z0 = axez.GetBinLowEdge(i); 140 141 Double_t E1 = axee.GetBinLowEdge(j+1); 142 Double_t E0 = axee.GetBinLowEdge(j); 139 143 140 144 Double_t n00 = hist2->GetBinContent(i, j); … … 207 211 void MParticle::InitRandom() 208 212 { 209 static TRandom rnd(0); 210 fPhi = rnd.Uniform(TMath::Pi()*2); 211 fPsi = rnd.Uniform(TMath::Pi()*2); 213 fPhi = gRandom->Uniform(TMath::Pi()*2); 214 fPsi = gRandom->Uniform(TMath::Pi()*2); 212 215 } 213 216 214 217 void MParticle::SetNewDirection(Double_t theta, Double_t phi) 215 218 { 216 TMatrixD B(3, 3); 217 218 B(0, 0) = cos(fTheta)*cos(fPsi); 219 B(1, 0) = cos(fTheta)*sin(fPsi); 220 B(2, 0) = -sin(fTheta); 221 222 B(0, 1) = -sin(fPsi); 223 B(1, 1) = cos(fPsi); 219 static TMatrixD B(3, 3); 220 221 const Double_t ct = cos(fTheta); 222 const Double_t st = sin(fTheta); 223 const Double_t cp = cos(fPsi); 224 const Double_t sp = sin(fPsi); 225 226 /* 227 TRotation B( ct*cp, ct*sp, -st, 228 -sp, cp, 0, 229 st*cp, st*sp, ct); 230 */ 231 232 // first row 233 B(0, 0) = ct*cp; 234 B(1, 0) = ct*sp; 235 B(2, 0) = -st; 236 237 // second row 238 B(0, 1) = -sp; 239 B(1, 1) = cp; 224 240 B(2, 1) = 0; 225 241 226 B(0, 2) = sin(fTheta)*cos(fPsi); 227 B(1, 2) = sin(fTheta)*sin(fPsi); 228 B(2, 2) = cos(fTheta); 229 230 // ------------------------------ 231 232 TVectorD r(3); 233 234 r(0) = sin(theta)*cos(phi); 235 r(1) = sin(theta)*sin(phi); 242 // third row 243 B(0, 2) = st*cp; 244 B(1, 2) = st*sp; 245 B(2, 2) = ct; 246 247 // ------------------------------ 248 249 static TVectorD r(3); 250 251 const Double_t sint = sin(theta); 252 253 /* 254 TVector3 r(sint*cos(phi), sint*sin(phi), cos(theta)); 255 */ 256 257 r(0) = sint*cos(phi); 258 r(1) = sint*sin(phi); 236 259 r(2) = cos(theta); 237 260 … … 253 276 Bool_t rc=kTRUE; 254 277 255 TVectorD x(3); 256 257 x(0) = sin(fTheta)*cos(fPsi); 258 x(1) = sin(fTheta)*sin(fPsi); 259 x(2) = cos(fTheta); 260 261 // ------------------------------ 262 263 const Double_t R = RofZ(&fZ); 264 265 const Double_t dx = R - dr*x(2); 266 278 const Double_t st = sin(fTheta); 279 280 TVector3 d(st*cos(fPsi), st*sin(fPsi), cos(fTheta)); 281 282 // ------------------------------ 283 284 const Double_t R = RofZ(&fZ); 285 const Double_t dx = R - dr*d.z(); 267 286 if (dx < 0) 268 287 { 269 dr = R/ x(2); // R>0 --> x(2)>0288 dr = R/d.z(); // R>0 --> x(2)>0 270 289 rc = kFALSE; 271 290 } 272 else 273 fX += dr*(1.-x(2)); 274 275 x *= dr; 276 277 // ------------------------------ 278 279 TVectorD r(3); 280 281 r(0) = fR*cos(fPhi); 282 r(1) = fR*sin(fPhi); 283 r(2) = R; 284 285 // ------------------------------ 286 287 r -= x; 291 292 fX += dr*(1.-d(2)); 293 d *= dr; 294 295 // ------------------------------ 296 297 TVector3 r(fR*cos(fPhi), fR*sin(fPhi), R); 298 299 r -= d; 300 301 // ------------------------------ 288 302 289 303 if (fR!=0) 290 fPhi = atan2(r(1), r(0)); 291 292 fR = sqrt(r(0)*r(0)+r(1)*r(1)); 304 fPhi = atan2(r.y(), r.x()); 305 fR = sqrt(r.x()*r.x()+r.y()*r.y()); 293 306 fZ = ZofR(&r(2)); 294 307 … … 298 311 Bool_t MParticle::SetNewPosition() 299 312 { 300 static TRandom rand(0); 301 Double_t r = rand.Exp(GetInteractionLength()); 313 Double_t r = gRandom->Exp(GetInteractionLength()); 302 314 return SetNewPosition(r); 303 315 } -
trunk/WuerzburgSoft/Thomas/mphys/MParticle.h
r1448 r1449 37 37 public: 38 38 MParticle(ParticleType_t t=kENone, const char *name=NULL, const char *title=NULL); 39 MParticle(MParticle &p, ParticleType_t t=kENone) : fPType(t) { *this = p; } 40 MParticle(MParticle &p, Double_t e, ParticleType_t t=kENone) : fPType(t) { *this = p; fEnergy = e; } 39 41 40 42 void InitRandom(); … … 89 91 Double_t GetPsi() const { return fPsi; } 90 92 91 ClassDef(MParticle, 1) // Container which holds hostograms for the Hillas parameters93 ClassDef(MParticle, 2) // Container which holds hostograms for the Hillas parameters 92 94 }; 93 95 -
trunk/WuerzburgSoft/Thomas/mphys/MPhoton.cc
r1448 r1449 200 200 DrawInteractionLength(fZ); 201 201 } 202 203 void MPhoton::Fill(TH1 &h, Double_t idx, Double_t w) const 204 { 205 h.Fill(fEnergy, pow(fEnergy, idx)*w); 206 } -
trunk/WuerzburgSoft/Thomas/mphys/MPhoton.h
r1428 r1449 5 5 #include "MParticle.h" 6 6 #endif 7 8 class TH1; 7 9 8 10 class MPhoton : public MParticle … … 17 19 } 18 20 21 MPhoton(MParticle &p) : MParticle(p, MParticle::kEGamma) { } 22 MPhoton(MParticle &p, Double_t e) : MParticle(p, e, MParticle::kEGamma) { } 23 19 24 void operator=(MParticle &p) { MParticle::operator=(p); } 25 26 void Fill(TH1 &h, Double_t idx, Double_t w) const; 20 27 21 28 // ---------------------------------------------------------------- -
trunk/WuerzburgSoft/Thomas/mphys/Makefile
r1364 r1449 22 22 # connect the include files defined in the config.mk file 23 23 # 24 INCLUDES = -I. -I../mbase 24 INCLUDES = -I. -I../mbase -I../mhist 25 25 26 26 #------------------------------------------------------------------------------ … … 29 29 30 30 SRCFILES = MParticle.cc \ 31 MPairProduction.cc \ 31 32 MPhoton.cc \ 32 MElectron.cc \ 33 MPairProduction.cc 33 MFit.cc \ 34 MCascade.cc \ 35 MElectron.cc 34 36 35 37 SRCS = $(SRCFILES) -
trunk/WuerzburgSoft/Thomas/mphys/PhysLinkDef.h
r1364 r1449 8 8 #pragma link C++ class MElectron+; 9 9 #pragma link C++ class MPhoton+; 10 #pragma link C++ class MCascade+; 11 #pragma link C++ class MFit+; 10 12 #pragma link C++ class MPairProduction+; 11 13 -
trunk/WuerzburgSoft/Thomas/mphys/analp.C
r1428 r1449 2 2 3 3 #include <float.h> 4 5 Double_t GetMin(TH1 *h) 6 { 7 Double_t min = FLT_MAX; 8 for (int i=1; i<=h->GetXaxis()->GetNbins(); i++) 9 { 10 if (h->GetBinContent(i)<min && h->GetBinContent(i)!=0) 11 min = h->GetBinContent(i); 12 } 13 return min; 14 } 15 16 void GetRange(TChain *chain, const char *name, Int_t &nbins, Double_t &min, Double_t &max, Double_t conv=1) 4 #include <iomanip.h> 5 6 #include <TH1.h> 7 #include <TH2.h> 8 #include <TLine.h> 9 #include <TLeaf.h> 10 #include <TChain.h> 11 #include <TGaxis.h> 12 #include <TStyle.h> 13 #include <TCanvas.h> 14 #include <TPolyLine.h> 15 #include <TPolyMarker.h> 16 17 #include "MH.h" 18 #include "MBinning.h" 19 20 #include "MFit.h" 21 #include "MPhoton.h" 22 23 void GetRange(TChain *chain, const char *name, Int_t &nbins, Double_t &min, Double_t &max, Double_t conv=1, Bool_t zero=kTRUE) 17 24 { 18 25 TString str("MPhoton.MParticle."); 26 str += name; 19 27 20 28 MPhoton *p = new MPhoton; 21 29 22 30 chain->SetBranchAddress("MPhoton.", &p); 31 chain->SetBranchStatus("*", 0); 32 chain->SetBranchStatus(str, 1); 23 33 24 34 min = FLT_MAX; 25 35 max = -FLT_MAX; 26 36 27 Int_t n = chain->GetEntries(); 37 Int_t numt = chain->GetTreeNumber(); 38 TLeaf *leaf = chain->GetLeaf(str); 39 40 if (!leaf && numt>=0) 41 return; 42 43 Stat_t n = chain->GetEntries(); 28 44 for (int i=0; i<n; i++) 29 45 { 30 46 chain->GetEntry(i); 31 47 32 TLeaf *leaf = chain->GetLeaf(str+name); 33 if (!leaf) 34 return 0; 48 if (numt != chain->GetTreeNumber()) 49 { 50 if (!(leaf = chain->GetLeaf(str))) 51 return; 52 53 numt = chain->GetTreeNumber(); 54 } 35 55 36 56 Double_t val = leaf->GetValue(); … … 39 59 continue; 40 60 41 if (val < min )61 if (val < min && (zero || val!=0)) 42 62 min = val; 43 63 if (val > max) … … 48 68 max *= conv; 49 69 50 chain.GetPlayer(); 51 TTreePlayer &play = *chain.GetPlayer(); 52 53 Int_t n; 54 play.FindGoodLimits(nbins, n, min, max, kFALSE); 55 nbins = n; 70 Int_t newn=0; 71 MH::FindGoodLimits(nbins, newn, min, max, kFALSE); 72 nbins = newn; 56 73 } 57 74 58 75 void draw1h1426(Double_t E, Double_t plot=1) 59 76 { 60 plot=2; 61 Double_t level = log10(E); 62 level -= log10(5.73e-0*pow( 0.39e3, plot)); 63 64 cout << "Level: " << level << endl; 65 66 TPolyMarker *m = new TPolyMarker(7); 67 /* 68 m->SetPoint(0, 0.28e3, 1.86e-0*pow( 0.28e3, plot)*level); 69 m->SetPoint(1, 0.39e3, 5.73e-0*pow( 0.39e3, plot)*level); 70 m->SetPoint(2, 0.80e3, 1.22e-0*pow( 0.80e3, plot)*level); 71 m->SetPoint(3, 1.55e3, 5.10e-2*pow( 1.55e3, plot)*level); 72 m->SetPoint(4, 2.82e3, 1.50e-2*pow( 2.82e3, plot)*level); 73 m->SetPoint(5, 5.33e3, 7.70e-3*pow( 5.33e3, plot)*level); 74 m->SetPoint(6, 10.00e3, 1.20e-4*pow(10.00e3, plot)*level); 75 */ 76 m->SetPoint(0, log10( 0.28e3), log10(1.86e-0*pow( 0.28e3, plot))+level); 77 m->SetPoint(1, log10( 0.39e3), log10(5.73e-0*pow( 0.39e3, plot))+level); 78 m->SetPoint(2, log10( 0.80e3), log10(1.22e-0*pow( 0.80e3, plot))+level); 79 m->SetPoint(3, log10( 1.55e3), log10(5.10e-2*pow( 1.55e3, plot))+level); 80 m->SetPoint(4, log10( 2.82e3), log10(1.50e-2*pow( 2.82e3, plot))+level); 81 m->SetPoint(5, log10( 5.33e3), log10(7.70e-3*pow( 5.33e3, plot))+level); 82 m->SetPoint(6, log10(10.00e3), log10(1.20e-4*pow(10.00e3, plot))+level); 77 plot += 1; 78 79 const Double_t level = E / (5.73e-0*pow( 0.39e3, plot)); 80 81 TPolyLine *l = new TPolyLine(6); 82 TPolyMarker *m = new TPolyMarker(6); 83 84 // m->SetPoint(0, log10( 0.28e3), log10(1.86e-0*pow( 0.28e3, plot)*level)); 85 m->SetPoint(0, log10( 0.39e3)-0.3, log10(5.73e-0*pow( 0.39e3, plot)*level)); 86 m->SetPoint(1, log10( 0.80e3)-0.3, log10(1.22e-0*pow( 0.80e3, plot)*level)); 87 m->SetPoint(2, log10( 1.55e3)-0.3, log10(5.10e-2*pow( 1.55e3, plot)*level)); 88 m->SetPoint(3, log10( 2.82e3)-0.3, log10(1.50e-2*pow( 2.82e3, plot)*level)); 89 m->SetPoint(4, log10( 5.33e3)-0.3, log10(7.70e-3*pow( 5.33e3, plot)*level)); 90 m->SetPoint(5, log10(10.00e3)-0.3, log10(1.20e-4*pow(10.00e3, plot)*level)); 83 91 m->SetMarkerStyle(kOpenStar); 84 // m->SetMarkerSize(1); 92 m->SetMarkerColor(kMagenta); 93 m->SetBit(kCanDelete); 85 94 m->Draw(); 95 96 // l->SetPoint(0, log10( 0.28e3), log10(1.86e-0*pow( 0.28e3, plot)*level)); 97 l->SetPoint(0, log10( 0.39e3)-0.3, log10(5.73e-0*pow( 0.39e3, plot)*level)); 98 l->SetPoint(1, log10( 0.80e3)-0.3, log10(1.22e-0*pow( 0.80e3, plot)*level)); 99 l->SetPoint(2, log10( 1.55e3)-0.3, log10(5.10e-2*pow( 1.55e3, plot)*level)); 100 l->SetPoint(3, log10( 2.82e3)-0.3, log10(1.50e-2*pow( 2.82e3, plot)*level)); 101 l->SetPoint(4, log10( 5.33e3)-0.3, log10(7.70e-3*pow( 5.33e3, plot)*level)); 102 l->SetPoint(5, log10(10.00e3)-0.3, log10(1.20e-4*pow(10.00e3, plot)*level)); 103 l->SetLineColor(kMagenta); 104 l->SetBit(kCanDelete); 105 l->Draw(); 86 106 } 87 107 88 108 void analp() 89 109 { 110 // ------------------------------------------------------------------- 111 90 112 TChain chain("Photons"); 113 chain.Add("cascade_0.1_18_1e2_1e5_B0_256_01.root"); 114 chain.Add("cascade_0.1_18_1e2_1e5_B0_256_02.root"); 115 chain.Add("cascade_0.1_18_1e2_1e5_B0_256_03.root"); 116 chain.Add("cascade_0.1_18_1e2_1e5_B0_256_04.root"); 117 chain.Add("cascade_0.1_18_1e2_1e5_B0_512_01.root"); 118 chain.Add("cascade_0.1_18_1e2_1e5_B0_512_03.root"); 119 chain.Add("cascade_0.1_18_1e2_1e5_B0_512_02.root"); 91 120 /* 92 chain.Add("delme3.root"); 93 chain.Add("delme3B.root"); 94 chain.Add("delme3C.root"); 95 chain.Add("delme3D.root"); 96 chain.Add("delme3E.root"); 121 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_3.root"); 122 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_4.root"); 123 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_5.root"); 124 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_6.root"); 125 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_7.root"); 126 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_8.root"); 127 chain.Add("cascade_0.03_18_1e2_1e5_B0_256_9.root"); 128 129 chain.Add("cascade_0.03_18_1e2_1e5_B0_512_01.root"); 130 chain.Add("cascade_0.03_18_1e2_1e5_B0_512_02.root"); 97 131 */ 98 chain.Add("delme3H.root"); 99 100 Int_t nbins = 24; 101 Double_t lo = 1e2; 102 Double_t hi = 1e6; 103 104 MBinning binsx; 105 binsx.SetEdgesLog(nbins, lo, hi); 106 107 // ------------------------------ 108 109 Double_t cutoff = 1e12; 110 111 Double_t alpha = -1; 112 Double_t plot = 1; 113 114 Int_t nbins = 16; 115 116 // ------------------------------ 117 118 Int_t n = chain.GetEntries(); 132 133 Int_t nbinse = 18; // number of bins in your histogram 134 Double_t lo = 1e2/1e3; // lower limit of the energy histogram 135 Double_t hi = 1e5; // upper limit of the energy histogram 136 137 Double_t minE = 1e2; // minimum value produced in the simulation 138 139 Double_t cutoff = 1e12; // arbitrary energy cutoff (throw away the events) 140 141 Double_t alpha = -1; // alpha of the energy spectrum (-1 is E^-2) 142 Double_t plot = 1; // plot of the enrgy spectrum (1 is E^2) 143 144 Int_t nbins = 16; // number of bins you want to have in psi/phi 145 146 // ------------------------------------------------------------------- 147 148 MBinning binspolx; 149 binspolx.SetEdges(16, -180, 180); 150 151 // ------------------------------------------------------------------- 152 153 Stat_t n = chain.GetEntries(); 119 154 120 155 cout << endl << "Found " << n << " entries." << endl; … … 123 158 return; 124 159 125 MBinning binspolx; 126 MBinning binspola; 127 MBinning binspolr; 128 binspolx.SetEdges(16, -180, 180); 160 // ----------------------------------- 161 162 MBinning bins; 163 164 cout << "Determin min/max..." << endl; 129 165 130 166 Double_t min, max; 131 167 GetRange(&chain, "fTheta", nbins, min, max, kRad2Deg*60); 132 binspola.SetEdges(nbins, min, max*1.1);133 168 cout << "fTheta, " << nbins << ": " << min << " ... " << max << " [']" << endl; 134 169 170 bins.SetEdges(nbins, min, max*1.1); 171 172 TH2D a, a2, a3; 173 MH::SetBinning(&a, &binspolx, &bins); 174 MH::SetBinning(&a2, &binspolx, &bins); 175 MH::SetBinning(&a3, &binspolx, &bins); 176 177 // ----------------------------------- 178 135 179 GetRange(&chain, "fR", nbins, min, max); 136 binspolr.SetEdges(nbins, min, max*1.1);137 180 cout << "fR, " << nbins << ": " << min << " ... " << max << " [kpc]" << endl; 138 181 139 TH1D h, h2, h3; 140 TH1D prim; 141 MH::SetBinning(&h, &binsx); 142 MH::SetBinning(&h2, &binsx); 143 MH::SetBinning(&h3, &binsx); 182 bins.SetEdges(nbins, min, max*1.1); 183 184 TH2D r, r2, r3; 185 MH::SetBinning(&r, &binspolx, &bins); 186 MH::SetBinning(&r2, &binspolx, &bins); 187 MH::SetBinning(&r3, &binspolx, &bins); 188 189 // ----------------------------------- 190 191 MBinning binsx; 192 binsx.SetEdgesLog(nbinse, lo, hi); 193 194 TH1D prim, h, h2, h3; 195 MH::SetBinning(&h, &binsx); 196 MH::SetBinning(&h2, &binsx); 197 MH::SetBinning(&h3, &binsx); 144 198 MH::SetBinning(&prim, &binsx); 145 146 TH2D r, r2, r3; 147 TH2D a, a2, a3; 148 MH::SetBinning(&a, &binspolx, &binspola); 149 MH::SetBinning(&r, &binspolx, &binspolr); 150 MH::SetBinning(&a2, &binspolx, &binspola); 151 MH::SetBinning(&r2, &binspolx, &binspolr); 152 MH::SetBinning(&a3, &binspolx, &binspola); 153 MH::SetBinning(&r3, &binspolx, &binspolr); 199 // prim.Sumw2(); 200 h.Sumw2(); 201 h2.Sumw2(); 202 h3.Sumw2(); 203 204 // ----------------------------------- 154 205 155 206 MPhoton *p = new MPhoton; 156 207 chain.SetBranchAddress("MPhoton.", &p); 208 chain.SetBranchStatus("*", 1); 157 209 158 210 chain.GetEntry(0); … … 165 217 cout << "Z = " << z << endl; 166 218 cout << "R = " << R << "kpc" << endl; 219 220 // ----------------------------------- 221 222 const Double_t skpc = 3600.*24.*365.*3.258*1e3; // [s/kpc] 223 GetRange(&chain, "fX", nbins, min, max, 1, kFALSE); 224 min *= skpc; 225 max *= skpc; 226 if (min<1e-2) 227 min=1e-2; 228 bins.SetEdgesLog(nbins, min, max); 229 cout << "dX, " << nbins << ": " << min << " ... " << max << " [s]" << endl; 230 231 TH1D t; 232 MH::SetBinning(&t, &bins); 233 t.Sumw2(); 234 235 // ---------------------------------------------------------------------- 236 237 chain.SetBranchAddress("MPhoton.", &p); 238 chain.SetBranchStatus("*", 1); 239 240 cout << "Filling: " << nbinse << " bins @ " << minE << " - " << hi << "... " << flush; 167 241 168 242 Double_t weight = 0; … … 193 267 continue; 194 268 195 h.Fill(Ep, pow(Ep,plot) * weight);196 197 269 Double_t phi = fmod(p->GetPhi()*kRad2Deg+180, 360)-180; 198 270 Double_t psi = fmod(p->GetPsi()*kRad2Deg+180, 360)-180; 199 200 r.Fill(phi, isprim?0:p->GetR(), weight);201 a.Fill(psi, isprim?0:p->GetTheta()*kRad2Deg*60, weight);202 271 203 272 if (isprim) 204 273 { 205 274 h3.Fill(Ep, pow(Ep,plot) * weight); 206 r3.Fill(phi, 0, 275 r3.Fill(phi, 0, weight); 207 276 a3.Fill(psi, 0, weight); 208 277 isprim = kFALSE; … … 211 280 212 281 h2.Fill(Ep, pow(Ep,plot) * weight); 213 r2.Fill(phi, p->GetR(), 282 r2.Fill(phi, p->GetR(), weight); 214 283 a2.Fill(psi, p->GetTheta()*kRad2Deg*60, weight); 284 285 Double_t tm1 = sqrt(R*R+p->GetR()*p->GetR()); 286 Double_t tm2 = (R+p->GetX())/tm1 - 1; 287 t.Fill(p->GetX()<=0 ? 0 : R*tm2*skpc, weight); 215 288 } 216 289 290 // ---------------------------------------------------------------------- 291 217 292 delete p; 218 293 219 TH1 *g=r.ProjectionX(); 220 cout << "Mean fPhi: " << g->GetMean() << " +- " << g->GetRMS() << endl; 221 delete g; 222 g=a.ProjectionX(); 223 cout << "Mean fPsi: " << g->GetMean() << " +- " << g->GetRMS() << endl; 224 delete g; 294 cout << "Done." << endl; 295 296 Double_t N = prim.GetBinContent(nbinse); 297 Double_t Nerr = prim.GetBinError(nbinse); 298 for (int i=1; i<=nbinse; i++) 299 { 300 Double_t E = prim.GetXaxis()->GetBinCenter(i); 301 if (E>minE) 302 continue; 303 304 Double_t E1 = prim.GetXaxis()->GetBinLowEdge(i+1); 305 Double_t E0 = prim.GetXaxis()->GetBinLowEdge(i); 306 307 E = sqrt(E1*E0); 308 309 prim.SetBinContent(i, N); 310 h3.SetBinContent(i, N); 311 prim.SetBinError(i, Nerr); 312 h3.SetBinError(i, Nerr); 313 } 314 315 h.Add(&h2, &h3); 316 r.Add(&r2, &r3); 317 a.Add(&a2, &a3); 318 319 if (alpha==-plot) 320 { 321 cout << "Observed Energy: " << h.Integral() << "GeV" << endl; 322 cout << "Emitted Energy: " << prim.Integral() << "GeV" << endl; 323 cout << "Ratio: " << h.Integral()/prim.Integral() << endl; 324 } 325 326 cout << "Mean fPhi: " << r.GetMean() << " +- " << r.GetRMS() << endl; 327 cout << "Mean fPsi: " << a.GetMean() << " +- " << a.GetRMS() << endl; 225 328 226 329 gStyle->SetOptStat(10); 330 gStyle->SetPalette(1, 0); 227 331 228 332 TLine line; 229 333 334 // ---------------------------------------------------------------------- 335 230 336 // delete gROOT->FindObject("Analysis Arrival"); 231 c = MH::MakeDefCanvas("Analysis Arrival", "");337 TCanvas *c = MH::MakeDefCanvas("Analysis Arrival", ""); 232 338 c->Divide(2,2); 233 234 gStyle->SetPalette(1, 0);235 339 236 340 c->cd(1); … … 241 345 r.SetXTitle("\\Phi [\\circ]"); 242 346 r.SetYTitle("R [kpc]"); 243 T Pad &pad = *gPad;347 TVirtualPad &pad = *gPad; 244 348 pad.Divide(2,2); 245 349 pad.cd(1); … … 248 352 gPad->SetTheta(0); 249 353 gPad->SetPhi(90); 250 g = r.DrawCopy("surf1pol");354 TH1 *g = r.DrawCopy("surf1pol"); 251 355 pad.cd(2); 252 356 gPad->SetLogy(); … … 275 379 a.SetXTitle("\\Psi [\\circ]"); 276 380 a.SetYTitle("\\Theta [']"); 277 T Pad &pad= *gPad;278 pad .Divide(2,2);279 pad .cd(1);381 TVirtualPad &pad2 = *gPad; 382 pad2.Divide(2,2); 383 pad2.cd(1); 280 384 gPad->SetLogy(); 281 385 gPad->SetLogz(); … … 283 387 gPad->SetPhi(90); 284 388 g = a.DrawCopy("surf1pol"); 285 pad .cd(2);389 pad2.cd(2); 286 390 gPad->SetLogy(); 287 391 gPad->SetLogz(); … … 289 393 gPad->SetPhi(90); 290 394 g->Draw("surf1pol"); 291 pad .cd(3);395 pad2.cd(3); 292 396 gPad->SetLogy(); 293 397 gPad->SetLogz(); … … 295 399 gPad->SetPhi(90); 296 400 g->Draw("surf1pol"); 297 pad .cd(4);401 pad2.cd(4); 298 402 gPad->SetLogy(); 299 403 gPad->SetLogz(); … … 307 411 g->SetDirectory(NULL); 308 412 TH1 *g2=r2.ProjectionY(); 309 g->SetMinimum( GetMin(g2)/2);413 g->SetMinimum(MH::GetMinimumGT(*g2)/2); 310 414 g->SetBit(kCanDelete); 311 415 g->SetTitle(" Hit Observers Plain "); … … 329 433 gPad->SetLogy(); 330 434 g=a.ProjectionY(); 331 g->SetMinimum( GetMin(g)/2);435 g->SetMinimum(MH::GetMinimumGT(*g)/2); 332 436 g->SetDirectory(NULL); 333 437 g->SetBit(kCanDelete); … … 350 454 g->Draw("same"); 351 455 352 // delete gROOT->FindObject("Analysis Photons"); 353 TCanvas *c = MH::MakeDefCanvas("Analysis Photons", "", 580, 870); 456 // ---------------------------------------------------------------------- 457 458 // delete gROOT->FindObject("Analysis Photons"); 459 c = MH::MakeDefCanvas("Analysis Photons", "", 580, 870); 354 460 c->Divide(1,2); 355 461 … … 364 470 h.GetXaxis()->SetLabelOffset(-0.015); 365 471 h.GetXaxis()->SetTitleOffset(1.1); 366 h.SetMarkerStyle(k Multiply);472 h.SetMarkerStyle(kPlus); 367 473 prim.SetFillStyle(0); 368 474 prim.SetMarkerStyle(kPlus); 369 475 prim.SetMarkerColor(kRed); 370 476 prim.SetLineColor(kRed); 371 TH1 &g1=*h.DrawCopy("P ");372 g2= *prim.DrawCopy("Psame");477 TH1 &g1=*h.DrawCopy("P E4"); 478 g2=prim.DrawCopy("Psame E0"); 373 479 g2->Draw("Csame"); 374 480 g1.Draw("Csame"); … … 378 484 h2.SetMarkerColor(kBlue); 379 485 h2.SetLineColor(kBlue); 380 TH1 &g3=*h2.DrawCopy("Psame ");486 TH1 &g3=*h2.DrawCopy("Psame E2"); 381 487 g3.Draw("Csame"); 382 488 h3.SetFillStyle(0); … … 385 491 h3.SetMarkerColor(kGreen); 386 492 h3.SetLineColor(kGreen); 387 TH1 &g4=*h3.DrawCopy("Psame ");493 TH1 &g4=*h3.DrawCopy("Psame E1"); 388 494 g4.Draw("Csame"); 389 495 … … 394 500 TH1D div; 395 501 MH::SetBinning(&div, &binsx); 502 div.Sumw2(); 396 503 div.Divide(&h, &prim); 397 div.SetTitle(" Spectrum / Primary Spectrum");504 div.SetTitle(" Spectrum / Primary Spectrum "); 398 505 div.GetXaxis()->SetLabelOffset(-0.015); 399 506 div.GetXaxis()->SetTitleOffset(1.1); 400 507 div.SetXTitle("E\\gamma [GeV]"); 401 508 div.SetYTitle("Ratio"); 509 TH1 *gHist = div.DrawCopy("E4"); 510 511 line.SetLineWidth(1); 512 line.SetLineColor(kGreen); 513 line.DrawLine(log10(lo), exp(-1), log10(hi), exp(-1)); 402 514 line.SetLineColor(kBlue); 403 line.SetLineWidth(1);404 div.DrawCopy();405 515 line.DrawLine(log10(lo), 1, log10(hi), 1); 516 517 MFit fit("exp(-1)-[1]*log10(x/[0])"); 518 for (int i=0; i<gHist->GetEntries(); i++) 519 { 520 if (gHist->GetBinContent(i+1)<exp(-1)) 521 { 522 fit.SetRange(gHist->GetBinCenter(i-2), gHist->GetBinCenter(i+2)); 523 cout << "Fitting from " << gHist->GetBinLowEdge(i-1) << " to "; 524 cout << gHist->GetBinLowEdge(i+1) << endl; 525 break; 526 } 527 } 528 fit.SetParameter(0, "t", 750, 10, 1e5); 529 fit.SetParameter(1, "m", 0.5, 0.1, 10); 530 fit.FitLog(gHist); 531 fit.Print(); 532 fit.DrawCopy("same"); 533 534 cout << "Cutoff: " << setprecision(2) << fit[0]/1e3 << "TeV +- "; 535 cout << fit.GetParError(0) << endl; 536 537 // ---------------------------------------------------------------------- 538 539 c = MH::MakeDefCanvas("Time Analysis", "", 580, 435); 540 gPad->SetLogx(); 541 // gPad->SetLogy(); 542 t.SetName("Times"); 543 t.SetTitle(" Arrival time distribution "); 544 t.SetXTitle("\\Delta t [s]"); 545 t.GetXaxis()->SetLabelOffset(-0.015); 546 t.GetXaxis()->SetTitleOffset(1.1); 547 t.DrawCopy("E4"); 548 line.DrawLine(log10(1), 0, log10(1), t.GetMaximum()*1.05); 549 line.DrawLine(log10(3600), 0, log10(3600), t.GetMaximum()*1.05); 550 line.DrawLine(log10(3600*24), 0, log10(3600*24), t.GetMaximum()*1.05); 551 line.DrawLine(log10(3600*24*365), 0, log10(3600*24*365), t.GetMaximum()*1.05); 406 552 } -
trunk/WuerzburgSoft/Thomas/mphys/phys.C
r1448 r1449 1 #include <iostream.h>1 #include "MCascade.h" 2 2 3 #include <fstream.h> 3 void phys() 4 { 5 MCascade cascade; 4 6 5 #include <TStopwatch.h> 6 #include <TF1.h> 7 #include <TH1.h> 8 #include <TH2.h> 9 #include <TList.h> 10 #include <TFile.h> 11 #include <TTree.h> 12 #include <TTimer.h> 13 #include <TStyle.h> 14 #include <TBranch.h> 15 #include <TRandom.h> 16 #include <TCanvas.h> 7 cascade.SetSourceZ(0.1); // Readshift of source 8 cascade.SetB(0/*1e-6*/); // [G] mean magnetic field 9 cascade.SetBradius(50); // [Mpc] 10 cascade.SetRuntime(8*60); // [min] maximum time to run the simulation 11 cascade.SetEnergyBins(18, 1e2, 1e5); // [GeV] 12 cascade.SetMaxInvCompton(512); // [#] maximum number of inv. Compton (-1 means infinite) 13 cascade.SetRatioInvCompton(0); // [%] allowed Emis of electron (0 means disabled) 14 cascade.SetSpectralIndex(-1); // -1 means a E^2 plot 15 cascade.SetDisplayIndex(1); // 1 means a E^-2 spectrum 17 16 18 #include "mbase/MParContainer.h" 19 #include "mphys/MPhoton.h" 20 #include "mphys/MElectron.h" 21 #include "mphys/MPairProduction.h" 22 #include "mhist/MBinning.h" 23 #include "mhist/MH.h" 24 25 // 2.96 26 // 2.87 27 // 2.73 28 Double_t PrimSpect(Double_t *x, Double_t *k) 29 { 30 return pow(pow(10, x[0]), k[0]); 17 // 18 // Run the simulation: filename, eventdisply (on/off) 19 // 20 //cascade.Run("cascade_0.03_18_1e2_1e5_B1e-6_50Mpc_256_1.root", kTRUE); 21 cascade.Run("cascade_0.1_18_1e2_1e5_B0_512_02.root", kFALSE); 31 22 } 32 23 33 Double_t PhotonSpect(Double_t *x, Double_t *k=NULL)34 {35 Double_t Ep = pow(10, x[0]);36 37 Double_t res = MPhoton::Int2(&Ep, k);38 return res*1e55; //65/k[0];39 40 //return MPhoton::Planck(&Ep, &k[1]);41 }42 43 Double_t Sbar_sigmas(Double_t *x, Double_t *k)44 {45 Double_t sbar = pow(10, x[0]);46 47 Double_t s = 1./(sbar*4);48 49 Double_t sigma = MPhoton::Sigma_gg(&s);50 51 return sigma*sbar*1e28;52 }53 54 Double_t RandomTheta(Double_t Eg, Double_t Ep)55 {56 Double_t E0 = 511e-6; // [GeV]57 58 Double_t f = Eg/E0*Ep/E0;59 60 if (f<1)61 return 0;62 63 TF1 func("RndTheta", Sbar_sigmas, 0, log10(f), 0);64 65 func.SetNpx(50);66 67 Double_t sbar = pow(10, func.GetRandom());68 Double_t theta = acos(1.-sbar*2/f);69 70 return theta;71 }72 73 Double_t GetEnergy(Int_t n, Double_t lo, Double_t hi)74 {75 static int bin=0;76 static TRandom rnd(0);77 78 Double_t w = log10(hi/lo)/n;79 80 Double_t E = lo*pow(10, rnd.Uniform(w) + w*(n-bin-1));81 82 //cout << endl << w << " " << n << " " << w*bin << " " << E << endl;83 84 if (++bin==n)85 bin=0;86 87 return E;88 89 /*90 // TF1 src ("PrimarySpectrum", PrimSpect, log10(lo), log10(hi), 1); // 10GeV-1000PeV91 // src.SetParameter(0, 0);92 // Double_t E = pow(10, src.GetRandom());93 94 //95 // 0: 11111111111111|22222222222222 2 2^0 + 1 196 // 1: 11111111|22222222222|33333333 3 2^1 + 1 297 // 2: 11111|22222|33333|44444|55555 5 2^2 + 1 798 // 3: | | | | | | | | 1599 //100 101 static int run=0;102 static int num=1;103 104 Double_t w = log10(hi/lo)/((1<<run) + 1);105 106 Double_t E = lo*pow(10, num*w);107 108 if (num == (1<<run))109 {110 run++;111 num=1;112 }113 else114 num++;115 116 return E;117 */118 }119 120 void DoIt()121 {122 // a --> 5123 // b --> 10124 // c --> 2125 126 // delme, delmeB starting integration at lolim127 // delme2, delme2B starting integration at -log10(Eg)-8128 // delme3, lolim, 24, 1e2-1e6, 2x inv.Compton129 // delme3B, lolim, 24, 1e2-1e6, 4x inv.Compton130 // delme3C, lolim, 24, 1e2-1e6, 8x inv.Compton131 // delme3D, lolim, 24, 1e2-1e6, 16x inv.Compton132 // delme3E, lolim, 24, 1e2-1e6, 32x inv.Compton133 134 // delme3H, lolim, 24, 1e2-1e6, 256x inv.Compton 8*60135 136 Double_t startz = 0.03; //MParticle::ZofR(&R);137 Double_t R = MParticle::RofZ(&startz); // [kpc]138 139 const char *filename = "cascade_0.03_18_1e2_1e5_B0_256_1.root";140 //const char *filename = "test.root";141 142 const Double_t B = 0;//1e-6*1e-4; // [T=1e4G] mean magnetic field143 144 Double_t runtime = 45*60; // [s] maximum time to run the simulation145 146 Int_t nbins = 18; // number of bins produced in energy spectrum147 148 Double_t lo = 1e2; // lower limit of displayed spectrum149 Double_t hi = 1e5; // upper limit of spectrum (cutoff)150 151 Int_t counter = 256; // maximum number of inv. Compton (-1 means infinite)152 153 Double_t alpha = -1; // -1 means a E^2 plot154 Double_t plot = 1; // 1 means a E^-2 spectrum155 156 Double_t bubbler = R-1e3*10; // [kpc]157 Double_t bubblez = MParticle::ZofR(&bubbler);158 159 // --------------------------------------------------------------------160 161 cout << "R = " << R << "kpc" << endl;162 cout << "Z = " << startz << endl;163 164 cout << "Setting up: Histograms... " << flush;165 166 MPairProduction pair;167 168 TH1D hist;169 TH1D histsrc;170 171 hist.SetMinimum(pow(lo, plot+alpha)/100);172 histsrc.SetMinimum(pow(lo, plot+alpha)/100);173 174 TList listg;175 TList liste;176 177 listg.SetOwner();178 liste.SetOwner();179 180 gStyle->SetOptStat(10);181 182 //183 // Don't change the order!!!184 //185 hist.SetFillStyle(0);186 hist.SetMarkerStyle(kPlus);187 histsrc.SetFillStyle(0);188 histsrc.SetMarkerStyle(kMultiply);189 histsrc.SetMarkerColor(kRed);190 histsrc.SetLineColor(kRed);191 192 MBinning bins;193 bins.SetEdgesLog(nbins, lo, hi);194 195 MH::SetBinning(&hist, &bins);196 MH::SetBinning(&histsrc, &bins);197 198 TCanvas *c=MH::MakeDefCanvas();199 200 gPad->SetGrid();201 gPad->SetLogx();202 gPad->SetLogy();203 204 hist.SetName("Spectrum");205 hist.SetXTitle("E [GeV]");206 hist.SetYTitle(Form("E^{%.1f} Counts", plot));207 hist.GetXaxis()->SetLabelOffset(-0.015);208 hist.GetXaxis()->SetTitleOffset(1.1);209 210 hist.Draw("P");211 histsrc.Draw("Psame");212 histsrc.Draw("same");213 hist.Draw("same");214 215 // ------------------------------216 217 cout << "Output File... " << flush;218 219 TFile file(filename, "RECREATE", "Intergalactic cascade", 9);220 cout << "Trees... " << flush;221 TTree *T1 = new TTree ("Photons", "Photons from Cascade");222 TTree *T2 = new TTree ("Electrons", "Electrons in the Cascade");223 cout << "Branches... " << flush;224 MPhoton dummyp;225 void *ptr = &dummyp;226 TBranch *B1 = T1->Branch("MPhoton.", "MPhoton", &ptr);227 MPhoton dummye;228 ptr = &dummye;229 TBranch *B2 = T2->Branch("MElectron.", "MElectron", &ptr);230 231 // ------------------------------232 233 cout << "Timers... " << flush;234 235 TTimer timer("gSystem->ProcessEvents();", 250, kFALSE);236 timer.TurnOn();237 238 TStopwatch clock;239 clock.Start();240 241 cout << "Done. " << endl;242 243 Int_t n=0;244 Double_t starttime = TStopwatch::GetRealTime(); // s245 while (TStopwatch::GetRealTime()<starttime+runtime)246 for (int i=0; i<nbins; i++)247 {248 n++;249 250 Double_t E = GetEnergy(nbins, lo, hi);251 Double_t weight = pow(E, alpha);252 histsrc.Fill(E, pow(E, plot) * weight);253 254 MPhoton *gamma=new MPhoton(E, startz);255 gamma->SetIsPrimary();256 gamma->SetSrcR(R);257 gamma->InitRandom();258 listg.Add(gamma);259 260 B1->SetAddress(&gamma);261 T1->Fill();262 263 cout << "--> " << n << ". " << Form("%d: %3.1e", (int)(starttime+runtime-TStopwatch::GetRealTime()), E) << flush;264 265 Double_t Esum=0;266 Double_t Emis=0;267 while (1)268 {269 if (listg.GetSize()!=0)270 cout << " |P" << flush;271 272 TIter NextP(&listg);273 MPhoton *p = NULL;274 B1->SetAddress(&p);275 while ((p=(MPhoton*)NextP()))276 {277 cout << ":" << flush;278 Double_t Eg = p->GetEnergy();279 280 Double_t E0 = 511e-6;281 Double_t z = p->GetZ();282 Double_t lolim = E0*E0/Eg;283 Double_t inf = (Eg<1e6 ? 3e-11*(z+1) : 3e-12*(z+1));284 if (Eg<5e4)285 inf = 3e-11*(z+1)*pow(10, 9.4-log10(Eg)*2);286 287 //TF1 phot("PhotonSpectrum", PhotonSpect, -log10(Eg)-8, -10.5, 2);288 //Double_t E0 = 511e-6; // [GeV]289 TF1 phot("PhotonSpectrum", PhotonSpect, log10(lolim), log10(inf), 2);290 phot.SetParameter(0, Eg);291 while (1)292 {293 if (!p->SetNewPosition())294 {295 cout << "!" << flush;296 297 hist.Fill(Eg, pow(Eg, plot)*weight);298 299 p->SetIsPrimary(kFALSE);300 T1->Fill();301 302 Esum += Eg;303 304 break;305 }306 307 //308 // Sample phtoton from background and interaction angle309 //310 phot.SetParameter(1, p->GetZ());311 Double_t pe = phot.GetRandom();312 if (pe==0)313 {314 cout << "z" << flush;315 continue;316 }317 318 Double_t Ep = pow(10, pe);319 Double_t theta = RandomTheta(Eg, Ep);320 if (theta==0)321 {322 cout << "t" << flush;323 continue;324 }325 326 if (!pair.Process(p, Ep, theta, &liste))327 {328 cout << "0" << flush;329 continue;330 }331 332 cout << "." << flush;333 break;334 }335 delete listg.Remove(p);336 }337 338 if (liste.GetSize()==0 && listg.GetSize()==0)339 break;340 341 if (liste.GetSize()!=0)342 cout << " |E" << flush;343 344 TIter Next(&liste);345 MElectron *e = NULL;346 B2->SetAddress(&e);347 while ((e=(MElectron*)Next()))348 {349 e->SetIsPrimary(kTRUE);350 T2->Fill();351 e->SetIsPrimary(kFALSE);352 353 Double_t Ee = e->GetEnergy();354 355 if (Ee<lo)356 continue;357 358 cout << ":" << flush;359 int test = counter<0 ? -1 : 0;360 while (test<0 ? true : (test++<counter))361 {362 if (!e->SetNewPositionB(e->GetZ()>bubblez ? B : 0))363 {364 cout << "!" << flush;365 break;366 }367 368 // WRONG!369 MPhoton *p = e->DoInvCompton(0);370 371 T2->Fill();372 373 cout << "." << flush;374 listg.Add(p);375 /*376 if (fabs(p->GetTheta()*3437)<60 && // < 60min377 p->GetEnergy()>lo)378 {379 cout << "." << flush;380 listg.Add(p);381 }382 else383 {384 if (p->GetEnergy()<E*pow(10, alpha)/5 || p->GetEnergy()<=lo)385 cout << "e" << flush;386 else387 cout << "t" << flush; // ignored388 delete p;389 Esum += p->GetEnergy();390 Emis += p->GetEnergy();391 }392 */393 if (fabs(e->GetTheta()*3437)>60) // < 60min394 {395 cout << "T" << flush;396 break;397 }398 399 if (e->GetEnergy()<Ee*1e-3) // <2e3400 {401 cout << "E" << flush;402 break;403 }404 }405 Esum += e->GetEnergy();406 Emis += e->GetEnergy();407 }408 liste.Delete();409 }410 cout << " ----> " << Form("%3.1f %3.1e / %3.1f %3.1e", Emis/E, Emis, Esum/E, Esum) << endl;411 412 hist.SetTitle(Form("E^{%.1f} z=%f T=%d'%d\" N=%d", alpha, startz,413 (int)runtime/60, (int)runtime%60, n));414 415 timer.Stop();416 c->Update();417 timer.Start(250);418 419 }420 cout << endl;421 422 clock.Stop();423 clock.Print();424 425 timer.Stop();426 427 file.Write();428 429 cout << "Wrote: " << filename << endl;430 cout << "Created " << n << " gammas from source with E^" << alpha << endl;431 cout << "Processing time: " << Form("%.1f", (TStopwatch::GetRealTime()-starttime)/n) << " sec/gamma." << endl;432 433 // ------------------------------434 435 gPad->Clear();436 437 hist.SetTitle(Form("E^{%.1f} z=%f T=%d'%d\" N=%d", alpha, startz, (int)runtime/60, (int)runtime%60, n));438 439 TH1 &h1 = *hist.DrawCopy("P");440 TH1 &h2 = *histsrc.DrawCopy("Psame");441 h2.Draw("Csame");442 h1.Draw("Csame");443 }444 445 // -------------------------------------------------------------------446 void phys()447 {448 /*449 Double_t Eg = 10;450 Double_t E0 = 511e-6;451 Double_t z = 0.03;452 Double_t lolim = E0*E0/Eg;453 Double_t inf = (Eg<1e6 ? 3e-11*(z+1) : 3e-12*(z+1));454 if (Eg<5e4)455 inf = 3e-11*(z+1)*pow(10, 9.4-log10(Eg)*2);456 TF1 phot("PhotonSpectrum", PhotonSpect, log10(lolim), log10(inf), 2);457 phot.SetParameter(0, Eg);458 phot.SetParameter(1, z);459 460 Double_t val[2] = {Eg,z};461 cout << phot.Integral(log10(lolim), log10(inf), val, 1e-2) << endl;462 463 cout << lolim << " " << inf << endl;464 465 phot.DrawCopy();466 return;467 */468 469 DoIt();470 471 /*472 Double_t E = 1e10;473 TF1 phot("PhotonSpectrum", PhotonSpect, -log10(E)-8, -10.5, 2);474 phot.SetParameter(0, E);475 phot.SetParameter(1, 5);476 phot.DrawCopy();477 return;478 */479 480 /*481 Double_t Eg = 1e5;482 483 Double_t E0 = 511e-6; // [GeV]484 Double_t lolim = E0*E0/Eg;485 Double_t inf = 4e-12; //E0*E0/Eg * sqrt(Eg);486 487 // 1e5: 5e-13, 4e-12488 // 1e6: 5e-14, 2e-12489 // 1e8: 5e-16, 1e-12490 // 1e10: 5e-18, 1e-12491 492 // 1e5: 2.6e-12, 4e-12493 // 1e6: 2.6e-13, 2e-12494 // 1e8: 2.6e-15, 1e-12495 // 1e10: 1.6e-17, 1e-12496 497 TF1 f("int2", MPhoton::Int2, lolim, inf, 2);498 f.SetParameter(0, Eg);499 f.SetParameter(1, 0);500 501 MH::MakeDefCanvas();502 gPad->SetLogx();503 f.DrawCopy();504 */505 }506
Note:
See TracChangeset
for help on using the changeset viewer.