File indexing completed on 2025-04-04 08:05:11
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037 #ifndef G4UrQMD1_3Interface_hh
0038 #define G4UrQMD1_3Interface_hh
0039
0040
0041
0042
0043
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058
0059
0060
0061
0062
0063 #include "G4SystemOfUnits.hh"
0064 #include "globals.hh"
0065
0066
0067
0068 const G4int nmax = 500;
0069 const G4int nspl = 500;
0070 const G4int smax = 500;
0071
0072 const G4int minnuc = 1;
0073 const G4int minmes = 100;
0074 const G4int maxmes = 132;
0075 const G4int numnuc = 16;
0076 const G4int numdel = 10;
0077 const G4int maxnuc = minnuc + numnuc - 1;
0078 const G4int mindel = minnuc + maxnuc;
0079 const G4int maxdel = mindel + numdel - 1;
0080 const G4int minres = minnuc + 1;
0081 const G4int maxres = maxdel;
0082 const G4int numlam = 13;
0083 const G4int numsig = 9;
0084 const G4int numcas = 6;
0085 const G4int numome = 1;
0086 const G4int minlam = mindel + numdel;
0087 const G4int maxlam = minlam + numlam - 1;
0088 const G4int minsig = minlam + numlam;
0089 const G4int maxsig = minsig + numsig - 1;
0090 const G4int mincas = minsig + numsig;
0091 const G4int maxcas = mincas + numcas - 1;
0092 const G4int minome = mincas + numcas;
0093 const G4int maxome = minome + numome - 1;
0094 const G4int minbar = minnuc;
0095 const G4int maxbar = maxome;
0096 const G4int offmeson = minmes;
0097 const G4int maxmeson = maxmes;
0098 const G4int maxbra = 11;
0099 const G4int maxbrm = 25;
0100 const G4int maxbrs1 = 10;
0101 const G4int maxbrs2 = 3;
0102 const G4int nsigs = 10;
0103 const G4int itblsz = 100;
0104 const G4int maxreac = 13;
0105 const G4int maxpsig = 12;
0106
0107
0108
0109 const G4int widnsp = 120;
0110 const G4double mintab = 0.10;
0111 const G4double maxtab1 = 5.0;
0112 const G4double maxtab2 = 50.0;
0113 const G4int tabver = 9;
0114
0115
0116
0117 const G4int numcto = 400;
0118 const G4int numctp = 400;
0119 const G4int maxstables = 20;
0120
0121
0122
0123 const G4int ncollmax = 100;
0124
0125
0126
0127 const G4int aamax = 300;
0128
0129
0130
0131 const G4int mprt = 200;
0132 const G4int oprt = 2;
0133
0134
0135
0136 const G4int bptmax = 20;
0137
0138
0139
0140
0141
0142
0143 const G4int n = 400;
0144
0145
0146 const G4int njspin = 8;
0147
0148
0149 const G4int jmax = 7;
0150
0151
0152
0153
0154
0155 typedef G4int ftnlogical;
0156
0157
0158
0159
0160
0161
0162
0163
0164 struct ccurqmd13urqmdparams
0165 {
0166 G4int u_at, u_zt, u_ap, u_zp;
0167 G4double u_elab, u_imp;
0168 G4int u_sptar, u_spproj;
0169 };
0170
0171
0172
0173 struct ccurqmd13sys
0174 {
0175 G4int npart, nbar, nmes, ctag, nsteps, uid_cnt, ranseed, event, ap, at, zp, zt, eos, dectag,
0176 nhardres, nsoftres, ndecres, nelcoll, nblcoll;
0177 };
0178
0179
0180
0181 struct ccurqmd13rsys
0182 {
0183 G4double time, acttime, bdist, bimp, bmin, ebeam, ecm;
0184 };
0185
0186 struct ccurqmd13comseed
0187 {
0188 ftnlogical firstseed;
0189 };
0190
0191
0192
0193 struct ccurqmd13logic
0194 {
0195 ftnlogical lsct[nmax], logSky, logYuk, logCb, logPau;
0196 };
0197
0198
0199
0200 struct ccurqmd13mdprop
0201 {
0202 G4double r0_t[nmax], rx_t[nmax], ry_t[nmax], rz_t[nmax];
0203 };
0204
0205
0206
0207 struct ccurqmd13cuts
0208 {
0209 G4double cutmax, cutPau, cutCb, cutYuk, cutSky, cutdww;
0210 };
0211
0212
0213
0214 struct ccurqmd13spdata
0215 {
0216 G4double spx[nspl], spPauy[nspl], outPau[nspl], spCby[nspl], outCb[nspl], spYuky[nspl],
0217 outYuk[nspl], spSkyy[nspl], outSky[nspl], spdwwy[nspl], outdww[nspl];
0218 };
0219
0220
0221
0222 struct ccurqmd13isys
0223 {
0224 G4int spin[nmax], ncoll[nmax], charge[nmax], ityp[nmax], lstcoll[nmax], iso3[nmax],
0225 origin[nmax], strid[nmax], uid[nmax];
0226 };
0227
0228
0229
0230 struct ccurqmd13coor
0231 {
0232 G4double r0[nmax], rx[nmax], ry[nmax], rz[nmax], p0[nmax], px[nmax], py[nmax], pz[nmax],
0233 fmass[nmax], rww[nmax], dectime[nmax];
0234 };
0235
0236
0237
0238 struct ccurqmd13frag
0239 {
0240 G4double tform[nmax], xtotfac[nmax];
0241 };
0242
0243
0244
0245 struct ccurqmd13aios
0246 {
0247 G4double airx[nmax], airy[nmax], airz[nmax], aipx[nmax], aipy[nmax], aipz[nmax], aorx[4][nmax],
0248 aory[4][nmax], aorz[4][nmax], aopx[4][nmax], aopy[4][nmax], aopz[4][nmax];
0249 };
0250
0251
0252
0253 struct ccurqmd13pots
0254 {
0255 G4double Cb0, Yuk0, Pau0, Sky20, Sky30, gamSky, gamYuk, drPau, dpPau, gw, sgw, delr, fdel, dt,
0256 da, db, dtimestep;
0257 };
0258
0259
0260
0261 struct ccurqmd13scoor
0262 {
0263 G4double r0s[smax], rxs[smax], rys[smax], rzs[smax], p0s[smax], pxs[smax], pys[smax], pzs[smax],
0264 sfmass[smax];
0265 };
0266
0267
0268
0269 struct ccurqmd13sisys
0270 {
0271 G4int sspin[smax], scharge[smax], sityp[smax], siso3[smax], suid[smax];
0272 };
0273
0274
0275
0276 struct ccurqmd13ssys
0277 {
0278 G4int nspec;
0279 };
0280
0281
0282
0283 struct ccurqmd13rtdelay
0284 {
0285 G4double p0td[nmax][2], pxtd[nmax][2], pytd[nmax][2], pztd[nmax][2], fmasstd[nmax][2];
0286 };
0287
0288
0289
0290 struct ccurqmd13itdelay
0291 {
0292 G4int ityptd[nmax][2], iso3td[nmax][2];
0293 };
0294
0295
0296
0297 struct ccurqmd13svinfo
0298 {
0299 G4int itypt[2], uidt[2], origint[2], iso3t[2];
0300 };
0301
0302
0303
0304 struct ccurqmd13ffermi
0305 {
0306 G4double ffermpx[nmax], ffermpy[nmax], ffermpz[nmax];
0307 };
0308
0309
0310
0311 struct ccurqmd13peq
0312 {
0313 G4double peq1, peq2;
0314 };
0315
0316
0317
0318
0319
0320
0321
0322
0323 struct ccurqmd13versioning
0324 {
0325 char versiontag[45];
0326 };
0327
0328
0329
0330 struct ccurqmd13resonances
0331 {
0332 G4double massres[maxbar - minbar + 1], widres[maxbar - minbar + 1];
0333 G4double massmes[maxmes - minmes + 1];
0334 G4double widmes[maxmes - minmes + 1];
0335 G4double mmesmn[maxmes - minmes + 1];
0336 G4double branres[maxdel - minnuc][maxbra + 1];
0337 G4double branmes[maxmes - minmes][maxbrm + 1];
0338
0339 G4double branbs1[maxsig - minlam][maxbrs1 + 1];
0340 G4double branbs2[maxcas - mincas][maxbrs2 + 1];
0341
0342 G4int bs1type[maxbrs1 + 1][4], bs2type[maxbrs2 + 1][4];
0343 G4int lbs1[maxsig - minlam][maxbrs1 + 1];
0344 G4int lbs2[maxcas - mincas][maxbrs2 + 1];
0345 G4int lbm[maxmes - minmes][maxbrm + 1];
0346
0347 G4int jres[maxbar - minbar + 1];
0348 G4int jmes[maxmes - minmes + 1];
0349 G4int lbr[maxdel - minnuc][maxbra + 1];
0350 G4int brtype[maxbra + 1][4];
0351 G4int pares[maxbar - minbar + 1], pames[maxmes - minmes + 1];
0352 G4int bmtype[maxbrm + 1][4];
0353 G4int isores[maxbar - minbar + 1], isomes[maxmes - minmes + 1];
0354 G4int strres[maxbar - minbar + 1], strmes[maxmes - minmes + 1];
0355 G4int mlt2it[maxmes - minmes];
0356 };
0357
0358
0359
0360 struct ccurqmd13sigtabi
0361 {
0362 G4int sigmaln[maxreac][2][maxpsig];
0363 G4int sigmainf[20][nsigs];
0364 };
0365
0366
0367
0368 struct ccurqmd13sigtabr
0369 {
0370 G4double sigmas[itblsz][nsigs], sigmascal[5][nsigs];
0371 };
0372
0373
0374
0375
0376 struct ccurqmd13decaywidth
0377 {
0378 G4double tabx[widnsp];
0379 G4double fbtaby[2][maxbar - minbar + 1][widnsp];
0380 G4double pbtaby[maxbra + 1][maxbar - minbar + 1][2][widnsp];
0381 G4double fmtaby[2][maxmes - minmes + 1][widnsp];
0382 G4double pmtaby[maxbrm + 1][maxmes - minmes + 1][2][widnsp];
0383 G4int wtabflg;
0384 };
0385
0386
0387
0388 struct ccurqmd13brwignorm
0389 {
0390 G4double bwbarnorm[maxbar - minbar + 1];
0391 G4double bwmesnorm[maxmes - minmes + 1];
0392 };
0393
0394
0395
0396 struct ccurqmd13xsections
0397 {
0398 G4double tabxnd[widnsp];
0399 G4double frrtaby[maxdel - 1][2][2][widnsp];
0400 };
0401
0402
0403
0404 struct ccurqmd13tabnames
0405 {
0406 char tabname[77];
0407 };
0408
0409
0410
0411
0412
0413 struct ccurqmd13options
0414 {
0415 G4int CTOption[numcto];
0416 G4double CTParam[numctp];
0417 };
0418
0419
0420
0421 struct ccurqmd13optstrings
0422 {
0423 char ctodc[numcto][2];
0424 char ctpdc[numctp][2];
0425 };
0426
0427
0428
0429 struct ccurqmd13loptions
0430 {
0431 ftnlogical fixedseed, bf13, bf14, bf15, bf16, bf17, bf18, bf19, bf20;
0432 };
0433
0434
0435
0436 struct ccurqmd13stables
0437 {
0438 G4int nstable;
0439 G4int stabvec[maxstables];
0440 };
0441
0442
0443
0444
0445
0446 struct ccurqmd13colltab
0447 {
0448 G4double cttime[ncollmax + 1], ctsqrts[ncollmax], ctsigtot[ncollmax], tmin;
0449 G4int cti1[ncollmax], cti2[ncollmax];
0450 G4int nct, actcol;
0451 ftnlogical ctvalid[ncollmax];
0452 G4int ctsav[ncollmax];
0453 G4int nsav, apt;
0454 G4double ctcolfluc[ncollmax];
0455 };
0456
0457
0458
0459
0460
0461 struct ccurqmd13inputs
0462 {
0463 G4int nevents, spityp[2], prspflg;
0464 G4int trspflg, spiso3[2], outsteps, bflag, srtflag, efuncflag;
0465 G4int nsrt, firstev, npb;
0466 };
0467
0468
0469
0470 struct ccurqmd13input2
0471 {
0472 G4double srtmin, srtmax, pbeam, betann, betatar, betapro;
0473 G4double pbmin, pbmax;
0474 };
0475
0476
0477
0478 struct ccurqmd13protarints
0479 {
0480 G4int pt_iso3[2][aamax], pt_ityp[2][aamax], pt_spin[2][aamax];
0481 G4int pt_charge[2][aamax], pt_aa[2], pt_uid[2][aamax];
0482 };
0483
0484
0485
0486 struct ccurqmd13protarreals
0487 {
0488 G4double pt_r0[2][aamax], pt_rx[2][aamax], pt_ry[2][aamax], pt_rz[2][aamax], pt_fmass[2][aamax],
0489 pt_dectime[2][aamax];
0490 G4double pt_p0[2][aamax], pt_px[2][aamax], pt_py[2][aamax], pt_pz[2][aamax];
0491 G4double pt_rho[2][aamax];
0492 G4double pt_pmax[2][aamax];
0493 };
0494
0495
0496
0497
0498 struct ccurqmd13inewpart
0499 {
0500 G4int itypnew[mprt], i3new[mprt], itot[mprt], inew[mprt], nexit;
0501 G4int iline, strcount, pslot[oprt], nstring1, nstring2, sidnew[mprt], itypold[oprt],
0502 iso3old[oprt];
0503 };
0504
0505
0506
0507 struct ccurqmd13rnewpart
0508 {
0509 G4double pnew[mprt][5], xnew[mprt][4], betax, betay, betaz, pold[oprt][5], p0nn, pxnn, pynn,
0510 pznn, pnn, mstring[2], pnnout, xtotfacold[oprt];
0511 };
0512
0513
0514
0515 struct ccurqmd13fnewpart
0516 {
0517 G4double leadfac[mprt];
0518 };
0519
0520
0521
0522
0523
0524 struct ccurqmd13boxic
0525 {
0526 G4int cbox;
0527 G4int boxflag;
0528 G4int mbox;
0529 G4int bptityp[bptmax], bptiso3[bptmax], bptpart[bptmax];
0530 G4int edensflag, para, solid, mbflag, mtest;
0531 };
0532
0533
0534
0535 struct ccurqmd13boxrc
0536 {
0537 G4double bptpmax[bptmax];
0538 G4double edens;
0539 G4double lbox;
0540 G4double lboxhalbe;
0541 G4double lboxd;
0542 G4double mbp0, mbpx, mbpy, mbpz;
0543 };
0544
0545
0546
0547 struct ccurqmd13normsplin
0548 {
0549 G4double x_norm[n][4], y_norm[n][4];
0550 G4double y2a[n][4], y2b[n][4], dx;
0551 };
0552
0553
0554
0555 struct ccurqmd13FRGSPA
0556 {
0557 G4double pjspns, pmix1s[njspin][3], pmix2s[njspin][3], pbars, parqls, parrs;
0558 };
0559
0560
0561
0562 struct ccurqmd13FRGCPA
0563 {
0564 G4double pjspnc, pmix1c[njspin][3], pmix2c[njspin][3], pbarc;
0565 };
0566
0567
0568
0569 struct ccurqmd13coparm
0570 {
0571 G4double parm[njspin];
0572 };
0573
0574
0575
0576 struct ccurqmd13const
0577 {
0578 G4double pi;
0579 };
0580
0581
0582
0583
0584 struct ccurqmd13frcoor
0585 {
0586 G4double frr0[nmax], frrx[nmax], frry[nmax], frrz[nmax], frp0[nmax], frpx[nmax], frpy[nmax],
0587 frpz[nmax];
0588 };
0589
0590
0591
0592 struct ccurqmd13values
0593 {
0594 G4double valint[1];
0595 };
0596
0597
0598
0599 struct ccurqmd13ini
0600 {
0601 ftnlogical bcorr;
0602 };
0603
0604
0605
0606 struct ccurqmd13factorials
0607 {
0608 G4double logfak[101];
0609 };
0610
0611
0612 struct ccurqmd13cgks
0613 {
0614 G4double cgktab[jmax + 1][2 * jmax + 1][2 * jmax + 1][jmax + 1][jmax + 1];
0615 };
0616
0617
0618
0619
0620 struct ccurqmd13energies
0621 {
0622 G4double ekinbar, ekinmes, esky2, esky3, eyuk, ecb, epau;
0623 };
0624
0625
0626
0627 extern "C"
0628 {
0629 extern int time_();
0630 extern void loginit_();
0631 extern void sseed_(int*);
0632 extern void uinit_(int*);
0633 extern void urqmd_();
0634 extern int pdgid_(int*, int*);
0635
0636 extern void g4urqmdblockdata_();
0637
0638
0639 extern struct ccurqmd13urqmdparams urqmdparams_;
0640
0641 extern struct ccurqmd13sys sys_;
0642 extern struct ccurqmd13rsys rsys_;
0643 extern struct ccurqmd13comseed comseed_;
0644 extern struct ccurqmd13logic logic_;
0645 extern struct ccurqmd13mdprop mdprop_;
0646 extern struct ccurqmd13cuts cuts_;
0647 extern struct ccurqmd13spdata spdata_;
0648 extern struct ccurqmd13isys isys_;
0649 extern struct ccurqmd13coor coor_;
0650 extern struct ccurqmd13frag frag_;
0651 extern struct ccurqmd13aios aios_;
0652 extern struct ccurqmd13pots pots_;
0653 extern struct ccurqmd13scoor scoor_;
0654 extern struct ccurqmd13sisys sisys_;
0655 extern struct ccurqmd13ssys ssys_;
0656 extern struct ccurqmd13rtdelay rtdelay_;
0657 extern struct ccurqmd13itdelay itdelay_;
0658 extern struct ccurqmd13svinfo svinfo_;
0659 extern struct ccurqmd13ffermi ffermi_;
0660 extern struct ccurqmd13peq peq_;
0661
0662 extern struct ccurqmd13versioning versioning_;
0663 extern struct ccurqmd13resonances resonances_;
0664 extern struct ccurqmd13sigtabi sigtabi_;
0665 extern struct ccurqmd13sigtabr sigtabr_;
0666
0667
0668 extern struct ccurqmd13decaywidth decaywidth_;
0669 extern struct ccurqmd13brwignorm brwignorm_;
0670 extern struct ccurqmd13xsections xsections_;
0671 extern struct ccurqmd13tabnames tabnames_;
0672
0673 extern struct ccurqmd13options options_;
0674 extern struct ccurqmd13optstrings optstrings_;
0675 extern struct ccurqmd13loptions loptions_;
0676 extern struct ccurqmd13stables stables_;
0677
0678 extern struct ccurqmd13colltab colltab_;
0679
0680 extern struct ccurqmd13inputs inputs_;
0681 extern struct ccurqmd13input2 input2_;
0682 extern struct ccurqmd13protarints protarints_;
0683 extern struct ccurqmd13protarreals protarreals_;
0684
0685 extern struct ccurqmd13inewpart inewpart_;
0686 extern struct ccurqmd13rnewpart rnewpart_;
0687 extern struct ccurqmd13fnewpart fnewpart_;
0688
0689 extern struct ccurqmd13boxic boxic_;
0690 extern struct ccurqmd13boxrc boxrc_;
0691
0692 struct ccurqmd13normsplin normsplin_;
0693
0694 struct ccurqmd13FRGSPA FRGSPA_;
0695 struct ccurqmd13FRGCPA FRGCPA_;
0696 struct ccurqmd13coparm coparm_;
0697 struct ccurqmd13const const_;
0698
0699 struct ccurqmd13frcoor frcoor_;
0700
0701 extern struct ccurqmd13energies energies_;
0702
0703 extern struct ccurqmd13values values_;
0704
0705 extern struct ccurqmd13ini ini_;
0706
0707 extern struct ccurqmd13factorials factorials_;
0708 extern struct ccurqmd13cgks cgks_;
0709 }
0710
0711
0712 #endif